@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mainVisual {
	margin-bottom: 0.8rem;
}
#main .mainVisual img {
	width: 100%;
}
#main .mainVisual {
  position: relative;
}
#main .textImg {
	max-width: none;
	position: absolute;
	bottom: -15.2%;
	left: -12.03%;
	z-index: 10;
	width: 120%; 
}
#main .banerBox {
	margin: 0 0.7rem 4.3rem 0.8rem;
	padding: 0.7rem 2.2rem 1.4rem 2.7rem;
	text-align: center;
	background: #fff;
	border-radius: 0.4rem;
	box-shadow: 0 0.3rem 0.4rem rgba(127, 127, 127, 0.5), 0 -0.1rem 0.3rem rgba(127, 127, 127, 0.2), -0.3rem -0.1rem 0.3rem rgba(127, 127, 127, 0.2);
}
#main .banerBox p {
	margin-bottom: 0.6rem;
	padding-bottom: 0.5rem;
	color: #003960;
	font-size: 0.95rem;
	font-weight: 700;
	border-bottom: 0.1rem solid #003960;
}
#main .banerBox .bnrList {
	margin-right: -0.4rem;
}
#main .banerBox .bnrList li {
	width: 33.33%;
}
#main .banerBox .bnrList li img {
	width: auto;
	max-height: 2.2rem;
}
#main .concerns {
	margin-bottom: 3.1rem;
}
#main .concerns .headLine01 {
	font-weight: 700;
	letter-spacing: 0.2em;
}
#main .concerns .innerBox {
	margin-bottom: 1.8rem;
	padding: 3.8rem 3.7rem 5.3rem;
	background: #D7F1FF;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 2.4rem), 50% 100%, 0 calc(100% - 2.4rem));
}
* #main .concerns .imgList li:nth-child(-n+2){
	margin-bottom: 3.0rem;
}
#main .btnBox {
	margin: 0 3rem;
	text-align: center;
}
#main .btnBox .lead {
	margin: 0 -1rem 2.2rem;
	color: #1F4A87;
	font-size: 1.4rem;
	line-height: 1.64;
	letter-spacing: 0.05em;
}
#main .btnBox .lead strong {
	font-weight: 800;
}
#main .btnBox .lead .underline {
	padding: 0 0.5rem;
	display: inline-block;
	position: relative;
	font-size: 1.8rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	background: linear-gradient(rgba(246, 237, 74, 0.62), rgba(246, 237, 74, 0.62)) no-repeat left bottom 10% / 100% 1rem;
}
#main .btnBox .lead .underline::after {
	width: 2.5rem;
	position: absolute;
	right: -2rem;
	top: -1.5rem;
	background: url(../img/index/icon01.png) no-repeat center center / 100%;
	aspect-ratio: 1;
	content: '';
}
#main .btnBox .btn {
	margin-bottom: 1rem;
}

