@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
body {
	background: #FDF9EA;
}
#main .sec01 {
	padding: 8.0rem 0;
}
#about .sec01 {
	min-height: 100rem;
}
#main .sec01 .content {
	max-width: 118rem;
}
#main .aboutBox {
	margin-bottom: 8.7rem;
	padding: 1.6rem 3rem 2rem;
	align-items: center;
	border-radius: 1.5rem;
	align-items: center;
	background: linear-gradient(0deg, #FDF9EA 0%, #FDF9EA 100%), #FDF9EA;
	background-blend-mode: multiply, normal;
}
#main .aboutBox h2 {
	margin: 0;
	font-size: 1.5rem;
	color: #3E3A39;
	font-weight: 700;
	letter-spacing: -0.06rem; 
}
#main .aboutBox .en {
	margin-top: -0.2rem;
	line-height: 1;
	font-size: 3.6rem;
	color: #fff;
	font-weight: 900;
	letter-spacing: 0;
}
#main .sec01 .imgBox {
	align-items: center;
}
#main .sec01 .imgBox h3 {
	width: 36.4rem;
	margin: 6rem 10.6rem 0 3.4rem;
	font-size: 2.8rem;
	line-height: 1.8;
	font-weight: 700;
	color: #F4AE2A; 
	height: 30.2rem;
	display: flex;
	padding: 0 0 3.5rem 2rem;
	align-items: center;
	justify-content: center;
	letter-spacing: 0;
	background: url(../img/about/bg01.png) no-repeat center;
	background-size: 100% 100%;
	box-sizing: border-box;
}
#main .sec01 .imgBox h3 > span {
	display: inline-block;
}
#main .sec01 .imgBox h3 .txtSpan {
	display: block;
	font-size: 3.2rem;
}
#main .sec01 .imgBox .textBox {
	flex: 1;
}
#main .sec01 .imgBox p {
	margin-bottom: 3.2rem;
	color: #3E3A39;
	line-height: 2;
	font-weight: 500;
	letter-spacing: 0;
	font-size: 1.6rem;
}
#main .sec01 .imgBox p:last-child {
	margin-bottom: 0;
}
#main .sec02 {
	margin-top: -16.9rem;
	position: relative;
	background-color: #fff;
	padding-bottom: 12.8rem;
}
#main .sec02 .content {
	max-width: 108rem;
}
#main .sec02::before {
	width: 100%;  
	height: 21rem;
	background: url(../img/about/bg02.png) no-repeat right top;
	background-size: 100% 100%;
	position: absolute;  
	top: -20rem;
	left: 0;  
	content: ""; 
	z-index: 1;
}
#main .sec02 h2 {
	color: #666666;
	position: relative;
	top: -1rem;
	z-index: 1;
	font-size: 3.2rem;
	font-weight: 700;
	margin-bottom: 5.7rem;
	letter-spacing: 0;
}
#main .sec02 .imgBox {
	max-width: 82rem;
	margin: 0 auto 9.4rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
	z-index: 1;
}
#main .sec02 .imgBox:last-child {
	margin-bottom: 0;
}
#main .sec02 .imgBox .photoBox {
	width: 34.5rem;
	text-align: center;
	margin: 3.1rem -0.5rem 0 4rem;
}
#main .sec02 .imgBox .textBox {
	padding: 3.7rem 0 0 0;
	flex: 1;
}
#main .sec02 .imgBox .textBox h3 {
	margin: 0 0.6rem 3.6rem;
}
#main .sec02 .imgBox::before {
	width: 40.5rem;  
	height: 31.6rem;
	background: url(../img/about/bg12.png) no-repeat;
	background-size: 100% auto;
	position: absolute;  
	top: -1.5rem;
	left: -16rem;  
	content: ""; 
	z-index: -1;
}
#main .sec02 .imgBox::before {
	width: 48.3rem;  
	height: 43.6rem;
	background: url(../img/about/bg03_new.png) no-repeat;
	background-size: 100% auto;
	position: absolute;  
	top: -3.1rem;
	left: -18.8rem;  
	content: ""; 
	z-index: -1;
}
#main .sec02 .imgBox p {
	color: #666666;
	line-height: 1.6;
	letter-spacing: -0.02rem;
}
#main .sec02 .imgBox02 .photoBox {
	margin: 5.6rem -2.1rem 0 5rem;
}
#main .sec02 .imgBox02::before {
	width: 46.1rem;  
	height: 41.6rem;
	background: url(../img/about/bg04_new.png) no-repeat;
	background-size: 100% auto;
	position: absolute;  
	top: -8rem;
	right: 5.3rem;  
	left: auto;
	content: ""; 
	z-index: -1;
}
#main .sec03 {
	padding: 4.1rem 0 14rem;
	position: relative;
	background-color: #fff;
}
#main .sec03:after {
	width: 100%;  
	height: 28rem;
	background: url(../img/common/f_bg03.png) no-repeat;
	background-size: 100% 100%;
	position: absolute;  
	bottom: -28rem;
	left: 0;  
	content: ""; 
	z-index: -1;
}
#main .sec03 .content {
	position: relative;
	z-index: 1;
	max-width: 81rem;
	margin-top: -8rem;
}
#main .sec03 .headLine01 {
	margin: 0 -0.5rem -0rem;
}
#main .valueUl {
	margin: 0 -2.4rem;
	display: flex;
	flex-wrap: wrap;
}
#main .valueUl li {
	width: 23.4rem;
	margin: 0 6.5rem 0.4rem 0;
	text-align: center;
}
#main .valueUl li:nth-child(3n) {
	margin-right: 0;
}
#main .valueUl li .textImg {
	min-height: 20.6rem;
	margin-bottom: -0.9rem;
	display: flex;
	align-items: center;
	justify-content: center;
}
#main .valueUl li p {
	color: #666666;
	margin: 0 1rem;
	font-size: 1.8rem;
	line-height: 1.55;
}

