@charset "UTF-8";

/*==========================================
 PC［1024px~］
===========================================*/
/*body {
	overflow: clip;
}*/

/*------------
 h1見出しタイトルエリア
------------*/
#ttlArea {
	width: 100%;
	position: relative;
}

#ttlArea {
	margin-top: 100px;
	max-height: 600px;
}

:is(.error404, .blog, .single-post, .archive, .wp-singular) #ttlArea .inner {
	position: relative;
	padding: 150px 0 100px;
}

.page #ttlArea .inner {
	padding: 150px 0;
	position: relative;
}

.h1-ttl,
#ttlArea h1 {
	margin-bottom: 4em;
	position: relative;
	display: flex;
	flex-direction: column;
	line-height: 1;
	font-weight: 400;
}

.page #ttlArea h1 {
	margin-bottom: 0;
}

:is(.h1-ttl, #ttlArea h1) .jp {
	line-height: 1.25;
	font-size: clamp(1.4rem, 1.2rem + 1vw, 2rem);
	color: var(--main-color);
}

:is(.h1-ttl, #ttlArea h1) .en {
	font-family: "Montserrat", sans-serif;
	font-weight: bold;
	font-size: clamp(3rem, 1.333rem + 8.33vw, 8rem);
}

#ttlArea:has(.ttlAreaImg) h1 :is(.en, .jp) {
	color: #fff;
}

.ttlAreaImg {
	margin: 0 calc(50% - 50vw);
	width: 100vw;
	height: 100%;
	object-fit: cover;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

/*------------
 breadcrumb
------------*/
#breadcrumb {
	position: relative;
	margin: 1em 0 100px;
	width: min(100%, 1000px);
}

:is(.single-voicelist, .page) #breadcrumb {
	margin: 1em auto 100px;
	width: min(90%, 1000px);
}


#breadcrumb::-webkit-scrollbar {
	display: none;
}

.breadcrumbList {
	display: flex;
	flex-wrap: wrap;
}

.breadcrumbList li {
	margin: 0 30px 0 0;
	padding: 0;
	position: relative;
}

.breadcrumbList li:after {
	content: '';
	width: 10px;
	height: 10px;
	background-image: url('../images/arrow-line.svg');
	background-repeat: no-repeat;
	background-size: 10px 10px;
	position: absolute;
	top: 3px;
	right: -20px;
}

.breadcrumbList li:last-child:after {
	content: none;
}

.breadcrumbList li:before {
	content: none;
}

.breadcrumbList li,
.breadcrumbList a {
	font-size: 1.1rem;
	font-weight: 300;
	line-height: 1.2;
}

.breadcrumbList li:last-child a {
	font-weight: 700;
	pointer-events: none;
	color: var(--text-color);
}

.breadcrumbList li a {
	padding: 0;
	width: inherit;
	color: var(--text-color);
	text-decoration: none;
}

/*------------
 本文見出し
------------*/
:where(#contentArea) h2 {
	font-size: clamp(2.8rem, 2.733rem + 0.33vw, 3rem);
}

/*------------
 コンテンツエリア
------------*/
#contentArea {
	width: min(100%, 1000px);
	margin: auto;
	position: relative;
	z-index: 1;
	font-weight: normal;
	font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
	line-height: 1.8;
}

:is(.page, .error404, .single-voicelist) #contentArea .inner {
	width: 100%;
}

:where(#contentArea) :is(section, .section) {
	margin: 100px 0;
}

:where(#contentArea) :is(section):nth-of-type(1) {
	margin-top: 0;
}

:is(section, .section).w100-bgImg {
	width: 100vw;
	margin: 0 calc(50% - 50vw);
	padding: 100px calc(50vw - 50%);
	position: relative;
	background-image: url('../images/bg-partsImg.jpg');
}


/*2カラム*/
.hbn-col-2Wrap {
	overflow: clip;
}

#hbn-col-2 {
	margin: 0 auto 60px;
	flex-direction: row;
}

#hbn-col-2 #ttl-area {
	width: 100%;
}

