@charset "utf-8";
/*
Theme Name: IEC
Theme URI: null
Description: Description
Author: 81bridge - SGX
Version: 1.0
*/

.aligncenter {
    display: block;
    margin: 0 auto;
}
.alignright {
    float: right;
}
.alignleft {
    float: left;
}
img[class*="wp-image-"],
img[class*="attachment-"] {
    height: auto;
    max-width: 100%;
}
.wp-block-image figure,
.wp-block-image figcaption {
    display: block;
}
a.nolink,
a.nolink:hover {
    opacity: 1;
    cursor: default;
    pointer-events: none;
}
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, figcaption, figure, section, footer, header, main, hgroup, menu, nav, summary {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;
	box-sizing: border-box;
}
html {
	font-size: 62.5%;
}
@media all and (min-width: 897px) and (max-width: 1365px) {
	html {
		font-size: calc(1000vw / 1366);
	}
}
@media all and (max-width: 389px) {
	html {
		font-size: calc(1000vw / 390);
	}
}
body, table, input, textarea, select, option {
	font-family: "Noto Sans JP", sans-serif;
}
article, aside, canvas, details, figcaption, figure, footer, header, main, hgroup, menu, nav, section, summary {
	display: block;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
chrome_annotation {
	border: none !important;
}
:focus {
	outline: 0;
}
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}
img {
	vertical-align: top;
	max-width: 100%;
    height: auto;
}
address {
	font-style: normal;
}
a,
a:link {
	color: #1A1A1A;
	text-decoration: none;
	transition: 0.3s;
}
a:visited {
	color: #1A1A1A;
}
a:hover {
	color: #1A1A1A;
}
a:active {
	color: #1A1A1A;
}
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	color: #1A1A1A;
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.5;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #1A1A1A;
}
.fixed {
	position: fixed;
	width: 100%;
	height: 100%;
}
#container {
	padding-top: 6rem;
	position: relative;
	text-align: left;
	background: url(img/common/bg01.webp) no-repeat right top / 83.1rem,url(img/common/bg02.webp) no-repeat left bottom / 136.6rem;
}
a[href^="tel:"] {
	cursor: default;
	pointer-events: none;
}
@media all and (min-width: 897px) {
	.sp {
		display: none !important;
	}
}
@media all and (max-width: 896px) {
	body {
		min-width: inherit;
		font-size: 1.4rem;
	}
	a:hover,
	a:hover img {
		opacity: 1 !important;
	}
	.pc {
		display: none !important;
	}
	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}
	#container {
		background: url(img/common/bg01_sp.webp) no-repeat right top 6rem / 38.9rem,url(img/common/bg02_sp.webp) no-repeat right bottom / 39rem;
	}
}
/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* 81-LSM */
/* clearfix */	
.clearfix:after {content: "";display: block;clear: both;}
/* flex */	
.flex,.flexA,.flexB,.flexC {display: flex;flex-wrap: wrap;}
.flexA {justify-content: space-around;}
.flexB {justify-content: space-between;}
.flexC {justify-content: center;}
.mon {
	font-weight: 500;
	font-family: "Montserrat", sans-serif;
}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
@media all and (max-width: 896px) {
}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 999;
}
#gHeader .hBox {
	margin: 0 auto;
	max-width: 136.6rem;
	position: relative;
	padding: 1.4rem 7.6rem 1.4rem 2.9rem;
}
#gHeader .logo {
	width: 10.3rem;
}
#gHeader .logo .blackLogo {
	display: none;
}
#gHeader .linkUl {
	padding-top: 0.2rem;
}
#gHeader .linkUl li {
	margin-left: 4.1rem;
}
#gHeader .linkUl li a {
	color: #FFF;
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: 0.05em;
}
#gHeader .linkUl li a:hover {
	opacity: 0.7;
}
#gHeader .menu {
	position: absolute;
	top: 2.4rem;
	right: 1.8rem;
	height: 2rem;
	width: 2.4rem;
	cursor: pointer;
	z-index: 300;
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
}	
#gHeader .menu span {
	background: #FFF;
	border: none;
	height: 1px;
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transition: all .35s ease;
	transition: all .35s ease;
	cursor: pointer;
}	
#gHeader .menu span:nth-of-type(2) {
	top: 0.5rem;
}	
#gHeader .menu span:nth-of-type(3) {
	top: 1rem;
}
#gHeader .menu.on .top {
	transform: translateY(0.5rem) translateX(0) rotate(25deg);
}
#gHeader .menu.on .middle {
	opacity: 0;
}
#gHeader .menu.on .bottom {
	transform: translateY(-0.5rem) translateX(0) rotate(-25deg);
}
.menuBox {
	display: none;
	position: fixed;
	top: 8.4rem;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	max-width: 131.8rem;
	max-height: calc(100vh - 10.4rem);
	overflow-y: auto;
	background-color: #FFF;
	border-radius: 1rem;
	box-shadow: 0 0 1rem 0 rgba(0, 0, 0, 0.25);
	z-index: 280;
}
.menuBox .subBox {
	margin: 0 auto;
	padding: 6.9rem 2rem 7rem;
	max-width: 112rem;
	box-sizing: content-box;
}
.menuBox .linkList {
	margin-top: 5.7rem;
	padding-right: 0.8rem;
	gap: 2rem;
}
.menuBox .linkList li {
	width: calc((100% - 6rem) / 4);
}
.menuBox .linkList li a {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	min-height: 7.6rem;
	border-radius: 1rem;
	background: #FFF;
	box-shadow: 0 0 1rem rgba(0, 0, 0, 0.25);
}
.menuBox .linkList li a .sub {
	padding: 0 0 0.1rem 3.2rem;
	display: inline-block;
	text-align: center;
	font-weight: 700;
	letter-spacing: 0.05em;
	background: url(img/common/icon01.webp) no-repeat left center / 2.2rem;
	transition: 0.3s;
}
#gHeader.on {
	background-color: #FFF;
}
#gHeader.on .logo .blackLogo {
	display: block;
}
#gHeader.on .logo .whiteLogo {
	display: none;
}
#gHeader.on .linkUl li a {
	color: #1A1A1A;	
}
#gHeader.on .menu span {
	background: #1A1A1A;
}
@media all and (min-width: 897px) {
	#gHeader .menu:hover {
		opacity: 0.7;
	}
	.menuBox .linkList li a:hover {
		background: #1A1A1A;
		color: #FFF;
		box-shadow: 0 0 1rem #FFF;
	}
	.menuBox .linkList li a:hover .sub {
		background-image: url(img/common/icon01_over.webp);
		background-position: left top calc(50% - 0.1rem);
	}
}
@media all and (max-width: 896px) {
	#gHeader .hBox {
		margin: 0;
		max-width: inherit;
		padding: 1.6rem 8rem 1.6rem 1.4rem;
	}
	#gHeader .logo {
		width: 9rem;
	}
	#gHeader .menu {
		right: 1.7rem;
	}
	.menuBox {
		top: 8rem;
		left: 2.5rem;
		right: 2.4rem;
		transform: none;
		width: auto;
		height: calc(100dvh - 10.2rem);
		max-height: inherit;
		max-width: inherit;
		overflow: auto;
		-webkit-overflow-scrolling: touch;
	}
	.menuBox .subBox {
		margin: 0;
		padding: 2.4rem 2rem 7rem;
		max-width: inherit;
	}
	.menuBox .linkUl {
		margin-bottom: 0.6rem;
	}
	.menuBox .linkUl li {
		margin: 0 auto 1.6rem;
		max-width: 29.3rem;
	}
	.menuBox .linkUl li:last-child {
		margin-bottom: 0;
	}
	.menuBox .linkUl li a {
		padding-bottom: 0.2rem;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: center;
		min-height: 5rem;
		box-shadow: 0 0 1rem 0 rgba(0, 0, 0, 0.25);
		background: #FFF;
		border-radius: 1rem;
		font-size: 1.4rem;
		font-weight: 500;
		letter-spacing: 0.05em;
	}
	.menuBox .linkList {
		margin-top: 3.2rem;
		padding-right: 0;
		display: block;
	}
	.menuBox .linkList li {
		margin-bottom: 1.6rem;
		width: auto;
	}
	.menuBox .linkList li:last-child {
		margin-bottom: 0;
	}
	.menuBox .linkList li a .sub {
		padding: 0 1rem 0 6rem;
		width: 100%;
		display: block;
		font-size: 1.6rem;
		background: url(img/common/icon01.webp) no-repeat left 3rem top calc(50% + 0.1rem) / 2.3rem;
	}
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter {
	padding: 11.6rem 0 4rem;
}
#gFooter .fBox {
	margin: 0 auto;
	padding: 0 2rem;
	max-width: 112rem;
	box-sizing: content-box;
}
#gFooter .fLogo {
	margin: 0 auto 4.6rem;
	width: 10.3rem;
}
#gFooter .textImg {
	margin: 0 auto 9.3rem;
	max-width: 54.3rem;
}
#gFooter .comMenuList li a {
	color: #FFF;
}
#gFooter .comMenuList li a::before {
	background-color: #FFF;
}
#gFooter .bottomBox {
	margin: 6.7rem 0 6.1rem;
	padding-top: 3.7rem;
	border-top: 1px solid #4C4C4C;
}
#gFooter .bottomBox .linkUl {
	display: flex;
	flex-wrap: wrap;
	gap: 6rem;
}
#gFooter .bottomBox .linkUl li a {
	color: #FFF;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}
