@charset "utf-8";
/* CSS Document */
	.page_title_wrap + section > div h2:first-of-type{
		margin-top: 3.67em;
	}
	
	
section {
position: relative;
    z-index: 0;
}
	
section > div > :is(p, dl, table, blockquote, div) {
    width: 90.91%;
    /*background: red;  デバッグ用 */
    margin-inline:auto;
}
	
section > div > :is(figure) > img {
}
	
		
section > div p,section .box h4 {
	letter-spacing: 0.05em; 
	/*letter-spacing: 0.075em; */
	text-align: justify; 
	font-family: 'BIZ UDPGothic', sans-serif; 
	font-weight: 700;    
	line-height: 1.875;
}		
section > div p:has(strong) {
}	
section > div p strong {
color:#754C24; font-size: 1.38em; font-weight: 700;
}
	
p:has(strong) + p {
	margin-top: 1em;
}
section:not(.page_title_wrap)::before {
        content: '';
        position: absolute;
        top: -54px;
        left: 50%;
        width: 100vw;
        height: 68px;
        transform: translateX(-50%);
        z-index: -1;
        background-image: radial-gradient(#fffbee 70%, transparent 71%);
        background-size: 68px 68px;
        background-repeat: repeat-x;
        background-position: center top;
    }		
section:not(.page_title_wrap)::after {
        content: '';
        position: absolute;
        bottom: -45px;
        left: 50%;
        width: 100vw;
        height: 68px;
        transform: translateX(-50%);
        z-index: -1;
        background-image: radial-gradient(#fffbee 70%, transparent 71%);
        background-size: 68px 68px;
        background-repeat: repeat-x;
        background-position: center top;
    }
	
		
section:not(.page_title_wrap, #list_refer):nth-of-type(odd) {
background: #fffbee;
}
	section:not(.page_title_wrap, #list_refer):nth-of-type(odd)::before{
        /*top: -30px;*/

		
	}	
	section:not(.page_title_wrap, #list_refer):nth-of-type(odd)::after{
        bottom: -30px;/**/
		
	}	
	section:not(.page_title_wrap, #list_refer):nth-of-type(even)::before{
        content: none;
		
	}	
	section:not(.page_title_wrap, #list_refer):nth-of-type(even)::after{
        content: none;
		
	}	

	
	section > div div.shadow{
		position: relative;
		
	}
	section > div div.shadow::after{
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;

    background-image:
      linear-gradient(
        90deg,
        rgba(95,191,173,1),
        rgba(242,142,30,1)
      );
       opacity: calc(.27 / 1.5);
    filter: blur(calc(4.75em / 6)); /*76*/
	}
	
section > div div.shadow::after{
        filter: blur(calc(4.75em / 4));
        width: calc(100% + 0.63em - 4.75em / 2);
        height: calc(100% + 20%  - 4.75em / 2);
        left: calc(1.625em + 4.75em / 2);
                top: 50%;
        bottom: calc(50% - 4.75em / 2);
        margin: auto;
}	
section#flow .shadow::after{
        opacity: calc(.15 / 1.5);
}	


	
section h3 + *{
margin-top:1.88em;
}

.two_column{
	gap:2em;
	
}



section .two_column a{
	display: block;
	
}
/**/

.btn_line {
	width: 27.63em;
	height: 9.75em;
	
}

.btn_line a{
	background: #39B04A;
	border-radius: 1.25em;
	        display: flex;
        align-items: center;
	text-decoration: none;
	line-height: 1;
        font-family: "Noto Sans JP", sans-serif;
font-weight: 700;
        line-height: 1.37;
	padding: 0.75em;
	
	padding-right: 1.63em;
	gap:2.69em;
}


.btn_line .icon img{
	
	width: 8.43em;
	height: 8.43em;
}

.btn_line .text{
	color: #fff;
	text-decoration: none;
	font-size: 2.06em;
	margin-top: -0.30em;
	
}
.btn_line .text span{display: block;}
.btn_line .text span > span{
	font-size: 1.61em; display: inline-block;         letter-spacing: 0.05em;        margin-right: 0.15em;}

.btn_line .arrow{
	margin-left: auto;
}
.btn_line .arrow img{
	
width: calc(0.45em * 1.5);
        height: calc(0.89em * 1.5);
}

/**/
.flow_line{
	
}
.flow_line h4{
	font-size: 1.25em;
	color: #754C24;
	text-align: center;
}

.flow_line .flow_box > div{
	display: flex;
	        max-width: 56.25em;
        margin-inline: auto;
	        justify-content: space-between;
}

.flow_line .flow_box > div img{
width: 7.84em;
	height: 7.84em;
	
}

.flow_line .flow_box span{
display: block;
}


.flow_content {
	position: relative;
}

.flow_content > div{
display: flex;
	flex-wrap: wrap;
	        gap: 0.43em 1.25em;
	        justify-content: left;
        max-width: 15.31em;
}

.flow_content h5{
color: #E27A13;
	font-size: 1.5em;
	    margin-top: 0.58em;
}

.flow_content + .flow_content::before,.flow_content + .flow_content::after{
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
}


.flow_content + .flow_content::before{
	width: 1px;
	height: 9.68em;
	background: #F28E1E;
	        left: -3.75em;
}


.flow_content + .flow_content::after{
	  background: #F28E1E;
  height:1.11em;
  width: 0.92em;
clip-path: polygon(0 0, 100% 50%, 0 100%);
	        left: -2.88em;
}


.flow_content p{
	line-height: 1.44;
	        letter-spacing: 0.1em;
}


section .sec-inner .box > div {
background: #FFF;
	border: 1px solid #00A498;
	border-radius: 1.25em;
	display: flex;
	align-items: center;
	
	padding: 0.625em 2.5em 0.625em 0em;
	
    box-sizing: border-box;
	min-height: 8.5625em;
	position: relative;
	
    }	


	
section .box > div h4 {
	font-size: 1.5625em;
	color: #0C7268;
	min-width: 7em;
	text-align: center;
	    align-self: stretch; /* 高さを親いっぱい */
    display: flex;
    align-items: center;
    justify-content: center;

    border-right: 1px solid #00A498;
    }	
	

	
	
section .box > div h4 + p{
	padding-left: 1.6875em;
	display: flex;
	
    }


.box + .box{margin-top:3.13em; position: relative;}



.box + .box::before{
	        content: "";
        position: absolute;
        left: 0;
        right: 0;
        margin: auto;
	background: #6BBF97;
        height: 1em;
        width: 2em;
        clip-path: polygon(0 0, 100% 0%, 50% 100%);
        top: -2.13em;
}




/**/

#form_mail > div p:first-of-type{
	text-align: center;
}
.form_content{
	margin-inline:auto;
	        display: flex;
        flex-direction: column;
        gap: 1.56em;
                padding: 0 1.81em;
        margin-top: 2.5em;
        padding-top: 2.5em;
        border-top: 1px solid #6BBF97;
	
}