@media all and (max-width: 896px) {
	.content {
		padding: 0 2rem;
	}
	#main .sec01 {
		min-height: inherit;
		padding: 6.4rem 0 26.3rem;
	}
	#main .aboutBox {
		margin-bottom: 10rem;
		padding: 1.2rem 2rem;
	}
	#main .aboutBox h2 {
		font-size: 1.5rem;
		letter-spacing: -0.06rem; 
	}
	#main .aboutBox .en {
		font-size: 2.4rem;
		letter-spacing: 0;
	}
	#main .sec01 .imgBox {
		display: block;
	}
	#main .sec01 .imgBox h3 {
		padding: 0 0 2.3rem 2rem;
		margin: 0 auto 5.3rem;
		width: 22rem;
		height: 18.2rem;
		line-height: 1.7;
		font-size: 2rem;
		background-image: url(../img/about/bg01_sp.png);
	}
	#main .sec01 .imgBox h3 .txtSpan {
		font-size: 2.4rem;
	}
	#main .sec01 .imgBox p {
		font-size: 1.5rem;
		line-height: 2.13;
	}
	#main .sec02::before {
		height: 24.1rem; 
		width: 100%;
		left: 0;
		top: -10rem;
		background-image: url(../img/about/bg02_sp.png);
	}
	#main .sec02 {
		padding: 0.8rem 0 2rem;
		margin-top: -9.3rem;
	}
	#main .sec02 h2 {
		margin: 0 0 6.5rem;
		font-size: 2.4rem;
	}
	#main .sec02 .imgBox {
		max-width: inherit;
		display: block;
		margin-bottom: 3.2rem;
	}
	#main .sec02 .imgBox .photoBox {
		width: auto;
		width: 54%;
		margin: 0 0 0 auto;
	}
	#main .sec02 .imgBox .textBox {
		padding: 0;
		margin-bottom: -3.8rem;
	}
	#main .sec02 .imgBox p {
		line-height: 1.75;
		font-size: 1.6rem;
		letter-spacing: 0.032rem;
	}
	#main .sec02 .imgBox .textBox h3 {
		margin: 0 0.3rem 1.7rem;
	}
	#main .sec02 .imgBox .textBox h3 img {
		width: 21.0rem;
	}
	#main .sec02 .imgBox::before {
		width: 19.8rem;
		height: 21.2rem;
		left: -2rem;
		top: -0rem;
		right: auto;
		background-image: url(../img/about/bg03_sp_new.png);
		background-size: 100% 100%;
	}
	#main .sec02 .imgBox02 .textBox h3 img {
		width: 17.2rem;
	}
	#main .sec03 .content {
		margin-top: 0;
	}
	#main .sec02 .imgBox .photoBox img {
		width: 100%;
	}
	#main .sec02 .imgBox02 .photoBox {
		width: auto;
		margin: 0 1.2rem;
	}
	#main .sec02 .imgBox02 .textBox {
		margin-bottom: 1.3rem;
	}
	#main .sec02 .imgBox02::before { 
		top: 0.5rem;
		right: 7rem;
		left: auto;
		width: 16rem;
		height: 12.5rem;
		background-image: url(../img/about/bg04_sp_new.png);
	}
	#main .sec02::after { 
		height: 37.33vw;
		bottom: -17.6vw; 
		width: calc(100% + 17rem);
		left: -8.6rem;
		background-image: url(../img/index/bg09_sp.png);
	}
	#main .sec03 {
		padding: 2.5rem 0 6.8rem;
	}
	#main .sec03 .headLine01 {
		margin: 0 0 0rem;
	}
	#main .sec03 .headLine01 img {
		width: 14.4rem;
	}
	#main .valueUl {
		margin: 0 -1rem;
		justify-content: space-between;
	}
	#main .valueUl li {
		width: 49.7%;
		margin: 0 0 1.2rem;
	}
	#main .valueUl li .textImg {
		margin-bottom: -0.7rem;
		min-height: 15rem;
	}
	#main .valueUl li p {
		margin: 0;
		font-size: 1.4rem;
		line-height: 1.43;
	}
	#main .sec03::after { 
		bottom: -32.2rem;
		height: 32.3rem;
		background-image: url(../img/common/f_bg03_sp.png);
	}
}

