html {
    width: 100%;
    margin: 0 auto;
    }

body {
    position: relative;
	width: 100%;
    min-height: 100vh;
    box-sizing: border-box;
	margin: 0 auto;
	padding-bottom: 40px;
    background: #ffffff;
	font-family: 'Noto Sans JP', sans-serif;
    font-size: clamp(0.75rem, 0.659rem + 0.45vw, 1rem); /* 12px-16pxで可変 */
    font-feature-settings: "palt";
    line-height: 2em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    }

*, *:before, *:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
    }

h1, h2, h3, h4, h5, h6 {
	font-family: 'Noto Sans JP', sans-serif;
	}

h1 {
    margin: 0;
	padding: 0;
	color: #000000;
    font-size: clamp(1.5rem, 1.227rem + 1.36vw, 2.25rem); /* 24px~36pxで可変 */
    font-weight: 700;
    letter-spacing: -0.05em;
    line-height: 1.2;
	}

h2 {
    clear: both;
    width: 100%;
    margin: 0 auto 40px auto;
    padding: 0;
    color: #000000;
    font-size: clamp(1.25rem, 1.159rem + 0.45vw, 1.5rem); /* 20px~24pxで可変 */
    font-weight: 700;
    letter-spacing: -0.05em;
    line-height: 1.2;
    text-align: center;
    }

h3 {
    width: 100%;
    margin: 0 auto 20px auto;
    padding: 0;
    color: #000000;
    font-size: clamp(1.125rem, 1.08rem + 0.23vw, 1.25rem); /* 18px~20pxで可変 */
    font-weight: 700;
    letter-spacing: -0.05em;
    line-height: 1.2;
    text-align: left;
    }

span.title01 {
    color: #ff9c00;
    }    