#gFooter .bottomBox .linkUl li a:hover {
	opacity: 0.7;
}
#gFooter address {
	color: #656565;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	text-align: center;
}
#gFooter .pageTop {
	position: fixed;
	bottom: 2.5rem;
	right: 1.5rem;
	width: 6rem;
	z-index: 100;
}
#gFooter .pageTop a:hover {
	opacity: 0.7;
}
@media all and (max-width: 896px) {
	#gFooter {
		padding: 8.2rem 0 4.8rem;
	}
	#gFooter .fBox {
		margin: 0;
		padding: 0 2rem;
		max-width: inherit;
	}
	#gFooter .fLogo {
		margin: 0 auto 3.4rem;
	}
	#gFooter .textImg {
		margin: 0 auto 3.9rem;
		max-width: 34.5rem;
	}
	#gFooter .comMenuList > li > a {
		padding: 1.8rem 0;
		color: #FFF;
		border-top: 1px solid #686868;
		border-bottom: none;
	}
	#gFooter .comMenuList.style01 > li > a {
		border-bottom: 1px solid #686868;
	}
	#gFooter .comMenuList > li > a:not(.special) {
		background-image: url(img/common/icon06_white.webp);
		background-size: 1.2rem;
	}
	#gFooter .comMenuList li a::before {
		background-color: #FFF;
	}
	#gFooter .comMenuList > li > a.special .arrow {
		background-image: url(img/common/icon05_white.webp);
		background-size: 2rem;
	}
	#gFooter .comMenuList > li > a.special .arrow.on {
		background-image: url(img/common/icon05_white_on.webp);
	}
	#gFooter .comMenuList .subUl {
		padding: 0 2.4rem 2.8rem;
		border-bottom: none;
	}
	#gFooter .bottomBox {
		margin: 0 0 5.5rem;
		padding-top: 2.6rem;
		display: block;
		border: none;
	}
	#gFooter .bottomBox .linkUl {
		padding: 0 0.4rem;
		display: block;
	}
	#gFooter .bottomBox .linkUl:not(:last-child) {
		margin-bottom: 6rem;
	}
	#gFooter .bottomBox .linkUl li:not(:last-child) {
		margin-bottom: 2.1rem;
	}
	#gFooter .bottomBox .linkUl li a {
		display: block;
		width: fit-content;
	}
	#gFooter .pageTop {
		bottom: 8rem;
		width: 4rem;
		display: none;
	}
}
/*------------------------------------------------------------
	pageTitle
------------------------------------------------------------*/
.pageTitle {
	padding: 3.6rem 0 11.9rem;
}
.pageTitle .text {
    padding: 0 1.5rem;
    margin: 13.2rem auto 0;
    color: #FFF;
    font-size: 1.8rem;
    text-align: center;
    font-weight: 500;
    letter-spacing: 0.09rem;
    line-height: 2.22;
    max-width: 89rem;
}
@media all and (max-width: 896px) {
	.pageTitle {
		padding: 2.3rem 0 14.3rem;
	}
	.pageTitle .text {
        padding: 0 2.4rem;
        margin-top: 6.8rem;
        font-size: 1.6rem;
        letter-spacing: 0.048rem;
        line-height: 1.5;
        max-width: 100%;
    }
}
/*------------------------------------------------------------
	pagePath
------------------------------------------------------------*/
#pagePath {
	margin: 0 auto 10.6rem;
	padding: 0 2rem;
	max-width: 112rem;
	box-sizing: content-box;
	position: relative;
	z-index: 5;
}
#pagePath li,
#pagePath li a {
	position: relative;
	display: inline-block;
	color: #FFF;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
}
#pagePath li {
	margin-right: 0.6rem;
}
#pagePath li a:hover {
	opacity: 0.7;
}
#pagePath li:not(:first-child)::before {
	margin-right: 1rem;
	display: inline-block;
	width: 0.6rem;
	height: 1rem;
	background: url(img/common/icon02.webp) no-repeat left top / 100%;
	content: '';
	vertical-align: -0.1rem;
}
@media all and (max-width: 896px) {
	#pagePath {
		margin: 0 2.4rem 5.6rem;
		padding: 0;
		max-width: inherit;
	}
	#pagePath li,
	#pagePath li a {
		font-size: 1.2rem;
	}
	#pagePath li {
		margin-right: 0.9rem;
	}
	#pagePath li:not(:first-child)::before {
		margin-right: 1.2rem;
	}
}
/*------------------------------------------------------------
	content
------------------------------------------------------------*/
.content {
	margin: 0 auto;
	padding: 0 2rem;
	max-width: 112rem;
	box-sizing: content-box;
}
@media all and (max-width: 896px) {
	.content {
		margin: 0;
		padding: 0 2.4rem;
		max-width: inherit !important;
	}
}
/*------------------------------------------------------------
	comBox
------------------------------------------------------------*/
.comBox {
	margin: 0 auto;
	padding: 10rem 0 10.6rem;
	max-width: 131.8rem;
	background: #FFF;
	border-radius: 1rem;
}
@media all and (max-width: 896px) {
	.comBox {
		margin: 0 2.4rem;
		padding: 5rem 0 5.8rem;
		max-width: inherit;
	}
}
/*------------------------------------------------------------
	headLine01
------------------------------------------------------------*/
.headLine01 {
	color: #FFF;
	text-align: center;
	font-weight: 500;
	letter-spacing: 0.05em;
}
.headLine01 .en {
	margin-bottom: 0.5rem;
	display: block;
	font-size: 4.2rem;
	font-weight: 500;
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0;
}
@media all and (max-width: 896px) {
	.headLine01 {
		font-size: 1.6rem;
	}
	.headLine01 .en {
		margin-bottom: 0.1rem;
		font-size: 3.2rem;
		line-height: 1.19;
	}
}
/*------------------------------------------------------------
	headLine02
------------------------------------------------------------*/
.headLine02 {
	margin-bottom: 5.6rem;
	color: #FFF;
	font-size: 5rem;
	font-weight: 500;
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
	text-align: center;
}
@media all and (max-width: 896px) {
	.headLine02 {
		margin-bottom: 2.9rem;
		font-size: 3.2rem;
	}
}
/*------------------------------------------------------------
	headLine03
------------------------------------------------------------*/
.headLine03 {
	margin-bottom: 4.1rem;
	color: #FFF;
	font-size: 3.2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.headLine03 .en {
	margin-bottom: -0.2rem;
	display: block;
	font-size: 1.6rem;
	font-weight: 500;
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0;
}
@media all and (max-width: 896px) {
	.headLine03 {
		margin-bottom: 1.2rem;
		font-size: 2.4rem;
	}
	.headLine03 .en {
		margin-bottom: -0.1rem;
		font-size: 1.4rem;
	}
}
/*------------------------------------------------------------
	headLine04
------------------------------------------------------------*/
.headLine04 {
	font-size: 2.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.32;
}
.headLine04 .en {
	margin-bottom: 0.5rem;
	display: block;
	font-size: 1.4rem;
	font-weight: 500;
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0;
}
@media all and (max-width: 896px) {
	.headLine04 {
		font-size: 2.4rem;
		line-height: 1.41;
	}
	.headLine04 .en {
		margin-bottom: 0;
	}
}
/*------------------------------------------------------------
	headLine05
------------------------------------------------------------*/
.headLine05 {
	margin-bottom: 3.3rem;
	font-size: 3.2rem;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.05em;
}
@media all and (max-width: 896px) {
	.headLine05 {
		margin-bottom: 4rem;
		font-size: 2.4rem;
	}
}
/*------------------------------------------------------------
	headLine06
------------------------------------------------------------*/
.headLine06 {
	margin-bottom: 4.3rem;
	padding-left: 4.6rem;
	position: relative;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.headLine06::before {
	margin-top: 0.1rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	width: 3rem;
	height: 0.4rem;
	background: #D9D9D9;
	content: '';
}
@media all and (max-width: 896px) {
	.headLine06 {
		margin-bottom: 2.4rem;
		padding-left: 3.3rem;
		font-size: 2rem;
		line-height: 1.4;
	}
	.headLine06::before {
		margin-top: 0;
		width: 2.3rem;
		top: 1.5rem;
		transform: none;
	}
}
/*------------------------------------------------------------
	comSecBox
------------------------------------------------------------*/
.comSecBox .content {
	max-width: 111rem;
}
.comSecBox .textList {
	margin-bottom: 6rem;
}
.comSecBox .textList li {
	padding-left: 1.3em;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 1.75;
	text-indent: -1.3em;
}
.comSecBox .textList li .link {
	margin: 1.9rem 0;
	width: 36.8rem;
}
.comSecBox .textList li .link a {
	padding: 0.8rem 0 1rem 7.2rem;
	display: block;
	color: #FFF;
	font-weight: 500;
	border-radius: 1rem;
	letter-spacing: 0.05em;
	background: #1A1A1A url(img/common/icon10.webp) no-repeat left 1.8rem center / 2rem;
}
.comSecBox .comScrollBox {
	margin: 0 auto 10.1rem;
	max-width: 93.9rem;
}
.comSecBox .bottomText {
	margin-top: 4.4rem;
	font-size: 1.4rem;
	font-weight: 500;
	text-align: center;
	letter-spacing: 0.05em;
}
.comSecBox .bottomText .sub {
	margin: 1.7rem auto 0;
	display: block;
	width: 14.5rem;
}
@media all and (min-width: 897px) {
	.comSecBox .textList li .link a:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	.comSecBox .content {
		padding: 0 2.8rem;
		max-width: inherit;
	}
	.comSecBox .textList {
		margin-bottom: 4.6rem;
	}
	.comSecBox .textList li {
		line-height: 1.57;
	}
	.comSecBox .textList li .link {
		margin: 1.1rem auto 1.3rem;
		width: auto;
		max-width: 29.4rem;
	}
	.comSecBox .textList li .link a {
		margin: 0 -0.4rem 0 -2.2rem;
		padding: 1.1rem 0 1.1rem 6.2rem;
		font-size: 1.3rem;
		border-radius: 0.5rem;
		background: #1A1A1A url(img/common/icon10.webp) no-repeat left 1.8rem center / 1.7rem;
	}
	.comSecBox .comScrollBox {
		margin: 0 -0.4rem 3.8rem;
		max-width: inherit;
	}
	.comSecBox .comBtn02 {
		width: auto;
		max-width: 29rem;
	}
	.comSecBox .comBtn02 a {
		margin: 0 -0.2rem;
		padding: 1rem 6.7rem 1.2rem 1.6rem;
	}
	.comSecBox .bottomText {
		margin-top: 3rem;
		font-size: 1.2rem;
	}
	.comSecBox .bottomText .sub {
		margin-top: 1rem;
	}
}
/*------------------------------------------------------------
	comScrollBox
------------------------------------------------------------*/
.comScrollBox {
	margin-bottom: 10.1rem;
	padding: 2.9rem 5.4rem;
	border: 1px solid #DDD;
	border-radius: 0.6rem;
	height: 23rem;
}
.comScrollBox ::-webkit-scrollbar {
	display: none;
}
.comScrollBox .text {
	margin-bottom: 2.2rem;
	font-size: 1.4rem;
	line-height: 1.57;
	letter-spacing: 0.02em;
}
.comScrollBox .text:last-child {
	margin-bottom: 0;
}
.comScrollBox .text a:hover {
	opacity: 0.7;
}
@media all and (max-width: 896px) {
	.comScrollBox {
		margin-bottom: 3.8rem;
		padding: 1.9rem 2rem 1.9rem 1.6rem;
	}
	.comScrollBox .text {
		margin-bottom: 1.8rem;
		font-size: 1.2rem;
		line-height: 1.5;
	}
}
/*------------------------------------------------------------
	simplebar
------------------------------------------------------------*/
.simplebar-track.simplebar-vertical {
	top: 1.5rem;
	bottom: 1.5rem;
	right: 1.4rem;
	width: 0.5rem;
	background: #EFF2F4;
	border-radius: 1rem;
}
.simplebar-scrollbar.simplebar-visible:before {
	opacity: 1;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: #979797;
	border-radius: 1rem;
}
@media all and (max-width: 896px) {
	.simplebar-track.simplebar-vertical {
		right: 0.8rem;
		width: 0.7rem;
	}
}
/*------------------------------------------------------------
	comTopText
------------------------------------------------------------*/
.comTopText {
	margin-bottom: 6.4rem;
	color: #FFF;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 2.22;
	letter-spacing: 0.05em;
	text-align: center;
}
@media all and (max-width: 896px) {
	.comTopText {
		margin-bottom: 4.6rem;
		font-size: 1.6rem;
		line-height: 1.5;
	}
}
/*------------------------------------------------------------
	comMenuList
------------------------------------------------------------*/
.comMenuList {
	padding: 0 4.1rem;
	gap: 2rem;
	flex-wrap: nowrap;
	justify-content: space-between;
}
.comMenuList > li {
	width: fit-content;
}
.comMenuList a:hover {
	opacity: 0.7;
}
.comMenuList > li > a {
	margin-bottom: 1.2rem;
	display: block;
	width: fit-content;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.comMenuList > li > a.nolink {
	pointer-events: none;
}
.comMenuList .subUl {
	margin-top: 1.2rem;
}
.comMenuList .subUl li {
	margin-bottom: 1.2rem;
}
.comMenuList .subUl li:last-child {
	margin-bottom: 0;
}
.comMenuList .subUl li a {
	padding-left: 1.8rem;
	display: block;
	position: relative;
	letter-spacing: 0.05em;
}
.comMenuList .subUl li a::before {
	margin-top: 1px;
	position: absolute;
	top: 50%;
	left: 0;
	width: 0.8rem;
	height: 1px;
	background: #1A1A1A;
	content: '';
}
.comMenuList .subUl + a {
	margin: 1rem 0 0;
}
.comMenuList .subUl.style01 {
	display: flex;
	gap: 4rem;
}
@media all and (max-width: 896px) {
	.comMenuList {
		padding: 0 0.4rem;
		display: block;
	}
	.comMenuList > li {
		width: auto;
	}
	.comMenuList > li > a {
		margin-bottom: 0;
		position: relative;
		padding: 1.9rem 0;
		font-size: 1.6rem;
		width: auto;
		display: block;
		border-bottom: 1px solid #C9C9C9;
	}
	.comMenuList > li > a:not(.special) {
		background: url(img/common/icon06.webp) no-repeat right center / 1.1rem;
	}
	.comMenuList > li > a.special.on {
		border: none;
	}
	.comMenuList > li > a.special .arrow {
		padding: 2rem 0 2rem 1rem;
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		right: -0.1rem;
		width: 1.8rem;
		height: 1rem;
		background: url(img/common/icon05.webp) no-repeat right center / 1.8rem;
		content: '';
		box-sizing: content-box;
		z-index: 10;
		pointer-events: visible;
	}
	.comMenuList > li > a.special .arrow.on {
		background-image: url(img/common/icon05_on.webp);
	}
	.comMenuList .subUl {
		display: none;
		margin-top: 0.4rem;
		padding: 0 2rem 2.8rem;
		border-bottom: 1px solid #C9C9C9;
	}
	.comMenuList .subUl li a {
		padding-left: 1.6rem;
		font-size: 1.6rem;
		display: block;
	}
	.comMenuList .subUl + a {
		margin: 0;
	}
	.comMenuList .subUl.style01 {
		display: none;
	}
}
/*------------------------------------------------------------
	comTableBox
------------------------------------------------------------*/
.comTableBox {
	margin: 0 auto;
	padding: 0 2rem;
	max-width: 93.8rem;
	box-sizing: content-box;
}
.comTableBox .note {
	margin-bottom: 3.8rem;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
}
.comTableBox table {
	margin-bottom: 1.9rem;
	border-collapse: collapse;
	width: 100%;
}
.comTableBox th,
.comTableBox td {
	display: block;
	text-align: left;
	box-sizing: border-box;
	word-break: break-all;
	letter-spacing: 0.05em;
}
.comTableBox th {
	margin-bottom: 1.2rem;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
}
.comTableBox th span {
	display: block;
}
.comTableBox th .must {
	margin-right: 1.9rem;
	padding: 0.4rem 0.2rem 0.5rem;
	width: 4.7rem;
	color: #FFF;
	font-size: 1.4rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.2;
	letter-spacing: 0.1em;
	background: #DF4242;
	border: 1px solid #DF4242;
	border-radius: 0.4rem;
}
.comTableBox th .must.any {
	border-color: #616568;
	background: #FFF;
	color: #616568;
}
.comTableBox th .sub {
	padding-top: 0.1rem;
}
.comTableBox th .sub small {
	margin-left: 1.7rem;
	font-size: 1.4rem;
	font-weight: 400;
}
.comTableBox td {
	margin-bottom: 4rem;
}
.comTableBox textarea,
.comTableBox input[type="tel"],
.comTableBox input[type="text"],
.comTableBox input[type="email"] {
	appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
    border-radius: 0.6rem;
    height: 5rem;
    border: none;
    box-sizing: border-box;
	color: #000;
    font-size: 1.4rem;
    padding: 0 2.4rem 0.1rem;
    width: 100%;
    letter-spacing: 0.1em;
    background-color: #EFF2F4;
}
.comTableBox textarea {
	padding: 1.4rem 2.4rem;
	resize: vertical;
	height: 19.6rem;
}
.comTableBox input::-webkit-input-placeholder,
.comTableBox textarea::-webkit-input-placeholder { /* WebKit browsers */
	color: #A8A8A8;
	opacity:1;
}
.comTableBox input:-moz-placeholder,
.comTableBox textarea:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
	color: #A8A8A8;
	opacity:1;
}
.comTableBox input::-moz-placeholder,
.comTableBox textarea::-moz-placeholder {
	color: #A8A8A8;
	opacity:1;
}
.comTableBox input:-ms-input-placeholder,
.comTableBox textarea:-ms-input-placeholder { /* Internet Explorer 10+ */
	color: #A8A8A8;
	opacity:1;
}
.comTableBox .inputList {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.comTableBox .inputList li {
	width: calc((100% - 1rem) / 2);
}
.comTableBox .submit li {
	margin: 0 auto;
	width: 38rem;
}
.comTableBox .submit li button {
	appearance:none;
	-moz-appearance:none;
	-webkit-appearance:none;
	padding: 0 1.7rem 0.2rem;
	width: 100%;
	height: 4rem;
	border-radius: 0.6rem;
	text-align: left;
	cursor: pointer;
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	color: #1A1A1A;
	border: none;
	box-sizing: border-box;
	background: #FFF url(img/common/icon03.webp) no-repeat right 1.6rem center / 1.3rem;
	box-shadow: 0 0 1rem 0 rgba(0, 0, 0, 0.25);
	transition: 0.3s;
}
.comTableBox .chooseUl li:not(:last-child) {
	margin-bottom: 1.2rem;
}
.comTableBox .chooseUl input[type="checkbox"] {
	display: none;
}
.comTableBox .chooseUl input[type="checkbox"] ~ span {
	padding: 0.5rem 0 1rem 2.7rem;
	font-size: 1.6rem;
    cursor: pointer;
	background: url(img/common/icon08.webp) no-repeat left center / 1.8rem;
}
.comTableBox .chooseUl input[type="checkbox"]:checked ~ span {
	background-image: url(img/common/icon08_on.webp);
}
@media all and (min-width: 897px) {
	.comTableBox .submit li button:hover {
		color: #FFF;
		background: #1A1A1A url(img/common/icon07.webp) no-repeat right 1.6rem center / 1.3rem;
		box-shadow: 0 0 1rem 0 #FFF;
	}
}
@media all and (max-width: 896px) {
	.comTableBox {
		margin: 0;
		padding: 0;
		max-width: inherit;
	}
	.comTableBox .note {
		margin-bottom: 2rem;
		font-size: 1.2rem;
	}
	.comTableBox table {
		margin-bottom: -0.5rem;
	}
	.comTableBox th,
	.comTableBox td {
		font-size: 1.6rem;
	}
	.comTableBox th .sub {
		width: calc(100% - 6.6rem);
	}
	.comTableBox th .sub small {
		margin: 0.5rem 0 0;
		font-size: 1.2rem;
		display: block;
	}
	.comTableBox td {
		margin-bottom: 3.4rem;
	}
	.comTableBox .inputList {
		display: block;
	}
	.comTableBox .inputList li {
		margin-bottom: 1.2rem;
		width: auto;
	}
	.comTableBox .inputList li:last-child {
		margin-bottom: 0;
	}
	.comTableBox .submit li {
		width: auto;
		max-width: 29rem;
	}
	.comTableBox .submit li button {
		padding: 0 6rem 0.2rem 1.6rem;
		height: 6.2rem;
		background: #FFF url(img/common/icon07_sp.webp) no-repeat right 1.5rem center / 1.3rem;
	}
}
/*------------------------------------------------------------
    comLinkList
------------------------------------------------------------*/
.comLinkList {
    margin-top: -2.9rem;
}
.comLinkList li {
    margin: 2.9rem 2.9rem 0 0;
    width: calc((100% - 6.6rem) / 3);
}
.comLinkList li:nth-child(3n) {
    margin-right: 0;
}
.comLinkList li a {
    position: relative;
    display: block;
    color: #FFF;
    border-radius: 1rem;
	overflow: hidden;
}
.comLinkList li img {
    width: 100%;
    border-radius: 1rem;
	transition: 0.3s;
}
.comLinkList li a::before {
    position: absolute;
    right: 2.7rem;
    top: 50%;
    width: 1.1rem;
    height: 1px;
    z-index: 1;
    transform: translateY(-50%);
    background-color: #FFF;
    content: "";
	z-index: 6;
}
.comLinkList li a::after {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0;
    transition: 0.3s;
    background-color: #1A1A1A;
    content: "";
	z-index: 5;
}
.comLinkList li .title {
    padding-bottom: 0.3rem;
    position: absolute;
    z-index: 2;
    top: 50%;
    transform: translateY(-50%);
    left: 2.8rem;
    font-size: 2.8rem;
    font-weight: 700;
    letter-spacing: 0.14rem;
	z-index: 6;
}
.comLinkList li .en {
    display: block;
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: 0;
    font-family: "Montserrat", sans-serif;
}
@media all and (min-width: 897px) {
	.comLinkList li a:hover {
		box-shadow: 0 0 1rem #FFF;
	}
	.comLinkList li a:hover img {
		transform: scale(1.1);
	}
    .comLinkList li a:hover::before {
        right: 2.5rem;
        width: 1.3rem;
        height: 0.8rem;
        background: url("img/common/icon07.webp") no-repeat;
        background-size: 100%;
    }
    .comLinkList li a:hover::after {
        opacity: 0.9;
    }    
}
@media all and (max-width: 896px) {
    .comLinkList {
        margin-top: 0;
        display: block;
    }
    .comLinkList li {
        margin: 0 0 2.7rem;
        width: auto;
    }
    .comLinkList li:last-child {
        margin-bottom: 0;
    }
    .comLinkList li a::after {
        display: none;
    }
    .comLinkList li a::before {
        right: 1.7rem;
        width: 1.3rem;
        height: 0.8rem;
        background: url("img/common/icon07.webp") no-repeat;
        background-size: 100%;
    }
    .comLinkList li .title {
        padding-bottom: 0;
        left: 2rem;
        font-size: 2.4rem;
        letter-spacing: 0.12rem;
    }
    .comLinkList li .en {
        margin-bottom: -0.6rem;
    }
}
/*------------------------------------------------------------
	comPickBox
------------------------------------------------------------*/
.comPickBox {
	margin-bottom: 7.6rem;
	position: relative;
	overflow: hidden;
}
.comPickBox .title {
	color: #FFF;
	font-size: 2.4rem;
	font-weight: 500;
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
}
.comPickBox .swiper-scrollbar {
	position: static;
	margin: 5.6rem auto 0;
	max-width: 111.2rem;
	height: 0.2rem;
	background: #515151;
}
.comPickBox .swiper-scrollbar-drag {
	background: #FFF;
}
@media all and (max-width: 896px) {
	.comPickBox {
		margin-bottom: 6.2rem;
		position: relative;
	}
	.comPickBox .title {
		margin: 0 -0.2rem;
		font-size: 2rem;
	}
	.comPickBox .swiper-scrollbar {
		position: static;
		margin: 3.3rem 2.4rem 0;
		max-width: inherit;
		--swiper-scrollbar-sides-offset: 2.4rem;
	}
}
/*------------------------------------------------------------
	.comPickList
------------------------------------------------------------*/
.comPickList {
	margin: 0 auto;
	padding-top: 2.8rem;
	max-width: 133.8rem;
	overflow: visible !important;
}
.comPickList li {
	margin: 0 1rem;
	width: 52.1rem;
}
.comPickList li a,
.comPickList li .area {
	position: relative;
	height: 100%;
	display: block;
	padding: 4.5rem 4rem 3.9rem;
	border-radius: 1rem;
	background: #EFF2F4;
	box-sizing: border-box;
}
.comPickList li a .newTag {
	position: absolute;
	top: -1.2rem;
	left: 0;
	width: 4rem;
	height: 4rem;
	background: #F73465;
	border-radius: 50%;
	color: #FFF;
	font-size: 1rem;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.05em;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	font-family: "Montserrat", sans-serif;
}
.comPickList li .text {
	font-size: 2rem;
	font-weight: 500;
	line-height: 1.7;
	letter-spacing: 0.05em;
	transition: 0.3s;
}
@media all and (min-width: 897px) {
	.comPickList li a:hover {
		background: #616568;
		box-shadow: 0 0 1rem 0 rgba(0, 0, 0, 0.40);
		transform: translateY(-1.5rem);
	}
	.comPickList li a:hover .comTopBox time {
		color: #FFF;
	}
	.comPickList li a:hover .text {
		color: #FFF;
	}
}
@media all and (max-width: 896px) {
	.comPickList {
		margin: 0;
		padding-top: 1rem;
		max-width: inherit;
	}
	.comPickList li {
		margin: 0 1.2rem;
		width: 29.3rem;
	}
	.comPickList li a,
	.comPickList li .area {
		padding: 2.6rem 2.5rem 2.7rem;
	}
	.comPickList li .text {
		font-size: 1.4rem;
		line-height: 1.57;
	}
	.comPickList li a .newTag {
		width: 3rem;
		height: 3rem;
		font-size: 0.8rem;
	}
}
/*------------------------------------------------------------
	comTopBox
------------------------------------------------------------*/
.comTopBox {
	margin-bottom: 2.1rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}
.comTopBox time {
	color: #797979;
	font-size: 1.4rem;
	font-weight: 500;
	font-family: "Montserrat", sans-serif;
	letter-spacing: 0.05em;
	transition: 0.3s;
}
.comTopBox .tagBox {
	margin: -0.4rem 0 0;
	width: calc(100% - 10.3rem);
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.comTopBox .tagBox .tag {
	padding: 0.5rem 1.6rem;
	width: fit-content;
	background-color: #FFF;
	border-radius: 2rem;
	font-size: 1.2rem;
	font-weight: 500;
	letter-spacing: 0.02em;
}
@media all and (max-width: 896px) {
	.comTopBox {
		margin-bottom: 0.7rem;
	}
	.comTopBox time {
		font-size: 1.2rem;
	}
	.comTopBox .tagBox {
		margin: -0.6rem 0 0;
		width: calc(100% - 8.2rem);
		gap: 0.5rem;
	}
	.comTopBox .tagBox .tag {
		padding: 0.5rem 1.6rem 0.6rem;
	}
}
/*------------------------------------------------------------
	comTagList
------------------------------------------------------------*/
.comTagList {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
}
.comTagList li {
	width: fit-content;
}
.comTagList li a {
	padding: 0.3rem 1.7rem 0.5rem 1.6rem;
	display: block;
	font-weight: 500;
	letter-spacing: 0.02em;
	text-align: center;
	background: #EFF2F4;
	border-radius: 2rem;
}
.comTagList li.on a {
	color: #FFF;
	background: #1A1A1A;
}
@media all and (min-width: 897px) {
	.comTagList li a:hover {
		color: #FFF;
		background: #1A1A1A;
	}
}
@media all and (max-width: 896px) {
	.comTagList {
		gap: 1rem;
	}
	.comTagList li a {
		padding: 0.5rem 1.7rem 0.6rem 1.6rem;
		font-size: 1.2rem;
	}
}
/*------------------------------------------------------------
	comSeminarList
------------------------------------------------------------*/
.comSeminarList {
	margin-bottom: 8.4rem;
	display: flex;
	flex-wrap: wrap;
	gap: 2.2rem;
}
.comSeminarList li {
	width: calc((100% - 4.4rem) / 3);
}
.comSeminarList li a,
.comSeminarList li .area {
	display: block;
	height: 100%;
	background: #EFF2F4;
	border-radius: 1rem;
}
.comSeminarList li .photo {
	aspect-ratio: 356 / 200;
}
.comSeminarList li .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 1rem;
}
.comSeminarList li .comTopBox {
	margin-bottom: 1.2rem;
}
.comSeminarList li .comTopBox .tagBox {
	margin: -0.5rem 0 0;
	width: calc(100% - 10rem);
}
.comSeminarList li .comTopBox .tagBox .tag {
	padding-bottom: 0.6rem;
}
.comSeminarList li .textBox {
	padding: 2.5rem 2.7rem 2.7rem;
}
.comSeminarList li .textBox .title {
	margin-bottom: 0.9rem;
	font-weight: 500;
	line-height: 1.625;
	letter-spacing: 0.05em;
	transition: 0.3s;
}
.comSeminarList li .textBox .text {
	font-size: 1.4rem;
	line-height: 1.57;
	letter-spacing: 0.05em;
	transition: 0.3s;
}
@media all and (min-width: 897px) {
	.comSeminarList li a:hover {
		background: #616568 !important;
		box-shadow: 0 0 1rem 0 rgba(0, 0, 0, 0.40);
		transform: translateY(-1rem);
	}
	.comSeminarList li a:hover .comTopBox time {
		color: #FFF;
	}
	.comSeminarList li a:hover .title {
		color: #FFF;
	}
	.comSeminarList li a:hover .text {
		color: #FFF;
	}
}
@media all and (max-width: 896px) {
	.comSeminarList {
		margin-bottom: 4.2rem;
		display: block;
	}
	.comSeminarList li {
		margin-bottom: 3rem;
		padding: 0 2.2rem 0 2.8rem;
		width: auto;
	}
	.comSeminarList li:last-child {
		margin-bottom: 0;
	}
	.comSeminarList li .photo {
		aspect-ratio: 244 / 138;
	}
	.comSeminarList li .comTopBox {
		margin-bottom: 0.6rem;
	}
	.comSeminarList li .comTopBox .tagBox {
		margin: -0.7rem 0 0;
		width: calc(100% - 8.4rem);
	}
	.comSeminarList li .textBox {
		padding: 1.9rem 1.8rem 1.2rem;
	}
	.comSeminarList li .textBox .title {
		margin-bottom: 0.9rem;
		line-height: 1.57;
		text-align: justify;
	}
	.comSeminarList li .textBox .text {
		font-size: 1.2rem;
	}
}
/*------------------------------------------------------------
	wp-pagenavi
------------------------------------------------------------*/
.wp-pagenavi {
	font-size: 0;
	clear: both;
	text-align: center;
}
.wp-pagenavi a,
.wp-pagenavi span {
	color: #B4B6B7;
	font-size: 1.6rem;
	font-family: "Montserrat", sans-serif;
	font-weight: 500;
	display: inline-block;
	text-decoration: none;
	padding: 0.5rem 0.6rem 0.5rem 0.5rem;
	margin: 0 1rem;
}
.wp-pagenavi span.current {
	color: #1A1A1A;
}
.wp-pagenavi .nextpostslink,
.wp-pagenavi .previouspostslink {
	vertical-align: -0.4rem;
}
.wp-pagenavi .nextpostslink img,
.wp-pagenavi .previouspostslink img {
	width: 2.1rem;
}
.wp-pagenavi .previouspostslink {
	margin-right: 5.2rem;
}
.wp-pagenavi .nextpostslink {
	margin-left: 5.2rem;
}
.wp-pagenavi .first,
.wp-pagenavi .last,
.wp-pagenavi .pages{
	display: none;
}
@media all and (min-width: 897px) {
	.wp-pagenavi a:hover {
		color: #1A1A1A;
	}
	.wp-pagenavi .nextpostslink:hover,
	.wp-pagenavi .previouspostslink:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	.wp-pagenavi {
		margin: 0 -2rem;
	}
	.wp-pagenavi a,
	.wp-pagenavi span {
		font-size: 1.4rem;
		padding: 0.5rem;
		margin: 0 0.7rem 0 0.8rem;
	}
	.wp-pagenavi .nextpostslink,
	.wp-pagenavi .previouspostslink {
		vertical-align: -0.2rem;
	}
	.wp-pagenavi .previouspostslink {
		margin-right: 0.3rem;
	}
	.wp-pagenavi .nextpostslink {
		margin-left: 0.3rem;
	}
}
/*------------------------------------------------------------
	comNewsList
------------------------------------------------------------*/
.comNewsList {
	margin-bottom: 9rem;
}
.comNewsList li a {
	padding: 3.5rem 0 1.6rem;
	display: block;
	border-bottom: 1px solid #D7D7D7;
}
.comNewsList li a:hover {
	opacity: 0.7;
}
.comNewsList li .comTopBox {
	margin-bottom: 1.7rem;
}
.comNewsList li .comTopBox .tagBox {
	margin-top: -0.5rem;
	width: calc(100% - 10.9rem);
}
.comNewsList li .comTopBox .tagBox .tag {
	padding-bottom: 0.6rem;
	background: #EFF2F4;
}
.comNewsList li .text {
	font-weight: 500;
	line-height: 1.62;
	letter-spacing: 0.05em;
}
@media all and (max-width: 896px) {
	.comNewsList {
		margin-bottom: 4rem;
	}
	.comNewsList li a {
		padding: 2.5rem 0 1.4rem;
	}
	.comNewsList li .comTopBox {
		margin-bottom: 1rem;
	}
	.comNewsList li .comTopBox time {
		font-size: 1.4rem;
	}
	.comNewsList li .comTopBox .tagBox {
		width: calc(100% - 9.7rem);
	}
	.comNewsList li .text {
		line-height: 1.42;
	}
}
/*------------------------------------------------------------
	comTopArea
------------------------------------------------------------*/
.comTopArea {
	margin-bottom: 14.4rem;
}
.comTopArea .headLine02 {
	margin-bottom: 0;
	text-align: left;
}
.comTopArea .text {
	padding-top: 0.7rem;
	width: 62.5rem;
	color: #FFF;
	font-weight: 500;
	line-height: 1.87;
	letter-spacing: 0.05em;
}
.comTopArea.style01 .text,
.comTopArea.style01 .headLine02 {
	color: #1A1A1A;
}
@media all and (max-width: 896px) {
	.comTopArea {
		margin-bottom: 4rem;
		display: block;
	}
	.comTopArea .headLine02 {
		margin-bottom: 0.7rem;
		text-align: center;
	}
	.comTopArea .text {
		padding-top: 0.7rem;
		width: auto;
		line-height: 1.625;
	}
}
/*------------------------------------------------------------
	comBtn01
------------------------------------------------------------*/
.comBtn01 {
	margin: 0 auto;
	width: 27.6rem;
}
.comBtn01 a {
	padding: 0.9rem 1.6rem 1rem 4rem;
	display: block;
	border-radius: 0.6rem;
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	box-shadow: 0 0 1rem 0 rgba(0, 0, 0, 0.25);
	text-align: right;
	background: #FFF url(img/common/icon03.webp) no-repeat left 1.5rem center / 1.3rem;
}
@media all and (min-width: 897px) {
	.comBtn01 a:hover {
		color: #FFF;
		background-color: #1A1A1A;
		background-image: url(img/common/icon07_back.webp);
		box-shadow: 0 0 1rem 0 #FFF;
	}
}
@media all and (max-width: 896px) {
	.comBtn01 a {
		background-image: url(img/common/icon07_back_sp.webp);
	}
}
/*------------------------------------------------------------
	comBtn02
------------------------------------------------------------*/
.comBtn02 {
	margin: 0 auto;
	width: fit-content;
}
.comBtn02 a {
	padding: 0.9rem 7rem 0.9rem 1.6rem;
	display: block;
	border-radius: 0.6rem;
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	box-shadow: 0 0 1rem 0 rgba(0, 0, 0, 0.25);
	text-align: left;
	background: #FFF url(img/common/icon03.webp) no-repeat right 1.6rem center / 1.3rem;
}
.comBtn02 a .en {
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
}
@media all and (min-width: 897px) {
	.comBtn02 a:hover {
		color: #FFF;
		background-color: #1A1A1A;
		background-image: url(img/common/icon07.webp);
		box-shadow: 0 0 1rem 0 #FFF;
	}
}
@media all and (max-width: 896px) {
	.comBtn02 a {
		padding-bottom: 1rem;
		line-height: 1.43;
		background-image: url(img/common/icon03_sp.webp);
	}
}
/*------------------------------------------------------------
	comPLink
------------------------------------------------------------*/
.comPLink {
	margin-top: 0.1rem;
}
.comPLink .sub {
	padding: 0.2rem 3.1rem 0 0;
	display: inline-block;
	font-size: 1.4rem;
	font-weight: 700;
	font-family: "Montserrat", sans-serif;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	background: url(img/common/icon03.webp) no-repeat right center / 1.3rem;
	transition: 0.3s;
}
.comPLink.style01 .sub {
	background-image: url(img/common/icon03_white.webp);
}
@media all and (min-width: 897px) {
	.comPLink a:hover {
		color: #969696;
		background-image: url(img/common/icon03_over.webp);
	}
}
@media all and (max-width: 896px) {
	.comPLink .sub {
		background-image: url(img/common/icon03_sp.webp);
	}
	.comPLink.style01 .sub {
		background-image: url(img/common/icon07.webp);
	}
}
/*------------------------------------------------------------
	contact
------------------------------------------------------------*/
#contact .pageTitle {
	padding-bottom: 13.1rem;
}
#contact .textList {
	gap: 2rem 0;
}
#contact .textList li {
	width: calc((100% - 2rem) / 2);
}
#contact .textList li a {
	padding: 4.4rem 4.5rem 3.7rem;
	display: block;
	background: #FFF;
	border-radius: 1rem;
	box-sizing: border-box;
}
#contact .textList li .subBox {
	margin-bottom: 2.8rem;
}
#contact .textList li .enText {
	margin-bottom: 0.2rem;
	font-weight: 500;
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
	transition: 0.3s;
}
#contact .textList li h2 {
	margin-bottom: 1.8rem;
	font-size: 3.2rem;
	font-weight: 700;
	line-height: 1.31;
	letter-spacing: 0.03em;
	transition: 0.3s;
}
#contact .textList li .text {
	line-height: 1.75;
	letter-spacing: 0.05em;
	transition: 0.3s;
}
#contact .textList li .link {
	margin-left: auto;
	padding: 0 2.6rem 0 1.9rem;
	position: relative;
	display: block;
	width: fit-content;
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
	background: url(img/common/icon04.webp) no-repeat left center / 1.3rem;
	transition: 0.3s;
}
#contact .textList li .link::before {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: -0.4rem;
	width: 1.3rem;
	height: 0.8rem;
	background: url(img/common/icon03.webp) no-repeat right center / 100%;
	content: '';
	transition: 0.3s;
}
@media all and (min-width: 897px) {
	#contact .textList li a:hover {
		background: #1A1A1A;
		box-shadow: 0 0 1rem #FFF;
	}
	#contact .textList li a:hover .enText,
	#contact .textList li a:hover h2,
	#contact .textList li a:hover .text {
		color: #FFF;
	}
	#contact .textList li a:hover .link {
		color: #FFF;
		background-image: url(img/common/icon04_over.webp);
	}
	#contact .textList li a:hover .link::before {
		background-image: url(img/common/icon07.webp);
	}
}
@media all and (max-width: 896px) {
	#contact .pageTitle {
		padding-bottom: 6.8rem;
	}
	#contact .textList {
		display: block;
	}
	#contact .textList li {
		margin-bottom: 2rem;
		width: auto;
	}
	#contact .textList li a {
		padding: 3.2rem 2.6rem 4rem;
	}
	#contact .textList li .enText {
		margin-bottom: -0.1rem;
	}
	#contact .textList li h2 {
		margin-bottom: 1.5rem;
		font-size: 2.4rem;
		line-height: 1.5;
		letter-spacing: 0.05em;
	}
	#contact .textList li .text {
		line-height: 1.57;
		letter-spacing: 0.05em;
	}
	#contact .textList li .link {
		margin: 0 auto;
		padding: 0 3rem 0 1.9rem;
	}
	#contact .textList li .link::before {
		right: 0;
		width: 1.3rem;
		height: 0.8rem;
		background: url(img/common/icon03_sp.webp) no-repeat right center / 100%;
	}
}
/*------------------------------------------------------------
	common_form
------------------------------------------------------------*/
#common_form.confirm .comBox {
	padding: 9.1rem 0 9.4rem;
}
#common_form.confirm .hTitle {
	margin-bottom: 0.8rem;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