#hbn-col-2 main {
	width: calc(100% - 300px);
}

#hbn-col-2 #contentArea {
	padding: 0;
}

#hbn-col-2 #contentArea::before {
	content: none;
}

#hbn-col-2 aside {
	padding: 0 0 0 50px;
	width: 300px;
}

#hbn-col-2.page aside {
	padding: 0 50px 0 0;
}

#sideArea {
	max-height: 90vh;
	overflow-y: scroll;
}

#sideArea::-webkit-scrollbar {
	display: none;
	/*Google Chrome、Safari、Microsoft Edge対応のスクロールバー非表示コード*/
}

/*サイド*/

.sideArea>div:first-child {
	width: 100%;
	position: sticky;
	top: 180px;
}

.sideArea .inner {
	width: 100%;
}

.sideArea h3 {
	padding-bottom: 1em;
	font-size: 3rem;
	font-weight: normal;
	font-family: "Montserrat", sans-serif;
	font-weight: 700;
	line-height: 1.25;
	position: relative;
}

.sideArea h3 .en {
	margin-bottom: 10px;
	padding-left: 15px;
	display: block;
	font-family: "Montserrat", sans-serif;
	font-weight: 700;
	font-size: 1.3rem;
	position: relative;
}

.sideArea h3 .en::before {
	content: '';
	width: 10px;
	height: 10px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	background: linear-gradient(180deg, rgba(143, 211, 245, 1) 0%, rgba(121, 202, 242, 1) 11%, rgba(64, 181, 236, 1) 25%, rgba(0, 157, 230, 1) 48%, rgba(0, 64, 152, 1) 76%, rgba(0, 32, 99, 1) 100%);
}

.sideArea h3:not(:first-child) {
	margin: 2em auto 0 0;
}

.sideArea .categoryList {
	margin-bottom: 60px;
}

.sideArea .categoryList li {
	border-bottom: solid 1px var(--bg-color);
}

.sideArea .categoryList li a {
	padding: 15px 30px 15px 10px;
	height: 100%;
	color: var(--text-color);
	text-decoration: none;
	display: flex;
	align-items: center;
	font-weight: bold;
	position: relative;
	line-height: 1.25;
}

.sideArea .categoryList li a::after {
	content: '';
	width: 20px;
	height: 20px;
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	background: url("../images/arrow.svg");
	background-position: center;
	background-size: contain;
	transition-duration: .3s;
}

@media (hover: hover) {
	.sideArea .categoryList li a:hover::after {
		right: 5px;
	}
}

.sideArea .categoryList li.current-cat a {
	color: var(--main-color);
}

/*固定ページのナビ*/
.pageNaiv {
	counter-reset: count 0;
}

.pageNaiv li {
	padding: 0 0 3em 2em;
	position: relative;
	font-weight: bold;
	opacity: .5;
}

.pageNaiv li:last-child {
	margin-bottom: 0;
}

.pageNaiv li:has(a.current) {
	opacity: 1;
}

.pageNaiv>li:before {
	content: "0" counter(count);
	counter-increment: count 1;
	position: absolute;
	left: 0;
	top: 2px;
	font-family: "Montserrat", sans-serif;
	font-weight: 700;
	color: var(--main-color);
}

.pageNaiv>li:not(:last-child):after {
	content: '';
	width: 1px;
	height: calc(100% - 3em);
	background-color: var(--bg-color);
	position: absolute;
	top: 2em;
	left: .55em;
}

.pageNaiv li a {
	text-decoration: none;
	color: var(--text-color);
}

/*END2カラム*/

/*------------
ページ内アンカー
------------*/
.anchorArea {
	margin-bottom: 3em;
	row-gap: 1em;
}

.anchorArea .btm {
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	text-align: justify;
}

.anchorArea .btm a {
	margin: 0 auto 0 0;
	padding: 1em 50px 1em 0;
	display: block;
	width: 100%;
	height: 100%;
	align-items: center;
	display: flex;
}

.anchorArea .btm a::before {
	width: 30px;
	height: 30px;
	top: 50%;
}