@media only screen and (max-width: 768px) {
    h1 {
        margin: 0;
	    padding: 0;
	    }

    h2 {
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    h3 {
        margin: 0 auto 20px auto;
        padding: 0;
        }
}

a:link {
	background-color: transparent;
	color: #000000;
	text-decoration: underline;
	}

a:visited {
	background-color: transparent;
	color: #000000;
	text-decoration: none;
	}

a:active {
	background-color: transparent;
	color: #000000;
	text-decoration: none;
	}

a:hover {
	background-color: transparent;
	color: #000000;
	text-decoration: none;
	}

.alpha a:hover img {
	opacity: 0.8;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
	}

img {
	max-width: 100%;
    width: 100%;
    vertical-align: top;
	}

/*__________________________________________________

  header
  __________________________________________________*/
header {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    header {
        width: 100%;
        margin: 0 auto;
        padding: 0;
        background: transparent;
        }
}


/*__________________________________________________

  container
  __________________________________________________*/
.container {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.container-sub {
    width: 100%;
    margin: 90px auto 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .container {
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }

    .container-sub {
        width: 100%;
        margin: 45px auto 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  heroBox
  __________________________________________________*/
.heroBox {
	width: 100%;
	margin: 0 auto 0 auto;
	padding: 0;
    background: transparent;
    text-align: center;
	}

@media only screen and (max-width: 1200px) {
    .heroBox {
	    width: 100%;
        height: auto;
	    margin: 0 auto 0 auto;
	    padding: 0;
	    }
}

@media only screen and (max-width: 768px) {
    .heroBox {
	    width: 100%;
	    margin: 0 auto 0 auto;
	    padding: 0;
	    }
}

/*__________________________________________________    

  meritBox
  __________________________________________________*/
.meritBox {
	width: 100%;
	margin: 0 auto 90px auto;
	padding: 60px 0;
    /*background: url("../../assets/images/common/merit_bg.png");
    background-size: cover;
    background-position: center;
    filter: drop-shadow(0px 5px 10px rgba(0, 0, 0, 0.3));*/
    text-align: center;
	}

.meritBox h2 {
    margin: 0 auto 60px auto;
    padding: 0;
    color: #704e33;
    font-size: clamp(1.125rem, 0.716rem + 2.05vw, 2.25rem); /* 18px～36pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.2;
    text-align: center;
    }

.meritBox h2 span.size {
    font-size: clamp(1.875rem, 1.193rem + 3.41vw, 3.75rem); /* 30px～60pxで可変 */
    font-weight: 700;
    }

.meritBox p.txt {
    margin: 0 auto 60px auto;
    padding: 0;
    color: #704e33;
    font-size: clamp(1.125rem, 0.716rem + 2.05vw, 2.25rem); /* 18px～36pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.3;
    text-align: center;
    }

.meritBox p.txt span.col01 {
    color: #ff9c00;
    }

.meritBox .merit-box {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.meritBox .merit-box .box01 {
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    }

@media only screen and (max-width: 1024px) {
    .meritBox {
        width: 100%;
        margin: 0 auto 90px auto;
        padding: 60px 0 0 0;
        /*background: url("../../assets/images/common/merit_bg.png");
        background-size: cover;
        background-position: center;
        filter: drop-shadow(0px 5px 10px rgba(0, 0, 0, 0.3));*/
        text-align: center;
        }

    .meritBox .merit-box {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 30px;
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }

    .meritBox .merit-box .box01 {
        width: 100%;
        margin: 0 auto 60px auto;
        padding: 0;
        }
}

@media only screen and (max-width: 768px) {
    .meritBox {
        width: 100%;
        margin: 0 auto 45px auto;
        padding: 30px 0;
        /*background: url("../../assets/images/common/merit_bg.png");
        background-size: cover;
        background-position: center;
        filter: drop-shadow(0px 5px 10px rgba(0, 0, 0, 0.3));*/
        text-align: center;
        }
    
    .meritBox h2 {
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .meritBox p.txt {
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .meritBox .merit-box {
        flex-direction: column;
        gap: 0;
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .meritBox .merit-box .box01 {
        width: 80%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
}

/*__________________________________________________    

  recommendBox
  __________________________________________________*/
.recommendBox {
	margin: 0;
	padding: 60px 0 60px 0;
    background: url("../../assets/images/common/recommend_bg.png") no-repeat;
    background-position: right;
    filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.3));
    text-align: center;
	}

.recommendBox .recommend-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.recommendBox .recommend-box .box01 {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 1024px) {
    .recommendBox .recommend-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
}

@media only screen and (max-width: 768px) {
    .recommendBox {
        margin: 0;
        padding: 30px 0 30px 0;
        background: url("../../assets/images/common/recommend_bg.png") no-repeat;
        background-position: right;
        filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.3));
        text-align: center;
        }
    
    .recommendBox .recommend-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .recommendBox .recommend-box .box01 {
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  worksBox
  __________________________________________________*/
.worksBox {
	width: 100%;
    width: 100%;
	margin: 90px auto 90px auto;
	padding: 0;
    text-align: center;
	}

.worksBox h2 {
    margin: 0 auto 40px auto;
    padding: 0;
    color: #009a3d;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.2;
    text-align: center;
    }

.worksBox h2 span.col01 {
    color: #ff8a00;
    }

.worksBox .works-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.works-box p.txt01 {
    width: 100%;
    margin: 0 auto 30px auto;
    padding: 0;
    color: #4f3924;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px～24pxで可変 */
    font-weight: 500;
    text-align: justify;
    line-height: 1.6;
    }

.works-box h3 {
    width: 100%;
    margin: 60px auto 30px auto;
    padding: 25px 30px;
    background: #009a3d;
    border-radius: 30px;
    color: #ffffff;
    font-size: clamp(0.938rem, 0.597rem + 1.7vw, 1.875rem); /* 15px～30pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    }

.works-box .unit-works {
    display: flex;
    justify-content: center;
    gap: 30px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.works-box .unit-works .boxL {
    max-width: 525px;
    width: 100%;
    margin: 0;
    padding: 0;
    }

.works-box .unit-works .boxL p.txt {
    width: 100%;
    margin: 0 0 30px 0;
    padding: 0;
    color: #4f3924;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px～24pxで可変 */
    font-weight: 500;
    text-align: justify;
    line-height: 1.6;
    }

.works-box .unit-works .boxR {
    max-width: 525px;
    width: 100%;
    margin: 0;
    padding: 0;
    }

.works-box .unit-works:nth-child(2n+1) { 
    flex-direction: row-reverse;
    }

.works-box .btn-box {
    max-width: 800px;
    width: 100%;
    margin: 30px auto;
    padding: 0;
    text-align: center;
    }

@media only screen and (max-width: 1024px) {
    .worksBox .works-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
}

@media only screen and (max-width: 768px) {
    .worksBox {
        width: 100%;
        width: 100%;
        margin: 45px auto 45px auto;
        padding: 0;
        text-align: center;
        }
    
    .worksBox h2 {
        margin: 0 auto 20px auto;
        padding: 0;
        text-align: center;
        }
    
    .worksBox .works-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .works-box p.txt01 {
        width: 100%;
        margin: 0 auto 20px auto;
        padding: 0;
        }
    
    .works-box h3 {
        width: 100%;
        margin: 30px auto 20px auto;
        padding: 15px 15px;
        background: #009a3d;
        border-radius: 30px;
        }
    
    .works-box .unit-works {
        flex-direction: column;
        gap: 0;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .works-box .unit-works .boxL {
        max-width: 100%;
        width: 100%;
        margin: 0;
        padding: 0;
        }
    
    .works-box .unit-works .boxL p.txt {
        width: 100%;
        margin: 0 0 20px 0;
        padding: 0;
        }
    
    .works-box .unit-works .boxR {
        max-width: 100%;
        width: 100%;
        margin: 0;
        padding: 0;
        }
    
    .works-box .unit-works:nth-child(2n+1) { 
        flex-direction: column;
        }
    
    .works-box .btn-box {
        max-width: 100%;
        width: 90%;
        margin: 30px auto;
        padding: 0;
        text-align: center;
        }
    
}

/* movie-box */
.movie-box {
    max-width: 900px;
    width: 100%;
    margin: 90px auto 90px auto;
    padding: 0;
    }

.movie-box h2 {
    margin: 0 auto 40px auto;
    padding: 0;
    color: #009a3d;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.2;
    text-align: center;
    }

.movie-box p.txt {
    max-width: 900px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    color: #503927;
    font-size: clamp(0.938rem, 0.597rem + 1.7vw, 1.875rem); /* 15px～30pxで可変 */
    font-weight: 500;
    }

.movie-box .youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    }

.youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 10px;
    width: 100%;
    height: 100%;
    }

.movie-box .btn-box {
    max-width: 800px;
    width: 100%;
    margin: 30px auto;
    padding: 0;
    text-align: center;
    }

@media only screen and (max-width: 768px) {
    .movie-box {
        max-width: 100%;
        width: 100%;
        margin: 45px auto 45px auto;
        padding: 0;
        }
    
    .movie-box h2 {
        margin: 0 auto 20px auto;
        padding: 0;
        text-align: center;
        }
    
    .movie-box p.txt {
        max-width: 100%;
        width: 90%;
        margin: 0 auto 30px auto;
        padding: 0;
        }

    .youtube iframe {
        position: absolute;
        top: 0;
        right: 0;
        border-radius: 0;
        width: 100%;
        height: 100%;
        }

    .movie-box .btn-box {
        max-width: 100%;
        width: 80%;
        margin: 30px auto;
        padding: 0;
        text-align: center;
        }
}

/* other-box */
.other-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.other-box p.txt01 {
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    color: #4f3924;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px～24pxで可変 */
    font-weight: 500;
    text-align: justify;
    line-height: 1.6;
    }

.other-box .btn-box {
    max-width: 800px;
    width: 100%;
    margin: 30px auto;
    padding: 0;
    text-align: center;
    }

@media only screen and (max-width: 1024px) {
    .other-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
}

@media only screen and (max-width: 768px) {
    .other-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .other-box p.txt01 {
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    .other-box .btn-box {
        max-width: 100%;
        width: 90%;
        margin: 30px auto;
        padding: 0;
        text-align: center;
        }
}

/*__________________________________________________    

  introBox
  __________________________________________________*/
.introBox {
	margin: 0 auto 90px auto;
	padding: 60px 0 90px 0;
    background: url("../../assets/images/common/intro_bg.png") no-repeat;
    background-position: center;
    filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.3));
    text-align: center;
	}

.introBox h2 {
    margin: 0 auto 40px auto;
    padding: 0;
    color: #009a3d;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.2;
    text-align: center;
    }

.introBox h2 span.col01 {
    color: #ff8a00;
    }

.introBox .intro-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.intro-box .box {
    max-width: 900px;
    width: 100%;
    margin: 30px auto 60px auto;
    padding: 40px 30px;
    background: #ffffff;
    border-radius: 30px;
    }

.intro-box .box p.txt01 {
    width: 100%;
    margin: 0 auto 30px auto;
    padding: 0;
    color: #503927;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px-24pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    text-align: justify;
    }

.intro-box .box p.txt02 {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    color: #503927;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px-24pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    text-align: justify;
    }

.intro-box .intro-img {
    max-width: 900px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .introBox {
        margin: 0 auto 45px auto;
        padding: 30px 0 45px 0;
        background: url("../../assets/images/common/intro_bg.png") no-repeat;
        background-position: center;
        filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.3));
        text-align: center;
        }
    
    .introBox h2 {
        margin: 0 auto 20px auto;
        padding: 0;
        text-align: center;
        }
    
    .introBox .intro-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .intro-box .box {
        max-width: 100%;
        width: 100%;
        margin: 15px auto 30px auto;
        padding: 20px 15px;
        background: #ffffff;
        border-radius: 30px;
        }
    
    .intro-box .box p.txt01 {
        width: 100%;
        margin: 0 auto 20px auto;
        padding: 0;
        text-align: justify;
        }
    
    .intro-box .box p.txt02 {
        width: 100%;
        margin: 0 auto;
        padding: 0;
        text-align: justify;
        }
    
    .intro-box .intro-img {
        max-width: 100%;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________    

  obsessionBox
  __________________________________________________*/
.obsessionBox {
    width: 100%;
	margin: 0 auto 90px auto;
	padding: 0;
    text-align: center;
	}

.obsessionBox h2 {
    margin: 0 auto 40px auto;
    padding: 0;
    color: #009a3d;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.2;
    text-align: center;
    }

.obsessionBox h2 span.col01 {
    color: #ff8a00;
    }

.obsessionBox .obsession-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.obsession-box h3 {
    width: 100%;
    margin: 60px auto 30px auto;
    padding: 25px 30px;
    background: #009a3d;
    border-radius: 30px;
    color: #ffffff;
    font-size: clamp(0.938rem, 0.597rem + 1.7vw, 1.875rem); /* 15px～30pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    text-align: center;
    }

.obsession-box .img-box {
    max-width: 795px;
    width: 100%;
    margin: 0 auto 30px auto;
    padding: 0;
    text-align: center;
    }

.obsession-box p.txt01 {
    width: 100%;
    margin: 0 auto 30px auto;
    padding: 0;
    color: #503927;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px～24pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    text-align: justify;
    }

.obsession-box p.txt02 {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    color: #503927;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px～24pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    text-align: justify;
    }

@media only screen and (max-width: 1024px) {
    .obsessionBox .obsession-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
}

@media only screen and (max-width: 768px) {
    .obsessionBox {
        width: 100%;
        margin: 0 auto 45px auto;
        padding: 0;
        text-align: center;
        }
    
    .obsessionBox h2 {
        margin: 0 auto 20px auto;
        padding: 0;
        text-align: center;
        }
    
    .obsessionBox .obsession-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .obsession-box h3 {
        width: 100%;
        margin: 0 auto 15px auto;
        padding: 15px 15px;
        background: #009a3d;
        border-radius: 30px;
        text-align: center;
        }
    
    .obsession-box p.txt01 {
        width: 100%;
        margin: 0 auto 20px auto;
        padding: 0;
        text-align: justify;
        }
    
    .obsession-box p.txt02 {
        width: 100%;
        margin: 0 auto;
        padding: 0;
        text-align: justify;
        }
}

/*__________________________________________________    

  stayBox
  __________________________________________________*/
.stayBox {
	margin: 0 0 80px 0;
	padding: 10px 0 60px 0;
    background: url("../../assets/images/common/stay_bg.png") no-repeat;
    background-position: left;
    filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.3));
    text-align: center;
	}

.stayBox .stay-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.stayBox .stay-box .box01 {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.stayBox .stay-box h3 {
    width: 100%;
    margin: 60px auto 30px auto;
    padding: 25px 30px;
    background: #009a3d;
    border-radius: 30px;
    color: #ffffff;
    font-size: clamp(0.938rem, 0.597rem + 1.7vw, 1.875rem); /* 15px～30pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    text-align: center;
    }

.stayBox .stay-box p.txt01 {
    width: 100%;
    margin: 0 auto 30px auto;
    padding: 0 15px;
    color: #503927;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px～24pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    text-align: justify;
    }

.stayBox .stay-box .unit-stay {
    display: flex;
    justify-content: center;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.stayBox .stay-box .unit-stay .boxL {
    width: 60%;
    margin: 0;
    padding: 0;
    }

.stayBox .stay-box .unit-stay .boxL .title {
    width: 100%;
    margin: 0 0 20px 15px;
    padding: 0;
    color: #009a3d;
    font-size: clamp(0.938rem, 0.597rem + 1.7vw, 1.875rem); /* 15px～30pxで可変 */
    font-weight: 700;
    text-align: left;
    }

.stayBox .stay-box .unit-stay .boxL p.txt {
    width: 100%;
    margin: 0 auto 20px auto;
    padding: 0 15px;
    color: #503927;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px～24pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: -0.05em;
    text-align: justify;
    }

.stayBox .stay-box .unit-stay .boxR {
    max-width: 425px;
    width: 100%;
    margin: 0;
    padding: 0 15px;
    }
   
.stayBox .stay-box .unit-stay:nth-child(2n+1) { 
    flex-direction: row-reverse;
    }

@media only screen and (max-width: 1024px) {
    .stayBox {
        height: 100%;
        margin: 0 0 90px 0;
        padding: 60px 0 60px 0;
        background: url("../../assets/images/common/stay_bg_sp.png") no-repeat;
        background-position: center;
        filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.3));
        text-align: center;
        }

    .stayBox .stay-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }

    .stayBox .stay-box .box01 {
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
    
    .stayBox .stay-box h3 {
        width: 100%;
        margin: 0 auto 15px auto;
        padding: 15px 15px;
        background: #009a3d;
        border-radius: 30px;
        text-align: center;
        }
}
    
@media only screen and (max-width: 768px) {
    .stayBox {
        height: 100%;
        margin: 0 0 80px 0;
        padding: 30px 0 30px 0;
        background: url("../../assets/images/common/stay_bg_sp.png") no-repeat;
        background-position: center;
        filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.3));
        text-align: center;
        }
    
    .stayBox .stay-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .stayBox .stay-box .box01 {
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
    
    .stayBox .stay-box h3 {
        width: 100%;
        margin: 0 auto 15px auto;
        padding: 15px 15px;
        background: #009a3d;
        border-radius: 30px;
        text-align: center;
        }
    
    .stayBox .stay-box p.txt01 {
        width: 100%;
        margin: 0 auto 10px auto;
        padding: 0 15px;
        text-align: justify;
        }
    
    .stayBox .stay-box .unit-stay {
        flex-direction: column;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
    
    .stayBox .stay-box .unit-stay .boxL {
        width: 100%;
        margin: 0;
        padding: 0;
        }
    
    .stayBox .stay-box .unit-stay .boxL .title {
        width: 100%;
        margin: 0 0 10px 15px;
        padding: 0;
        color: #009a3d;
        font-size: clamp(0.938rem, 0.597rem + 1.7vw, 1.875rem); /* 15px～30pxで可変 */
        font-weight: 700;
        text-align: left;
        }
    
    .stayBox .stay-box .unit-stay .boxL p.txt {
        width: 100%;
        margin: 0 auto 10px auto;
        padding: 0 15px;
        color: #503927;
        font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px～24pxで可変 */
        font-weight: 500;
        line-height: 1.6;
        letter-spacing: -0.05em;
        text-align: justify;
        }
    
    .stayBox .stay-box .unit-stay .boxR {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 20px auto;
        padding: 0 15px;
        }
       
    .stayBox .stay-box .unit-stay:nth-child(2n+1) { 
        flex-direction: column;
        }
}

/*__________________________________________________    

  voiceBox
  __________________________________________________*/
.voiceBox {
	margin: 0 0 80px 0;
	padding: 10px 0 60px 0;
    background: url("../../assets/images/common/voice_bg.png") no-repeat;
    background-position: right;
    filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.3));
    text-align: center;
	}