#common_form.confirm .note {
	margin-bottom: 3.9rem;
}
#common_form.confirm .comTableBox table {
	margin-bottom: 8.5rem;
}
#common_form.confirm .comTableBox th,
#common_form.confirm .comTableBox td {
	padding: 0.5rem 1.4rem 0.8rem;
	font-weight: 400;
	display: table-cell;
	border: 1px solid #1A1A1A;
	border-bottom: 2px solid #1A1A1A;
}
#common_form.confirm .comTableBox thead th {
	padding: 0.6rem 1.4rem 0.8rem;
	font-weight: 700;
	background: #D9D9D9;
	border-bottom: 2px solid #1A1A1A;
}
#common_form.confirm .comTableBox thead th:first-child {
	width: 27%;
	border-right: 2px solid #1A1A1A;
}
#common_form.confirm .comTableBox tbody th {
	border-bottom: 2px solid #1A1A1A;
	border-right: 2px solid #1A1A1A;
}
#common_form.confirm .comTableBox tbody tr:nth-child(2n) th,
#common_form.confirm .comTableBox tbody tr:nth-child(2n) td {
	background: #D9D9D9;
}
#common_form.confirm .comTableBox tbody tr:last-child th,
#common_form.confirm .comTableBox tbody tr:last-child td {
	border-bottom: 1px solid #1A1A1A;
}
#common_form.confirm .comTableBox .submit {
	gap: 2.8rem;
}
#common_form.confirm .comTableBox .submit li {
	margin: 0;
	width: fit-content;
}
#common_form.confirm .comTableBox .submit li button {
	padding: 0 7rem 0.2rem 1.5rem;
}
#common_form.confirm .comTableBox .submit li.back button {
	padding: 0 1.6rem 0.2rem 7rem;
	background-position: left 1.5rem center;
}
#common_form.complete .comBox {
	padding: 8.6rem 0 8.5rem;
}
#common_form.complete .hTitle {
	margin-bottom: 3.4rem;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.67;
	letter-spacing: 0.05em;
	text-align: center;
}
#common_form.complete .text {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 2.22;
	letter-spacing: 0.05em;
	text-align: center;
}
@media all and (min-width: 897px) {
	#common_form.confirm .comTableBox .submit li.back button:hover {
		background-image: url(img/common/icon07_back.webp);
	}
}
@media all and (max-width: 896px) {
	#common_form .pageTitle {
		padding-bottom: 4.4rem;
	}
	#common_form #pagePath {
		margin-bottom: 3.5rem;
	}
	#common_form .headLine01 .en {
		margin-bottom: 0.5rem;
	}
	#common_form.confirm .comBox {
		padding: 5rem 0 6.1rem;
	}
	#common_form.confirm .hTitle {
		margin-bottom: 0.6rem;
		font-size: 1.6rem;
	}
	#common_form.confirm .note {
		margin-bottom: 2.8rem;
	}
	#common_form.confirm .comTableBox table {
		margin-bottom: 4.2rem;
	}
	#common_form.confirm .comTableBox th,
	#common_form.confirm .comTableBox td {
		margin: 0;
		display: block;
		width: 100% !important;
		border: 1px solid #1A1A1A !important;
	}
	#common_form.confirm .comTableBox thead {
		display: none;
	}
	#common_form.confirm .comTableBox tbody tr:nth-child(2n) th,
	#common_form.confirm .comTableBox tbody tr:nth-child(2n) td {
		background: #FFF;
	}
	#common_form.confirm .comTableBox tbody td {
		padding-top: 0.6rem;
		background: #D9D9D9 !important;
	}
	#common_form.confirm .comTableBox .submit {
		display: block;
	}
	#common_form.confirm .comTableBox .submit li {
		margin: 1.5rem auto 0;
		width: 18.7rem;
	}
	#common_form.confirm .comTableBox .submit li:first-child {
		margin-top: 0;
	}
	#common_form.confirm .comTableBox .submit li button {
		padding: 0 5rem 0.2rem 1.5rem;
		height: 4rem;
	}
	#common_form.confirm .comTableBox .submit li.back button {
		padding: 0 1.5rem 0.2rem 5rem;
		background-position: left 1.5rem center;
		text-align: right;
		background-image: url(img/common/icon07_back_sp.webp);
	}
	#common_form.complete .comBox {
		padding: 5rem 0 6.3rem;
	}
	#common_form.complete .hTitle {
		margin-bottom: 2rem;
		font-size: 2rem;
		line-height: 1.6;
	}
	#common_form.complete .text {
		font-size: 1.4rem;
		line-height: 1.57;
	}
}
/*------------------------------------------------------------
    history
------------------------------------------------------------*/
#history {
    margin-bottom: 12.6rem;
}
#history .pageTitle {
    padding-bottom: 14.2rem;
}
#history .historyBox {
    margin: 0 1.8rem 12.8rem;
}
#history .historyBox dl {
    padding-bottom: 2.4rem;
    position: relative;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    color: #FFF;
    align-items: center;
}
#history .historyBox dl:last-child {
    padding-bottom: 3.6rem;
}
#history .historyBox dl::before {
    position: absolute;
    left: 5.4rem;
    width: 1px;
    top: 0rem;
    bottom: 0;
    background-color: #FFF;
    content: "";
}
#history .historyBox dt {
    position: relative;
    padding-left: 0.2rem;
    width: 11rem;
    height: 11rem;
    font-size: 2rem;
    letter-spacing: 0.1rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    border: 1px solid #FFF;
    font-weight: 500;
    border-radius: 50%;
    background-color: #1A1A1A;
    font-family: "Montserrat", sans-serif;
}
#history .historyBox dd {
    width: calc(100% - 17.15rem);
    padding-bottom: 0.2rem;
    line-height: 1.625;
    letter-spacing: 0.08rem;
}
@media all and (max-width: 896px) {
    #history {
        margin-bottom: 0.9rem;
    }
    #history .pageTitle {
        padding-bottom: 6.9rem;
    }
    #history .historyBox {
        margin: 0 0 11.1rem;
    }
    #history .historyBox dl {
        padding-bottom: 2.9rem;
    }
    #history .historyBox dl:last-child {
        padding-bottom: 0;
    }
    #history .historyBox dl::before {
        left: 2.6rem;
        top: 0.6rem;
        bottom: -0.6rem;
    }
    #history .historyBox dt {
        padding-left: 0;
        width: 5.5rem;
        height: 5.5rem;
        font-size: 1.2rem;
        letter-spacing: 0.06rem;
    }
    #history .historyBox dd {
        width: calc(100% - 7.3rem);
        padding-bottom: 0;
        line-height: 1.57;
        letter-spacing: 0.028rem;
    }
}
/*------------------------------------------------------------
    profile
------------------------------------------------------------*/
#profile {
    margin-bottom: 12.6rem;
}
#profile .pageTitle {
    padding-bottom: 14.2rem;
}
#profile .comapnyBox {
    margin: 0 2rem 14.6rem;
}
#profile .comapnyBox .tableBox {
    margin: 0 auto;
    padding: 6.2rem 0 12rem;
    max-width: 131.8rem;
    position: relative;
    border-radius: 1rem;
    overflow: hidden;
    background-color: #F3F3F3;
}
#profile .comapnyBox .tableBox::before {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    clip-path: polygon(0 0, 0 calc(100% - 14rem), calc(50% + 24.4rem) 0);
    background-color: #FFF;
    content: "";
}
#profile .comapnyBox .content {
    position: relative;
    max-width: 91.6rem;
}
#profile table {
    width: 100%;
    border-collapse: collapse;
}
#profile th,
#profile td {
    padding: 2.3rem 0 2.4rem;
    vertical-align: top;
    text-align: left;
    word-break: break-all;
    letter-spacing: 0.08rem;
    border-bottom: 1px solid #D7D7D7;
}
#profile th {
    width: 21.2%;
    font-weight: 700;
}
#profile td .map {
    margin: 2.5rem 0 0.5rem;
    position: relative;
}
#profile td .map iframe {
    width: 100%;
    height: 28.6rem;
    vertical-align: top;
}
@media all and (max-width: 896px) {
    #profile {
        margin-bottom: 0.9rem;
    }
    #profile .pageTitle {
        padding-bottom: 7.5rem;
    }
    #profile .comapnyBox {
        margin: 0 2.4rem 7.5rem;
    }
    #profile .comapnyBox .tableBox {
        padding: 4.3rem 0 6rem;
    }
    #profile .comapnyBox .tableBox::before {
        clip-path: polygon(0 0, 100% 0, 100% 8.9rem, 0 calc(50% + 8.4rem));
    }
    #profile th,
    #profile td {
        padding: 0.9rem 0 1.3rem;
        width: 100% !important;
        display: block;
        letter-spacing: 0.07rem;
    }
    #profile th {
        padding: 1.1rem 0 0;
        border-bottom: none;
    }
    #profile td .map {
        margin: 1.3rem 0 0.6rem;
        padding-bottom: 39.2%;
    }
    #profile td .map iframe {
        position: absolute;
        height: 100%;
        object-fit: cover;
    }
}
/*------------------------------------------------------------
	seminar
------------------------------------------------------------*/
#seminar .pageTitle {
	padding-bottom: 7.8rem;
}
#seminar .comBox {
	padding: 9.4rem 0 8.5rem;
}
#seminar .searchBox {
	margin-bottom: 6.5rem;
}
#seminar .searchBox .search {
	margin: -0.9rem 0.8rem 0 0;
	width: 29.4rem;
	position: relative;
	order: 2;
}
#seminar .searchBox .search input[type="text"] {
	appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
    border-radius: 0.6rem;
    height: 5rem;
    border: 1px solid #D7D7D7;
    box-sizing: border-box;
	color: #000;
    font-size: 1.4rem;
    padding: 0 5.5rem 0 1.7rem;
    width: 100%;
    letter-spacing: 0.03em;
    background-color: #FFF;
}
#seminar .searchBox .search input::-webkit-input-placeholder { /* WebKit browsers */
	color: #D7D7D7;
	opacity:1;
}
#seminar .searchBox .search input:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
	color: #D7D7D7;
	opacity:1;
}
#seminar .searchBox .search input::-moz-placeholder {
	color: #D7D7D7;
	opacity:1;
}
#seminar .searchBox .search input:-ms-input-placeholder { /* Internet Explorer 10+ */
	color: #D7D7D7;
	opacity:1;
}
#seminar .searchBox .search input[type="submit"] {
	appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
	position: absolute;
	top: 0;
	right: 0;
	width: 4.4rem;
	height: 100%;
	background: url(img/common/icon09.webp) no-repeat center center / 1.7rem;
	border: none;
	z-index: 10;
	cursor: pointer;
}
#seminar .comSeminarList {
	padding-right: 0.8rem;
}
@media all and (min-width: 897px) {
	#seminar .searchBox .search input[type="submit"]:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#seminar .pageTitle {
		padding-bottom: 6.7rem;
	}
	#seminar .comBox {
		padding: 4.6rem 0 4.3rem;
	}
	#seminar .searchBox {
		margin-bottom: 3.2rem;
		display: block;
	}
	#seminar .searchBox .search {
		margin: 0 0 3.5rem;
		width: auto;
	}
	#seminar .comSeminarList {
		padding-right: 0;
	}
}
/*------------------------------------------------------------
	news
------------------------------------------------------------*/
#news .pageTitle {
	padding-bottom: 7.8rem;
}
#news .comBox {
	padding: 9.4rem 0 9.7rem;
}
#news .comBox .comTagList {
	margin-bottom: 5.8rem;
}
#news.detail {
	padding-bottom: 10rem;
}
#news.detail .pageTitle {
	padding-bottom: 6.8rem;
}
#news.detail #pagePath {
	margin-bottom: 0;
}
#news.detail .comBox {
	margin-bottom: 10rem;
	padding: 8.2rem 0 8.7rem;
}
#news.detail .topArea .comTopBox {
	margin-bottom: 1.4rem;
}
#news.detail .topArea .comTopBox .tagBox {
	margin-top: -0.5rem;
	width: calc(100% - 10.9rem);
}
#news.detail .topArea .comTopBox .tagBox .tag {
	padding-bottom: 0.6rem;
	background: #EFF2F4;
}
#news.detail .topArea h1 {
	margin-bottom: 2.3rem;
	padding-bottom: 2.3rem;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	border-bottom: 1px solid #D7D7D7;
	text-align: justify;
}
#news.detail .inner p {
	line-height: 1.75;
	letter-spacing: 0.05em;
	word-break: break-all;
}
#news.detail .inner p a {
	text-decoration: underline;
}
#news.detail .inner p a:hover {
	opacity: 0.7;
}
@media all and (max-width: 896px) {
	#news .pageTitle {
		padding-bottom: 6.7rem;
	}
	#news .comBox {
		padding: 4.6rem 0 4.7rem;
	}
	#news .comBox .comTagList {
		margin-bottom: 1.6rem;
	}
	#news.detail {
		padding-bottom: 0.8rem;
	}
	#news.detail .pageTitle {
		padding-bottom: 4.4rem;
	}
	#news.detail .comBox {
		margin-bottom: 4.9rem;
		padding: 4.4rem 0 5.3rem;
	}
	#news.detail .topArea .comTopBox {
		margin-bottom: 0.8rem;
	}
	#news.detail .topArea .comTopBox time {
		font-size: 1.4rem;
	}
	#news.detail .topArea .comTopBox .tagBox {
		width: calc(100% - 9.7rem);
	}
	#news.detail .topArea h1 {
		margin-bottom: 1.8rem;
		padding-bottom: 1.8rem;
		font-size: 1.6rem;
	}
	#news.detail .inner p {
		line-height: 1.57;
	}
}
/*------------------------------------------------------------
    top-message
------------------------------------------------------------*/
#message {
    margin-bottom: 12.6rem;
}
#message .pageTitle {
    padding-bottom: 14.2rem;
}
#message .messageBox {
    margin: 0 2rem 14.6rem;
}
#message .messageBox .inner {
    margin: 0 auto;
    padding: 8.6rem 0 7.7rem;
    max-width: 131.8rem;
    position: relative;
    border-radius: 1rem;
    overflow: hidden;
    background-color: #F3F3F3;
}
#message .messageBox .inner::before {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    clip-path: polygon(0 0,  calc(50% + 22.8rem) 0, calc(50% - 22.9rem) 100%, 0% 100%);
    background-color: #FFF;
    content: "";
}
#message .messageBox .imgBox {
    position: relative;
}
#message .messageBox .imgBox .textBox {
    padding: 0 3rem 0 9.9rem;
    width: calc(100% - 50.3rem);
}
#message .messageBox .imgBox .textBox p {
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.78;
    text-align: justify;
    letter-spacing: 0.09rem;
}
#message .messageBox .imgBox .textBox .subBox {
	margin-bottom: 2.1rem;
}
#message .messageBox .imgBox .textBox .subBox p {
	margin-bottom: 2.9rem;
	line-height: 1.61;
}
#message .messageBox .imgBox .textBox .subBox p:last-child {
	margin-bottom: 0;
}
#message .messageBox .imgBox .textBox .name {
    line-height: 1.2;
}
#message .messageBox .imgBox .textBox .name span {
    margin-left: 1.8rem;
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: 0.12rem;
}
#message .messageBox .imgBox .photoBox {
	margin-top: 0.9rem;
    width: 50.3rem;
}
@media all and (max-width: 896px) {
    #message {
        margin-bottom: 0.9rem;
    }
    #message .pageTitle {
        padding-bottom: 7.5rem;
    }
    #message .messageBox {
        margin: 0 2.4rem 7.5rem;
    }
    #message .messageBox .inner {
        padding: 4.7rem 0 5rem;
    }
    #message .messageBox .inner::before {
        clip-path: polygon(0 0, 100% 0, 100% 8.1rem, 0 calc(50% + 21.1rem));
    }
    #message .messageBox .imgBox {
        margin-right: 0;
        display: block;
    }
    #message .messageBox .imgBox .textBox {
		padding: 0 2.4rem;
        width: auto;
    }
    #message .messageBox .imgBox .textBox p {
        font-size: 1.6rem;
        line-height: 1.5;
        text-align: left;
        letter-spacing: 0.08rem;
    }
	#message .messageBox .imgBox .textBox .subBox p {
		margin-bottom: 2rem;
	}
    #message .messageBox .imgBox .textBox .name {
        line-height: 1.2;
        font-size: 1.4rem;
        letter-spacing: 0.07rem;
    }
    #message .messageBox .imgBox .textBox .name span {
        display: block;
        margin: 0.8rem 0 0;
        font-size: 2rem;
        letter-spacing: 0.1rem;
    }
    #message .messageBox .imgBox .photoBox {
		margin: 2rem auto 0;
        width: auto;
        max-width: 29rem;
    }
	#message .messageBox .imgBox .photoBox img {
		width: 100%;
	}
}
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#index .mainVisual {
	margin-top: -6rem;
	height: 100vh;
	min-height: 55rem;
	position: relative;
}
#index .mainVisual .bgBox {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
#index .mainVisual .bgBox::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0.76;
	background: #6A7D97;
	mix-blend-mode: multiply;
	content: '';
}
#index .mainVisual .bgBox video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 57% 50%;
}
#index .mainVisual .inner {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 10;
	overflow: hidden;
}
#index .mainVisual .inner.inner01 {
	z-index: 1000;
	transition: 2s ease-out;
	background: #fff;
}
#index .mainVisual .inner.hide {
	opacity: 0;
	user-select: none;
	pointer-events: none;
}
#index .mainVisual .inner.inner01 video {
	transform: translateX(-6.8%);
	transition: .5s ease-out;
}
body.loaded #index .mainVisual .inner.inner01 video {
	transform: translateX(0);
}
#index .mainVisual .inner img,
#index .mainVisual .inner video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#index .mainVisual .inner.inner02 {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	transition: 1.2s ease-out;
}
#index .mainVisual .inner.inner03 {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	opacity: 0;
	user-select: none;
	pointer-events: none;
}
#index .mainVisual .inner.inner03.show {
	opacity: 1;
	user-select: inherit;
	pointer-events: inherit;
}
#index .mainVisual .inner.inner03 .textBox {
	padding-top: 4.9rem;
	width: 100%;
	max-width: 85rem;
}
#index .mainVisual .inner.inner03 .textBox .text {
	margin-bottom: 4.5rem;
	color: #FFF;
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 2.04;
	letter-spacing: 0.05em;
	opacity: 0;
	filter: blur(10px);
	transform: scale(1.05);
	transition: 1s ease;
}
#index .mainVisual .inner.inner03.show .textBox .text {
	opacity: 1;
	filter: blur(0);
	transform: scale(1);
}
#index .mainVisual .inner.inner03.show .textBox .text:nth-child(2) {
	transition-delay: 0.2s;
}
#index .mainVisual .inner.inner03 .textBox .text:last-child {
	margin-bottom: 0;
	transition-delay: 0.4s;
}
#index .news {
	padding: 5.7rem 0 3.8rem;
	background: #FFF;
	overflow: hidden;
}
#index .news .topArea {
	margin-bottom: 0.3rem;
}
#index .news .topArea .hTitle {
	font-size: 2.4rem;
	font-weight: 500;
	font-family: "Montserrat", sans-serif;
	text-transform: uppercase;
}
#index .news .topArea .rBox {
	padding: 0.3rem 0.8rem 0 0;
	width: calc(100% - 20rem);
}
#index .news .topArea .rBox .comTagList {
	width: calc(100% - 21.9rem);
	justify-content: flex-end;
}
#index .news .comPickList {
	max-width: 132.8rem;
}
#index .news .comPickList li {
	margin: 0 0.5rem;
	width: 39.5rem;
}
#index .news .comPickList li a {
	padding: 3.3rem 3rem 2.9rem;
}
#index .news .comPickList li .comTopBox {
	margin-bottom: 1.1rem;
}
#index .news .comPickList li .comTopBox .tagBox {
	margin-top: -0.5rem;
	width: calc(100% - 11rem);
}
#index .news .comPickList li .comTopBox .tagBox .tag {
	padding-bottom: 0.6rem;
}
#index .news .comPickList li .text {
	font-size: 1.6rem;
	line-height: 1.625;
	text-align: justify;
}
#index .about {
	padding: 18rem 0 20rem;
	position: relative;
	z-index: 1;
}
#index .about .bgBox {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	opacity: 0.3;
}
#index .about .bgBox video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#index .about .text {
	margin-bottom: 7.8rem;
	color: #FFF;
	font-size: 2rem;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.05em;
	text-align: center;
}
#index .business {
	padding: 15.5rem 0 20rem;
}
#index .business .inner .subInner {
	margin-bottom: 12rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}