/* @media all and (max-width: 374px) {
	#main .valueUl li p {
		font-size: 1.3rem;
	}
} */



/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#service {
	background: #FFF4F6;
}
#service .aboutBox {
	margin-bottom: 0;
	background: linear-gradient(0deg, #FFF4F5 0%, #FFF4F5 100%), #FFF4F5;
}
#service .circulation {
	margin-bottom: 26.7rem;
}
#service .circulation .content {
	max-width: 116rem;
}
#service .circulation .imgBox {
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
	justify-content: space-between;
}
#service .circulation .imgBox .lBox {
	width: 50rem;
	margin: -2.2rem 0 0 0;
	aspect-ratio: 1000 / 994;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background: url(../img/service/photo01.png) no-repeat center;
	background-size: 100% auto;
}
#service .circulation .imgBox h2 {
	color: #E2485C;
	font-size: 3.2rem;
	font-weight: 700;
	line-height: 175%;
	text-align: center;
}
#service .circulation .imgBox .rBox {
	flex: 1;
	padding-top: 0.2rem;
}
#service .circulation .imgBox .rBox p {
	margin-bottom: 2.8rem;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 175%; 
}
#service .circulation .imgBox .rBox p:last-child {
	margin-bottom: 0;
}
#service .txt {
	margin-bottom: 6.6rem;
	font-size: 1.6rem;
	color: #3E3A39;
	text-align: center;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0;
}
#service .sec04 h3 {
	margin-bottom: 3rem;
}
#service .sec04 .content {
	max-width: 118rem;
}
#service .planBox {
	margin: 0 5rem;
	align-items: center;
	border-radius: 1.5rem;
	padding: 3rem 11rem;
	background-color: #fff; 
}
#service .planBox .title {
	margin-right: 8rem;
}
#service .planBox .textBox {
	flex: 1;
}
#service .planBox p {
	font-size: 1.5rem;
	margin-bottom: 2rem;
	font-weight: 500;
	line-height: 2;
	color: #3E3A39;
	letter-spacing: 0;
}
#service .planBox .ttl {
	margin-bottom: 1rem;
	font-size: 2rem;
	font-weight: 700;
	line-height: 2;
}
#service .planBox .comLink05 a {
	box-sizing: border-box;
	letter-spacing: 0;
	background-image: url(../img/common/icon13.png);
	border: 2px solid #3E3A39;
}
#service .sec04 {
	padding-bottom: 24.2rem;
}
#service .sec05 {
	padding-top: 5rem;
	padding-bottom: 25rem;
	position: relative;
	background-color: #fff;
}
#service .sec05 .inner {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
}
#service .sec05 .inner .photoBox {
	width: 50.7rem;
	margin-right: 7.7rem;
	margin-left: -0.2rem;
}
#service .sec05 .inner .rBox {
	padding-top: 3.5rem;
	flex: 1;
	overflow: hidden;
}
#service .sec05 .inner .rBox .foo {
	width: 100%;
}
#service .sec05 .inner .ttlBox {
	position: relative;
	margin-bottom: 1.8rem;
	display: flex;
	justify-content: space-between;
}
#service .sec05 .inner .ttlBox .prev,
#service .sec05 .inner .ttlBox .next {
	position: relative;
	z-index: 1;
}
#service .sec05 .inner .ttlBox .dots {
	position: absolute;
	top: 50%;
	width: 100%;
	transform: translateY(-50%);
}
#service .sec05 .inner .ttlBox .dot {
	text-align: center;
	display: flex;
	justify-content: center;
	gap: 1rem;
}
#service .sec05 .inner .ttlBox .subDot {
	cursor: pointer;
	display: block;
	width: 1.2rem;
	height: 1.2rem;
	border-radius: 100%;
	background-color: #D9D9D9;
}
#service .sec05 .inner .ttlBox li:nth-of-type(1) .subDot {
	--color: #3F8F82;
}
#service .sec05 .inner .ttlBox li:nth-of-type(2) .subDot {
	--color: #F4AE2A;
}
#service .sec05 .inner .ttlBox li:nth-of-type(3) .subDot {
	--color: #E2485C;
}
#service .sec05 .inner .ttlBox li:nth-of-type(4) .subDot {
	--color: #E88355;
}
#service .sec05 .inner .ttlBox li.slick-active .subDot {
	background-color: var(--color);
}
#service .sec05 .inner .ttlBox .prev a {
	display: inline-block;
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0.032rem;
	padding: 0.5rem 0 0.5rem 4rem;
	background: url(../img/service/prev.png) no-repeat left center;
	background-size: 3rem auto;
}
#service .sec05 .inner .ttlBox .next a {
	display: inline-block;
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0.032rem;
	padding: 0.5rem 4rem 0.5rem 0;
	background: url(../img/service/next.png) no-repeat right center;
	background-size: 3rem auto;
}
#service .sec05 .inner .ttlBox .next a strong,
#service .sec05 .inner .ttlBox .prev a strong {
	font-weight: 500;
}
#service .sec05 .innerBox {
	box-sizing: border-box;
	border-radius: 2rem;
	padding: 2.1rem 3rem 3rem;
	background: #ECF5F2;
}
#service .sec05 .innerBox02 {
	background-color: #FFFBEF;
}
#service .sec05 .innerBox03 {
	background-color: #FFF4F6;
}
#service .sec05 .innerBox04 {
	background-color: #FFF3E2;
}
#service .sec05 .innerBox h3 {
	margin-bottom: 0.5rem;
	color: #3F8F82;
	text-align: center;
	font-size: 3.4rem;
	font-weight: 400;
	letter-spacing: 0.068rem;
}
#service .sec05 .innerBox02 h3 {
	color: #F4AE2A;
}
#service .sec05 .innerBox03 h3 {
	color: #E2485C;
}
#service .sec05 .innerBox04 h3 {
	color: #E88355;
}
#service .sec05 .innerBox .centerTxt {
	margin-bottom: 1.5rem;
	color: #666;
	/* display: flex;
	align-items: center;
	justify-content: center;
	min-height: 6rem; */
	box-sizing: border-box;
	text-align: center;
	font-size: 2rem;
	font-weight: 500;
	line-height: 150%; 
	letter-spacing: 0.04rem;
}
#service .sec05 .innerBox h4 {
	margin-bottom: 1rem;
	color: #E2E2E2;
	font-size: 1.8rem;
	font-weight: 900;
	line-height: 100%; 
	letter-spacing: 0.036rem;
	overflow: hidden;
}
#service .sec05 .innerBox h4 span {
	display: inline-block;
	padding-right: 0.5rem;
	position: relative;
}
#service .sec05 .innerBox h4 span:after {
	width: 9999px;  
	height: 1px;
	background-color: #E2E2E2;
	position: absolute;  
	top: 60%;
	transform: translateY(-50%);
	left: 100%;
	content: ""; 
}
#service .sec05 .innerBox .subList {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
}
#service .sec05 .innerBox .subList li {
	height: 100%;
	width: 16rem;
}
#service .sec05 .innerBox .subList a {
	height: 100%;
	display: block;
	border-radius: 1rem;
	background: #FFF;
	box-sizing: border-box;
	padding: 1.4rem 1rem;
}
#service .sec05 .innerBox .subList p {
	color: #666;
	font-size: 1.3rem;
	margin-bottom: 1.5rem;
	font-weight: 500;
	line-height: 130%; 
}
#service .sec05 .innerBox .subList .ttl {
	margin-bottom: 1.5rem;
	color: #3E3A39;
	text-align: center;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 125%; 
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}
#service .sec05 .innerBox .subList .link {
	width: 11rem;
	margin: 0 auto;
}
#service .sec05 .innerBox .subList .link span {
	min-height: 2.8rem;
	border-radius: 100vmax;
	font-size: 1.3rem;
	padding-right: 2.3rem;
	font-weight: 700;
	color: #3E3A39;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	background: #EEEEEE url(../img/service/icon_arrow-right.png) no-repeat right 0.7rem center;
	background-size: 1.8rem auto;
}

