@charset "utf-8";
/*------------------------------------------------------------
	welfare
------------------------------------------------------------*/
#main {
	padding-bottom: 10rem;
}
#main .topSec {
	padding: 10.1rem 0 17.1rem;
	background-image: url(../img/welfare/top_bg.png);
	background-position: center top 11.4rem;
}
#main .topSec P {
	margin-bottom: 6rem;
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.3rem;
}
#main .topSec .btnList li {
	width: 29.1rem;
	margin: 0 1.2rem;
}
#main .topSec .btnList a {
	display: block;
	padding: 2rem 6.9rem;
	font-size: 2.4rem;
	line-height: 1.4;
	letter-spacing: 0.2rem;
	border-radius: 2rem;
	border: 1px solid #1D3443;
	background: #FFF url(../img/common/icon18.png) no-repeat right 6.8rem center/3.1rem;
}
#main .topSec .btnList .bgColor {
	background-color: #EAF4F3;
}
#main .topSec .btnList a:hover {
	opacity: 0.7;
}
#main .headLine03 {
	font-weight: 500;
	position: relative;
}
#main .headLine03 .sml {
	width: 68.3rem;
	margin-left: 6.2rem;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 0.2rem;
	line-height: 1.8;
}
#main .sec01 {
	margin-bottom: 10.6rem;
	position: relative;
	z-index: 1;
}
#main .sec01 .circle {
	position: absolute;
	left: -16rem;
	top: -18rem;
	width: 50.7rem;
	z-index: -1;
}
#main .sec01 .bgBox {
	margin: 0 2.3rem;
	position: relative;
	padding: 9rem 0 8.7rem;
	background-color: rgba(28, 216, 210, 0.5);
	border-radius: 5rem;
}
#main .sec01 .textList li {
	padding: 2rem 2rem 0.5rem;
	background-color: #fff;
	box-sizing: border-box;
	border-radius: 1rem;
}
#main .sec01 .textList li.bg {
	background-color: #EAF4F3;
}
#main .sec01 .textList .ttl {
	margin-bottom: 1rem;
	padding: 0 1rem 0.5rem;
	font-size: 2rem;
	font-weight: 500;
	letter-spacing: 0.3rem;
	border-bottom: 3px solid #1CD8D2;
}
#main .sec01 .textList p {
	font-size: 1.6rem;
	line-height: 1.5;
	opacity: 0.8;
}
#main .sec02 .bgBox {
	padding: 6.3rem 0 7.5rem;
	background-color: #EAF4F3;
}
#main .sec02 .title {
	max-width: 160.2rem;
	margin: 0 auto 4rem;
	padding: 0.9rem 4.1rem 1rem;
	color: #fff;
	font-size: 4rem;
	font-weight: 700;
	letter-spacing: 0.4rem;
	border-radius: 5rem;
	background-color: #1CD8D2;
	box-sizing: border-box;
}
#main .sec02 .title .en {
	margin: -1.5rem 0 0 2.7rem;
	display: inline-block;
	vertical-align: middle;
	font-weight: 500;
	font-size: 2.4rem;
	letter-spacing: 0.3rem;
}
#main .sec02 .textList + .title {
	margin-top: 10.2rem;
}
#main .sec03 .bgBox {
	margin-top: -1px;
	padding: 12.6rem 0 19rem;
	position: relative;
	background: url(../img/welfare/sec03_bg03.jpg) repeat-x left top/10rem 100%;
	border-radius: 5rem;
}
#main .sec03 .bgBox .content {
	max-width: 132rem;
}
#main .sec03 .info01 {
	width: 64rem;
	margin: 0 auto 17rem;
	color: #fff;
}
#main .sec03 .info01 .title {
	margin-bottom: 3.9rem;
	text-align: center;
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: 0.3rem;
}
#main .sec03 .info01 p {
	line-height: 1.8;
	letter-spacing: 0.2rem;
}
#main .sec03 .info01 .name {
	margin-top: 2.5rem;
	text-align: right;
	font-size: 1.6rem;
}
#main .sec03 .info01 .name span {
	margin-left: 2.2rem;
	display: inline-block;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.3rem;
}
#main .sec03 .info02 {
	margin-bottom: 16rem;
}
#main .sec03 .info02 .lBox {
	padding-top: 6.3rem;
	width: 36rem;
	color: #fff;
	position: relative;
	z-index: 1;
}
#main .sec03 .info02 .lBox:after {
	margin: -2.8rem 0 0 -2rem;
	position: absolute;
	left: 50%;
	top: 50%;
	width: 77.8rem;
	aspect-ratio: 1/1;
	transform: translate(-50%, -50%);
	background: url(../img/welfare/sec03_bg01.png) no-repeat left top/100%;
	z-index: -1;
	content: "";
}
#main .sec03 .info02 .lBox h4 {
	margin-bottom: 2.2rem;
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: 0.3rem;
}
#main .sec03 .info02 .lBox h4 img {
	display: block;
	margin: 0 auto 2.8rem;
	width: 12.5rem;
	transform: translateX(-2rem);
}
#main .sec03 .info02 .lBox p {
	line-height: 1.5;
}
#main .sec03 .info02 .rBox {
	width: 71rem;
}
#main .sec03 .info02 .rBox img {
	width: 100%;
}
#main .sec03 .imgBox {
	margin-bottom: 16.5rem;
	position: relative;
	z-index: 1;
	align-items: flex-start;
}
#main .sec03 .imgBox:after {
	position: absolute;
	left: calc(50% + 31rem);
	top: 2.5rem;
	width: 80.6rem;
	aspect-ratio: 1/1;
	background: url(../img/welfare/sec03_bg02.png) no-repeat left top/100%;
	z-index: -1;
	content: "";
}
#main .sec03 .imgBox h4 {
	margin: 0 0 1.7rem 8.9rem;
}
#main .sec03 .imgBox h4 .sml {
	padding-left: 3.8rem;
	display: block;
	color: #fff;
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: 0.3rem;
	background: url(../img/common/icon17.png) no-repeat left 1.8rem/1.8rem;
	content: "";
}
#main .sec03 .imgBox .en {
	display: inline-block;
	font-size: 4.8rem;
	font-weight: 500;
	letter-spacing: 0.3rem;
	background: linear-gradient(180deg, #51E6DF 0%, #90F2E4 48.56%, #D3FFE9 100%);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
#main .sec03 .imgBox .phoBox {
	width: calc(50% + 1.6rem);
}
#main .sec03 .imgBox .phoBox img {
	width: 100%;
	border-radius: 0 2rem 2rem 0;
}
#main .sec03 .imgBox .txtBox {
	width: 75.3rem;
	position: relative;
	z-index: 1;
}
#main .sec03 .imgBox .txtBox .txt01 {
	margin: 18.3rem 0 5.5rem -10.3rem;
	display: inherit;
	font-size: 3.6rem;
	font-weight: 700;
	line-height: 2.4;
	letter-spacing: 0.3rem;
}
#main .sec03 .imgBox .txtBox .txt01 span {
	padding: 1.3rem 2rem;
	background-color: #fff;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}