.form_item{
	display: flex;
	        align-items: flex-start;
}
.form_item:has(textarea){
	display: flex;
}
.form_item label:first-of-type{
        display: flex;
        align-items: baseline;
	width: 16.88em;
	                margin-top: 0.8em;
	        margin-right: 2.63em;
	        flex-shrink: 0;
}
.form_item label .tag{
        color: #fff;
        display: inline-block;
        padding: 0.25em 0.38em;
        border-radius: 0.31em;
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 500;
        letter-spacing: 0.2em;
	margin-right: 1em;
	font-size: 0.88em;
}
.form_item label .tag.optional{
	background: #AEAEAE;
}
.form_item label .tag.required{
	background: #EC2028;
}

.form_item label{
font-size: 1.13em;
}
.form_item label .tag + span{
	        display: flex;
        flex-direction: column;
}
.form_item > label + *{
	flex-grow: 1;
}
.form_item > div span.ex{
	        display: block;
        font-size: 0.88em;
        color: #575757;
	
        font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
}
.form_item .unit{
	        align-self: center;
	        margin-left: 0.8em;
	        font-size: 0.94em;
}
.form_item input,
.form_item textarea{
	background: #FFFCF3;
	border: 1px solid #876239;
	        min-height: 3.13em;
	        padding: 0.63em;
	width:100%;
}
.form_item input,
.form_item textarea{
	background: #FFFCF3;
	border: 1px solid #876239;
	        min-height: 3.85em;
	        padding: 0.63em;
	width:100%;
}
input[name="child-age"]{
	width: 6.94em;
}
input[name="your-tel"],
input[name="your-add"]{
	width: 21.44em;
}