#service .sec05:after {
	width: 100%;  
	height: 21rem;
	background: url(../img/service/bg.png) no-repeat;
	background-size: 100% 100%;
	position: absolute;  
	top: -21rem;
	left: 0;  
	content: ""; 
}
#service .sec05 .content {
	max-width: 118rem;
}
#service .sec05 h2 {
	margin-bottom: -0.4rem;
	text-align: left;
	position: relative;
	z-index: 2;
	top: -1rem;
}
#main .serviceList {
	margin: 0 2.0rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
#main .serviceList li {
	padding: 3rem;
	margin: 0 1.5rem 5rem;
	width: calc(33.33% - 3rem);
	border-radius: 1.5rem;
	box-sizing: border-box;
	background: #F5F5F5; 
}
#main .serviceList li h3 {
	margin-bottom: 2rem;
	text-align: center;
	font-size: 1.8rem;
	color: #3E3A39;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0;
}
#main .serviceList li .img {
	margin-bottom: 2rem;
	text-align: center;
}
#main .serviceList li p {
	font-size: 1.5rem;
	font-weight: 500;
	color: #3E3A39;
	line-height: 2;
	letter-spacing: 0;
}

#gFooter::after {
	display: block !important;
	height: 28rem;
	top: -28rem;
	z-index: -1;
	background-image: url(../img/common/f_bg03.png);
}
.popBox {
	margin: 0 auto;
	max-width: 84rem;
	padding: 5rem 5rem 0;
	box-sizing: border-box;
	border-radius: 4rem 3rem 3rem 3rem;
	background: #FFF;	
	position: relative;
}
.popBox .close {
	cursor: pointer;
	position: absolute;
	top: -4rem;
	right: 0.5rem;
	width: 3.2rem;
	z-index: 10;
}
.popBox p {
	margin-bottom: 2.8rem;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 175%; 
}
.popBox .ttl {
	margin-bottom: 3.5rem;
	font-size: 4rem;
	font-weight: 700;
	line-height: 150%; 
	letter-spacing: 0.08rem;
}
.popBox .ttl small {
	margin-bottom: -1.2rem;
	margin-top: 0.5rem;
	display: block;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.048rem;
}
.popBox .ttl02 {
	margin-bottom: 0.8rem;
	align-items: center;
	display: flex;
	color: #666;
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.036rem;
}
.popBox .ttl02 small {
	margin: 0 0 -0.5rem 1rem;
	font-size: 1.4rem;
	font-weight: 900;
	letter-spacing: 0.028rem;
}
.popBox .list {
	margin: 0 0 2.8rem 1rem;
}
.popBox .list li {
	padding-left: 1.3rem;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 200%; 
	position: relative;
}
.popBox .list li::before {
	width: 0.3rem;  
	height: 0.3rem;
	border-radius: 100%;
	background-color: currentColor;
	position: absolute;  
	top: 1.4rem;
	left: 0;
	content: ""; 
}
.popInner {
	padding-bottom: 3.4rem;
	position: relative;
}
.popInner .subList {
	justify-content: flex-end;
	width: 21rem;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	position: absolute;
	top: 0;
	right: 0;
}
.popInner .subList li {
	width: 10rem;
	border-radius: 1rem;
	background: #A6C5AF;
	color: #FFF;
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
	padding: 0.6rem 0.5rem;
	box-sizing: border-box;
	letter-spacing: 0.04rem;
}
.popInner .subList .item02 {
	background-color: #EDC669;
}
.popInner .subList .item03 {
	background-color: #EDC669;
}
.popInner .subList .item04 {
	background-color: #E7808D;
}
.popInner .subList .item05 {
	background-color: #E88355;
}
.popInner .flowList {
	margin-top: -1.5rem;
}
.popInner .flowList dl {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	justify-content: space-between;
}
.popInner .flowList dt {
	padding: 1.4rem 2rem 1.4rem 0;
	box-sizing: border-box;
	width: 17rem;
	text-align: right;
	font-size: 1.6rem;
	font-weight: 700;
}
.popInner .flowList dd {
	padding: 1.4rem 0 1.4rem 2rem;
	flex: 1;
	font-size: 1.4rem;
	font-weight: 500;
	position: relative;
}
.popInner .flowList dd::before {
	width: 1px;  
	background-color: #E0E0E0;
	position: absolute;  
	top: 2.5rem;
	bottom: -3rem;
	left: 0;
	content: ""; 
}
.popInner .flowList li:last-child dd::before {
	display: none;
}
.popInner .flowList dd:after {
	width: 1rem;  
	height: 1rem;
	background-color: #E0E0E0;
	position: absolute;  
	top: 50%;
	transform: translateY(-50%);
	left: -0.45rem;
	border-radius: 100%;
	content: ""; 
}
.popBoxSub {
	margin: 0 -5rem;
	padding: 1.5rem 3rem 3rem;
	border-radius: 0 0 3rem 3rem;
	background: #E0E0E0;
}
.popBoxSub .ttl03 {
	margin-bottom: 2rem;
	color: #FFF;
	font-size: 2.4rem;
	line-height: 1;
	font-weight: 900;
	letter-spacing: 0.048rem;
}
.popBox .popList {
	padding: 0 1rem;
	display: flex;
	flex-wrap: wrap;
	gap: 2rem 3.5rem;
}
.popBox .popList li {
	width: calc((100% - (3.5rem * 2 + 0.1rem)) / 3);
}
.popBox .popList a {
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 99.9rem;
	background: #3E3A39 url(../img/service/icon02.png) no-repeat right 1rem center;
	background-size: 2.2rem auto;
	color: #FFF;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 500;
	min-height: 4.4rem;
	padding-right: 3rem;
	padding-left: 1rem;
}
.popBox .popList a:hover {
	opacity: 0.7;
}
.popBox .popList .on a {
	background-color: #EEE;
	pointer-events: none;
	background-image: url(../img/service/icon01.png);
}
.mfp-container {
	padding: 80px 20px;
	overflow-y: auto;
	position: fixed;
}
.mfp-fade.mfp-bg {
	opacity: 0;
	-webkit-transition: all 0.5s ease-out;
	transition: all 0.5s ease-out;
}
.mfp-fade.mfp-bg.mfp-ready {
	opacity: 0.3;
	background: #808080;
}
.mfp-fade.mfp-bg.mfp-removing {
	opacity: 0;
}
.mfp-fade.mfp-wrap .mfp-content {
	opacity: 0;
	-webkit-transition: all 0.5s ease-out;
	transition: all 0.5s ease-out;
}
.mfp-fade.mfp-wrap.mfp-ready .mfp-content {
	opacity: 1;
}
.mfp-fade.mfp-wrap.mfp-removing .mfp-content {
	opacity: 0;
}