.anchorArea .btm a::before {
	top: 50%;
	background: url('../images/arrow.svg');
	background-size: contain;
	transform: translateY(-50%) rotate(90deg);
	right: 0;
}

@media (hover: hover) {
	.anchorArea .btm a:hover {
		background-color: var(--bl-color);
	}

	.anchorArea .btm a:hover::before {
		right: 0;
		transform: translateY(-30%) rotate(90deg);
	}
}

.anchorArea.col-2 .btm {
	width: 48%;
}

/*------------
 dlのスタイル
------------*/
:where(#contentArea) dl {
	margin: 1em 0;
	line-height: 1.8;
	display: flex;
	flex-wrap: wrap;
}

:where(#contentArea) dt {
	margin-bottom: 1em;
	padding-bottom: 1em;
	font-weight: bold;
	width: 30%;
	border-bottom: solid 1px var(--bg-color);
	font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
}

:where(#contentArea) dd {
	margin-bottom: 1em;
	padding-bottom: 1em;
	word-break: break-all;
	width: 70%;
	border-bottom: solid 1px var(--bg-color);
	font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
}

/*------------
 ulのスタイル
------------*/
:where(#contentArea) ul {
	margin: 1em 0;
	line-height: 1.8;
	font-size: clamp(1.4rem, 1.333rem + 0.33vw, 1.6rem);
}

:where(#contentArea) ul:not(.anchorArea, .newsList, .PrevNextArea, .page-numbers, .formList, .col-3, .col-2, .col-4, .jobList, .thumb-cardList, .interviewList) li:not(.btm-bgcolor, .btm) {
	padding: 0 0 0 2rem;
	position: relative;
}

:where(#contentArea) ul:not(.anchorArea, .newsList, .PrevNextArea, .page-numbers, .formList, .col-3, .col-2, .col-4, .jobList, .thumb-cardList, .interviewList) li:not(.btm-bgcolor, .btm):before {
	content: '';
	width: 1rem;
	height: 1rem;
	background-color: var(--main-color);
	border-radius: 50%;
	position: absolute;
	top: 1rem;
	left: 0;
}

:where(#contentArea) ul:not(.anchorArea, .newsList, .PrevNextArea, .page-numbers, .formList, .col-3, .col-2, .col-4) li:not(.btm-bgcolor, .btm):has(a[target="_blank"]):before {
	top: 15px;
}

/*横並び*/
ul:not(.anchorArea, .newsList, .PrevNextArea, .page-numbers, .formList, .col-3, .col-2, .col-4).flex {
	justify-content: flex-start;
}

ul:not(.nav-item_sub >ul, .anchorArea, .newsList, .PrevNextArea, .page-numbers, .formList, .col-3, .col-2, .col-4).flex li {
	margin-right: 1em;
}

/*矢印リスト*/
.arrowList li::before {
	content: none !important;
}

.arrowList li a {
	padding-left: 30px;
}

.arrowList li a::before {
	content: '';
	width: 20px;
	height: 20px;
	background-image: url('../images/arrow.svg');
	position: absolute;
	top: 10px;
	left: 0;
	transform: translateY(-50%);
	background-repeat: no-repeat;
	background-position: center;
}

/*interviewリスト
.interviewList {
	margin-bottom: 3em;
	padding: 0 1em;
	position: relative;
}

.interviewList::before {
	content: '';
	width: 100vw;
	height: 50%;
	margin: 0 calc(50% - 50vw) 0 0;
	padding: 0 calc(50vw - 50%);
	background: linear-gradient(180deg, #fff 0%, #fff 30%, #FAFAFA 30%, #FAFAFA 100%);
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
	z-index: -1;
}

.interviewList img {
	width: 100%;
	margin: 0 auto 20px;
	aspect-ratio: 1/1;
	object-fit: cover;
	display: block;
}

.interviewList a {
	color: var(--text-color);
	text-decoration: none;
}

#contentArea .interviewList :is(h3, p) {
	margin-bottom: 1em;
}

#contentArea .interviewList h3 {
	padding-left: 5px;
}*/