.form_item > label + *:has(input[type="checkbox"]){
	        background: #FFFBEB;
        border-radius: 0.63em;
	min-height: 4.38em;
        display: flex;
        align-items: center;
}
.form_item label:has(input[type="checkbox"]){
	display: flex;
        align-items: center;
	        width: 100%;
	        margin: unset;
	        cursor: pointer;
}

.form_item label:has(input[type="checkbox"]) span{
display: inline-flex;
        align-items: center;
	        gap: 0.88em;
}

input[type="checkbox"]{
		position: absolute;
	opacity: 0;/**/
	min-height: unset;
        width: unset;
	
}
.form_item.policy .radio{
	position: relative;
	padding-left: 2rem;
	cursor: pointer;
}

/* 外側の丸 */
.form_item.policy .radio::before{
        content: "";
        position: absolute;
                left: -0.77em;
        top: 50%;
        transform: translateY(-50%);
        width: 1.66em;
        height: 1.66em;
        border: 1px solid #333;
        border-radius: 50%;
        box-sizing: border-box;
        background: #fff;
}

/* 内側の● */
.form_item.policy .radio::after{
        content: "";
        position: absolute;
        left: -0.45em;
        top: 50%;
        transform: translateY(-50%);
        width: 1em;
        height: 1em;
        border-radius: 50%;
        background: #F28E1E;
        opacity: 0;
}

/* チェック時 */
.form_item.policy input[type="checkbox"]:checked + span .radio::after{
	opacity: 1;
}

input[type="checkbox"] + span a{
	display: inline-flex;
	align-items: center;
	color: unset;
}
input[type="checkbox"] + span a::after{
	content: "";
	display: block;
	background: blue;
	width: 1em;
	height: 1em;
	background: url("../images/form/icon_blank.svg");
        left: 0.5em;
        position: relative;
}


.caution{
	text-align: center;
	    margin-top: 2em;
}

div:has( > input[type="submit"]){
        display: flex;
        align-items: center;
        width: 18.52em;
        height: 4.68em;
	margin-inline: auto;
	position: relative;
	
}

div:has( > input[type="submit"])::after{
content: "";
	position: absolute;
	top:0;
	bottom: 0;
	margin: auto;
	right: 1em;
        background-image: url(../images/common/link_ico_col06.svg);
        background-repeat: no-repeat;
        /* background-size: 10.69% auto; */
        width: 2.25em;
        height: 2.25em;
	
	
}


input[type="submit"]{
	border: 3px solid #f28e1e;
        border-radius: 33px;
        box-sizing: border-box;
        background-color: #fff;
        background-image: url(images/common/link_ico_col06.svg);
        background-repeat: no-repeat;
        background-size: 10.69% auto;
        background-position: right 5.86% center;
        font-size: 93.75%;
        line-height: 1;
        letter-spacing: 0.1em;
        color: #000000;
        text-decoration: none;
        box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
        position: relative;
	        width: 100%;
        font-size: 1.13em;
        font-weight: 700;
	        font-family: 'BIZ UDPGothic', sans-serif;
	border-radius: 1000px;
	        min-height: 4.16em;
	
	        transition: all 0.5s;
}

input[type="submit"]:disabled,
div:has( > input[type="submit"]:disabled),
div:has( > input[type="submit"]:disabled)::after{
	opacity: .6;
	
}
input[type="submit"]:hover{
        opacity: 1;
        background-color: #f28e1e;
        color: #fff;
}


input[type="submit"] + *{
	position: absolute;
	
}
/**/
section .sec-inner ul li{
	line-height: 2.5em;
	display: flex;
	align-items: center;
	gap:0.75em;
	        margin-left: 3.38em;
}


section .sec-inner ul li::before{
	content: "";
	display: block;
	width: 0.88em;
	height: 0.88em;
	background: #E81C24;
	border-radius: 50%;
}









.ga4 *{
	        font-family: "Noto Sans JP", sans-serif;
        font-weight: 400;
	letter-spacing: 0;
}
.ga4 h4{
	font-size: 1.25em;
    text-align: center;
    padding-bottom: 0.7em;
    border-bottom: 1px solid #AEAEAE
}
.ga4 h4 + p{
margin-top: 0.63em;
        text-align: justify !important;
}
