/* -----------------------------------------------
= kv
----------------------------------------------- */
.kv .page-title {
	position: relative;
	height: 223px;
	margin-inline: 12px;
}
.kv .page-title img {
	height: 100%;
	object-fit: cover;
	object-position: 80% 50%;
}
.kv .page-title h1 {
	position: absolute;
	left: 12px;
	bottom: 10px;
	color: #fff;
}
.kv .page-title h1 span {
	display: block;
}
.kv .page-title h1 span:first-child {
	font-family: var(--en);
	font-size: calc(1.2rem / 1.6);
	font-weight: 600;
}
.kv .page-title h1 span:last-child {
	font-family: var(--min);
	font-size: calc(2rem / 1.6);
	font-weight: 300;
	letter-spacing: .08em;
}
@media print, screen and (min-width: 768px) {/* PC */
.kv .page-title {
	height: 680px;
	max-height: calc(100vh - 80px);
	margin-inline: 40px;
}
.kv .page-title h1 {
	left: 40px;
	bottom: 40px;
}
.kv .page-title h1 span:first-child {
	font-size: calc(2.4rem / 1.6);
}
.kv .page-title h1 span:last-child {
	font-size: calc(3.6rem / 1.6);
	letter-spacing: .06em;
}
}/* @media */
/* -----------------------------------------------
= intro
----------------------------------------------- */
.intro {
	margin: 27px 12px 70px;
}
.intro h2 {
	margin-bottom: 25px;
	font-family: var(--min);
	font-size: calc(1.6rem / 1.6);
	font-weight: 300;
}
.intro p {
	margin-bottom: 25px;
	font-size: calc(1.4rem / 1.6);
	line-height: calc(22 / 14);
	letter-spacing: .02em;
}
@media print, screen and (min-width: 768px) {/* PC */
.intro {
	margin: 65px 80px 140px;
}
.intro h2 {
	margin-bottom: 40px;
	font-size: calc(3.2rem / 1.6);
}
.intro p {
	margin-bottom: 40px;
	font-size: calc(1.8rem / 1.6);
	line-height: calc(40 / 18);
	letter-spacing: .06em;
}
}/* @media */
/* -----------------------------------------------
= map
----------------------------------------------- */
.map {
	margin: 0 12px 87px;
}
@media print, screen and (min-width: 768px) {/* PC */
.map {
	max-width: 1161px;
	margin: 0 auto 200px;
	padding-inline: 40px;
}
}/* @media */
/* -----------------------------------------------
= company
----------------------------------------------- */
.company .list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}
.company .list a {
	display: block;
	position: relative;
	height: 84px;
	color: #fff;
}
.company .list a::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.4);
}
.company .list a::after {
	content: "";
	position: absolute;
	inset: 5px;
	border: 1px solid #fff;
	opacity: 0;
}
.company .list a.is-open::after {
	opacity: 1;
}
.company .list a p {
	display: grid;
	place-content: center;
	position: absolute;
	inset: 0;
	z-index: 1;
	font-size: calc(1.3rem / 1.6);
	font-weight: 700;
	letter-spacing: .08em;
}
.company .list a img {
	height: 100%;
	object-fit: cover;
}
.company .detail {
	height: 0;
	overflow: hidden;
	transition: height .4s ease;
}
.company .detail-in {
	padding: 40px 12px;
}
.company .detail h2 {
	max-width: 230px;
	margin: 0 auto 20px;
}
.company .detail .text {
	margin-bottom: 50px;
	font-size: calc(1.3rem / 1.6);
	line-height: calc(20 / 13);
	letter-spacing: .03em;
}
.company .detail .img {
	max-width: 300px;
	margin: 0 auto 60px;
}
.company .detail .img img {
	border-radius: 10px;
}
.company .detail .link .set + .set {
	margin-top: 30px;
}
.company .detail .link h3 {
	margin-bottom: 20px;
	font-size: calc(1.3rem / 1.6);
	font-weight: 700;
	line-height: calc(20 / 13);
	text-align: center;
	letter-spacing: .02em;
}
.company .detail .link a {
	display: block;
	position: relative;
	padding-block: 20px;
	border-top: 1px solid #8c8c8c;
	border-bottom: 1px solid #8c8c8c;
	font-weight: 700;
}
.company .detail .link a::before,
.company .detail .link a::after {
	content: "";
	position: absolute;
}
.company .detail .link a::before {
	top: calc(50% - 25px);
	right: 0;
	width: 48px;
	height: 48px;
	background: #000;
	border: 1px solid #1a1a1a;
	border-radius: 50%;
}
.company .detail .link a::after {
	top: calc(50% - 4.5px);
	right: 9px;
	width: 30px;
	height: 9px;
	background: url(../../img/area/index_icon_link.svg) no-repeat 50% / 100% auto;
}
.company .detail .link a span {
	display: block;
}
.company .detail .link a span:first-child {
	margin-bottom: 10px;
	font-size: calc(1.2rem / 1.6);
	letter-spacing: .04em;
}
.company .detail .link a span:last-child {
	font-size: calc(1.4rem / 1.6);
}
@media print, screen and (min-width: 768px) {/* PC */
.company .list {
	grid-template-columns: repeat(4, 1fr);
}
.company .list a {
	height: 168px;
}
.company .list a::after {
	inset: 10px;
}
.company .list a p {
	padding-inline: 15px;
	font-size: calc(2rem / 1.6);
}
.company .detail-in {
	max-width: 1300px;
	margin-inline: auto;
	padding: 100px;
}
.company .detail .inner {
	display: flex;
	gap: calc(120 / 1500 * 100vw);
	margin-bottom: 75px;
}
.company .detail .set {
	flex: 1;
	order: 2;
}
.company .detail h2 {
	max-width: 460px;
	margin: 0 0 80px;
}
.company .detail .text {
	margin-bottom: 0;
	font-size: calc(1.8rem / 1.6);
	line-height: calc(32 / 18);
	letter-spacing: .06em;
}
.company .detail .img {
	order: 1;
	max-width: calc(600 / 1300 * 100%);
	margin: 0 auto 60px;
}
.company .detail .link {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0 calc(86 / 1500 * 100vw);
}
.company .detail .link .set {
	display: grid;
	grid-row: span 2;
	grid-template-rows: subgrid;
}
.company .detail .link .set + .set {
	margin-top: 0;
}
.company .detail .link h3 {
	display: grid;
	place-content: center;
	margin-bottom: 15px;
	font-size: calc(1.8rem / 1.6);
	line-height: calc(28 / 18);
}
.company .detail .link a {
	padding-block: 30px;
}
.company .detail .link a::before {
	top: calc(50% - 28px);
	width: 54px;
	height: 54px;
}
.company .detail .link a::after {
	right: 12px;
}
.company .detail .link a span:first-child {
	margin-bottom: 10px;
	font-size: calc(1.6rem / 1.6);
}
.company .detail .link a span:last-child {
	font-size: calc(2rem / 1.6);
}
}/* @media */
@media (hover:hover) {
.company .list a::after {
	transition: opacity .3s;
}
.company .list a:hover::after {
	opacity: 1;
}
.company .detail .link a::before {
	transition: .3s;
}
.company .detail .link a:hover::before {
	background: #fff;
	border-color: #8c8c8c;
}
.company .detail .link a:hover::after {
	background: url(../../img/area/index_icon_link_hover.svg) no-repeat 50% / 100% auto;
}
}/* @media */
/* -----------------------------------------------
= career
----------------------------------------------- */
.career {
	padding-bottom: 1px;
	background: #f2f2f2;
}
.career .title {
	padding: 30px 12px 50px;
	color: #fff;
	text-align: center;
}
.career.group .title {
	background: linear-gradient(#3c75d1, #f2f2f2);
}
.career.area .title {
	background: linear-gradient(#3c9c8e, #f2f2f2);
}
.career .title h2 {
	position: relative;
	margin-bottom: 10px;
	padding-bottom: 15px;
	font-family: var(--min);
	font-size: calc(2.2rem / 1.6);
	font-weight: 300;
	letter-spacing: .1em;
}
.career .title h2::after {
	content: "";
	position: absolute;
	left: calc(50% - 19px);
	bottom: 0;
	width: 38px;
	height: 2px;
	background: url(../../img/area/index_dot_white.svg) no-repeat 50% / 100% auto;
}
.career .title p {
	font-size: calc(1.2rem / 1.6);
	font-weight: 700;
	letter-spacing: .08em;
}
.career .case {
	margin: 0 12px 50px;
	padding: 20px;
	background: #fff;
	border: 1px solid #a0a0a0;
	border-radius: 10px;
}
.career .num {
	margin-bottom: 10px;
	font-size: calc(1rem / 1.6);
	font-weight: 700;
	text-align: center;
}
.career.group .num {
	color: #004bc3;
}
.career.area .num {
	color: #3c9c8e;
}
.career .num span {
	display: block;
	font-size: calc(1.3rem / 1.6);
}
.career .theme {
	display: grid;
	place-content: center;
	min-height: 30px;
	margin-bottom: 15px;
	padding: 10px 5px;
	color: #fff;
	border-radius: 30px;
	font-size: calc(1.3rem / 1.6);
	line-height: calc(18 / 13);
	font-weight: 700;
	text-align: center;
}
.career.group .theme {
	background: linear-gradient(#3c75d1, #a0e6ff);
}
.career.area .theme {
	background: linear-gradient(#3c9c8e, #c8ffc8);
}
.career .comment p {
	position: relative;
	margin-bottom: 15px;
	padding: 25px 10px;
	background: #f2f2f2;
	border-radius: 20px;
	font-size: calc(1.6rem / 1.6);
	font-weight: 700;
	letter-spacing: .02em;
}
.career.group .comment p {
	color: #004bc3;
}
.career.area .comment p {
	color: #007d46;
}
.career .comment p::after {
	content: "";
	position: absolute;
	left: 41px;
	bottom: -26px;
	width: 59px;
	height: 37px;
	background: url(../../img/area/index_career_comment_bg_sp.svg) no-repeat 50% / cover;
}
.career .comment img {
	display: block;
	width: 110px;
	margin-inline: auto;
	border-radius: 50%;
}
.career .item + .item {
	position: relative;
	margin-top: 33px;
}
.career .item + .item::before {
	content: "";
	position: absolute;
	top: -24px;
	left: calc(50% - 15px);
	width: 30px;
	height: 30px;
	background: url(../../img/area/index_career_arrow.svg) no-repeat 50% / cover;
}
.career .item h3 {
	font-size: calc(1.1rem / 1.6);
}
.career .item p {
	margin-bottom: 5px;
	padding: 12px;
	font-size: calc(1.3rem / 1.6);
	font-weight: 700;
	border-radius: 10px;
}
.career .item .period {
	color: #fff;
}
.career.group .item .period {
	background: #3c75d1;
}
.career.area .item .period {
	background: #3c9c8e;
}
.career.group .item .affiliation {
	color: #3c75d1;
	background: #a0e6ff;
}
.career.area .item .affiliation {
	color: #007d46;
	background: #c8ffc8;
}
.career.group .item .job {
	background: #cde9ff;
}
.career.area .item .job {
	background: #e9facd;
}
.career .item .skill {
	background: #f2f2f2;
	font-weight: 500;
}
.career .item .skill span {
	font-weight: 700;
}
.career.group .item .skill span {
	color: #004bc3;
}
.career.area .item .skill span {
	color: #007d46;
}
.career.area .item a {
	text-decoration: underline;
}
@media print, screen and (min-width: 768px) {/* PC */
.career {
	padding: 0 40px 40px;
}
.career .title {
	margin-inline: -40px;
	padding: 40px 40px 90px;
}
.career .title h2 {
	margin-bottom: 20px;
	padding-bottom: 25px;
	font-size: calc(4rem / 1.6);
}
.career .title h2::after {
	left: calc(50% - 33px);
	width: 66px;
	height: 4px;
}
.career .title p {
	font-size: calc(1.6rem / 1.6);
}
.career .case {
	max-width: 1220px;
	margin: 0 auto 60px;
	padding: 40px;
	border-radius: 40px;
}
.career .num {
	margin-bottom: 15px;
	font-size: calc(1.6rem / 1.6);
}
.career .theme {
	min-height: 0;
	max-width: 800px;
	margin: 0 auto 30px;
	padding: 15px 10px;
	border-radius: 3em;
	font-size: calc(1.8rem / 1.6);
	line-height: calc(28 / 18);
}
.career .num span {
	font-size: calc(2.4rem / 1.6);
}
.career .comment {
	display: flex;
	align-items: center;
	gap: 0 70px;
	margin-bottom: 30px;
}
.career .comment p {
	order: 2;
	flex: 1;
	margin-bottom: 0;
	padding: 30px 45px;
	border-radius: 30px;
	font-size: calc(2.4rem / 1.6);
	letter-spacing: .06em;
}
.career .comment p::after {
	left: -39px;
	bottom: calc(50% - 19px);
	width: 39px;
	height: 38px;
	background: url(../../img/area/index_career_comment_bg_pc.svg) no-repeat 50% / cover;
}
.career .comment img {
	order: 1;
	width: 220px;
}
.career .item + .item {
	margin-top: 48px;
}
.career .item + .item::before {
	top: -36px;
	left: 80px;
	width: 25px;
	height: 25px;
}
.career .item h3 {
	display: none;
}
.career .sub-title {
	display: flex;
	margin-bottom: 10px;
}
.career .sub-title h3 {
	padding: 0 16px;
	font-size: calc(1.4rem / 1.6);
	text-align: center;
	box-sizing: border-box;
}
.career .sub-title h3:nth-child(1) {
	width: calc(180 / 1220 * 100%);
}
.career .sub-title h3:nth-child(2) {
	width: calc(240 / 1220 * 100%);
}
.career .sub-title h3:nth-child(3) {
	width: calc(164 / 1220 * 100%);
}
.career .sub-title h3:nth-child(4) {
	flex: 1;
}
.career .item {
	display: flex;
}
.career .item p {
	display: grid;
	place-content: center;
	margin-bottom: 0;
	padding: 10px 16px;
	font-size: calc(1.6rem / 1.6);
	text-align: center;
	border-radius: 0;
	box-sizing: border-box;
}
.career .item .period {
	width: calc(180 / 1220 * 100%);
	border-radius: 15px 0 0 15px;
}
.career .item .affiliation {
	width: calc(240 / 1220 * 100%);
}
.career .item .job {
	width: calc(164 / 1220 * 100%);
}
.career .item .skill {
	flex: 1;
	display: block;
	border-radius: 0 15px 15px 0;
	text-align: left;
}
}/* @media */
@media (hover:hover) {
.career.area .item a:hover {
	text-decoration: none;
}
}
/* -----------------------------------------------
= related
----------------------------------------------- */
.related {
	padding: 40px 12px;
}
.related h3 {
	margin-bottom: 10px;
	font-family: var(--min);
	font-size: calc(1.3rem / 1.6);
	font-weight: 300;
}
.related li {
	margin-bottom: 12px;
}
.related li a {
	display: block;
	position: relative;
	padding: 10px 30px 10px 10px;
	background: #f3f3f3;
	border-top: 1px solid #ff747e;
	border-bottom: 1px solid #ff747e;
	font-size: calc(1.3rem / 1.6);
}
.related li a::before {
	content: "";
	position: absolute;
	top: calc(50% - 7.5px);
	right: 8px;
	width: 15px;
	height: 15px;
	background: #ee505c;
}
.related li a::after {
	content: "";
	position: absolute;
	top: calc(50% - 4px);
	right: 12px;
	width: 7px;
	height: 8px;
	background: #fff;
	clip-path: polygon(0 0, 100% 50%, 0 100%);
}
@media print, screen and (min-width: 768px) {/* PC */
.related {
	max-width: 1100px;
	margin-inline: auto;
	padding: 110px 40px 135px;
}
.related h3 {
	margin-bottom: 30px;
	font-size: calc(2rem / 1.6);
	text-align: center;
}
.related ul {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 49px 60px;
}
.related li {
	margin-bottom: 0;
}
.related li a {
	padding: 25px 70px 25px 25px;
	font-size: calc(2rem / 1.6);
}
.related li a::before {
	top: calc(50% - 10px);
	right: 20px;
	width: 20px;
	height: 20px;
}
.related li a::after {
	top: calc(50% - 5.5px);
	right: 25px;
	width: 10px;
	height: 11px;
}
}/* @media */
@media (hover:hover) {
.related li a {
	transition: color .3s;
}
.related li a:hover {
	color: var(--red);
}
}/* @media */