#main .btnBox .btn a {
	display: inline-block;
}
#main .btnBox .tel a {
	display: inline-block;
}
#main .about .headLine01 {
	padding: 1.3rem 1rem 1.1rem;
}
#main .about .bgBox01 {
	padding: 0.9rem 2.9rem 3.4rem 2.8rem;
	background: url(../img/index/bg01.png) repeat center center / 2.8rem;
}
#main .about .text01 {
	margin-bottom: 1.7rem;
	text-align: center;
	color: #002D4C;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
	letter-spacing: 0.09em;
	line-height: 2.1;
}
#main .about .text01 strong {
	color: #1F4A87;
	font-weight: 900;
}
#main .about .text01 .highlight {
	padding-bottom: 0.1rem;
	font-weight: 900;
	background: #FFFF80;
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
}
#main .about .img01 {
	margin-bottom: 5rem;
	position: relative;
}
#main .about .img01 img {
	width: 100%;
}
#main .about .img01::after {
	margin-left: 0.6rem;
	width: 4.4rem;
	height: 2.5rem;
	position: absolute;
	left: 50%;
	bottom: -3.8rem;
	transform: translateX(-50%);
	background: url(../img/index/icon02.png) no-repeat center center / 100%;
	content: '';
}
#main .about .merit {
	position: relative;
}
#main .about .merit::after {
	margin-left: 0.6rem;
	width: 4.4rem;
	height: 2.5rem;
	position: absolute;
	left: 50%;
	bottom: -3.8rem;
	transform: translateX(-50%);
	background: url(../img/index/icon02.png) no-repeat center center / 100%;
	content: '';
}
#main .about .merit .heading {
	margin-bottom: 1.2rem;
	padding: 0.2rem;
	text-align: center;
	color: #fff;
	font-weight: 600;
	font-size: 1.845rem;
	letter-spacing: 0.2em;
	border-radius: 3rem;
	background: #F47F5B;
}
#main .about .meritList {
	padding: 1rem 0.7rem 1.7rem 1.5rem;
	background: #EBF8FF;
	border-radius: 0.5rem;
}
#main .about .meritList li:not(:last-child){
	margin-bottom: 1.8rem;
}
#main .target {
	padding: 1.7rem 1.5rem 11rem;
	background: url(../img/index/bg03.png) repeat center center / 10.1rem;
}
#main .target .heading {
	margin: 0 auto 1.9rem;
	padding-bottom: 0.9rem;
	width: fit-content;
	text-align: center;
	font-size: 1.3rem;
	font-weight: 700;
	font-family: "Noto Sans JP", sans-serif;
	letter-spacing: 0.1em;
	border-bottom: 0.1rem solid #1D4781;
}
#main .target .heading span {
	margin: 0.1rem auto 0;
	padding: 0.2rem 0.8rem;
	width: fit-content;
	display: block;
	font-weight: 900;
	color: #fff;
	letter-spacing: 0.05em;
	background: #F47F5B;
	border-radius: 5rem;
}
#main .target .imgList {
	padding: 1.6rem 1.1rem 1.6rem 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.3rem 0;
	position: relative;
	background: #fff;
	border-radius: 0.9rem;
	border: 0.1rem solid #CEE2F4;
}
#main .target .imgList::after {
	margin-left: 0.6rem;
	width: 4.4rem;
	height: 2.5rem;
	position: absolute;
	left: 50%;
	bottom: -4rem;
	transform: translateX(-50%);
	background: url(../img/index/icon07.png) no-repeat center center / 100%;
	content: '';
}
#main .about .btnBox {
	margin-top: -6.1rem;
}
#main .about .btnBox .lead {
	margin-bottom: 2.5rem;
}
#main .about .btnBox .lead .underline::after {
	top: -4rem;
	right: -2.5rem;
}
#main .about {
	margin-bottom: 2.5rem;
}
#main .problems {
	margin-bottom: 3.5rem;
}
#main .problems .headLine01 {
	padding: 1.8rem 1rem 1.6rem;
	font-size: 1.3rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 1.78;
	background: #304D70;
}
#main .problems .innerBox {
	margin-bottom: 0.7rem;
	padding: 4.3rem 2.9rem 8.1rem;
	background: #EAEAEA;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 4.8rem), 50% 100%, 0 calc(100% - 4.8rem));
}
#main .problems .textBox {
	position: relative;
}
#main .problems .textBox::before {
	content: '';
	background: url(../img/index/bg04.png) no-repeat left top / 100%;
	width: 2.5rem;
	height: 2.6rem;
	position: absolute;
	left: -1.5rem;
	top: -1.2rem;
}
#main .problems .textBox::after {
	content: '';
	background: url(../img/index/bg05.png) no-repeat left top / 100%;
	width: 3.4rem;
	height: 2.7rem;
	position: absolute;
	right: -2.6rem;
	top: -1.3rem;
}
#main .problems .textList {
	padding: 0.6rem 0.5rem 1rem 1.5rem;
	background: #fff;
	border-radius: 0.6rem;
}
#main .problems .textList::before {
	content: '';
	background: url(../img/index/bg06.png) no-repeat left top / 100%;
	width: 1.6rem;
	height: 2.9rem;
	position: absolute;
	left: -1.5rem;
	bottom: -0.5rem;
}
#main .problems .textList::after {
	content: '';
	background: url(../img/index/bg07.png) no-repeat left top / 100%;
	width: 2.8rem;
	height: 2.7rem;
	position: absolute;
	right: -2.7rem;
	bottom: -0.7rem;
}
#main .problems .textList li {
	padding: 1.6rem 0 1.1rem 1.9rem;
	position: relative;
	color: #043D82;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	line-height: 1.47;
	border-bottom: 0.1rem dashed rgba(4, 61, 130, 0.17);
}
#main .problems .textList li:last-child {
	border-bottom: none;
}
#main .problems .textList li::before {
	content: '';
	width: 1.4rem;
	position: absolute;
	left: -0.1rem;
	top: 1.9rem;
	aspect-ratio: 1;
	background: url(../img/index/icon03.png) no-repeat left top / 1.4rem;
}
#main .problems .textList li .highlight {
	font-weight: 800;
	background: rgba(51, 158, 196, 0.21);
}
#main .problems .btnBox {
	margin: 0 1rem;
}
#main .problems .btnBox .lead {
	margin-bottom: 0;
	line-height: 1.71;
}
#main .problems .btnBox .lead .sml {
	font-size: 1.2rem;
}
#main .problems .btnBox .lead .underline {
	font-size: 1.9rem;
	background-position: left bottom 40%;
}
#main .problems .btnBox .lead .underline::after {
	top: -3.5rem;
	right: -3.5rem;
	transform: rotate(7deg);
}
#main .inheritance .heading {
	padding: 0.4rem;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.2rem;
	text-align: center;
	color: #fff;
	font-size: 2rem;
	font-weight: bold;
	letter-spacing: 0.16em;
	background: #304D70;
}
#main .inheritance .heading img {
	width: 4.8rem;
	flex-shrink: 0;
}
#main .inheritance .heading .txt {
	margin-top: 0.5rem;
	display: block;
}
#main .inheritance .innerBox {
	padding: 3rem 4.2rem 2.7rem;
	background: #EBF8FF;
}
#main .inheritance .textList {
	display: flex;
	flex-direction: column;
	gap: 2.4rem 0;
}
#main .inheritance .text01 {
	padding: 1.6rem 1rem 1.2rem;
	text-align: center;
	font-size: 1.2rem;
	color: #1F4A87;
	line-height: 1.7;
	letter-spacing: 0.07em;
	background: #CDEBF9;
}
#main .inheritance .text01 strong {
	font-weight: 800;
}
#main .inheritance .text01 .highlight {
	background: #F9EE30;
	font-weight: 600;
}
#main .inheritance {
	margin-bottom: 3rem;
}
#main .btmBox .textBox {
	margin: 0 2.5rem 3.5rem;
	padding: 0.4rem 1rem 0;
	text-align: center;
	border-radius: 1.1rem;
	border: 0.1rem solid #1F4A87;
}
#main .btmBox .textBox p {
	margin-bottom: 0.7rem;
	color: #1F4A87;
	font-size: 1.2rem;
	line-height: 1.75;
	letter-spacing: 0.07em;
}
#main .btmBox .textBox p .highlight {
	padding: 0.3rem 1rem 0.2rem 2.6rem;
	color: #fff;
	font-weight: 700;
	background: #1F4A87;
	border-radius: 4rem;
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
}
#main .btmBox .textBox .img img {
	width: 18.3rem;
}
#main .btmBox .btnBox .lead {
	margin: 0 -1.5rem 0.5rem;
	padding-bottom: 3.8rem;
	line-height: 1.56;
	background: url(../img/index/bg08.png) no-repeat center bottom / 23.8rem;
}
#main .btmBox .btnBox .lead .sml {
	font-size: 1.2rem;
	position: relative;
	display: inline-block;
}
#main .btmBox .btnBox .lead .sml::after {
	content: '';
	width: 2.5rem;
	height: 2.5rem;
	position: absolute;
	right: -2.3rem;
	top: -1.5rem;
	transform: rotate(7deg);
	background: url(../img/index/icon01.png) no-repeat center center / 100%;
}
#main .btmBox .btnBox .lead strong {
	font-size: 1.9rem;
	font-weight: 800;
}
#main .btmBox .btnBox .lead .underline {
	padding: 0;
	font-size: 1.9rem;
	font-weight: 800;
	background-position: left bottom 0.4rem;
}
#main .btmBox .btnBox .lead .underline::after {
	display: none;
}
#main {
	margin-bottom: 8.4rem;
}

