@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mainVisual {
	margin: -0.1rem 0 10.2rem auto;
	width: calc(50% + 60rem);
	position: relative;
}
#main .mainVisual .fvImg {
	position: relative;
	overflow: hidden;
	border-radius: 2.2rem 0 0 2.2rem;
}
#main .mainVisual .fvImg::before {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: url(../img/index/fv_bg.png) no-repeat center center / cover;
	content: '';
	z-index: 1;
}
#main .mainVisual .fvImg img {
	width: 100%;
	transform: scale(1);
	transition: transform 5s linear;
}
#main .mainVisual .fvImg.active img {
	transform: scale(1.2);
}
#main .mainVisual .textBox {
	display: flex;
	gap: 1.2rem;
	flex-direction: row-reverse;
	align-items: flex-end;
	position: absolute;
	left: 5rem;
	bottom: 2rem;
	z-index: 3;
}
#main .mainVisual .textBox p {
	font-feature-settings: "palt";
	font-weight: 700;
	text-align: left;
	writing-mode: vertical-rl;
	white-space: nowrap;
	letter-spacing: 0.085em;
	line-height: 2;
}
#main .mainVisual .textBox .text01 {
	font-size: 4rem;
}
#main .mainVisual .textBox .text02 {
	margin-bottom: 0.5rem;
	font-size: 2.8rem;
	letter-spacing: 0.14em;
}
#main .information {
	padding-bottom: 2.9rem;
	position: relative;
}
#main .information::after {
	margin-top: -0.1rem;
	width: 100%;
	height: 12.5rem;
	position: absolute;
	left: 0;
	top: 100%;
	background: url(../img/index/bg01.png) no-repeat center top / 100% 100%;
	content: '';
}
#main .information .content {
	position: relative;
	z-index: 1;
}
#main .information .headLine01 {
	margin-bottom: 7rem;
	text-align: right;
}
#main .information .comInfoList {
	margin-bottom: 9rem;
}
#main .information .comInfoList li {
	position: relative;
}
#main .information .comInfoList li::after {
	width: auto;
	height: 100%;
	position: absolute;
	right: -3.6rem;
	top: 0;
	border-left: 0.2rem dotted #98C8AD;
	content: '';
}
#main .information .comInfoList li:nth-child(3n)::after {
	display: none;
}
#main .bgBox {
	padding: 0.1rem 0 24.5rem;
	background: #F4F8FB;
}
#main .about {
	margin-bottom: 18.9rem;
	display: flex;
	position: relative;
	z-index: 1;
}
#main .about .photoBox {
	margin-top: -6.7rem;
	width: calc(50% - 25rem);
	text-align: right;
	order: 1;
}
#main .about .photoBox img {
	width: 43.2rem;
}
#main .about .textBox {
	margin-top: 20rem;
	flex: 1;
}
#main .about .textBox .innerBox {
	max-width: 77rem;
	margin-left: auto;
}
#main .about .textBox .headLine01 {
	margin-bottom: 9.8rem;
	text-align: left;
	position: relative;
}
#main .about .textBox .headLine01::after {
	width: 17.5rem;
	height: 0.1rem;
	position: absolute;
	left: 0;
	bottom: -5.1rem;
	background: #92B9DA;
	content: '';
}
#main .about .textBox .headLine01 .en {
	color: #92B9DA;
	letter-spacing: 0.2em;
}
#main .about .textBox p {
	font-weight: 500;
	font-size: 2.4rem;
	letter-spacing: 0.075em;
	line-height: 2.4167;
}
#main .strength {
	display: flex;
	justify-content: space-between;
}
#main .strength .photoBox {
	margin-top: 1.9rem;
	width: calc(50% - 20rem);
}
#main .strength .photoBox img {
	width: 46.3rem;
}
#main .strength .textBox {
	width: calc(50% + 10rem);
}
#main .strength .textBox .innerBox {
	max-width: 61.9rem;
}
#main .strength .textBox h2 {
	margin-bottom: 5.6rem;
	display: flex;
	gap: 3.5rem;
}
#main .strength .textBox h2 .icon {
	width: 6.6rem;
}
#main .strength .textBox h2 .txt {
	margin-top: 0.2rem;
	flex: 1;
	font-size: 4rem;
	letter-spacing: 0.36em;
}
#main .strength .textBox .strList {
	margin-bottom: 3.2rem;
}
#main .strength .textBox .strList li {
	margin-bottom: 3.6rem;
	padding-bottom: 4rem;
	border-bottom: 0.3rem dotted #92B9DA;
}
#main .strength .textBox .strList li:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}
#main .strength .textBox .strList li h3 {
	margin-bottom: 1.2rem;
	font-size: 2.8rem;
	font-weight: 500;
	color: #5B99C1;
	letter-spacing: 0.1em;
	line-height: 1.9;
}
#main .strength .textBox .strList li h3 .txtBg {
	margin-right: 1rem;
	padding: 0 1rem 0.2rem;
	color: #fff;
	background: linear-gradient(90deg, rgba(91, 153, 193, 1) 0%, rgba(152, 200, 173, 1) 100%);
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
}
#main .strength .textBox .strList li p {
	text-align: justify;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 2;
}
#main .strength .textBox .comBtn.blank {
	justify-content: flex-start;
}
#main .services {
	padding: 0.1rem 0 32.2rem;
	position: relative;
	background: url(../img/index/services_bg.png) no-repeat center bottom / 100% auto;
}
#main .services::before {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: linear-gradient(180deg, rgba(255, 255, 255, 1) 0.06%, rgba(138, 226, 241, 1) 100%);
	opacity: 0.7;
	content: '';
	mix-blend-mode: multiply;
}
#main .services .leadImg {
	margin: -7.4rem 0 10rem auto;
	width: calc(50% + 9.9rem);
	position: relative;
	z-index: 1;
}
#main .services .leadImg img {
	width: 100%;
	border-radius: 3.7rem 0 0 4rem;
}
#main .services .content {
	position: relative;
	z-index: 1;
}
#main .services .headLine01 {
	margin: -21rem 0.7rem 13.3rem;
	text-align: left;
}
#main .services .headLine01 .en {
	margin-bottom: 3rem;
	color: #92B9DA;
}
#main .services .imgList {
	gap: 8.6rem 3.2rem;
}
#main .services .imgList li {
	padding: 3.9rem 4rem 2.5rem;
	width: calc((100% - 6.4rem) / 3);
	position: relative;
	background: #fff;
	border: 0.1rem solid #92B9DA;
	border-radius: 2.5rem;
	box-shadow: 0.7rem 0.7rem 0.7rem rgba(77, 115, 160, 0.15);
}
#main .services .imgList li .num {
	color: #92B9DA;
	font-size: 3.8rem;
	font-weight: 700;
	position: absolute;
	left: 4.2rem;
	top: 2.9rem;
}
#main .services .imgList li .photo {
	margin: 0 0.1rem 2.2rem 0.2rem;
	border-radius: 1.4rem;
	mask: url(../img/index/mask_bg01.png) no-repeat left top / 8rem 8rem, linear-gradient(#000, #000) no-repeat left top 8rem / 100% calc(100% - 8rem), linear-gradient(#000, #000) no-repeat left 8rem top / calc(100% - 8rem) 100%;
}
#main .services .imgList li .photo img {
	width: 100%;
}
#main .services .imgList li .ttl {
	text-align: center;
	color: #92B9DA;
	font-size: 2.4rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	line-height: 1.75;
	font-feature-settings: "palt";
	margin: 0 -2rem 1.8rem;
}
#main .services .imgList li .text {
	font-size: 1.8rem;
	font-weight: 500;
	text-align: justify;
	line-height: 1.944;
}
#main .company {
	padding-top: 0.1rem;
	position: relative;
	background: #98C8AD;
	z-index: 1;
}
#main .company .content {
	margin-top: -16.3rem;
	padding-bottom: 12.4rem;
	width: 120rem;
	background: #fff;
	border-radius: 10.8rem 10.8rem 0 0;
	overflow: hidden;
}
#main .company .leadImg {
	margin-bottom: 9.8rem;
	padding: 0.5rem;
}
#main .company .leadImg img {
	width: 100%;
	border-radius: 10.4rem 10.4rem 0 0;
}
#main .company .headLine01 {
	margin-bottom: 9.1rem;
}
#main .company .headLine01 .en {
	margin-bottom: 3.2rem;
}
#main .company .innerBox {
	margin: 0 auto;
	max-width: 100rem;
}
#main .company .tblBox {
	margin: 0 3rem 8.7rem;
	display: flex;
	justify-content: space-between;
}
#main .company .tblBox .col {
	width: 47.5%;
}
#main .company .tblBox table {
	width: 100%;
	border-collapse: collapse;
}
#main .company .tblBox th,
#main .company .tblBox td {
	padding: 2.1rem 0;
	vertical-align: middle;
	text-align: left;
	font-size: 1.8rem;
	line-height: 2;
	font-weight: 500;
	letter-spacing: 0.1em;
	box-sizing: border-box;
	border-top: 0.1rem solid #98C8AD;
	border-bottom: 0.1rem solid #98C8AD;
}
#main .company .tblBox th {
	text-align: center;
	color: #6DAF95;
	width: 22%;
}
#main .company .tblBox td {
	padding-left: 2.2rem;
}
#main .company .tblBox .col01 th {
	width: 32%;
}
#main .company .subBox01 {
	margin-bottom: 11rem;
}
#main .company .subBox01 .headLine01 {
	margin-bottom: 3.9rem;
}
#main .company .comBtn.blank a {
	width: 40rem;
}
#main .company .subBox02 {
	margin-bottom: 13rem;
}
#main .company .subBox02 .headLine01 {
	margin-bottom: 6.5rem;
}
#main .company .subBox02 .bnrList {
	margin: 0 4.2rem 7.6rem 0;
	gap: 13.6rem;
}
#main .company .subBox02 .bnrList li a {
	width: fit-content;
	display: block;
}
#main .company .subBox02 .bnrList li a img {
	width: auto;
	max-height: 8.1rem;
}
#main .company .subBox01 .comBtn.blank a {
	color: #92B9DA;
	border-color: #92B9DA;
	background-image: url(../img/common/icon21.png);
}
#main .company .subBox02 .comBtn.blank a {
	padding-left: 4.5rem;
	color: #E68B37;
	border-color: #E68B37;
	background-image: url(../img/common/icon15.png);
}
#main .company .map {
	height: 41rem;
	position: relative;
	border-radius: 3rem;
	overflow: hidden;
	clip-path: inset(0 0 0 0);
	background: #F8F7F7;
}
#main .company .map iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}
@media all and (min-width: 897px) {
	#main .company .subBox01 .comBtn.blank a:hover {
		color: #fff;
		background-color: #C8DCED;
		border-color: #C8DCED;
	}
	#main .company .subBox02 .comBtn.blank a:hover {
		color: #fff;
		background-color: #F2C59B;
		border-color: #F2C59B;
	}
}
@media all and (max-width: 896px) {
	#main .mainVisual {
		margin: 0 0 11.3rem 1.9rem;
		width: auto;
	}
	#main .mainVisual .fvImg {
		border-radius: 0 0 0 3.4rem;
	}
	#main .mainVisual .fvImg::before {
		background-image: url(../img/index/fv_bg_sp.png);
	}
	#main .mainVisual .textBox {
		display: block;
		position: absolute;
		left: 3rem;
		bottom: 2.6rem;
	}
	#main .mainVisual .textBox p {
		writing-mode: horizontal-tb;
		letter-spacing: 0.2em;
	}
	#main .mainVisual .textBox .text01 {
		margin-bottom: 0.3rem;
		font-size: 2.3rem;
	}
	#main .mainVisual .textBox .text02 {
		margin-bottom: 0;
		font-size: 1.7rem;
		line-height: 1.78;
		letter-spacing: 0.2em;
	}
	#main .information {
		padding-bottom: 5.5rem;
	}
	#main .information::after {
		height: 3.5rem;
		background-image: url(../img/index/bg01_sp.png);
	}
	#main .information .headLine01 {
		margin-bottom: 5.7rem;
		text-align: center;
	}
	#main .information .comInfoList {
		margin-bottom: 5.3rem;
	}
	#main .information .comInfoList li::after {
		display: none;
	}
	#main .information .comInfoList li:nth-child(n+2) {
		display: none;
	}
	#main .information .comInfoList li .photo {
		margin-bottom: 3.6rem;
	}
	#main .information .comInfoList li .cata {
		margin-bottom: 1.5rem;
	}
	#main .bgBox {
		padding-bottom: 9.3rem;
	}
	#main .about {
		margin-bottom: 5.3rem;
		display: block;
	}
	#main .about .photoBox {
		margin: -0.4rem 0 4.9rem;
		width: 100%;
	}
	#main .about .photoBox img {
		width: 100%;
	}
	#main .about .textBox {
		margin: 0 2rem;
	}
	#main .about .textBox .innerBox {
		max-width: initial;
		margin-left: 0;
	}
	#main .about .textBox .headLine01 {
		margin-bottom: 5.4rem;
		text-align: center;
	}
	#main .about .textBox .headLine01::after {
		width: 8.8rem;
		left: 50%;
		bottom: -2.4rem;
		transform: translateX(-50%);
	}
	#main .about .textBox .headLine01 .en {
		margin-bottom: 1.8rem;
	}
	#main .about .textBox p {
		margin-bottom: 2.7rem;
		font-size: 1.4rem;
		text-align: center;
		line-height: 2.321;
		letter-spacing: 0.05em;
	}
	#main .about .textBox p:last-child {
		margin-bottom: 0;
	}
	#main .strength {
		display: block;
	}
	#main .strength .photoBox {
		margin: 0 0 8rem;
		width: 100%;
	}
	#main .strength .photoBox img {
		width: 100%;
	}
	#main .strength .textBox {
		margin: 0 3.2rem;
		width: auto;
	}
	#main .strength .textBox .innerBox {
		max-width: initial;
	}
	#main .strength .textBox h2 {
		margin-bottom: 4.5rem;
		gap: 1.4rem;
		align-items: center;
		justify-content: center;
	}
	#main .strength .textBox h2 .icon {
		margin-left: 0.5rem;
		width: 4.5rem;
		flex-shrink: 0;
	}
	#main .strength .textBox h2 .txt {
		margin-top: 0.2rem;
		font-size: 2.2rem;
		flex: initial;
	}
	#main .strength .textBox .strList {
		margin-bottom: 5.2rem;
	}
	#main .strength .textBox .strList li {
		margin-bottom: 6rem;
		padding-bottom: 5.5rem;
		border-width: 0.1rem;
	}
	#main .strength .textBox .strList li:last-child {
		margin-bottom: 0;
		padding-bottom: 0;
	}
	#main .strength .textBox .strList li .photo {
		margin: 0 0 3.6rem 0.1rem;
	}
	#main .strength .textBox .strList li .photo img {
		width: 100%;
		border-radius: 1rem;
	}
	#main .strength .textBox .strList li h3 {
		margin-bottom: 2.7rem;
		text-align: center;
		font-size: 1.7rem;
		letter-spacing: 0.05em;
		line-height: 2.1;
	}
	#main .strength .textBox .strList li h3 .txtBg {
		margin-right: 0.5rem;
		padding: 0 0.8rem 0.1rem;
	}
	#main .strength .textBox .strList li p {
		font-size: 1.4rem;
	}
	#main .strength .textBox .comBtn.blank {
		justify-content: center;
	}
	#main .services {
		padding: 0 0 10.4rem;
		background-image: url(../img/index/services_bg_sp.png);
	}
	#main .services .leadImg {
		margin: 0 0 5.4rem;
		width: 100%;
	}
	#main .services .leadImg img {
		width: 100%;
		border-radius: 0;
	}
	#main .services .content {
		margin: 0 3.2rem;
	}
	#main .services .headLine01 {
		margin: 0 0 5.6rem;
		text-align: center;
	}
	#main .services .headLine01 .en {
		margin-bottom: 1.8rem;
	}
	#main .services .imgList {
		gap: 6rem 0;
	}
	#main .services .imgList li {
		padding: 3.5rem 3.6rem 3.4rem;
		width: 100%;
		border-radius: 2.1rem;
	}
	#main .services .imgList li .num {
		font-size: 3.4rem;
		left: 3.8rem;
		top: 2.5rem;
	}
	#main .services .imgList li .photo {
		margin: 0 0.1rem 2rem 0.2rem;
		mask: url(../img/index/mask_bg01_sp.png) no-repeat left top / 7rem 7rem, linear-gradient(#000, #000) no-repeat left top 7rem / 100% calc(100% - 7rem), linear-gradient(#000, #000) no-repeat left 7rem top / calc(100% - 7rem) 100%;
	}
	#main .services .imgList li .ttl {
		font-size: 2.1rem;
		line-height: 1.73;
		margin: 0 -2rem 1.3rem;
	}
	#main .services .imgList li .text {
		font-size: 1.4rem;
		line-height: 2;
	}
	#main .company {
		padding-top: 0;
	}
	#main .company .content {
		margin: 0 1.8rem;
		padding-bottom: 7.5rem;
		width: auto;
		border-radius: 0;
		overflow: visible;
	}
	#main .company .leadImg {
		margin: 0 -1.8rem 3.3rem;
		padding: 0;
	}
	#main .company .leadImg img {
		border-radius: 0;
	}
	#main .company .headLine01 {
		margin-bottom: 4.6rem;
	}
	#main .company .headLine01 .en {
		margin-bottom: 1.3rem;
	}
	#main .company .innerBox {
		margin: 0 2.5rem;
		max-width: initial;
	}
	#main .company .tblBox {
		margin: 0 0 6.4rem;
		display: block;
		border-top: 0.1rem solid #98C8AD;
	}
	#main .company .tblBox .col {
		width: auto;
	}
	#main .company .tblBox th,
	#main .company .tblBox td {
		padding: 1.2rem 0;
		font-size: 1.4rem;
		line-height: 1.714;
		border-top: none;
	}
	#main .company .tblBox th {
		padding-right: 0.8rem;
		width: 31.5%;
		line-height: 1.68;
	}
	#main .company .tblBox td {
		padding-left: 0;
	}
	#main .company .tblBox .col01 th {
		width: 32%;
	}
	#main .company .pho {
		margin: 0 1.9rem 6.2rem 2rem;
	}
	#main .company .pho img {
		width: 100%;
		border-radius: 0.8rem;
	}
	#main .company .subBox01 {
		margin-bottom: 5.9rem;
	}
	#main .company .subBox01 .headLine01 {
		margin-bottom: 2.5rem;
		font-size: 1.4rem;
	}
	#main .company .comBtn.blank a {
		width: 26rem;
	}
	#main .company .subBox02 {
		margin-bottom: 9.2rem;
	}
	#main .company .subBox02 .headLine01 {
		margin-bottom: 3.2rem;
		font-size: 1.4rem;
	}
	#main .company .subBox02 .bnrList {
		margin: 0 0 4.3rem;
		gap: 4.5rem 0;
		flex-direction: column;
		align-items: center;
	}
	#main .company .subBox02 .bnrList li a img {
		max-height: 5.05rem;
	}
	#main .company .subBox02 .comBtn.blank a {
		padding-left: 4rem;
	}
	#main .company .map {
		width: 100%;
		height: auto;
		border-radius: 0.5rem;
		aspect-ratio: 580/370;
	}
}