@charset "utf-8";
/* CSS Document */
	.page_title_wrap + section > div h2:first-of-type{
		margin-top: calc(32px + 17px);
	}
	
	
section {
position: relative;
    z-index: 0;
}
	
section > div > :is(p, dl, table, blockquote, div) {
    /*width: 90.91%;
    background: red;  デバッグ用 */
    margin-inline:auto;
}
	
		
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) {
	        line-height: 1.5;
}	
section > div p strong {
color:#754C24; font-size: 1.5rem; font-weight: 700;
}
p:has(strong) + p {
	margin-top: 1em;
}
	
section:not(.page_title_wrap)::before {
        content: '';
        position: absolute;
        top: -17px;
        left: 50%;
        width: 100vw;
        height: 34px;
        transform: translateX(-50%);
        z-index: -1;
        background-image: radial-gradient(#fffbee 70%, transparent 71%);
        background-size: 34px 34px;
        background-repeat: repeat-x;
        background-position: center top;
    }		
section:not(.page_title_wrap)::after {
        content: '';
        position: absolute;
        bottom: -17px;
        left: 50%;
        width: 100vw;
        height: 34px;
        transform: translateX(-50%);
        z-index: -1;
        background-image: radial-gradient(#fffbee 70%, transparent 71%);
        background-size: 34px 34px;
        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{
		
	}	
	section:not(.page_title_wrap, #list_refer):nth-of-type(odd)::after{
		
	}	
	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#about_refer figure img{
		
	}	
	
	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);
	}



section > div div.shadow::after{
        filter: blur(calc(3.8rem / 4));
        width: calc(100vw - 3.8rem / 2);
        height: calc(100% - 3.8rem / 2);
                top: 50%;
        bottom: calc(50% - 1.88em);
        margin: auto;
	        transform: translateX(-50%);
        left: 50%;
}


section > div div.shadow:has(a)::after {
        width: calc(100% + 1.3rem - 3.8rem / 2);
        height: calc(100% + 1.5rem - 3.8rem / 2);
        bottom: calc(50% - 1.88em);

        transform: translateX(-50%);
		        left: calc(50% + 1.35rem);
    }



section#flow .shadow::after{
        opacity: calc(.15 / 1.5);
}	


	
section .sec-inner .box > div{
background: #FFF;
	border: 1px solid #00A498;
	border-radius: 1rem;
	display: flex;
	flex-direction: column;
	
	
	padding: 1rem 2rem 1.5rem;
	
    box-sizing: border-box;
	/*min-height: 8.5625em;*/
	position: relative;
	
    }	
	

section#certificate .sec-inner p + div:has(h4){margin-top: 2.5rem;}
section#certificate .sec-inner div:has(h4) + div:has(h4){margin-top: 2.5rem;}
section#certificate .sec-inner h3 + p{margin-top:2.5rem;}
	

section .sec-inner .box + .box{margin-top:3.8rem;}
	
	
	
section .box h4 {
	font-size: 1.5rem;
	color: #0C7268;
	text-align: center;
width: 100%;
    border-bottom: 1px solid #00A498;
	        line-height: 2;
    }	
	
    section > div h4.h4_midashi + p {
           margin-top: 1.5rem;
    }
	
section .box h4 + p,section .box_half h4 + p{
	font-size: 1.3rem;
	        line-height: 1.73;
	        margin-top: 0.9rem;
    }
	

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



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




section h3 + * {
margin-top: 1.8rem;
	
    }
	


.two_column{
	gap:2rem;
}

section .two_column a{
	display: block;
	
}

/**/

.btn_line {
	width: 22.1rem;
	height: 7.8rem;
	
}

.btn_line a{
	background: #39B04A;
	border-radius: 1rem;
	        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.6rem;
	
	padding-right: 1.3rem;
	gap:2.2rem;
}


.btn_line .icon img{
	
        width: 6.75rem;
        height: 6.75rem;
}

.btn_line .text{
	color: #fff;
	text-decoration: none;
	font-size: 1.65rem;
	margin-top: -0.30em;
	        white-space: nowrap;
	
}
.btn_line .text span{display: block;}
.btn_line .text span > span{
	font-size: 2.65rem; display: inline-block;         letter-spacing: 0.05em;        margin-right: 0.3rem;}

.btn_line .arrow{
	margin-left: auto;
}
.btn_line .arrow img{
	
width: calc(0.36rem * 1.5);
        height: calc(0.71rem * 1.5);
}


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

.flow_line .flow_box > div{
	display: flex;
        margin-inline: auto;
	        justify-content: space-between;
	flex-direction: column;
	gap: 3.2rem;
}

.flow_line .flow_box > div img{
width: 6.25rem;
	height:  6.25rem;
	margin-left: 0.75rem;
	flex-shrink: 0;
	
}