@media all and (min-width: 897px) {
	.popBox .close:hover {
		opacity: 0.7;
	}
	.popBox .ttlStyle {
		margin-bottom: 7rem;
	}
	#service .sec05 .inner .ttlBox .prev.color3 a:hover {
		color: #E88355;
		background-image: url(../img/service/prev2.png);
	}
	#service .sec05 .inner .ttlBox .prev.color0 a:hover {
		color: #3F8F82;
		background-image: url(../img/service/prev3.png);
	}
	#service .sec05 .inner .ttlBox .prev.color1 a:hover {
		color: #F4AE2A;
		background-image: url(../img/service/prev4.png);
	}
	#service .sec05 .inner .ttlBox .prev.color2 a:hover {
		color: #E2485C;
		background-image: url(../img/service/prev5.png);
	}
	#service .sec05 .inner .ttlBox .next.color1 a:hover {
		color: #F4AE2A;
		background-image: url(../img/service/next2.png);
	}
	#service .sec05 .inner .ttlBox .next.color2 a:hover {
		color: #E2485C;
		background-image: url(../img/service/next3.png);
	}
	#service .sec05 .inner .ttlBox .next.color3 a:hover {
		color: #E88355;
		background-image: url(../img/service/next4.png);
	}
	#service .sec05 .inner .ttlBox .next.color0 a:hover {
		color: #3F8F82;
		background-image: url(../img/service/next5.png);
	}
	#service .sec05 .innerBox .subList a:hover .link span {
		background-color: #3E3A39;
		color: #fff;
		background-image: url(../img/service/icon_arrow-right-white.png);
	}
}