@media (max-width: 896px) and (min-width: 751px) {
  #main .btnBox .btn img {
    width: 630px; 
  }
}

@media (min-width: 897px) {

	#gHeader h1{
		padding-top: 8.0rem;
	}

	#gHeader h1 .txt01 {
	padding: 0.4rem 0.5rem;
	width: 30rem;
	font-size: 3.0rem;
}
	#gHeader h1 .txt02 {
	padding: 1.5rem 1rem 2.5rem;
	font-weight: 700;
	font-size: 4.3rem;
}

#main .banerBox p {
	margin: 0.5rem auto 1.5rem;
	padding-bottom: 1.0rem;
	font-size: 2.3rem;
}
#main .banerBox .bnrList li {
	margin: 1.0rem auto 3.0rem;
}

#main .banerBox .bnrList li img {
	max-height: 4.3em;
}
#main .concerns .headLine01,#main .about .headLine01 {
	padding: 2.0rem 1rem 2.0rem;
	font-size: 4.0rem;
}
* #main .concerns .imgList li:nth-child(-n+2){
	margin-bottom: 4.0rem;
}
#main .concerns .innerBox {
	padding: 8.0rem 5.0rem 10.3rem;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 5.0rem), 50% 100%, 0 calc(100% - 5.0rem));
}
#main .btnBox .lead {
	margin: 3.0rem -1rem 4.5rem;
	font-size: 3.0rem;
}
#main .btnBox .lead .underline {
	font-size: 4.3rem;
	background: linear-gradient(rgba(246, 237, 74, 0.62), rgba(246, 237, 74, 0.62)) no-repeat left bottom 10% / 100% 2.7rem;
}
#main .btnBox .lead .underline::after {
	width: 5.0rem;
	right: -3.5rem;
	top: -2.5rem;
}