.flow_line .flow_box span{
display: block;
}

.flow_content {
	position: relative;
}

.flow_content > div{
display: flex;
	        justify-content: left;
	        align-items: center;
}

.flow_content h5{
color: #E27A13;
	font-size: 1.5rem;
	flex-shrink: 0;
}

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


.flow_content + .flow_content::before{
	width: 100%;
	height: 1px;
	background: #F28E1E;
	        top: -2rem;
}


.flow_content + .flow_content::after{
	  background: #F28E1E;
  height:0.75rem;
  width: 0.9rem;
clip-path: polygon(0 0, 100% 0%, 50% 100%);
        top: -1.4rem;
}

.flow_content p{
	margin-left: 1.7rem;
	        line-height: 1.3;
	max-width: 15.35rem;
	        letter-spacing: 0.1em;
}
.flow_content:last-of-type p span{
    display: inline;
}


/**/


.form_content{
	margin-inline:auto;
	        display: flex;
        flex-direction: column;
        gap: 2.5rem;
        margin-top: 2rem;
        padding-top: 2rem;
        border-top: 1px solid #6BBF97;
	
}

.form_item{
	display: flex;
	        align-items: flex-start;
	        flex-direction: column;
}
.form_item:has(textarea){
	display: flex;
}
.form_item label:first-of-type{
        display: flex;
        align-items: baseline;
}
.form_item label .tag{
        color: #fff;
        display: inline-block;
        padding: 0.3rem 0.4rem;
        border-radius: 0.4rem;
        font-family: "Noto Sans JP", sans-serif;
        font-weight: 500;
        letter-spacing: 0.2em;
        margin-right: 0.75rem;
        font-size: 1.33rem;
}
.form_item label .tag.optional{
	background: #AEAEAE;
}
.form_item label .tag.required{
	background: #EC2028;
}

.form_item label{
font-size: 1.5rem;
}
.form_item label .tag + span{
        display: inline-block;
}
.form_item > label + *{
	flex-grow: 1;
}
.form_item > div span.ex{
	        display: block;
        font-size: 1.25rem;
        color: #575757;
	
        font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
}
.form_item .unit{
	        align-self: center;
	        margin-left: 1rem;
	        font-size: 1.5rem;
}
.form_item input,
.form_item textarea{
	background: #FFFCF3;
	border: 1px solid #876239;
        min-height: 4rem;
        padding: 0.63em;
        width: 100%;
        box-sizing: border-box;
	width:100%;
	margin-top: 1rem;
}
input[name="child-age"]{
	width: 15.28rem;
}
input[name="your-tel"],
input[name="your-add"]{
}


.form_item > label + *:has(input[type="checkbox"]){
	        background: #FFFBEB;
	min-height: 4.75rem;
        display: flex;
        align-items: center;
margin-top: 1.2rem;
	        width: 100%;
}
.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.4rem;
}

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.8rem;
        top: 50%;
        transform: translateY(-50%);
        width: 1.8rem;
        height: 1.8rem;
        border: 1px solid #333;
        border-radius: 50%;
        box-sizing: border-box;
        background: #fff;
}

/* 内側の● */
.form_item.policy .radio::after{
content: "";
        position: absolute;
        left: -0.25em;
        top: 50%;
        transform: translateY(-50%);
        width: 1rem;
        height: 1rem;
        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;
        position: relative;
}


.caution{
	    margin-top: 2rem;
}

.caution span{
	display: block;
}

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.65rem;
        height: 2.65rem;
	
	
}


input[type="submit"]{
	border: 0.15rem solid #f28e1e;
        border-radius: 33px;
        box-sizing: border-box;
        background-color: #fff;
        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.35rem;
        font-weight: 700;
	        font-family: 'BIZ UDPGothic', sans-serif;
	border-radius: 1000px;
	        min-height: 5.5rem;
	
	        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{
}


input[type="submit"] + *{
	position: absolute;
	
}
/**/
section .sec-inner ul li{
        line-height: 1.48;
        display: flex;
        align-items: baseline;
        gap: 0.8rem;
        margin-top: 1.2rem;
}


section .sec-inner ul li::before{
	content: "";
	display: block;
	width: 1.3rem;
	height: 1.3rem;
	background: #E81C24;
	border-radius: 50%;
	flex-shrink: 0;
}









.ga4 *{
	        font-family: "Noto Sans JP", sans-serif;
        font-weight: 400;
	letter-spacing: 0;
}
.ga4 h4{
font-size: 1.4rem;
        text-align: center;
        padding-bottom: 1.2rem;
        border-bottom: 1px solid #AEAEAE;
}
.ga4 h4 + p{
        margin-top: 0.8rem;
	font-size: 1.2rem;
}

/**/
#form_mail:focus,
#form_mail:focus-within {
    outline: none !important;
    border-top: none !important;
}