#index .business .inner .subInner:last-child {
	margin-bottom: 0;
}
#index .business .inner .subInner .textBox {
	padding: 3rem 0 0;
	width: calc(100% - 62rem);
}
#index .business .inner .subInner .textBox .text {
	margin-bottom: 5.3rem;
	color: #FFF;
	line-height: 1.75;
	letter-spacing: 0.05em;
}
#index .business .inner .subInner .textBox .comBtn02 {
	margin: 0;
}
#index .business .inner .subInner .photoBox {
	margin-right: 0.8rem;
	width: 47.4rem;
}
#index .business .inner .subInner .photoBox img {
	border-radius: 1rem;
}
#index .business .inner .subInner.reverse .photoBox {
	order: 2;
}
#index .seminar {
	margin: 0 auto;
	padding: 12.6rem 0 12.7rem;
	max-width: 131.8rem;
	box-sizing: content-box;
	background: #EFF2F4 url(img/index/seminar_bg01.webp) no-repeat right center / auto 100%;
	border-radius: 1rem;
	overflow: hidden;
}
#index .seminar .comTopArea {
	margin-bottom: 7.3rem;
	align-items: center;
}
#index .seminar .comTopArea .text {
	padding-top: 0.5rem;
}
#index .seminar .comSeminarList {
	margin-bottom: 0;
	display: block;
	margin-left: 2.4rem;
}
#index .seminar .comSeminarList > ul {
	padding: 0;
}
#index .seminar .comSeminarList li {
	margin-right: 1rem;
	width: 39.5rem;
}
#index .seminar .comSeminarList li a {
	background: #FFF;
}
#index .seminar .comSeminarList li .textBox {
	padding: 2.3rem 2.7rem 2.2rem 3rem;
}
#index .seminar .comSeminarList li .textBox .comTopBox {
	margin-bottom: 0.9rem;
}
#index .seminar .comSeminarList li .textBox .comTopBox .tagBox {
	margin-top: -0.6rem;
}
#index .seminar .comSeminarList li .textBox .comTopBox .tagBox .tag {
	padding: 0.3rem 1.6rem 0.5rem;
	font-size: 1.6rem;
	background: #EFF2F4;
}
#index .seminar .comSeminarList li .textBox .title {
	text-align: justify;
}
#index .seminar .innerBox {
	margin: 4.3rem 0 0 -1.2rem;
	padding-right: 1.2rem;
	align-items: center;
}
#index .seminar .innerBox .swiper-scrollbar {
	margin-top: 0.8rem;
	position: static;
	width: calc(100% - 28rem);
	height: 0.2rem;
	background: #D7D7D7;
}
#index .seminar .innerBox .swiper-scrollbar .swiper-scrollbar-drag {
	background: #1A1A1A;
}
#index .seminar .innerBox .comBtn02 {
	margin-right: 1rem;
}
#index .column {
	padding: 16.5rem 0 18.7rem;
}
#index .column .comTopArea {
	margin-bottom: 5rem;
}
#index .column .linkList {
	padding: 0 0.8rem 0 0.1rem;
	gap: 2.9rem;
}
#index .column .linkList li {
	width: calc((100% - 5.8rem) / 3);
}
#index .column .linkList li a {
	padding: 3.3rem 2.4rem 2.2rem 2.8rem;
	position: relative;
	border-radius: 1rem;
	overflow: hidden;
	aspect-ratio: 351 / 280;
	z-index: 1;
	color: #FFF;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