@media all and (max-width: 896px) {
	#service .aboutBox {
		padding: 1rem 2rem 1.1rem;
	}
	#service .sec01 {
		padding-bottom: 5rem;
	}
	#service h2 {
		font-size: 2rem;
		letter-spacing: 0;
		line-height: 1.75;
		font-weight: 700;
	}
	#service .txt {
		margin: 0 1.5rem 8rem;
		text-align: left;
		font-size: 1.5rem;
		line-height: 2;
	}
	#service .sec04 h3 {
		margin-bottom: 2rem;
		text-align: center;
	}
	#service .sec04 h3 img {
		width: 29.6rem;
	}
	#service .planBox {
		margin: 0 1.5rem;
		padding: 2.8rem 2.5rem 3rem;
		display: block;
	}
	#service .planBox .title {
		margin: 0 0 3.1rem;
		text-align: center;
	}
	#service .planBox p {
		font-size: 1.4rem;
		margin-bottom: 2rem;
	}
	#service .planBox .ttl {
		text-align: center;
		font-size: 1.6rem;
		font-weight: 700;
		letter-spacing: -0.016rem;
	}
	#service .planBox .comLink05 {
		max-width: 25.5rem;
	}
	#service .planBox .comLink05 a {
		font-size: 1.5rem;
		background-position: right 0.8rem center;
	}
	#service .sec04 {
		padding-bottom: 15.8rem;
	}
	#service .sec05::after {
		height: 24.1rem;
		top: -10rem;
		background-image: url(../img/service/bg_sp.png);
	}
	#service .sec05 h2 {
		margin: 0 0 1.8rem;
		top: auto;
	}
	#service .sec05 h2 img {
		width: 14.2rem;
	}
	#service .sec05 .content {
		position: relative;
		padding: 0 2rem;
		z-index: 1;
	}
	#service .sec05 .inner {
		display: block;
	}
	#service .sec05 .inner .photoBox {
		width: auto;
		margin: 0 -1.3rem 1rem;
	}
	#service .sec05 .inner .photoBox img {
		width: 100%;
	}
	#main .serviceList {
		display: block;
		margin: 0;
	}
	#main .serviceList li {
		width: auto;
		margin: 0 0 3rem;
	}
	#main .serviceList li:last-child {
		margin-bottom: 0;
	}
	#main .serviceList li .img img {
		width: 6.3rem;
	}
	#main .serviceList li .img {
		margin-bottom: 1.5rem;
	}
	#main .serviceList li h3 {
		margin-bottom: 1.6rem;
		letter-spacing: 0;
		font-size: 1.7rem;
	}
	#service .sec05 {
		padding-top: 1rem;
		padding-bottom: 7.8rem;
	}
	#gFooter::after {
		height: 32.3rem;
		top: -32rem;
		background-image: url(../img/common/f_bg03_sp.png);
	}
	.popBox {
		padding: 2.3rem 2.3rem 0;
		border-radius: 2rem;
	}
	.popInner .subList {
		margin-bottom: 3.6rem;
		position: static;
		width: auto;
		justify-content: center;
		gap: 1rem 1.5rem;
	}
	.popInner .subList li {
		width: calc(12rem * 1.25);
		border-radius: calc(1rem * 1.25);
	}
	.popBox p {
		margin-bottom: 3.5rem;
		font-size: calc(1.5rem * 1.27);
		font-weight: 500;
		line-height: 150%; 
	}
	.popBox .ttl {
		margin-inline: -5px;
		margin-bottom: 3rem;
		text-align: center;
		font-size: calc(2.9rem * 1.25);
		font-weight: 700;
		line-height: 125%; 
		letter-spacing: 0.058rem;
	}
	.popBox .ttl02 {
		margin-bottom: 2rem;
		font-size: calc(1.8rem * 1.27);
		font-weight: 700;
		letter-spacing: 0.036rem;
	}
	.popBox .ttl02 small {
		font-size: calc(1.4rem * 1.27);
		font-weight: 900;
		letter-spacing: 0.028rem;
		margin-left: 1.5rem;
	}
	.popBox .list li {
		margin-bottom: 0.5rem;
		font-size: calc(1.4rem * 1.27);
		font-weight: 500;
		line-height: 150%; 
	}
	.popBox .list {
		margin-bottom: 3rem;
	}
	.popInner .flowList dl {
		align-items: flex-start;
	}
	.popInner .flowList dt {
		line-height: 1;
		width: 15.3rem;
		font-size: calc(1.6rem * 1.27);
		font-weight: 700;
		padding-block: 1.1rem 1.9rem;
		display: flex;
		align-items: center;
		justify-content: flex-end;
		min-height: 7rem;
		letter-spacing: 0.032rem;
	}
	.popInner .flowList dd {
		font-size: calc(1.3rem * 1.27);
		font-weight: 500;
		padding-left: 2.5rem;
		padding-block: 1.90rem;
		line-height: 130%; 
		letter-spacing: 0.026rem;
	}
	.popInner .flowList dd::after { 
		transform: translateY(0);
		width: 1.3rem;
		height: 1.3rem;
		top: 2.5rem;
		left: -0.6rem;
	}
	.popInner .flowList dd::before {
		top: 3rem;
		bottom: -3.8rem;
	}
	.popInner .flowList li:last-child dd {
		padding-bottom: 0;
	}
	.popInner {
		padding-bottom: 2.7rem;
	}
	.popBoxSub {
		margin: 0 -2.3rem;
		padding: 1.9rem 2.5rem 4rem;
		border-radius: 0 0 2rem 2rem;
	}
	.popBoxSub .ttl03 {
		margin-bottom: 2.5rem;
		font-size: calc(2rem * 1.27);
		font-weight: 900;
		letter-spacing: 0.04rem;
	}
	.popBox .popList {
		padding: 0;
		gap: 1.3rem 1.7rem;
	}
	.popBox .popList li {
		width: calc((100% - 1.7rem) / 2);
	}
	.popBox .popList a {
		line-height: 1.25;
		min-height: calc(4rem * 1.25);
		font-size: calc(1.3rem * 1.25);
		background-size: 2rem auto;
	}
	.popBox .close {
		width: 4.5rem;
		top: -6rem;
	}
	.popBox .btmClose {
		cursor: pointer;
		position: absolute;
		z-index: 10;
		left: 0;
		width: 100%;
		text-align: center;
		top: calc(100% + 2rem);
	}
	.popBox .btmClose span {
		display: inline-block;
		color: #FFF;
		text-align: center;
		font-size: calc(1.7rem * 1.27);
		font-weight: 700;
		padding-top: 4.2rem;
		background: url(../img/service/close.png) no-repeat center top;
		background-size: 4rem auto;
	}
	#service .aboutBox .en {
		font-size: 1.7rem;
	}
	#service .circulation .imgBox {
		display: block;
	}
	#service .circulation .imgBox .lBox {
		width: auto;
		margin: 0 1.6rem -.4rem;
	}
	#service .circulation .imgBox h2 {
		font-size: 2.5rem;
		font-weight: 700;
		line-height: 1.6;
	}
	#service .circulation .imgBox .rBox p {
		font-size: 1.5rem;
		font-weight: 500;
		line-height: 2.13;
		margin-bottom: 3.2rem;
	}
	#service .circulation {
		margin-bottom: 14rem;
	}
	#service .sec05 .inner .ttlBox .prev a {
		font-size: 1.5rem;
		font-weight: 500;
		line-height: 100%;
		letter-spacing: 0.03rem;
	}
	#service .sec05 .inner .ttlBox .next a {
		font-size: 1.5rem;
		font-weight: 500;
		line-height: 100%;
		letter-spacing: 0.03rem;
	}
	#service .sec05 .inner .ttlBox .next a strong,
	#service .sec05 .inner .ttlBox .prev a strong {
		display: block;
	}
	#service .sec05 .inner .ttlBox {
		margin-bottom: 1.4rem;
	}
	#service .sec05 .innerBox {
		padding: 1.4rem 2rem 3rem;
		border-radius: 3rem;
	}
	#service .sec05 .innerBox h3 {
		margin-bottom:1rem;
		font-size: 2.4rem;
		font-weight: 500;
		letter-spacing: 0.048rem;
	}
	#service .sec05 .innerBox .centerTxt {
		min-height: 5rem;
		font-size: 1.6rem;
		font-weight: 500;
		line-height: 150%; 
	}
	#service .sec05 .innerBox h4 {
		margin-bottom: 1.5rem;
	}
	#service .sec05 .innerBox .subList {
		flex-direction: column;
		gap: 1.6rem;
	}
	#service .sec05 .innerBox .subList li {
		width: 100%;
	}
	#service .sec05 .innerBox .subList a {
		padding: 0.8rem 2rem 1rem;
	}
	#service .sec05 .innerBox .subList .ttl {
		margin-bottom: 1.1rem;
	}
	#service .sec05 .innerBox .subList p {
		margin-bottom: 1.1rem;
	}
	.mfp-container {
		padding-inline: 0;
	}
}

/* @media all and (max-width: 374px) {
	#service h2 {
		font-size: 1.8rem;
	}
	#service .planBox .comLink05 a {
		font-size: 1.3rem;
	}
} */