#main .sec03 .imgBox .txtBox .infoBox {
	margin: 0 0 7rem 5.5rem;
	min-height: 57.8rem;
	align-items: center;
	padding: 5rem 4.9rem;
	background: url(../img/welfare/info_bg.jpg) repeat-x left top/10rem 100%;
	border-radius: 2rem;
}
#main .sec03 .imgBox .txtBox .infoBox .name {
	width: 18.2rem;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.2rem;
}
#main .sec03 .imgBox .txtBox .infoBox .name .large {
	font-size: 4.8rem;
	letter-spacing: 0.4rem;
}
#main .sec03 .imgBox .txtBox .infoBox .infoList {
	margin-top: 2.4rem;
	flex: 1;
}
#main .sec03 .imgBox .txtBox .infoBox .infoList li {
	padding: 0 0 1rem 5.5rem;
	font-size: 2.4rem;
	letter-spacing: 0.2rem;
	border-left: 1px dotted #1D3443;
}
#main .sec03 .imgBox .txtBox .infoBox .infoList li:nth-child(2) {
	font-size: 1.8rem;
	line-height: 1.8;
}
#main .sec03 .imgBox .txtBox .infoBox .infoList .ttl {
	margin-bottom: 1rem;
	display: block;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.3rem;
}
#main .sec03 .imgBox .txtBox .infoBox .infoList li:not(:last-child) {
	margin-bottom: 4rem;
}
#main .sec03 .imgBox .txtBox .message {
	margin: 0 1.5rem 0 8.5rem;
}
#main .sec03 .imgBox .txtBox .message p {
	margin-bottom: 3.2rem;
	color: #fff;
	line-height: 1.8;
	letter-spacing: 0.2rem;
}
#main .sec03 .imgBox .txtBox .message p:last-child {
	margin-bottom: 0 !important;
}
#main .sec03 .imgBox .txtBox .message .ttl {
	margin-bottom: 0.9rem;
	color: #C8D1D9;
	font-size: 3rem;
	line-height: 1.5;
	letter-spacing: 0.3rem;
}
#main .sec03 .imgBox02 {
	margin-bottom: 22rem;
	flex-direction: row-reverse;
}
#main .sec03 .imgBox02 .phoBox img {
	border-radius: 2rem 0 0 2rem;
}
#main .sec03 .imgBox03 {
	margin-bottom: 0;
}
#main .btmSec {
	margin-top: -5rem;
	padding: 19rem 0;
	background: rgba(234, 244, 243, 0.5);
}
@media all and (min-width: 1670px) {
	#main .sec03 .imgBox02 .phoBox {
		width: calc(50% + 0.4rem);
	}
	#main .sec03 .imgBox02 .txtBox {
		width: 79.7rem;
	}
	#main .sec03 .imgBox02 .txtBox .infoBox {
		margin-right: 10rem;
	}
}
@media all and (min-width: 897px) {
	#main .headLine03 {
		margin: 0 0.2rem 4.2rem;
		display: flex;
	}
	#main .sec01 .textList {
		max-width: 152rem;
		margin: -4.2rem auto 0;
	}
	#main .sec01 .textList li {
		width: 23.09%;
		min-height: 14.8rem;
		margin: 4.2rem 2.54% 0 0;
	}
	#main .sec01 .textList li:nth-child(4n) {
		margin-right: 0;
	}
	#main .sec02 {
		margin-bottom: 12rem;
	}
	#main .sec03 .headLine03 .sml {
		margin-top: 1.8rem;
	}
	#main .sec03 .imgBox .txtBox .infoBox .infoList li:nth-child(2) {
		padding-top: 0.8rem;
	}
	#main .sec03 .imgBox .txtBox .infoBox .infoList li:nth-child(2) .ttl {
		margin-bottom: 2rem;
	}
	#main .sec03 .imgBox03:after {
		top: -3rem;
	}
	#main .sec03 .imgBox03 .txtBox .txt01 {
		margin: 19.3rem 0 5.5rem -13rem;
	}
	#main .sec03 .imgBox02:after {
		right: calc(50% + 42.5rem);
		left: auto;
		top: -7.5rem;
	}
	#main .sec03 .imgBox02 .phoBox h4 {
		margin-right: 15.5rem;
		text-align: right;
	}
	#main .sec03 .imgBox02 .txtBox .txt01 {
		margin: 16.2rem -19.5rem 5.5rem 0;
		text-align: right;
	}
	#main .sec03 .imgBox02 .txtBox .infoBox {
		margin-left: 0;
		margin-right: 5.5rem;
	}
	#main .sec03 .imgBox02 .txtBox .message {
		margin: 0 12rem 0 3rem;
	}
}
@media all and (max-width: 896px) {
	#main .topSec {
		padding: 5rem 0 8rem;
		background-position: center top 5rem;
	}
	#main .topSec P {
		margin-bottom: 3rem;
		font-size: 1.6rem;
	}
	#main .topSec .btnList {
		gap: 1rem;
		justify-content: space-between;
	}
	#main .topSec .btnList li {
		width: calc((100% - 1rem)/2);
		margin: 0;
	}
	#main .topSec .btnList a {
		padding: 1rem 3rem;
		font-size: 1.6rem;
		background-position: right 2rem center;
		background-size: 2.4rem;
	}
	#main .headLine03 .sml {
		width: auto;
		margin-left: 0;
		display: block;
		font-size: 1.4rem;
	}
	#main .sec01 {
		margin-bottom: 6rem;
	}
	#main .sec01 .bgBox {
		margin: 0 1.5rem;
		padding: 4rem 0 !important;
		border-radius: 2rem;
	}
	#main .sec01 .textList {
		display: block;
	}
	#main .sec01 .textList li {
		padding: 2rem;
		margin-bottom: 1rem;
	}
	#main .sec01 .textList li:nth-child(even).bg {
		background-color: #EAF4F3;
	}
	#main .sec01 .textList li:nth-child(odd).bg {
		background-color: #FFFFFF;
	}
	#main .sec01 .textList li:nth-child(even) {
		background-color: #EAF4F3;
	}
	#main .sec02 .textList li {
		background-color: #FFFFFF !important;
	}

	#main .sec01 .textList li:last-child {
		margin-bottom: 0;
	}
	#main .sec01 .textList .ttl {
		padding: 0 0 0.5rem;
		font-size: 1.8rem;
		border-bottom-width: 0.2rem;
	}
	#main .sec01 .textList p {
		font-size: 1.3rem;
	}
	#main .sec02 .title {
		max-width: inherit;
		margin: 0 auto 2rem;
		padding: 0.9rem 2rem 1rem;
		font-size: 2.6rem;
	}
	#main .sec02 .title .en {
		margin: -0.7rem 0 0 1rem;
		font-size: 1.8rem;
		letter-spacing: 0.1rem;
	}
	#main .sec02 .textList + .title {
		margin-top: 4rem;
	}
	#main .sec03 .bgBox {
		padding: 6rem 0 8rem;
		background-size: 5rem 100%;
	}
	#main .sec03 .info01 {
		width: auto;
		margin-bottom: 3rem;
	}
	#main .sec03 .info01 .title {
		margin-bottom: 2.5rem;
		font-size: 2.2rem;
	}
	#main .sec03 .info01 .name {
		font-size: 1.4rem;
	}
	#main .sec03 .info01 .name span {
		font-size: 1.8rem;
	}
	#main .sec03 .info02 {
		margin-bottom: 6rem;
		display: block;
	}
	#main .sec03 .info02 .lBox {
		padding: 2rem 0;
		width: auto;
	}
	#main .sec03 .info02 .lBox:after {
		margin: -1rem 0 0 -1rem;
		width: 50rem;
	}
	#main .sec03 .info02 .lBox h4 {
		margin-bottom: 1.5rem;
		font-size: 2.4rem;
		text-align: center;
	}
	#main .sec03 .info02 .lBox h4 img {
		margin-bottom: 1.5rem;
		transform: translateX(0);
	}
	#main .sec03 .info02 .rBox {
		margin-top: 2rem;
		width: auto;
	}
	#main .sec03 .imgBox {
		margin-bottom: 6rem;
		display: block;
	}
	#main .sec03 .imgBox:after {
		left: calc(50% + 31rem);
		top: 2.5rem;
		width: 40rem;
	}
	#main .sec03 .imgBox h4 {
		margin: 0 0 1.7rem 2rem;
	}
	#main .sec03 .imgBox h4 .sml {
		padding-left: 2rem;
		font-size: 1.6rem;
		background-position: left 0.8rem;
		background-size: 1rem;
	}
	#main .sec03 .imgBox .en {
		font-size: 2.4rem;
	}
	#main .sec03 .imgBox .phoBox {
		width: auto;
	}
	#main .sec03 .imgBox .phoBox img {
		border-radius: 2rem !important;
	}
	#main .sec03 .imgBox .txtBox {
		margin: -2rem 2rem 0;
		width: auto;
	}
	#main .sec03 .imgBox .txtBox .txt01 {
		margin: 0 0 3rem;
		font-size: 2rem;
	}
	#main .sec03 .imgBox .txtBox .txt01 span {
		padding: 0.4rem 1.5rem;
	}
	#main .sec03 .imgBox .txtBox .infoBox {
		margin: 0 0 4rem;
		min-height: inherit;
		padding: 2rem 3rem;
		background-size: 5rem 100%;
	}
	#main .sec03 .imgBox .txtBox .infoBox .sub {
		display: block;
	}
	#main .sec03 .imgBox .txtBox .infoBox .name {
		width: auto;
		font-size: 2rem;
	}
	#main .sec03 .imgBox .txtBox .infoBox .name .large {
		font-size: 3rem;
	}
	#main .sec03 .imgBox .txtBox .infoBox .infoList {
		margin-top: 0.5rem;
	}
	#main .sec03 .imgBox .txtBox .infoBox .infoList li {
		padding: 1.5rem 0;
		font-size: 1.6rem;
		border-left: none;
		border-bottom: 1px dotted #1D3443;
	}
	#main .sec03 .imgBox .txtBox .infoBox .infoList li:nth-child(2) {
		font-size: 1.4rem;
	}
	#main .sec03 .imgBox .txtBox .infoBox .infoList .ttl {
		margin-bottom: 0.5rem;
		font-size: 2rem;
	}
	#main .sec03 .imgBox .txtBox .infoBox .infoList li:not(:last-child) {
		margin-bottom: 0;
	}
	#main .sec03 .imgBox .txtBox .message {
		margin: 0 0.5rem;
	}
	#main .sec03 .imgBox .txtBox .message p {
		margin-bottom: 2rem;
	}
	#main .sec03 .imgBox .txtBox .message .ttl {
		font-size: 2.4rem;
	}
	#main .sec03 .imgBox02 {
		margin-bottom: 6rem;
	}
	#main .btmSec {
		padding: 10rem 2rem 5rem;
	}
}