#index .column .linkList li a .photo {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
#index .column .linkList li a .photo::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #1A1A1A;
	opacity: 0;
	content: '';
	transition: 0.3s;
	z-index: 5;
}
#index .column .linkList li a .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.3s;
}
#index .column .linkList li a .comPLink {
	margin-left: auto;
}
#index .contact {
	padding: 10rem 0 14.5rem;
	position: relative;
	z-index: 1;
	overflow: hidden;
}
#index .contact .bgBox {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	opacity: 0.3;
	filter: blur(1rem);
}
#index .contact .bgBox video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#index .contact .headLine02 {
	margin-bottom: 1.9rem;
}
#index .contact .text {
	margin-bottom: 6.7rem;
	color: #FFF;
	text-align: center;
	letter-spacing: 0.05em;
}
#index .contact .linkList {
	padding-right: 0.8rem;
	gap: 2rem 0;
}
#index .contact .linkList li {
	width: calc((100% - 2rem) / 2);
}
#index .contact .linkList li a {
	padding-top: 0.2rem;
	min-height: 10.8rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	border-radius: 1rem;
	background: #FFF;
}
#index .contact .linkList li a .sub {
	padding: 0.5rem 0 0.7rem 3.8rem;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	background: url(img/common/icon01.webp) no-repeat left center / 2.2rem;
	transition: 0.3s;
}
@media all and (min-width: 897px) {
	#index .column .linkList li a:hover {
		box-shadow: 0 0 1rem #FFF;
	}
	#index .column .linkList li a:hover .photo img {
		transform: scale(1.1);
	}
	#index .column .linkList li a:hover .photo::before {
		opacity: 0.9;
	}
	#index .column .linkList li a:hover .comPLink .sub {
		background-image: url(img/common/icon07.webp);
	}
	#index .contact .linkList li a:hover {
		background: #1A1A1A;
		color: #FFF;
		box-shadow: 0 0 1rem #FFF;
	}
	#index .contact .linkList li a:hover .sub {
		background-image: url(img/common/icon01_over.webp);
	}
}
@media all and (max-width: 896px) {
	#index .mainVisual {
		margin-top: -6rem;
		min-height: inherit;
	}
	#index .mainVisual .inner img,
	#index .mainVisual .inner video {
		position: absolute;
		left: -29%;
		top: 0;
		object-fit: contain;
		width: 158%;
		max-width: inherit;
	}
	#index .mainVisual .inner.inner01 {
		background: #FFF;
		text-align: center;
	}
	#index .mainVisual .inner.inner01 img {
		object-fit: contain;
	}
	#index .mainVisual .inner.inner03 .textBox {
		padding: 4.9rem 2rem 0;
		width: auto;
		max-width: inherit;
		box-sizing: border-box;
	}
	#index .mainVisual .inner.inner03 .textBox .text {
		margin-bottom: 4.5rem;
		font-size: 1.6rem;
		line-height: 1.6;
	}
	#index .news {
		padding: 4.7rem 0 10.7rem;
		position: relative;
	}
	#index .news .topArea {
		margin-bottom: 0;
		display: block;
	}
	#index .news .topArea .hTitle {
		margin-bottom: 1.6rem;
		font-size: 2rem;
	}
	#index .news .topArea .rBox {
		padding: 0;
		width: auto;
		display: block;
	}
	#index .news .topArea .rBox .comTagList {
		width: auto;
		justify-content: flex-start;
	}
	#index .news .comPickList {
		margin-bottom: 2.7rem;
		padding: 3.4rem 0 0;
	}
	#index .news .comPickList li {
		margin: 0 1.2rem;
		width: 29.3rem;
	}
	#index .news .comPickList li a {
		padding: 2.6rem 2.5rem 2.7rem;
	}
	#index .news .comPickList li .comTopBox {
		margin-bottom: 0.6rem;
	}
	#index .news .comPickList li .comTopBox .tagBox {
		margin-top: -0.6rem;
		width: calc(100% - 8.1rem);
	}
	#index .news .comPickList li .text {
		font-size: 1.4rem;
		line-height: 1.57;
	}
	#index .news .comPLink {
		margin: 0;
        width: fit-content;
        position: absolute;
        bottom: 8.4rem;
        left: 50%;
        transform: translateX(-50%);
	}
	#index .about {
		padding: 5.6rem 0 5rem;
	}
	#index .about .text {
		margin-bottom: 4.4rem;
		font-size: 1.6rem;
		line-height: 1.625;
	}
	#index .business {
		padding: 5.6rem 0 9rem;
	}
	#index .business .inner .subInner {
		margin-bottom: 5.2rem;
		display: block;
	}
	#index .business .inner .subInner .textBox {
		padding: 1.9rem 0 0;
		width: auto;
	}
	#index .business .inner .subInner .textBox .text {
		margin-bottom: 1.8rem;
		line-height: 1.57;
	}
	#index .business .inner .subInner .textBox .comBtn02 {
		margin: 0 auto;
	}
	#index .business .inner .subInner .photoBox {
		margin-right: 0;
		width: auto;
		aspect-ratio: 342 / 186;
	}
	#index .business .inner .subInner .photoBox img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	#index .seminar {
		margin: 0 2.4rem;
		padding: 4.3rem 0 6.2rem;
		max-width: inherit;
		background: #EFF2F4;
	}
	#index .seminar .comTopArea {
		margin-bottom: 4.2rem;
	}
	#index .seminar .comTopArea .text {
		padding-top: 0.8rem;
		line-height: 1.57;
	}
	#index .seminar .comSeminarList {
		margin: 0;
		display: block;
	}
	#index .seminar .comSeminarList > ul {
		padding-left: 0;
	}
	#index .seminar .comSeminarList li {
		margin: 0 1.3rem 0 1.2rem;
		padding: 0;
		width: 24.4rem;
	}
	#index .seminar .comSeminarList li .textBox {
		padding: 1.9rem 1.6rem 1.2rem 1.9rem;
	}
	#index .seminar .comSeminarList li .textBox .comTopBox {
		margin-bottom: 0.6rem;
	}
	#index .seminar .comSeminarList li .textBox .comTopBox .tagBox {
		margin-top: -0.7rem;
	}
	#index .seminar .comSeminarList li .textBox .comTopBox .tagBox .tag {
		padding: 0.5rem 1.6rem 0.6rem;
		font-size: 1.2rem;
	}
	#index .seminar .innerBox {
		margin: 4.4rem 0 0;
		padding: 0;
		display: block;
	}
	#index .seminar .innerBox .swiper-scrollbar {
		margin-top: 0;
		width: auto;
	}
	#index .seminar .innerBox .comBtn02 {
		margin: 4.6rem auto 0;
	}
	#index .column {
		padding: 7.7rem 0 4.9rem;
	}
	#index .column .comTopArea {
		margin-bottom: 3.4rem;
	}
	#index .column .comTopArea .text {
		padding-top: 1.4rem;
		line-height: 1.57;
	}
	#index .column .linkList {
		padding: 0;
		display: block;
	}
	#index .column .linkList li {
		margin-bottom: 2.4rem;
		width: auto;
	}
	#index .column .linkList li a {
		padding: 2.8rem 1.6rem 1.5rem 2.6rem;
		aspect-ratio: 342 / 209;
	}
	#index .contact {
		padding: 5.1rem 0 7.1rem;
	}
	#index .contact .headLine02 {
		margin-bottom: 2.1rem;
	}
	#index .contact .text {
		margin-bottom: 2.6rem;
		text-align: left;
		line-height: 1.57;
	}
	#index .contact .linkList {
		padding-right: 0;
		display: block;
	}
	#index .contact .linkList li {
		margin-bottom: 1.6rem;
		width: auto;
	}
	#index .contact .linkList li:last-child {
		margin-bottom: 0;
	}
	#index .contact .linkList li a {
		padding-top: 0.2rem;
		min-height: 6.5rem;
	}
	#index .contact .linkList li a .sub {
		padding: 0.5rem 5.6rem 0.7rem;
		font-size: 1.6rem;
		width: 100%;
		display: block;
		text-align: center;
		line-height: 1.375;
		background: url(img/common/icon01.webp) no-repeat left 3.1rem center / 2.2rem;
	}
}
/*------------------------------------------------------------
	company
------------------------------------------------------------*/
#company .pageTitle {
	margin-bottom: 12.4rem;
	padding-bottom: 11rem;
	position: relative;
	z-index: 5;
}
#company .pageTitle .bgBox {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	opacity: 0.3;
}
#company .pageTitle .bgBox video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#company .linkList {
	padding-right: 0.8rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 2rem 0;
}
#company .linkList li {
	width: calc((100% - 2rem) / 2);
}
#company .linkList li a {
	padding: 4.3rem 3rem 2.9rem 4.3rem;
	position: relative;
	color: #FFF;
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	justify-content: space-between;
	z-index: 1;
	aspect-ratio: 546 / 334;
	border-radius: 1rem;
	overflow: hidden;
	box-sizing: border-box;
}
#company .linkList li a .photo {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
#company .linkList li a .photo::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #1A1A1A;
	opacity: 0;
	content: '';
	transition: 0.3s;
	z-index: 5;
}
#company .linkList li a .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.3s;
}
#company .linkList li a .comPLink {
	margin-left: auto;
}
@media all and (min-width: 897px) {
	#company .linkList li a:hover {
		box-shadow: 0 0 1rem #FFF;
	}
	#company .linkList li a:hover .photo::before {
		opacity: 0.9;
	}
	#company .linkList li a:hover .photo img {
		transform: scale(1.1);
	}
	#company .linkList li a:hover .comPLink .sub {
		background-image: url(img/common/icon07.webp);
	}
}
@media all and (max-width: 896px) {
	#company .pageTitle {
		margin-bottom: 4.8rem;
		padding-bottom: 5rem;
	}
	#company .pageTitle .text {
		margin-top: 5.4rem;
		letter-spacing: 0.05em;
		line-height: 1.625;
	}
	#company .linkList {
		padding-right: 0;
		display: block;
	}
	#company .linkList li {
		margin-bottom: 2.4rem;
		width: auto;
	}
	#company .linkList li:last-child {
		margin-bottom: 0;
	}
	#company .linkList li a {
		padding: 2.8rem 1.6rem 1.5rem 2.6rem;
		aspect-ratio: 342 / 209;
	}
}
/*------------------------------------------------------------
	correction
------------------------------------------------------------*/
#correction .pageTitle {
	padding-bottom: 11rem;
}
#correction .comBox {
	padding: 10.4rem 0 8rem;
}
@media all and (max-width: 896px) {
	#correction .pageTitle {
		padding-bottom: 5.1rem;
	}
	#correction .pageTitle .text {
		margin-top: 4.5rem;
		padding: 0 2rem;
	}
	#correction .comBox {
		padding: 5.2rem 0 5.6rem;
	}
}
/*------------------------------------------------------------
	koushi
------------------------------------------------------------*/
#koushi .pageTitle {
	padding-bottom: 11rem;
}
#koushi .comBox {
	margin-bottom: 2rem;
	padding: 10.4rem 0 12.5rem;
}
#koushi .comBox.style01 {
	padding-bottom: 10.9rem;
}
#koushi .comBox.style02 {
	padding-bottom: 10.1rem;
}
#koushi .comBox:last-child {
	margin-bottom: 0;
}
#koushi .recruiting .headLine05 {
	margin-bottom: 6.5rem;
}
#koushi .recruiting .subInner:not(:last-child) {
	margin-bottom: 6.8rem;
}
#koushi .recruiting .textList {
	margin-bottom: 4.3rem;
	padding-right: 0.8rem;
	display: flex;
	flex-wrap: wrap;
	gap: 2.2rem;
}
#koushi .recruiting .textList li {
	width: calc((100% - 4.4rem) / 3);
	background: #EFF2F4;
	border-radius: 1rem;
}
#koushi .recruiting .textList li .title {
	padding: 2.2rem 1rem;
	color: #FFF;
	font-size: 2.4rem;
	font-weight: 700;
	text-align: center;
	background-color: #1A1A1A;
	border-radius: 1rem 1rem 0 0;
}
#koushi .recruiting .textList li .title sup {
	font-size: 2.2rem;
	vertical-align: 0.1rem;
}
#koushi .recruiting .textList li .text {
	padding: 2.5rem 3.2rem 3.1rem;
	min-height: 16.8rem;
	line-height: 1.75;
	text-align: justify;
	box-sizing: border-box;
}
#koushi .recruiting .textList li .text sup {
	vertical-align: 0;
}
#koushi .recruiting .textBox .text {
	margin-bottom: 2.8rem;
	line-height: 1.75;
	font-weight: 500;
	letter-spacing: 0.05em;
}
#koushi .recruiting .textBox .text:last-child {
	margin-bottom: 0;
}
#koushi .recruiting .textBox .text .color01 {
	color: #DF4242;
	font-weight: 700;
}
#koushi .recruiting .textBox .text a {
	color: #DF4242;
	text-decoration: underline;
}
#koushi .recruiting .headLine06 + .textBox {
	margin-top: -1rem;
}
#koushi .noteBox .textList li {
	padding-left: 1.2em;
	font-weight: 500;
	line-height: 1.75;
	letter-spacing: 0.05em;
	text-indent: -1.2em;
}
@media all and (min-width: 897px) {
	#koushi .recruiting .textBox .text a:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#koushi .pageTitle {
		padding-bottom: 5.1rem;
	}
	#koushi .pageTitle .text {
		margin-top: 4.5rem;
	}
	#koushi .comBox {
		margin-bottom: 3.5rem;
		padding: 5.2rem 0 5.6rem;
	}
	#koushi .comBox.style01 {
		padding-bottom: 5.6rem;
	}
	#koushi .comBox.style02 {
		padding-bottom: 5.6rem;
	}
	#koushi .recruiting .headLine05 {
		margin-bottom: 3.9rem;
	}
	#koushi .recruiting .subInner:not(:last-child) {
		margin-bottom: 4.2rem;
	}
	#koushi .recruiting .textList {
		margin-bottom: 3.1rem;
		padding-right: 0;
		display: block;
	}
	#koushi .recruiting .textList li {
		margin-bottom: 2rem;
		width: auto;
	}
	#koushi .recruiting .textList li:last-child {
		margin-bottom: 0;
	}
	#koushi .recruiting .textList li .title {
		padding: 1.7rem 1rem 1.9rem;
		font-size: 2rem;
	}
	#koushi .recruiting .textList li .title sup {
		font-size: 1.8rem;
	}
	#koushi .recruiting .textList li .text {
		padding: 2rem 2.7rem 2rem;
		min-height: inherit;
		line-height: 1.57;
	}
	#koushi .recruiting .textBox .text {
		margin-bottom: 2.2rem;
		line-height: 1.57;
	}
	#koushi .noteBox .textList li {
		padding-left: 1.3em;
		line-height: 1.57;
		text-indent: -1.3em;
	}
	#koushi .comSecBox .textList {
		margin-bottom: 2.5rem;
	}
}
/*------------------------------------------------------------
	recruitment
------------------------------------------------------------*/
#recruitment .pageTitle {
	padding-bottom: 11rem;
}
#recruitment .subInner {
	margin: 0 auto 2rem;
	padding: 8.2rem 0 8.8rem;
	max-width: 131.8rem;
	background: #FFF url(img/recruitment/bg01.webp) no-repeat right center / auto 100%;
	border-radius: 1rem;
}
#recruitment .subInner:nth-child(2n) {
	background-image: url(img/recruitment/bg02.webp);
	background-position: left center;
}
#recruitment .subInner:last-child {
	margin-bottom: 0;
}
#recruitment .imgBox {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#recruitment .imgBox .photoBox {
	padding-top: 0.5rem;
	width: 53rem;
}
#recruitment .imgBox .photoBox img {
	border-radius: 1rem;
}
#recruitment .imgBox.reverse .photoBox {
	order: 2;
}
#recruitment .imgBox .textBox {
	width: calc(100% - 62rem);
}
#recruitment .imgBox .textBox .headLine03 {
	color: #1A1A1A;
}
#recruitment .imgBox .textBox .headLine03 .tag {
	margin-left: 2.5rem;
	padding: 0.3rem 1.5rem 0.4rem;
	display: inline-block;
	background: #EFF2F4;
	font-weight: 500;
	font-size: 1.6rem;
	letter-spacing: 0.03em;
	border-radius: 2rem;
	vertical-align: 0.5rem;
}
#recruitment .imgBox .textBox .text {
	margin-bottom: 7.4rem;
	line-height: 1.75;
	letter-spacing: 0.05em;
}
#recruitment .imgBox .textBox .comBtn02 {
	margin: 0;
}
@media all and (max-width: 896px) {
	#recruitment .pageTitle {
		padding-bottom: 7.5rem;
	}
	#recruitment .subInner {
		margin: 0 2.4rem 3rem;
		padding: 2.8rem 0 4.9rem;
		max-width: inherit;
		background: #FFF url(img/recruitment/bg03.webp) no-repeat right bottom / 100% !important;
	}
	#recruitment .imgBox {
		display: block;
	}
	#recruitment .imgBox .photoBox {
		margin-bottom: 2.3rem;
		padding-top: 0;
		width: auto;
	}
	#recruitment .imgBox .photoBox img {
		width: 100%;
	}
	#recruitment .imgBox .textBox {
		width: auto;
	}
	#recruitment .imgBox .textBox .headLine03 {
		margin-bottom: 1.8rem;
	}
	#recruitment .imgBox .textBox .headLine03 .tag {
		margin-left: 2rem;
		padding: 0.4rem 1.5rem 0.5rem;
		font-size: 1.4rem;
		vertical-align: 0.4rem;
	}
	#recruitment .imgBox .textBox .text {
		margin-bottom: 3.7rem;
		line-height: 1.57;
		letter-spacing: 0;
	}
	#recruitment .imgBox .textBox .comBtn02 {
		margin: 0 auto;
	}
}
/*------------------------------------------------------------
	privacy
------------------------------------------------------------*/
#privacy .pageTitle {
	padding-bottom: 14.3rem;
}
#privacy .comBox {
	padding: 8.5rem 0 12rem;
}
#privacy .textBox:not(:last-child) {
	margin-bottom: 4.3rem;
}
#privacy .textBox .hTitle {
	margin-bottom: 1.2rem;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1.33;
}
#privacy .textBox .text {
	margin-bottom: 1.1rem;
	letter-spacing: 0.03em;
}
#privacy .textBox .text.mb01 {
	margin-bottom: 2.4rem;
}
#privacy .textBox .text .lineLink {
	text-decoration: underline;
}
#privacy .textBox .textList li {
	padding-left: 1.2em;
	letter-spacing: 0.03em;
	text-indent: -1.2em;
}
#privacy .textBox .textList li a {
	text-decoration: underline;
}
#privacy .textBox .textList + .textList {
	margin-top: 0.5rem;
}
#privacy .textBox .area {
	margin-top: 2.4rem;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
}
#privacy .textBox .area .logo {
	margin: 0 0 1.4rem 2.8rem;
	width: 7.5rem;
}
#privacy .textBox .comBtn02 {
	margin: 4rem 0 0 auto;
}
#privacy.policy .comBox {
	padding-bottom: 14rem;
}
#privacy.attention .comBox {
	padding-bottom: 8.7rem;
}
#privacy.sitepolicy .comBox {
	padding-bottom: 9.2rem;
}
@media all and (min-width: 897px) {
	#privacy .textBox .text a:hover,
	#privacy .textBox .textList li a:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#privacy .pageTitle {
		padding-bottom: 7.5rem;
	}
	#privacy .comBox {
		padding: 3.5rem 0 4.9rem;
	}
	#privacy .textBox:not(:last-child) {
		margin-bottom: 6.2rem;
	}
	#privacy .textBox .hTitle {
		margin-bottom: 1.8rem;
		font-size: 2rem;
		line-height: 1.2;
	}
	#privacy .textBox .text {
		margin-bottom: 1.7rem;
		line-height: 1.57;
	}
	#privacy .textBox .textList li {
		line-height: 1.57;
	}
	#privacy .textBox .area {
		margin-top: 2.2rem;
		display: block;
	}
	#privacy .textBox .area .logo {
		margin: -0.6rem auto 0;
	}
	#privacy.policy .pageTitle {
		padding-bottom: 5.8rem;
	}
	#privacy.policy .pageTitle #pagePath {
		margin-bottom: 3.5rem;
	}
	#privacy.policy .pageTitle .headLine01 .en {
		margin-bottom: 0.5rem;
	}
	#privacy.policy .comBox,
	#privacy.attention .comBox,
	#privacy.sitepolicy .comBox {
		padding-bottom: 6.5rem;
	}
	#privacy.policy .textBox:not(:last-child),
	#privacy.attention .textBox:not(:last-child),
	#privacy.sitepolicy .textBox:not(:last-child) {
		margin-bottom: 2rem;
	}
	#privacy .textBox .comBtn02 {
		margin: 4rem auto 0;
	}
}
/*------------------------------------------------------------
	plusone
------------------------------------------------------------*/
#plusone .pageTitle {
	padding-bottom: 2.3rem;
}
#plusone .linkList {
	margin-bottom: 12.4rem;
	padding-right: 0.8rem;
	gap: 2.2rem;
}
#plusone .linkList li {
	width: calc((100% - 4.4rem) / 3);
}
#plusone .linkList li a {
	padding: 1rem 4rem 0.9rem 1.8rem;
	display: block;
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	border-radius: 0.6rem;
	background: #FFF url(img/common/icon11.webp) no-repeat right 1.4rem center / 0.8rem;
}
#plusone .comBox.style01 {
	margin-bottom: 4rem;
	padding-bottom: 16.5rem;
}
#plusone .comBox.style02 {
	margin-bottom: 4rem;
	padding-bottom: 13.5rem;
}
#plusone .comBox.style03 {
	padding-bottom: 15.5rem;
}
#plusone .headLine05 {
	margin-bottom: 8.2rem;
}
#plusone .photoList {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 8.4rem 0;
}
#plusone .photoList li {
	width: calc((100% - 2rem) / 2);
}
#plusone .photoList li .photo {
	margin: 0 auto 3rem;
	max-width: 40.9rem;
}
#plusone .photoList li .title {
	margin-bottom: 1.5rem;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: center;
}
#plusone .photoList li .text {
	margin: 0 auto;
	width: 38.2rem;
	line-height: 1.75;
	letter-spacing: 0.05em;
	text-align: justify;
}
#plusone .photoList li .text.style01 {
	width: 39rem;
	letter-spacing: 0;
}
@media all and (min-width: 897px) {
	#plusone .linkList li a:hover {
		color: #FFF;
		background: #1A1A1A url(img/common/icon11_over.webp) no-repeat right 1.4rem center / 0.8rem;
		box-shadow: 0 0 1rem #FFF;
	}
}
@media all and (max-width: 896px) {
	#plusone .pageTitle {
		padding-bottom: 4.6rem;
	}
	#plusone .linkList {
		margin-bottom: 5rem;
		padding-right: 0;
		display: block;
	}
	#plusone .linkList li {
		margin: 0 auto 1.2rem;
		width: auto;
		max-width: 34.2rem;
	}
	#plusone .linkList li:last-child {
		margin-bottom: 0;
	}
	#plusone .linkList li a {
		background: #FFF url(img/common/icon11.webp) no-repeat right 1.2rem center / 0.8rem;
	}
	#plusone .comBox {
		padding-top: 4.2rem;
	}
	#plusone .comBox.style01 {
		margin-bottom: 3.6rem;
		padding-bottom: 6.8rem;
	}
	#plusone .comBox.style02 {
		margin-bottom: 3.6rem;
		padding-bottom: 6.6rem;
	}
	#plusone .comBox.style03 {
		padding-bottom: 6.8rem;
	}
	#plusone .headLine05 {
		margin-bottom: 2rem;
	}
	#plusone .photoList {
		display: block;
	}
	#plusone .photoList li {
		margin-bottom: 2.7rem;
		width: auto;
	}
	#plusone .photoList li:last-child {
		margin-bottom: 0;
	}
	#plusone .photoList li .photo {
		margin: 0 auto 1.5rem;
		max-width: 26rem;
	}
	#plusone .photoList li .title {
		margin-bottom: 1.1rem;
		font-size: 2rem;
	}
	#plusone .photoList li .text {
		margin: 0;
		width: auto !important;
		line-height: 1.57;
		letter-spacing: 0.05em !important;
	}
}
/*------------------------------------------------------------
	philosophy
------------------------------------------------------------*/
#philosophy {
	padding-bottom: 15.5rem;
}
#philosophy .pageTitle {
	padding-bottom: 15.8rem;
}
#philosophy .linkArea {
	margin: 0 auto 13.1rem;
	padding-right: 0.7rem;
	max-width: 111rem;
	box-sizing: content-box;
	position: relative;
}
#philosophy .linkArea .link {
	position: absolute;
}
#philosophy .linkArea .link.style01 {
	top: 5.4rem;
	right: 17.3rem;
}
#philosophy .linkArea .link.style02 {
	top: 17.9rem;
	right: 0rem;
}
#philosophy .linkArea .link.style03 {
	bottom: 11rem;
	right: 14.8rem;
}
#philosophy .linkArea .link a {
	padding: 0 6rem 0.6rem 0;
	position: relative;
	display: block;
	color: #FFF;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
