@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: #F5FDFF;
}
	section:not(.page_title_wrap, #list_refer):nth-of-type(odd)::before{
        top: -30px;
        background-image: radial-gradient(#F5FDFF 70%, transparent 71%);
		
	}	
	section:not(.page_title_wrap, #list_refer):nth-of-type(odd)::after{
        bottom: -30px;
        background-image: radial-gradient(#F5FDFF 70%, transparent 71%);
		
	}	
	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(.15 / 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% - 4.75em / 2);
        left: calc(1.625em + 4.75em / 2);
        top: 50%;
                bottom: calc(50% - 3.13em);
        margin: auto;
}
section .sec-inner .box {
background: #FFF;
	border: 1px solid #00A498;
	border-radius: 1.25em;
	padding-block: 0.88em 1.25em;
    box-sizing: border-box;
	        min-height: 15.28em;
	position: relative;
	
    }	
	section .sec-inner .box > div {
	display: flex;
	flex-direction: column;
	align-items: center;
	/* gap: 0.65em; */
	}	


	section .sec-inner .box p {
	font-size: 1.25em;
	text-align: center;
	line-height: 1.35;
	}	




	

section h2 + p{
	margin-top: 1.75em;
}

section .four_column > div {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	column-gap: 1.25em;
	
    }	
section .four_column  figure {
	width: 10.56em;
	height: 9.38em;
    }	
section .four_column figure img{
	        width: 100%;
        height: 100%;
    }	



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


section .two_column h4{
	font-size: 1.25em;
	letter-spacing: 0.05em;
	color: #754C24;
	
}


section .two_column h4.support{
	
	color: #1E877F;
	margin-top: 2em;
}
section .two_column ul{
	margin-top: 1.13em;
	
}
section .two_column ul li{
	display: flex;
	        align-items: center;
	column-gap: 0.75em;
	        line-height: 2.25;
}
section .two_column ul li::before{
content: "";
	display: block;
	width: 0.88em;
	height: 0.88em;
	background: #F28E1E;
	border-radius: 50%;
}
section .three_column{

}
section .three_column > div{
	width: 25.63em;
	margin-top: 0.88em;
	align-items: center;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	align-items: baseline;
}
section .three_column > div div{
	display: flex;
	flex-direction: column;
	column-gap: 0.63em;
	align-items: center;
}


section .three_column figure{
	width: 7.38em;
	height: 7.38em;
}
section .three_column p{
    white-space: nowrap;
	line-height: 1.5;
	text-align: center;
}

section .three_column figure + p{
	        margin-top: 0.31em;
}