/*------------
 olのスタイル
------------*/
:where(#contentArea) ol {
	margin: 1em 0;
	counter-reset: count 0;
	line-height: 1.8;
	font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
}

:where(#contentArea) ol li {
	padding: 0 0 .5em 2em;
	position: relative;
}

:where(#contentArea) ol li:last-child {
	margin-bottom: 0;
	font-weight: normal;
}

:where(#contentArea) ol>li:before {
	content: counter(count) " ";
	counter-increment: count 1;
	position: absolute;
	left: 0;
	top: 2px;
	font-family: "Montserrat", sans-serif;
	font-weight: 700;
}

ol.flowList li {
	margin-bottom: 50px;
	padding: 1em 1em 1em 4em;
	background: #fff;
	border-radius: 2vmax;
	border: solid 1px var(--line-color);
}

:where(#contentArea) ol.flowList>li:before {
	left: 2em;
	top: 50%;
	transform: translateY(-50%);
	color: var(--main-color);
}

:where(#contentArea) ol.flowList>li:not(:last-child):after {
	content: '';
	width: 1px;
	height: 50px;
	background-color: var(--line-color);
	position: absolute;
	bottom: -51px;
	left: 2.15em;
}

/*------------
 テーブルのスタイル
------------*/
.wp-block-table table,
table {
	margin: 1em 0;
	width: 100%;
	font-size: clamp(1.4rem, 1.327rem + 0.36vw, 1.6rem);
	line-height: 1.8;
	background-color: #fff;
	overflow: hidden;
}

.wp-block-table table th,
.wp-block-table table td,
th,
td {
	padding: 1.5em;
	vertical-align: middle;
	font-weight: bold;
	text-align: left;
	border: none;
	border-bottom: solid 1px var(--bg-color);
}


.wp-block-table table td,
td {
	font-weight: normal;
}

.wp-block-table table.thw30 th,
.thw30 th {
	width: 30%;
}

.wp-block-table table.sp-th100 td,
.sp-th100 td {
	padding: 1em;
	vertical-align: middle;
}

.wp-block-table table p:last-child,
table p:last-child {
	margin-bottom: 0;
}

/*沿革のテーブル*/
.historyTbale th {
	font-family: "Montserrat", sans-serif;
	color: var(--main-color);
}

/*--------
　テキストのスタイル関連
---------*/
:where(main) p {
	margin-bottom: 1em;
}

:where(main, footer) :where(h2, h3, h4, h5, h6) {
	margin: 1.25em 0;
}

.indent {
	padding-left: 1.5rem;
	text-indent: -1.5rem;
}

.m-top0 {
	margin-top: 0;
}

.m-bottom0 {
	margin-bottom: 0;
}

.m-bottom1em {
	margin-bottom: 1em;
}

.m-bottom2em {
	margin-bottom: 2em;
}

.m-bottom3em {
	margin-bottom: 3em;
}

.m-bottom5em {
	margin-bottom: 5em;
}

/*hr*/
.wp-block-separator {
	border-top: 1px solid var(--bg-color);
	margin: 5em 0;
}

/*インデント*/
.indentback {
	text-indent: -1em;
	padding-left: 1em;
}

/*iframe*/
.iframe {
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 75%;
}

.iframe iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/*------------
 imgのスタイル
------------*/
.img100 {
	width: 100%;
	height: auto;
}

.img30 {
	width: 30%;
	min-width: 250px;
	height: auto;
}

.max-400img {
	width: min(100%, 400px);
	height: auto;
}

.max-300img {
	width: min(100%, 300px);
	height: auto;
}

.max-200img {
	width: min(100%, 200px);
	height: auto;
}

.img_block {
	display: block;
	margin: 0 auto;
}

.img_block.m-bottom3em {
	margin: 0 auto 3em;
}

.img_block.m-bottom2em {
	margin: 0 auto 2em;
}

.img_block.m-bottom1em {
	margin: 0 auto 1em;
}

figcaption {
	font-size: 1.4rem;
}

.img-radius {
	border-radius: 1vmax;
}