#philosophy .linkArea .link a::before {
	position: absolute;
	content: '';
	visibility: hidden;
	transition: 0.3s;
}
#philosophy .linkArea .link a .en {
	margin-bottom: -0.3rem;
	display: block;
	text-transform: uppercase;
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0;
	font-family: "Montserrat", sans-serif;
}
#philosophy .linkArea .link a .arrow {
	position: absolute;
	right: 0;
	top: 2rem;
	width: 4rem;
	height: 4rem;
	border-radius: 0.6rem;
	box-shadow: 0 0 1rem rgba(0, 0, 0, 0.25);
	background: #FFF url(img/common/icon11.webp) no-repeat center center / 0.8rem;
	transition: 0.3s;
}
#philosophy .linkArea .link.style01 a::before {
	top: 5.8rem;
	left: -54.6rem;
	width: 43rem;
	height: 20rem;
	background: url(img/company/philosophy/img02.webp) no-repeat left top / 100%;
	opacity: 0;
}
#philosophy .linkArea .link.style02 a::before {
	top: -0.7rem;
	left: -70.5rem;
	width: 60rem;
	height: 25rem;
	background: url(img/company/philosophy/img03.webp) no-repeat left top / 100%;
	opacity: 0;
}
#philosophy .linkArea .link.style03 a::before {
	top: -10.4rem;
	right: 29.7rem;
	width: 69rem;
	height: 29.5rem;
	background: url(img/company/philosophy/img04.webp) no-repeat left top / 100%;
	opacity: 0;
}
#philosophy .subInner {
	margin: 0 auto;
	position: relative;
	padding: 8rem 0 9rem;
	max-width: 131.8rem;
	border-radius: 1rem;
	box-sizing: border-box;
	background: #F3F3F3;
	overflow: hidden;
	/* background: #FFF url(img/company/philosophy/bg01.webp) no-repeat right center / auto 100%; */
	z-index: 1;
}
#philosophy .subInner::before {
	position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    clip-path: polygon(0 0,calc(50% + 21.3rem) 0,calc(50% - 10.7rem) 100%,0 100%);
    background-color: #FFF;
    content: "";
	z-index: -1;
}
#philosophy .subInner:not(:last-child) {
	margin-bottom: 2rem;
}
#philosophy .subInner.style01 {
	padding-bottom: 10.3rem;	
}
#philosophy .subInner.style01::before {
    clip-path: polygon(0 0,calc(50% + 23.1rem) 0,calc(50% - 14.9rem) 100%,0 100%);
}
#philosophy .subInner.style02 {
	padding-bottom: 10.5rem;
}
#philosophy .subInner.style02::before {
	clip-path: polygon(0 0,calc(50% + 22.8rem) 0,calc(50% - 19rem) 100%,0 100%);
}
#philosophy .subInner .imgBox {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#philosophy .subInner .imgBox .lBox {
	width: 37rem;
}
#philosophy .subInner .imgBox .lBox .headLine03 {
	margin-bottom: 7rem;
	padding: 0.1rem 0 0 2.5rem;
	color: #1A1A1A;
	position: relative;
}
#philosophy .subInner .imgBox .lBox .headLine03::before {
	position: absolute;
	top: 0.4rem;
	left: 0;
	bottom: 0.4rem;
	width: 0.4rem;
	background: #D9D9D9;
	content: '';
}
#philosophy .subInner .imgBox .lBox .photo01 {
	margin: 0 0.1rem 0 auto;
	width: 21.7rem;
}
#philosophy .subInner .imgBox .rBox {
	padding: 7.3rem 0 0;
	width: calc(100% - 57.2rem);
}
#philosophy .subInner .imgBox .headLine05 {
	margin-bottom: 1.3rem;
	text-align: left;
	line-height: 1.43;
}
#philosophy .subInner .imgBox .textBox .text {
	margin-bottom: 2.8rem;
	font-weight: 500;
	line-height: 1.75;
	letter-spacing: 0.05em;
}
#philosophy .subInner .imgBox .textBox .text:last-child {
	margin-bottom: 0;
}
#philosophy .subInner .imgBox.style02 .lBox {
	width: 55rem;
}
#philosophy .subInner .imgBox.style02 .lBox .headLine03 {
	margin-bottom: 7.7rem;
}
#philosophy .subInner .imgBox.style02 .lBox .subBox {
	padding-left: 2.7rem;
}
#philosophy .subInner .imgBox.style02 .lBox .subBox .headLine05 {
	margin-bottom: 1.4rem;
}
#philosophy .subInner .imgBox.style02 .rBox {
	padding-top: 7.9rem;
	width: calc(100% - 60rem);
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox {
	position: relative;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox {
	margin: 0 auto;
	width: 33.8rem;
	height: 33.8rem;
	overflow: hidden;
	position: relative;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox svg {
	width: 100%;
	height: auto;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area {
	position: absolute;
	color: #FFF;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	transition: 0.3s;
	cursor: pointer;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area.area01 {
	padding: 0 0 3.2rem 2.1rem;
	top: 0;
	left: 1.1rem;
	width: 15.6rem;
	height: 16.4rem;
	background: url(img/company/philosophy/img06.webp) no-repeat left top / 100%;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area.area02 {
	padding: 0 5.7rem 1.9rem 0;
	top: 12rem;
	left: 0.1rem;
	width: 16.4rem;
	height: 18.4rem;
	background: url(img/company/philosophy/img07.webp) no-repeat left top / 100%;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area.area03 {
	padding: 6.4rem 0 0 0.5rem;
	bottom: -0.1rem;
	left: 7.3rem;
	width: 19.4rem;
	height: 16.4rem;
	background: url(img/company/philosophy/img08.webp) no-repeat left top / 100%;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area.area04 {
	padding: 0 0 1.9rem 6.9rem;
	top: 12rem;
	right: -0.1rem;
	width: 16.4rem;
	height: 18.4rem;
	background: url(img/company/philosophy/img09.webp) no-repeat left top / 100%;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area.area05 {
	padding: 0 1.9rem 3.1rem 0;
	top: 0;
	right: 0.8rem;
	width: 15.6rem;
	height: 16.4rem;
	background: url(img/company/philosophy/img10.webp) no-repeat left top / 100%;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .centerArea {
	margin: 0.1rem 0 0 0.2rem;
	padding: 0 0 0.6rem 0.3rem;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 16.4rem;
	height: 16.4rem;
	background: #F4F4F4;
	border-radius: 50%;
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea {
	padding: 1.3rem 2rem 1.5rem;
	position: absolute;
	width: 25.8rem;
	color: #FFF;
	letter-spacing: 0.05em;
	background: #939393;
	border-radius: 1rem 1rem 0 1rem;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea::before {
	position: absolute;
	bottom: -2rem;
	right: 0;
	width: 2.4rem;
	height: 2.1rem;
	background: #939393;
	clip-path: polygon(0 0,100% 0,100% 100%);
	content: '';
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea .title {
	font-weight: 700;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea .text {
	margin-bottom: 0;
	font-weight: 400;
	line-height: 1.5;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style01 {
	top: -9.3rem;
	left: -4.9rem;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style02 {
	top: 4.3rem;
	left: -9.8rem;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style03 {
	bottom: -5.2rem;
	left: 2.7rem;
	border-radius: 1rem 0 1rem 1rem;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style03::before {
	bottom: auto;
	top: -2rem;
	clip-path: polygon(100% 0,0 100%,100% 100%);
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style04 {
	right: -9.9rem;
	top: 4.2rem;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style05 {
	top: -9.3rem;
	right: -3rem;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style04,
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style05 {
	border-radius: 1rem 1rem 1rem 0;
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style04::before,
#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.style05::before {
	right: auto;
	left: 0;
	clip-path: polygon(0 0,100% 0,0 100%);
}
#philosophy .subInner .imgBox.style02 .rBox .circleBox .innerText {
	margin-top: 2.4rem;
	font-size: 2.4rem;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.05em;
}
#philosophy .subInner .imgBox.style03 .lBox {
	width: 40rem;
}
#philosophy .subInner .imgBox.style03 .lBox .headLine03 {
	margin-bottom: 18.1rem;
}
#philosophy .subInner .imgBox.style03 .lBox .photo02 {
	margin: 0 auto;
	width: 32rem;
}
#philosophy .subInner .imgBox.style03 .rBox {
	padding-top: 9.9rem;
	width: calc(100% - 46.8rem);
}
#philosophy .subInner .imgBox.style03 .rBox .headLine05 {
	margin-bottom: 1.3rem;
}
#philosophy .outTitle {
	margin: 11.5rem 0 10.6rem;
	color: #FFF;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.92;
	text-align: center;
	letter-spacing: 0.05em;
}
#philosophy .comLinkList li {
	margin-right: 0;
	width: 47.6rem;
}
#philosophy .comLinkList li a::before {
	right: 2.2rem;
}
@media all and (min-width: 897px) {
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea {
		opacity: 0;
		transition: .5s;
		user-select: none;
		pointer-events: none;
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea:hover,
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea.active {
		opacity: 1;
		user-select: inherit;
		pointer-events: auto;
	}
	#philosophy .linkArea .link a:hover .arrow {
		box-shadow: 0 0 1rem #FFF;
		background: #1A1A1A url(img/common/icon11_over.webp) no-repeat center center / 0.8rem;
	}
	#philosophy .linkArea .link a:hover::before {
		opacity: 1;
		visibility: visible;
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area.active,
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area:hover {
		color: #1A1A1A;
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area01.active,
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area01:hover {
		background-image: url(img/company/philosophy/img06_over.webp);
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area02.active,
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area02:hover {
		background-image: url(img/company/philosophy/img07_over.webp);
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area03.active,
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area03:hover {
		background-image: url(img/company/philosophy/img08_over.webp);
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area04.active,
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area04:hover {
		background-image: url(img/company/philosophy/img09_over.webp);
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area05.active,
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .subBox .area05:hover {
		background-image: url(img/company/philosophy/img10_over.webp);
	}
}
@media all and (max-width: 896px) {
	#philosophy {
		padding-bottom: 0.9rem;
	}
	#philosophy .pageTitle {
		padding-bottom: 5.6rem;
	}
	#philosophy .linkArea {
		margin: 0 auto 8.8rem;
		padding-right: 0;
		max-width: inherit;
	}
	#philosophy .linkArea img {
		margin: 0 auto 2.2rem;
		display: block;
		width: 34.4rem;
	}
	#philosophy .linkArea .link {
		margin-bottom: 1.7rem;
		padding: 0 2.4rem;
		position: static !important;
	}
	#philosophy .linkArea .link:last-child {
		margin-bottom: 0;
	}
	#philosophy .linkArea .link a {
		margin: 0 auto;
		max-width: 34.2rem;
		padding: 0 0 0;
		font-size: 2rem;
	}
	#philosophy .linkArea .link a .en {
		margin-bottom: -0.1rem;
		font-size: 1.4rem;
	}
	#philosophy .linkArea .link a .arrow {
		right: 0.1rem;
		top: 0.8rem;
	}
	#philosophy .subInner {
		margin: 0 2.4rem;
		padding: 4.3rem 0 5.6rem;
		max-width: inherit;
	}
	#philosophy .subInner::before {
		clip-path: polygon(0 0,100% 0,100% 8rem,0 calc(100% - 3rem));
	}
	#philosophy .subInner:not(:last-child) {
		margin-bottom: 3.6rem;
	}
	#philosophy .subInner.style01 {
		padding-bottom: 5.2rem;
	}
	#philosophy .subInner.style01::before {
		clip-path: polygon(0 0,100% 0,100% 10.6rem,0 calc(50% + 3.4rem));
	}
	#philosophy .subInner.style02 {
		padding-bottom: 5.2rem;
	}
	#philosophy .subInner.style02::before {
		clip-path: polygon(0 0,100% 0,100% 8rem,0 calc(100% - 16.5rem));
	}
	#philosophy .subInner .imgBox {
		display: block;
	}
	#philosophy .subInner .imgBox .lBox {
		width: auto !important;
	}
	#philosophy .subInner .imgBox .lBox .headLine03 {
		margin-bottom: 3.5rem;
		padding: 0.1rem 0 0 2rem;
	}
	#philosophy .subInner .imgBox .lBox .headLine03::before {
		top: 0.3rem;
	}
	#philosophy .subInner .imgBox .lBox .photo01 {
		margin: 0 auto;
		width: 12.5rem;
	}
	#philosophy .subInner .imgBox .rBox {
		padding: 6.1rem 0 0;
		width: auto !important;
	}
	#philosophy .subInner .imgBox .headLine05 {
		margin-bottom: 1.4rem;
		line-height: 1.16;
	}
	#philosophy .subInner .imgBox .textBox .text {
		margin-bottom: 2.3rem;
		line-height: 1.57;
		letter-spacing: 0;
	}
	#philosophy .subInner .imgBox.style02 .lBox .headLine03 {
		margin-bottom: 3.3rem;
	}
	#philosophy .subInner .imgBox.style02 .lBox .subBox {
		padding-left: 0;
	}
	#philosophy .subInner .imgBox.style02 .lBox .subBox .headLine05 {
		margin-bottom: 1.3rem;
	}
	#philosophy .subInner .imgBox.style02 .rBox {
		padding-top: 3.6rem;
	}
	#philosophy .subInner .imgBox.style02 .rBox .textImg {
		margin: 0 auto 2.7rem;
		max-width: 25.5rem;
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea {
		padding: 0;
		position: static;
		width: auto;
		color: #1A1A1A;
		font-size: 1.6rem;
		background: transparent;
		border-radius: 0;
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea:not(:last-child) {
		margin-bottom: 2.2rem;
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea::before {
		display: none !important;
	}
	#philosophy .subInner .imgBox.style02 .rBox .circleBox .textArea .text {
		letter-spacing: 0.05em;
	}
	#philosophy .subInner .imgBox.style03 .lBox .headLine03 {
		margin: 0 -1rem 5.6rem 0;
	}
	#philosophy .subInner .imgBox.style03 .lBox .photo02 {
		width: 21.7rem;
	}
	#philosophy .subInner .imgBox.style03 .rBox {
		padding-top: 7.4rem;
	}
	#philosophy .subInner .imgBox.style03 .rBox .headLine05 {
		margin-bottom: 1.2rem;
	}
	#philosophy .subInner .imgBox.style03 .rBox .textBox .text {
		margin-bottom: 2.2rem;
	}
	#philosophy .subInner .imgBox.style03 .rBox .textBox .text:last-child {
		margin-bottom: 0;
	}
	#philosophy .outTitle {
		margin: 5.8rem 0 6.6rem;
		font-size: 2rem;
		line-height: 1.6;
	}
	#philosophy .comLinkList li {
		margin-right: 0;
		width: auto;
	}
	#philosophy .comLinkList li a::before {
		right: 1.7rem;
	}
}
#philosophy .circleBox .subBox svg .bg {
	fill: #000;
	transition: .3s;
}
#philosophy .circleBox .subBox svg .txt {
	fill: #fff;
	transition: .3s;
}
@media all and (min-width: 897px) {
	#philosophy .circleBox .subBox svg g {
		cursor: pointer;
	}
	#philosophy .circleBox .subBox svg g.active .bg,
	#philosophy .circleBox .subBox svg g:hover .bg {
		fill: #fff;
	}
	#philosophy .circleBox .subBox svg g.active .txt,
	#philosophy .circleBox .subBox svg g:hover .txt {
		fill: #000;
	}
}
#main .wpcf7-list-item {
	margin-left: 0;
}
.comTableBox .chooseUl li:not(:last-child) .wpcf7-not-valid-tip {
	display: none;
}