#main .btnBox .btn img{
	width: 85%;
}

#main .about .text01 {
	margin: 3.0rem 0 4.0rem 0;
	font-size: 3.0rem;
}
#main .about .img01::after,#main .about .merit::after,#main .target .imgList::after {
	width: 10.0rem;
	height: 5.6rem;
	bottom: -9.0rem;
}
#main .about .merit .heading {
	margin: 12.0rem 0 3.0rem 0;
	padding: 1.3rem;
	font-size: 4.0rem;
	border-radius: 5.0rem;
}
#main .about .meritList {
	padding: 2rem 1.4rem 3.4rem 3.0rem;
	border-radius: 0.5rem;
}
#main .about .meritList li:not(:last-child){
	margin-bottom: 3.5rem;
}
#main .target .heading {
	margin: 7.0rem auto 3.0rem;
	padding-bottom: 3.0rem;
	font-size: 3.0rem;
	font-weight: 700;
	border-bottom: 0.3rem solid #1D4781;
}
#main .target .imgList {
	padding: 3.2rem 2.2rem 3.2rem 3.0rem;
	margin-bottom: 3.0rem;
}
#main .target .imgList li:not(:last-child) {
	margin-bottom: 0.5rem;
}
#main .about .btnBox .lead .underline::after {
	width: 5.0rem;
	top: -8rem;
	right: -3.5rem;
}
#main .problems .headLine01 {
	padding: 3.6rem 2rem 3.2rem;
	font-size: 3.0rem;
	font-weight: 500;
}

#main .problems .innerBox {
	margin-bottom: 0.7rem;
	padding: 8.3rem 6.0rem 16.1rem;
	clip-path: polygon(0 0,100% 0,100% calc(100% - 8rem),50% 100%,0 calc(100% - 8rem));
}

#main .problems .textList li::before {
	width: 3.0rem;
	top: 4.2rem;
	background: url(../img/index/icon03.png) no-repeat left top / 100%;
}

#main .problems .textBox::before {
	width: 6.0rem;
	height: 6.2rem;
	left: -3.0rem;
	top: -4.2rem;
}
#main .problems .textBox::after {
	width: 6.8rem;
	height: 6.4rem;
	position: absolute;
	right: -5.6rem;
	top: -4.0rem;
}
#main .problems .textList li {
	padding: 3.5rem 0 3.2rem 3.8rem;
	font-size: 3.0rem;
}
#main .problems .textList::before {
	width: 4.3rem;
	height: 7.8rem;
	left: -4.0rem;
	bottom: -4.0rem;
}
#main .problems .textList::after {
	width: 6.4rem;
	height: 6.4rem;
	position: absolute;
	right: -5.0rem;
	bottom: -3.2rem;
}

#main .problems .btnBox .lead .sml {
	font-size: 2.8rem;
}
#main .problems .btnBox .lead .underline {
	font-size: 4.5rem;
}
#main .problems .btnBox .lead .underline::after {
	top: -7.0rem;
	right: -7.0rem;
}

#main .inheritance .heading img {
	width: 10.0rem;
}
#main .inheritance .heading .txt {
	margin-left: 1.0rem;
	font-size: 4.5rem;
}
#main .inheritance .textList {
	display: flex;
	flex-direction: column;
	gap: 5.0rem 0;
	margin: 2.0rem auto;
}
#main .inheritance .innerBox {
	gap: 5.0rem 0;
	padding: 2.0rem 5.0rem;
}

#main .inheritance .text01 {
	padding: 3.2rem 2rem 2.4rem;
	font-size: 3.0rem;
}
#main .btmBox .textBox {
	margin: 5.0rem 5.0rem 7.0rem;
	padding: 2rem 3rem 0;
	border-radius: 3.0rem;
	border: 0.2rem solid #1F4A87;
}
#main .btmBox .textBox p {
	font-size: 3.0rem;
}

#main .btmBox .textBox .img img {
	width: 40.0rem;
}

#main .btmBox .btnBox .lead {
	padding-bottom: 8rem;
	background: url(../img/index/bg08.png) no-repeat center bottom / 50.8rem;
}
#main .btmBox .btnBox .lead .sml {
	font-size: 2.7rem;
}
#main .btmBox .btnBox .lead .sml::after {
	content: '';
	width: 5.5rem;
	height: 5.5rem;
	position: absolute;
	right: -4.3rem;
	top: -3.0rem;
}
#main .btmBox .btnBox .lead strong {
	font-size: 4.5rem;
}
#main .btmBox .btnBox .lead .underline {
	font-size: 4.5rem;
}

}