.float_right {
	margin: 10px 0 10px 10px;
	float: right;
	z-index: 1;
	position: relative;
}

.cf::after {
	content: "";
	display: block;
	clear: both;
}

.youtube {
	width: 100%;
	aspect-ratio: 16 / 9;
}

.youtube iframe {
	width: 100%;
	height: 100%;
}

/*--ライトボックスなど--*/
.wp-lightbox-overlay {
	z-index: 1000000;
}

.blocks-gallery-grid,
.wp-block-gallery {
	justify-content: center;
}

.wp-lightbox-container button:not(:hover):not(:active):not(.has-background) {
	background-color: var(--main-color);
	border: none;
	opacity: 1;
}

.wp-lightbox-overlay .scrim {
	background-color: rgb(0 0 0 /.7) !important;
}

.wp-lightbox-overlay .close-button:hover,
.wp-lightbox-overlay .close-button:not(:hover):not(:active):not(.has-background) {
	background: #fff !important;
}



/*
.wp-block-image.wp-lightbox-container {
	position: relative;
}

.wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption)::before,
.wp-block-image.wp-lightbox-container::after,
.wp-block-image.wp-lightbox-container::before {
	content: '';
	width: 20px;
	height: 20px;
	position: absolute;
	top: 10px;
	right: 10px;
	border-radius: 5px;
}


.wp-block-image.wp-lightbox-container::before {
	background-color: var(--main-color);
}


.wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption)::before {
	content: none;
}

.wp-block-image.wp-lightbox-container::after {
	background-image: url('../images/icon-search.svg');
	background-repeat: no-repeat;
	top: 11px;
	right: 8px;
}*/

.wp-lightbox-overlay .scrim {
	background-color: rgb(0 0 0 /.7) !important;
}

.wp-lightbox-overlay .close-button:hover,
.wp-lightbox-overlay .close-button:not(:hover):not(:active):not(.has-background) {
	background: #fff !important;
}

/*先輩の声*/
.single-voicelist .interviewBox {
	margin-bottom: 3em;
}

.single-voicelist .interviewBox .wp-block-column .InterviewImg {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/*先輩の声関連記事*/
#voiceArea {
	margin-top: 5em;
}

/*==========================================
 tb［541px-1080px以下］
===========================================*/
@media screen and (max-width: 1080px) {

	/*------------
	h1見出しタイトルエリア
	------------*/
	.page #ttlArea {
		margin-top: 85px;
	}

	/*------------
	ページ内アンカー
	------------*/

	.anchorArea .btm {
		width: 48%;
	}


	/*------------
	 コンテンツエリア
	------------*/
	:is(.page, .error404, .single-voicelist) #contentArea .inner {
		width: min(90%, 1000px);
	}

	/*2カラム*/
	#hbn-col-2 {
		flex-direction: column;
	}

	#hbn-col-2 main {
		margin-bottom: 60px;
		width: 100%;
	}

	#hbn-col-2 aside {
		padding: 3em 0 0;
		width: 100%;
		border-right: none;
		border-top: solid 1px var(--line-color);
		position: relative;
	}

	/*固定ページのaside*/
	#hbn-col-2.page {
		flex-direction: row;
	}

	#hbn-col-2.page aside {
		padding: 0 1em 0 0;
		width: max(200px, 30%);
		border-top: none;
	}

	#hbn-col-2.page main {
		width: calc(100% - max(200px, 30%));
	}

	/*END2カラム*/
	/*------------
	ページ内アンカー
	------------*/

	/*------------
	 テーブルのスタイル
	------------*/
	.js-scrollable {
		overflow: hidden;
	}

	.js-scrollable table {
		width: 1000px;
	}

	.scroll-hint-icon {
		top: 15% !important;
	}

}