/* ====================================
// SNS Link Section Styles
==================================== */

/* 1. お問い合わせリストの下に大きな余白を追加 (上部余白の確保) */
#gFooter .fBox .comMenuList.style01 {
    margin-bottom: 30px !important; 
}

/* 2. SNSセクション全体のスタイルと余白調整を一つにまとめる */
#gFooter .fBox .snsBox {
    /* 余白の調整 */
    margin-top: 50px !important;    
    margin-bottom: 10px !important; 
    
    /* 既存のスタイル */
    padding: 20px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
}

#gFooter .fBox .snsBox .snsCatch {
    /* 全体誘導文（キャッチコピー）のスタイル */
    text-align: center;
    margin-bottom: 10px !important;
    font-size: 1.8rem; /* ★文字サイズ維持★ */
    font-weight: bold;
    color: #fff;
    line-height: 1.6;
}

#gFooter .fBox .snsBox .snsLinkUl {
    /* アイコン全体を中央寄せで横並びに配置 */
    display: flex;
    justify-content: center;
    gap: 30px;
    list-style: none;
    padding: 0;
}

#gFooter .fBox .snsBox .snsLinkUl li {
    text-align: center;
    width: 120px;
}

/* ★★★ アイコンサイズを大きくするコードです ★★★ */
#gFooter .fBox .snsBox .snsLinkUl li a img {
    /* アイコンのサイズを100pxに設定し、強制適用 */
    width: 60px !important;  
    height: 60px !important; 
    display: block;
    margin: 0 auto 8px;
    transition: opacity 0.3s;
}