.voiceBox .voice-box {
    display: flex;
    justify-content: flex-end;
    gap: 30px;
    max-width: 1563px;
    width: 100%;
    margin: 0 0 0 auto;
    padding: 0;
    }

.voiceBox .voice-box .boxL {
    max-width: 100%;
    width: 50%;
    margin: 0;
    padding: 60px 0 0 0;
    }

.voiceBox .voice-box .boxL h2 {
    margin: 0 0 40px 60px;
    padding: 0;
    color: #503927;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.2;
    text-align: left;
    }

.voiceBox .voice-box .boxL .comment {
    max-width: 717px;
    width: 100%;
    margin: 0 0 0 60px;
    padding: 0;
    }

.voiceBox .voice-box .boxR {
    max-width: 792px;
    width: 50%;
    margin: 50px 0 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .voiceBox {
        margin: 0 0 40px 0;
        padding: 10px 0 30px 0;
        background: url("../../assets/images/common/voice_bg_sp.png") no-repeat;
        background-position: center;
        filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.3));
        text-align: center;
        }
    
    .voiceBox .voice-box {
        flex-direction: column;
        gap: 0;
        max-width: 100%;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
    
    .voiceBox .voice-box .boxL {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 30px 0 0 0;
        }
    
    .voiceBox .voice-box .boxL h2 {
        margin: 0 auto 20px auto;
        padding: 0;
        text-align: center;
        }
    
    .voiceBox .voice-box .boxL .comment {
        max-width: 100%;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
    
    .voiceBox .voice-box .boxR {
        max-width: 100%;
        width: 90%;
        margin: 25px 0 0 auto;
        padding: 0;
        }
}

/*__________________________________________________

  worksflowBox
  __________________________________________________*/
.worksflowBox {
    clear: both;
    max-width: 100%;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    }

.worksflowBox h2 {
    margin: 0 auto 60px auto;
    padding: 0;
    color: #009a3d;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.3;
    text-align: center;
    }

.worksflowBox .worksflow-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.worksflow-img {
    max-width: 900px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .worksflowBox {
        clear: both;
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    .worksflowBox h2 {
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .worksflowBox .worksflow-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .worksflow-img {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
}

/*__________________________________________________

  flowBox
  __________________________________________________*/
.flowBox {
    clear: both;
    max-width: 100%;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    }

.flowBox h2 {
    margin: 0 auto 60px auto;
    padding: 0;
    color: #009a3d;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.3;
    text-align: center;
    }

.flowBox .flow-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.flowBox .flow-box p.txt01 {
    width: 100%;
    margin: 0 auto 30px auto;
    padding: 0;
    color: #503927;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px-24pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    text-align: center;
    }

.flowBox .flow-box p.txt02 {
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    color: #503927;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12px-24pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    text-align: center;
    }


.flow-img {
    max-width: 900px;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    }

.flow-box .btn-box {
    max-width: 643px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 1024px) {
    .flowBox .flow-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }

    .flowBox .flow-box p.txt01 {
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: justify;
        }
    
    .flowBox .flow-box p.txt02 {
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: justify;
        }
}

@media only screen and (max-width: 768px) {
    .flowBox {
        clear: both;
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    .flowBox h2 {
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .flowBox .flow-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .flowBox .flow-box p.txt01 {
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: justify;
        }
    
    .flowBox .flow-box p.txt02 {
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: justify;
        }
    
    
    .flow-img {
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    .flow-box .btn-box {
        max-width: 100%;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________

  memberBox
  __________________________________________________*/
.memberBox {
    clear: both;
    max-width: 100%;
    width: 100%;
    margin: 0 auto 60px auto;
    padding: 0;
    }

.memberBox h2 {
    margin: 0 auto 60px auto;
    padding: 0;
    color: #009a3d;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.3;
    text-align: center;
    }

.memberBox h2 span.col01 {
    color: #ff8a00;
    }

.memberBox .member-box {
    max-width: 600px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

@media only screen and (max-width: 768px) {
    .memberBox {
        clear: both;
        max-width: 100%;
        width: 100%;
        margin: 0 auto 30px auto;
        padding: 0;
        }
    
    .memberBox h2 {
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .memberBox .member-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
}

/*__________________________________________________

  contactBox
  __________________________________________________*/
.contactBox {
    clear: both;
    max-width: 100%;
    width: 100%;
    margin: 0 auto 100px auto;
    padding: 0;
    }

.contactBox h2 {
    margin: 0 auto 60px auto;
    padding: 0;
    color: #009a3d;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.3;
    text-align: center;
    }

.contactBox .contact-box01 {
    width: 100%;
    margin: 0 auto 90px auto;
    padding: 0;
    }

.contact-box01 .btn {
    max-width: 800px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.contactBox .contact-box02 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 1110px;
    gap: 30px;
    width: 100%;
    margin: 0 auto 90px auto;
    padding: 0;
    }

.contact-box02 .btn {
    max-width: 539px;
    width: 50%;
    margin: 0;
    padding: 0;
    }

@media only screen and (max-width: 1200px) {
    .contactBox {
        clear: both;
        max-width: 100%;
        width: 100%;
        margin: 0 auto 50px auto;
        padding: 0;
        }
    
    .contactBox .contact-box01 {
        width: 90%;
        margin: 0 auto 90px auto;
        padding: 0;
        }

    .contact-box01 .btn {
        max-width: 100%;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        }

    .contactBox .contact-box02 {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        max-width: 100%;
        gap: 30px;
        width: 100%;
        margin: 0 auto 90px auto;
        padding: 0;
        }

    .contact-box02 .btn {
        max-width: 100%;
        width: 45%;
        margin: 0;
        padding: 0;
        }
}

@media only screen and (max-width: 768px) {
    .contactBox {
        clear: both;
        max-width: 100%;
        width: 100%;
        margin: 0 auto 50px auto;
        padding: 0;
        }
    
    .contactBox h2 {
        margin: 0 auto 30px auto;
        padding: 0;
        text-align: center;
        }
    
    .contactBox .contact-box01 {
        flex-direction: column;
        max-width: 100%;
        gap: 0;
        width: 100%;
        margin: 0 auto 45px auto;
        padding: 0;
        }
    
    .contact-box01 .btn {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }
    
    .contactBox .contact-box02 {
        flex-direction: column;
        max-width: 100%;
        width: 80%;
        gap: 0;
        width: 100%;
        margin: 0 auto 0 auto;
        padding: 0;
        }
    
    .contact-box02 .btn {
        max-width: 100%;
        width: 80%;
        margin: 0 auto 20px auto;
        padding: 0;
        }
}

/*__________________________________________________

  form
  __________________________________________________*/
.formBox {
    clear: both;
    max-width: 100%;
    width: 100%;
    margin: 0 auto 100px auto;
    padding: 0;
    }

.form-box {
    clear: both;
    max-width: 1110px;
    width: 100%;
    margin: 0 auto 90px auto;
    padding: 60px 0 20px 0;
    background: #ffffff;
    border-radius: 30px;
    box-shadow: 0px 0px 10px 10px rgba(0, 0, 0, 0.05);
    }

.form-box h2 {
    margin: 0 auto 30px auto;
    padding: 0;
    color: #009a3d;
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); /* 24px～48pxで可変 */
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.3;
    text-align: center;
    }

.form-box p.txt01 {
    margin: 0 auto;
    padding: 0;
    color: #503927;
    font-size: clamp(0.75rem, 0.477rem + 1.36vw, 1.5rem); /* 12@x-24pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    text-align: center;
    }

.formBox .btn-box {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    }

.form-box a:link {
	background-color: transparent;
	color: #1800ee;
	text-decoration: underline;
	}

.form-box a:visited {
	background-color: transparent;
	color: #1800ee;
	text-decoration: none;
	}

.form-box a:active {
	background-color: transparent;
	color: #1800ee;
	text-decoration: none;
	}

.form-box a:hover {
	background-color: transparent;
	color: #1800ee;
	text-decoration: none;
	}

@media only screen and (max-width: 1024px) {
    .form-box {
        clear: both;
        width: 97%;
        margin: 0 auto 40px auto;
        padding: 0;
        }

    .form-box {
        clear: both;
        max-width: 100%;
        width: 90%;
        margin: 0 auto 20px auto;
        padding: 0 0 10px 0;
        background: #ffffff;
        border-radius: 30px;
        box-shadow: none;
        }
}

@media only screen and (max-width: 768px) {
    .formBox {
        clear: both;
        max-width: 100%;
        width: 100%;
        margin: 0 auto 50px auto;
        padding: 0;
        }
    
    .form-box {
        clear: both;
        max-width: 100%;
        width: 90%;
        margin: 0 auto 20px auto;
        padding: 0 0 10px 0;
        background: #ffffff;
        border-radius: 30px;
        box-shadow: none;
        }
    
    .form-box h2 {
        margin: 0 auto 15px auto;
        padding: 0;
        text-align: center;
        }
    
    .form-box p.txt01 {
        margin: 0 auto;
        padding: 0;
        text-align: center;
        }
    
    .formBox .btn-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 0;
        }

}

/*__________________________________________________

  return
  __________________________________________________*/
.return {
    clear: both;
    width: 50px;
    right: 0;
	margin: 0 0 0 auto;
	padding: 40px 0 300px 0;
    text-align: right;
	}

@media only screen and (max-width: 768px) {
	.return {
        clear: both;
        width: 50px;
        right: 0;
	    margin: 0 0 0 auto;
	    padding: 50px 0 220px 0;
        text-align: right;
	    }
}

/*__________________________________________________

  footer
  __________________________________________________*/
.footerBox {
    position: absolute;
    bottom: 0;
    clear: both;
    width: 100%;
	margin: 0 auto;
	padding: 0;
    background: #90ce9c;
	}

.footer-box {
    max-width: 1110px;
    width: 100%;
    margin: 0 auto;
	padding: 20px 0;
	color: #503927;
	}

.footer-box .box {
    width: 100%;
    margin: 0;
    padding: 0;
    font-size: clamp(0.75rem, 0.614rem + 0.68vw, 1.125rem); /* 12px-18pxで可変 */
    font-weight: 500;
    line-height: 1.6;
    }

.footer-logo {
    max-width: 684px;
    width: 100%;
    margin: 0;
    padding: 0;
    }

.footer-logo02 {
    max-width: 309px;
    width: 100%;
    margin: 20px 0 0 0;
    padding: 0;
    }

@media only screen and (max-width: 1024px) {
    .footer-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 10px 0;
        }
}

@media only screen and (max-width: 768px) {
    .footerBox {
        position: absolute;
        bottom: 0;
        clear: both;
        width: 100%;
        margin: 0 auto;
        padding: 0;
        background: #90ce9c;
        }
    
    .footer-box {
        max-width: 100%;
        width: 90%;
        margin: 0 auto;
        padding: 10px 0;
        }
    
    .footer-box .box {
        width: 100%;
        margin: 0;
        padding: 0;
        }
    
    .footer-logo {
        max-width: 100%;
        width: 90%;
        margin: 0;
        padding: 0;
        }

    .footer-logo02 {
        max-width: 100%;
        width: 50%;
        margin: 20px 0 0 0;
        padding: 0;
        }
}

/*__________________________________________________    

  ctaBox
  __________________________________________________*/
.ctaBox {
    position: fixed;
    z-index: 2;
    top: 620px;
	width: 100%;
	margin: 0;
	padding: 0;
    text-align: right;
	}

.ctaBox .cta-box {
    max-width: 100%;
    width: 100%;
    margin: 0 0 0 auto;
    padding: 0;
    }

.ctaBox .cta-box .cta-img {
    max-width: 234px;
    width: 100%;
    margin: 0 60px 0 0;
    padding: 0;
    }

@media only screen and (max-width: 1500px) {
    .ctaBox {
        position: fixed;
        z-index: 2;
        top: 600px;
        width: 100%;
        margin: 0;
        padding: 0;
        text-align: right;
        }
    
    .ctaBox .cta-box {
        max-width: 100%;
        width: 100%;
        margin: 0 0 0 auto;
        padding: 0;
        }
    
    .ctaBox .cta-box .cta-img {
        max-width: 234px;
        width: 100%;
        margin: 0 0 0 0;
        padding: 0;
        }
}

@media only screen and (max-width: 1024px) {
    .ctaBox {
        position: fixed;
        z-index: 2;
        top: unset;
        bottom: 0;
        width: 100%;
        margin: 0;
        padding: 0;
        text-align: right;
        }

    .ctaBox .cta-box {
        max-width: 100%;
        width: 100%;
        margin: 0 0 0 auto;
        padding: 0;
        }

    .ctaBox .cta-box .cta-img {
        max-width: 234px;
        width: 100%;
        margin: 0;
        padding: 0;
        }
}

@media only screen and (max-width: 768px) {
    .ctaBox {
        position: fixed;
        z-index: 2;
        top: unset;
        bottom: 0;
        width: 100%;
        margin: 0;
        padding: 0;
        text-align: right;
        }

    .ctaBox .cta-box {
        max-width: 100%;
        width: 100%;
        margin: 0 0 0 auto;
        padding: 0;
        }

    .ctaBox .cta-box .cta-img {
        max-width: 234px;
        width: 100%;
        margin: 0;
        padding: 0;
        }
}

@media only screen and (max-width: 640px) {
    .ctaBox {
        position: fixed;
        z-index: 2;
        top: unset;
        bottom: 0;
        width: 100%;
        margin: 0;
        padding: 0;
        text-align: right;
        }

    .ctaBox .cta-box {
        max-width: 100%;
        width: 100%;
        margin: 0 0 0 auto;
        padding: 0;
        }

    .ctaBox .cta-box .cta-img {
        max-width: 100%;
        width: 30%;
        margin: 0;
        padding: 0;
        }
}

@media only screen and (max-width: 414px) {
    .ctaBox {
        position: fixed;
        z-index: 2;
        top: unset;
        bottom: 0;
        width: 100%;
        margin: 0;
        padding: 0;
        text-align: right;
        }

    .ctaBox .cta-box {
        max-width: 100%;
        width: 100%;
        margin: 0 0 0 auto;
        padding: 0;
        }

    .ctaBox .cta-box .cta-img {
        max-width: 100%;
        width: 30%;
        margin: 0;
        padding: 0;
        }
}


/*__________________________________________________

  common
  __________________________________________________*/
@media (max-width: 768px) {
	.pconly {
	    display: none;
	    }
}

@media (min-width: 768px) {
	.sponly {
	    display: none;
	    }
}

@media screen and (max-width: 1024px) {
    .br-sp { display: none; }
}

@media screen and (min-width: 768px) {
    .br-pc { display: none; }
}

hr.type01 {
	margin: 10px 0 40px 0;
	padding: 0;
	border: none;
    border-top: dotted 1px #cccccc;
    height: 1px;
    color: #FFFFFF;
	}