/*==========================================
 sp［540px以下］
===========================================*/
@media screen and (max-width: 540px) {

	/* iOSでのデフォルトスタイルをリセット */
	input[type="submit"],
	input[type="button"] {
		border-radius: 0;
		-webkit-box-sizing: content-box;
		-webkit-appearance: button;
		appearance: button;
		border: none;
		box-sizing: border-box;
		cursor: pointer;
	}

	input[type="submit"]::-webkit-search-decoration,
	input[type="button"]::-webkit-search-decoration {
		display: none;
	}

	input[type="submit"]:focus,
	input[type="button"]:focus {
		outline-offset: -2px;
	}

	/*------------
	h1見出しタイトルエリア
	------------*/
	.page #ttlArea {
		margin-top: 70px;
	}

	:is(.error404, .blog, .single-post, .archive) #ttlArea .inner {
		padding: 150px 0 0;
	}

	.page-template-page-contact-form #ttlArea .inner {
		padding: 50px 0;
	}

	/*------------
	 breadcrumb
	------------*/
	#breadcrumb {
		overflow-x: scroll;
	}

	.breadcrumbList {
		width: 200%;
	}

	.breadcrumbList li:after {
		padding: 0 5px;
	}

	.breadcrumbList a {
		font-size: 1.1rem;
	}

	/*------------
	 コンテンツエリア
	------------*/
	:where(#contentArea) :is(section, .section) {
		margin: 5em 0;
	}

	/*固定ページのaside*/
	#hbn-col-2.page {
		flex-direction: column;
	}

	#hbn-col-2.page aside h3 {
		display: none;
	}

	#hbn-col-2.page aside {
		width: 100%;
		padding: 0;
		margin-bottom: 3em;
	}

	.pageNaiv {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		row-gap: 1em;
	}

	.pageNaiv li {
		margin: 0;
		padding: 0;
		width: 48%;
		display: flex;
		align-items: center;
		text-align: justify;
		border-bottom: solid 1px var(--line-color);
		opacity: 1;
	}

	.pageNaiv li a {
		margin: 0 auto 0 0;
		padding: 1em 50px 1em 0;
		display: block;
		width: 100%;
		height: 100%;
		align-items: center;
		display: flex;
		line-height: 1.5;
	}

	.pageNaiv li::before,
	.pageNaiv li:not(:last-child)::after {
		content: none;
	}

	.pageNaiv li a::after {
		content: '';
		top: 50%;
		background: url('../images/arrow.svg');
		background-size: contain;
		transform: translateY(-50%) rotate(90deg);
		right: 0;
		width: 30px;
		height: 30px;
		position: absolute;
	}

	#hbn-col-2.page main {
		width: 100%;
	}


	/*テキスト・画像*/
	.img30 {
		padding: 0;
		width: 100%;
	}

	/*------------
	imgのスタイル
	------------*/
	.float_right {
		margin: 0 auto 1em;
		float: none;
	}

	/*------------
	ulのスタイル
	------------*/
	/*custom-pagination*/
	.pagerArea {
		width: 100%;
	}


	/*------------
	dlのスタイル
	------------*/
	:where(#contentArea) :is(dt, dd) {
		width: 100%;
	}

	:where(#contentArea) dt {
		border: none;
		margin-bottom: 0;
		padding-bottom: .25em;
		font-size: 1.6rem;
	}

	:where(#contentArea) dl.dt-auto {
		display: grid;
		grid-template: 1fr;
	}

	:where(#contentArea) dl.dt-auto :is(dt, dd) {
		grid-column: auto;
	}

	:where(#contentArea) dl.dt-auto dt {
		padding-right: 0;
	}

	#contentArea dl.border-dotDL dt::before {
		content: none;
	}

	/*------------
	 テーブルのスタイル
	------------*/
	:is(th, td) {
		line-height: 1.6;
	}

	/*th td 100%*/
	.sp-th100 :is(th, td) {
		display: block;
		width: 100%;
	}

	.sp-th100 :is(th, td) {
		border: none;
	}

	.sp-th100 tr {
		border-bottom: solid 1px var(--bg-color);
	}

	.sp-th100 th {
		padding: 1.5em .5em .5em;
	}

	.sp-th100 td {
		padding: 0 .5em 1.5em;
	}

	.js-scrollable table {
		width: 700px;
	}

}