#gFooter .fBox .snsBox .snsLinkUl li a:hover img {
    opacity: 0.7;
}

#gFooter .fBox .snsBox .snsLinkUl li .snsText {
    /* 各SNSの誘導文の文字サイズ */
    display: block;
    font-size: 1.0rem; /* ★文字サイズ維持★ */
    color: rgba(255, 255, 255, 0.8);
}

/* ------------------------------------------------------------------ */
/* +Plus One シリーズ - 画像ホバー時の「光る」効果 (最終修正版) */
/* ------------------------------------------------------------------ */

/* 固定ページ ID #plusone 内の、全ての製品画像 (ul.photoList 内の img) の初期設定 */
/* セレクタの詳細度を上げて、他の競合するスタイルを確実に上書きします */
#plusone .photoList .photo img {
    /* 変化を滑らかにするための設定 (全ての変化を0.4秒かけて行う) */
    /* widthやheightなど他のプロパティが邪魔をしないよう 'all' を指定 */
    transition: all 0.4s ease-in-out;
    
    /* 通常時の明るさ（100%） */
    filter: brightness(100%);
    
    /* わずかに縮小させておく */
    transform: scale(1.0); 
    
    /* 画像の表示方法をブロック要素に指定 (レイアウトが崩れにくい) */
    display: block;
}

/* マウスオーバー (hover) した際のスタイル */
/* リンク (a) にホバーした際に、中の画像 (img) を変化させる */
#plusone .photoList .photo a:hover img {
    /* 明るくして光る効果（25%明るくします） */
    filter: brightness(125%);
    
    /* わずかに拡大して立体感を出す */
    transform: scale(1.05); 
    
    cursor: pointer;
}