@charset "utf-8";
html {
  visibility: hidden;
}
html.wf-active, html.wfno-load {
    visibility: visible;
}
img{
    display: block;
    width:100%;
    height:auto;
    object-fit: cover;
}
a {
    font-family: "Shippori Mincho", serif;
}
a.anchor{
    display: block;
    position: relative;
    top: -150px;
    visibility: hidden;
}
body{
    color:#303534;
}
body.top{
    animation: loading 2s;
}
@keyframes loading {
    0% {
        opacity: 0.5;
    }
    100% {
        opacity: 1;
    }
}
body p, .yu-g, th, td{
    font-family: "yu-gothic-pr6n", sans-serif;
    font-weight: 400;
    font-style: normal;
}
h1, h2, h3, h4, h5, h6{
    font-family: "Shippori Mincho", serif;
}
h1, h2, h3, h4, h5, h6{
    line-height: 1.3em;
}
.h_type01{
    font-size:clamp(22px,3vw,36px);
    color:#4b7e2e;
    font-weight: 600;
}
.h_type02{
    display: flex;
    flex-flow: column;
    font-size:clamp(22px,5vw,36px);
    color:#4b7e2e;
    font-weight: 400;
    text-align: center;
    line-height: 1.2em;
}
.h_type02 span{
    display: inline-block;
    font-family: "sheila", serif;
    font-size:22px;
    line-height: 1.5em;
}
.h_type03{
    display: flex;
    align-items: baseline;
    font-size:clamp(22px,3vw,36px);
    color:#4b7e2e;
    font-weight: 600;
}
.h_type03 span{
    font-family: "sheila", serif;
    font-size:clamp(16px,3vw,22px);
}
.l_btn{
    display:flex;
    justify-content: center;
    align-items:center;
    width:320px;
    height:55px;
    margin:0 auto;
    text-align: center;
    font-size:18px;
    font-weight: 400;
    line-height: 1.3em;
    border-radius: 50px;
}
.l_btn:hover{
    opacity: 0.7;
    transition: .3s;
}
.l_btn img, .l_btn.type02 img{
    width:14px;
    margin-left:10px;
}
.l_btn.type01{
    color:#fff;
    background-color:#4b7e2e;
}
.l_btn.type01.orange{
    background-color:#b48b39;
}
.l_btn.type01.red{
    background-color:#862154;
}
.l_btn.type01 i{
    margin-left:1em;
}
.l_btn.type02{
    color:#4b7e2e;
    border:solid 1px;
    background-color:transparent;
}
.l_btn.type03{
    color:#4b7e2e;
    border:solid 1px;
    border-radius: 0;
}
.l_btn.type04{
    font-size:16px;
}
.link-box_2{
    display: flex;
    justify-content: space-around;
    width:100%;
}
.link-box_2.small{
    justify-content: flex-start;
}
.link-box_2.small a.l_btn{
    width:160px;
    height:35px;
    font-size:14px;
}
.link-box_2.small a:nth-of-type(1){
    margin-right:2em;
}
img.type01{
    margin-top:50px;
    height:380px;
}
body p{
    line-height:1.8em;
}
.sheila {
    font-family: "sheila", serif;
    font-weight: 400;
    font-style: normal;
}
.sheila_b {
    font-family: "sheila", serif;
    font-weight: 700;
    font-style: normal;
}
.sh {
    font-family: "Shippori Mincho", serif;
}
body p{
    font-size:clamp(14px, 5vw, 16px);
}
.pc{
    display: block;
}
.ip{
    display: none;
}
.sp{
    display: none;
}
.contact-btn {
    position: fixed;
    right: 3vw;
    bottom: 5vh;
    z-index: 99;
    width: 120px;
    height: 120px;
    background: #db7093;
    transform: rotate(45deg);
    color:#f2f2f2;
    background-color:#862154;
}
.contact-btn span.border {
    border: solid 1px #f2f2f2;
    width: 110px;
    height: 110px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.contact-btn .text{
    position: absolute;
    transform: rotate(-45deg);
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width:110px;
    height:110px;
    font-family: "Shippori Mincho", serif;
    text-align: center;
    line-height: 1.3em;
}
.contact-btn .sheila{
    font-weight: 100;
/*    margin-top:2px;*/
}
.contact-btn .text::before, .contact-btn .text::after{
    content:"";
    width:0.9px;
    height:56px;
    background-color:#f2f2f2;
    transform: rotate(90deg);
    position: absolute;
}
.contact-btn .text::before{
    top:-10px;
}
.contact-btn .text::after{
    bottom:-9px;
}
.contact-btn:hover{
    color:#862154;
    background-color:#f2f2f2;
    transition: .3s;
}
.contact-btn:hover .text::before, .contact-btn:hover .text::after{
    background-color:#862154;
}
.contact-btn:hover span.border{
    border:solid 0.8px #862154;
}
.wd01{
    width:80vw;
    max-width:1200px;
    margin:auto;
}
.wd02{
    width:80vw;
    max-width:1000px;
    margin:auto;
}
p.md {
    margin: 35px 1em 0;
    font-family: "Shippori Mincho", serif;
    font-size: clamp(18px, 2vw, 24px);
    line-height: 1.4em;
}
p.lw{
    margin:35px 1em 50px;
}
.pd100{
    padding:100px 0;
}
.pd50{
    padding:50px 0;
}
.pd_t50{
    padding-top:50px;
}
.pd_t100{
    padding-top:100px;
}
.pd_b100{
    padding-bottom:100px;
}
ul.list_note li{
    font-family: "yu-gothic-pr6n", sans-serif;
    text-indent: -1em;
    margin:0 0 0 1em;
    line-height: 1.8em;
}
section.type01 .box01{
    padding:50px 0 100px;
}
section.type01 .box01, div.type01, section.type02 .box01{
    display: flex;
    flex-flow: column;
    align-items: center;
    text-align: center;
}
section.type01 img.catch{
    height:70vh;
    min-height:300px;
}
section.type02 .box01{
    padding:50px 0 50px;
}
section.type03 img.catch{
    height:60vh;
    min-height:320px;
    margin-top:35px;
}
section.type03 .box01{
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin:35px 0 80px;
}
section.type03 .box01 p.md{
    margin:35px 0 0;
}
section.type03 .box01 p.lw{
    margin:35px 0 50px;
}
section.type03 .box01.reverse{
    flex-flow: row-reverse;
}
section.type03 .box01 .wrap{
    margin-right:1em;
}
section.type03 .box01.reverse .wrap{
    margin-right:inherit;
    margin-left:1em;
}
section.type03 .box01 img{
    width:50%;
    height:400px;
}
section.type04 img.catch{
    height:70vh;
    min-height:500px;
}
section.type04 .box01{
    display: flex;
    justify-content: space-between;
    margin:50px 0;
}
section.type04 .box01.reverse{
    flex-flow: row-reverse;
}
section.type04 .box01 .cont01{
    width:40%;
    max-width:800px;
    padding:50px 3% 50px 10vw;
    background-color:#fff;
}
section.type04 .box01 .cont01 h3{
    flex-flow: column;
}
section.type04 .box01 .cont01 p.md{
    margin:35px 0 0;
}
section.type04 .box01 .cont01 p.lw{
    margin:35px 0 50px;
    word-break: keep-all;
    overflow-wrap: break-word;
}
section.type04 .box01.reverse .cont01{
    padding:50px 10vw 50px 3%;
}
section.type04 .box01 img{
    width:50%;
    max-height:600px;
    clip-path: polygon(15% 0%, 100% 0%, 100% 100%, 0 100%);
}
section.type04 .box01.reverse img{
    clip-path: polygon(100% 100%, 85% 0%, 0% 0%, 0% 100%);
}
section.type04 .box01 .cont01 .l_btn{
    margin:0;
}
section.type04 .overview{
    background-color:#f2f2f2;
}
section.type04 .overview h4{
    font-size:clamp(18px, 5vw, 26px);
    text-align: center;
    padding:50px 0 35px;
}
section.type04 .overview p{
    padding:0 50px 50px;
}
section.s_smpl{
    margin-top:50px;
}
ul.type01{
    display: flex;
    justify-content: space-between;
}
ul.type01 li.box{
    width:32%;
}
ul.type01 img{
    height:260px;
}
ul.type01 li.box:nth-of-type(1) img{
    margin-bottom:30px;
}
section.outdoor ul.type01 li.box:nth-of-type(1) img{
    margin-bottom:0;
}
ul.type01 h3{
    margin:15px 0;
    padding-bottom:15px;
    text-align: center;
    font-size:clamp(18px, 3vw, 26px);
    font-weight: 500;
    border-bottom: solid 1px #c0ba98;
}
ul.type01 ul li{
    display: flex;
    align-items: baseline;
    margin-bottom:5px;
}
ul.type01 ul li::before{
    content:'・';
}
ul.type01 ul.case li::before{
    content:'■';
    font-size:20px;
}
ul.type02{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    margin:10px 0 50px;
}
ul.type02 li{
    width:32%;
    margin-bottom:35px;
}
ul.type02 li img{
    height:280px;
}
ul.type02 li h4, .drink-wrap h4{
    margin:10px 0 0;
    padding:8px 0 10px;
    font-size:clamp(18px, 3vw, 24px);
    font-weight: 600;
    border-top:solid 1px #CCCCCC;
}
.drink-wrap{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    margin-bottom:50px;
}
.drink-wrap.plan{
    width:100%;
}
.drink-wrap.plan h4{
    font-size:18px;
    font-weight: normal;
}
.drink-wrap.plan ul.detail{
    margin:35px 0 50px;
}
.drink-wrap .box01{
    width:48%;
}
.drink-wrap.plan .box01{
    width:100%;
}
table.drink{
    width:100%;
    border-collapse: collapse;
}
table.drink th, table.drink tr.border td, table.drink.other td, table.drink.plan td{
    border-bottom: solid 1px #ececec;
}
table.drink th, table.drink td{
    padding:10px;
}
table.drink th{
    text-align: left;
}
table.drink tr:nth-last-of-type(1) th, table.alcohol tr:nth-last-of-type(2) th, table.drink.other tr:nth-last-of-type(1) td, table.drink.plan tr:nth-last-of-type(1) td{
    border:none;
}
table.alcohol td:nth-of-type(2), table.other td{
    text-align: right;
}
table.drink.plan{
    width:50%;
}
table.drink.plan th{
    width:12em;
}
table.type01{
    width:100%;
    border-collapse: collapse;
    line-height: 1.3em;
    margin:10px 0;
}
table.type01 tr{
    display: flex;
    justify-content: space-between;
    align-items: center;
    height:90px;
    border-bottom:solid 1px #ececec;
}
table.type01 tr:nth-of-type(1){
    background-color:#ececec;
    height:75px;
    border-bottom:none;
}
table.type01 tr:nth-of-type(1) th{
    font-weight: 500;
}
table.type01 th a{
    font-family: "yu-gothic-pr6n", sans-serif;
    font-weight: 400;
    color: #4b7e2e;
}
table.type01 tr th, table.type01 tr td{
    width:23%;
    text-align: center;
}
table.type02{
    width:100%;
    border-collapse: collapse;
    line-height: 1.3em;
    margin:10px 0;
}
table.type02 tr{
    display: flex;
    justify-content: space-between;
    align-items: center;
    height:90px;
    background-color:#fff;
    border-bottom:solid 1px #f2f2f2;
}
table.type02 tr:nth-of-type(1) th{
    font-weight: 600;
}
table.type02 tr th, table.type02 tr td{
    width:50%;
    text-align: center;
}
header{
    position: fixed;
    top:0;
    left:0;
    z-index: 800;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width:100%;
    height:70px;
    background-color:#ebebeb;
}
header .wd01{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
header img.logo{
    width:180px;
}
header .box01{
    display: flex;
    justify-content: space-around;
}
header .box01 img{
    width:14px;
    object-fit: contain;
    margin-right:8px;
}
header .box01 a{
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right:1em;
}
header .box01 a.tel{
    margin-right:100px;
/*    margin-right:2em;*/
    padding:10px 30px;
    color:#B48B39;
    border:solid 1px #B48B39;
    border-radius: 50px;
    letter-spacing: 1px;
}
header .box01 a.tel:hover{
    color:#fff;
    background-color:#B48B39;
    transition: .3s;
}
header .box01 a.tel:hover img{
    filter:drop-shadow(1px 1px 0px #fff);
}
/*
header .box01 a:nth-of-type(n+2):hover{
    opacity: 0.7;
    transition: .3s;
}
*/
/*
header .box01 a:nth-last-of-type(1){
    margin-right:100px;
}
*/
header .box01 .sns{
    display: flex;
    align-items: center;
    margin-right:2em;
}
header .box01 .sns a:hover, a.access:hover, a.price:hover{
    opacity: 0.7;
    transition: .3s;
}
.eyecatch.top{
    position: relative;
}
.eyecatch.top .box01 {
    position: absolute;
    top: 0;
    bottom: 0;
    display: flex;
    flex-flow: column;
    justify-content: center;
    margin: auto 0;
    width: 100%;
    height: 360px;
    color:#fff;
    background-color: rgb(0, 0, 0, 0.5);
    text-align: center;
    z-index: 3;
}
.eyecatch.top .box01 h2{
    font-size:clamp(26px,5vw,48px);
    font-weight: 500;
    line-height: 1em;
}
.eyecatch.top .box01 p{
    margin:1em 0;
}
.eyecatch.top .box01 h2, .eyecatch.top .box01 p{
    text-shadow:2px 2px 0 rgb(0,0,0,0.8);
}
.eyecatch.top .box01 h2 span.wrap{
    font-size:clamp(24px,5vw,42px);
}
.eyecatch.top .box01 h2 span.small{
    font-size:clamp(18px,3vw,38px);
}
.eyecatch.top .box01 ul{
    display: flex;
    justify-content: center;
    align-items: center;
    width:70%;
    margin:0 auto;
}
.eyecatch.top .box01 ul li{
    display: flex;
    justify-content: center;
    align-items: baseline;
    width:28%;
    margin:auto 1em;
    padding:7px 0;
    background-color:#7a3034;
    font-weight: 300;
}
.eyecatch.top .box01 ul li span{
    font-size:24px;
    margin:0 3px;
}
.eyecatch.sub{
    height:35vh;
    min-height:500px;
    background-repeat: no-repeat;
    background-size: cover;
}
.eyecatch.sub .box01{
    width:100%;
    height:100%;
    background-color:rgb(0,0,0,0.25);
    position: relative;
}
.eyecatch.sub .box01 h2 {
    position: absolute;
    top: 50px;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    margin: auto;
    font-size:clamp(36px, 5vw, 48px);
    font-weight: 400;
    line-height: 1em;
    color:#fff;
}
.eyecatch.sub .box01 h2 span{
    font-family: "sheila", sans-serif;
    font-size:22px;
}
.eyecatch.sub.low{
    height:25vh;
    min-height:210px;
}
.eyecatch.sub.low .box01 h2{
    font-size:clamp(28px, 5vw, 36px);
}
.eyecatch.training{
    background-image: url(../img/tr-dai_ex.jpg);
    background-position:50% 35%;
}
.eyecatch.guestroom{
    background-image: url(../img/e-catch_room.jpg);
    background-position: 50% 55%;
}
.eyecatch.meal{
    background-image: url(../img/e-catch_dining.jpg);
    background-position: 50% 55%;
}
.eyecatch.outdoor{
    background-image: url(../img/e-catch_outdoor.jpg);
    background-position: 50% 35%;
}
.eyecatch.information{
    background-image: url(../img/lobby01.jpg);
    background-position: 50% 45%;
}
.eyecatch.blog{
    background-image: url(../img/e-catch_blog.jpg);
    background-position: 50% 90%;
}
.eyecatch.hidamari{
    background-image: url(../img/hidamari01.jpg);
    background-position: 50% 60%;
}
section.gray{
    background-color:#f2f2f2;
}
/*top　コンセプト*/
section.concept.top{
    background-image: url(../img/bg-forest01.png);
    background-repeat: no-repeat;
    background-position:top right;
    background-size: contain;
    position: relative;
    height:800px;
    padding:100px 0 250px;
}
section.concept.top .wrap{
    height:100%;
    position: relative;
}
section.concept.top .box01{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    width:50vw;
    background-color:rgb(236,236,236,0.75);
    box-shadow:10px 10px 1px rgb(0,0,0,0.3);
    position: absolute;
    top:0;
    z-index: 5;
}
section.concept.top .box01 .cont01{
    margin:50px 50px 50px 10vw;
}
section.concept.top .box01 h2{
    margin-bottom:1em;
}
section.concept.top .box01 p{
    margin-top:10px;
}
section.concept.top img{
    width:auto;
}
section.concept.top img:nth-of-type(1){
    position: absolute;
    bottom:0;
    width:40%;
    margin:0 0 0 10vw;
}
section.concept.top img:nth-of-type(2){
    position: absolute;
    right:0;
    bottom:0;
    width:60%;
    clip-path: polygon(15% 0%, 100% 0%, 100% 100%, 0% 100%);
}
section.concept.top .box02{
    display: flex;
    justify-content: center;
    margin:80px auto;
}
/*top 芝生広場*/
section.use.top img{
    object-position: 50% 80%;
}
section.use.top h2 span:nth-of-type(2){
    line-height: 0.7em;
}
section.use.top h2 span:nth-of-type(2) span{
    font-size:24px;
}
/*top 研修施設*/
section.training.top .box02{
    display: flex;
    justify-content: space-around;
    width:50%;
    margin:auto;
}
section.training.top .box02 .cont01{
    display: flex;
    justify-content: center;
    align-items: center;
    width:180px;
    height:180px;
    text-align: center;
    color:#f2f2f2;
    background-color:#aa8336;
    border-radius: 50%;
}
section.training.top .box02 .cont01 p{
    font-size: 24px;
    font-family: "Shippori Mincho", serif;
    line-height: 1.4em;
}
ul.training-box{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: flex-start;
    width:1200px;
    margin:50px auto;
}
ul.training-box li{
    position: relative;
    width:33%;
    height:280px;
    margin-bottom:6px;
    color:#fff;
}
ul.training-box li a{
    display: block;
    width:100%;
    height:100%;
}
ul.training-box li .wrap{
    position: absolute;
    bottom:0;
    z-index: 2;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width:100%;
    height:60px;
    background:linear-gradient(to bottom, rgb(0,0,0,0), rgb(0,0,0,1));
}
ul.training-box li h3{
    margin-left:20px;
    font-size:22px;
}
ul.training-box li .wrap .cont01{
    display: flex;
    align-items: center;
    margin-right:20px;
}
ul.training-box li .wrap .num p{
    font-size:14px;
}
ul.training-box li .wrap .num span:nth-of-type(1){
    margin:0 0 0 4px;
    font-size:clamp(22px, 5vw, 36px);
    font-weight: 800;
}
ul.training-box li .wrap .num span:nth-of-type(2){
    font-size:16px;
    font-weight: 800;
}
ul.training-box li .wrap .anc{
    display: flex;
    justify-content: center;
    align-items: center;
    width:70px;
    height:40px;
    margin-left:10px;
    font-size:14px;
    border:solid 1px;
}
ul.training-box li a:hover .anc{
    color:#fff;
    background-color:#4b7e2e;
    border-color:#4b7e2e;
    transition: .5s;
}
ul.training-box li a img{
    height:280px;
    transform: scale(1);
    transition: .5s ease-in-out;
}
ul.training-box li a:hover img, ul.recomm-box li:hover img{
    transform: scale(1.1);
}
ul.training-box li a .scale, ul.recomm-box li .scale{
    display: block;
    line-height: 0;
    overflow: hidden;
}
/*top このようなお客様へ*/
ul.recomm-box{
    display: flex;
    justify-content: space-between;
    width:1200px;
    margin:35px auto 0;
}
ul.recomm-box li{
    width:380px;
    height:380px;
    position: relative;
}
ul.recomm-box li a{
    display: block;
    width:100%;
    height:100%;
    position: absolute;
    z-index: 2;
}
ul.recomm-box li .wrap{
    position: absolute;
    top:0;
    bottom:0;
    right:0;
    left:0;
    margin:auto;
    z-index: 2;
    width:360px;
    height:360px;
    border:solid 1px #fff;
}
ul.recomm-box li .wrap div{
    position: absolute;
    right:0;
    left:0;
    bottom:20px;
    display: flex;
    justify-content: center;
    align-items: center;
    height:50px;
    margin:auto 2em;
    text-align: center;
    font-size:20px;
    font-weight: 400;
    color:#fff;
    background-color:#7a3034;
}
ul.recomm-box li .scale{
    position: absolute;
    z-index: 1;
}
ul.recomm-box li .scale img{
    height:380px;
    transform: scale(1);
    transition: .5s ease-in-out;
}
ul.recomm-box li:hover img{
    transform: scale(1.1);
}
ul.recomm-box li:hover .wrap div{
    color:#7a3034;
    background-color:#fff;
    transition: .5s;
}
/*top 宿泊と食事*/
section.service .box01{
    width:1200px;
    margin:35px auto 0;
}
section.service .box01 .wrap{
    display: flex;
    flex-flow: row wrap;
}
section.service .box01 .wrap.reverse{
    flex-flow:row-reverse;
}
section.service .box01 img{
    width:600px;
    height:600px;
}
section.service .box01 .cont01{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width:600px;
    height:600px;
    text-align: center;
    background-color:#fff;
}
section.service .box01 h3{
    font-size:clamp(18px, 3vw, 26px);
    font-weight: 500;
}
section.service .box01 p{
    margin:40px 0;
}
/*top 屋外エリア*/
section.outdoor.top{
    background-color: #e3e9e1;
}
section.outdoor.top .wrap{
    position: relative;
}
section.outdoor.top .bg-box{
    position: absolute;
    top:0;
    z-index: 0;
    width:30%;
}
section.outdoor.top .bg-box img{
    height:100%;
}
section.outdoor.top .bg01{
    left:0;
    height:100%;
}
section.outdoor.top .bg01 img{
    object-position: right;
}
section.outdoor.top .bg02{
    right:0;
}
section.outdoor.top .bg02 img{
    object-position: left;
}
section.outdoor.top .box01, section.outdoor.top .box02{
    position:relative;
    z-index: 1;
}
section.outdoor.top .box02{
    width:1200px;
    margin:auto;
}
section.outdoor.top .box02 .cont01, section.outdoor.top .box02 .cont02{
    display: flex;
    flex-flow: row nowrap;
    height:400px;
}
section.outdoor.top .box02 .cont01 img{
    width:600px;
}
section.outdoor.top .box02 .cont02 img{
    width:400px;
}
section.outdoor.top .box02 .cont02 img.bbq{
    object-position: 80% 50%;
}
/*aside お知らせ*/
section.news.aside ul{
    margin:35px 0 50px;
}
section.news.aside ul li{
    display: flex;
    align-items: center;
    margin:1em 0 2em;
    padding:1em 0;
    border-bottom:solid 1px #ececec;
}
section.news.aside ul li a{
    display: flex;
}
section.news.aside ul li .wrap{
    display: flex;
    align-items: center;
}
section.news.aside ul li .category{
    display: flex;
    justify-content: center;
    align-items: center;
    font-size:10px;
    width:80px;
    height:20px;
    margin-right:2em;
    color:#fff;
    background-color:#7a3034;
}
section.news.aside ul li .day{
    margin-right:2em;
    color:#c0ba98;
}
section.news.aside ul li h3{
    font-weight: 500;
}
/*top aside SDGs*/
section.sdgs.aside ul{
    display: flex;
    justify-content: space-between;
    margin:35px 0 50px;
}
section.sdgs.aside ul li{
    display: flex;
    width:30%;
    margin-bottom:30px;
}
section.sdgs.aside ul li a{
    width:100%;
}
section.sdgs.aside ul li img{
    width:100%;
    height:200px;
}
section.sdgs.aside ul li .day{
    display: inline-flex;
    font-size:12px;
    color:#808080;
    margin:1em 0;
}
/*aside アクセス*/
section.access iframe{
    width:100%;
    height:460px;
    margin-top:35px;
}
section.access .cont01{
    display: flex;
    justify-content: center;
    margin:2em 0;
    text-align: center;
}
/*footer*/
footer{
    padding:100px 0 200px;
    color:#fff;
    background-color:#464d4b;
    background-image: url(../img/bg-footer.svg);
    background-repeat: repeat-x;
    background-position:left bottom;
}
footer a{
    font-family: "yu-gothic-pr6n", sans-serif;
}
footer .wd01{
    display: flex;
    flex-flow: column;
    justify-content: space-around;
    height:100%;
}
footer .box01{
    display: flex;
    justify-content: space-between;
    margin-right:80px;
}
footer .box01 .cont01{
    display: flex;
    flex-flow: column;
}
footer ul{
    display: inline-flex;
    flex-flow: column;
    margin-bottom:3em;
}
footer ul li{
}
footer ul li a{
    display: block;
    padding:5px 0;
}
footer ul li:nth-of-type(1){
    font-size:18px;
    font-weight: 800;
    margin-bottom:1em;
}
footer ul li:nth-of-type(n+2){
    padding-left:5px;
}
footer .box02{
    display: flex;
    flex-flow: column;
    align-items: flex-end;
    text-align: right;
}
footer .box02 .cont01{
    display: flex;
}
footer .box02 .cont01 img{
    width:200px;
    margin-left:2em;
}
footer .box02 p{
    margin:1em 0;
}
footer small{
    font-size:12px;
    margin-top:35px;
}
/*about*/
a.link_d{
    margin-top:50px;
    text-decoration: underline;
}
ul.aof{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap:25px 2%;
    margin:50px auto 0;
}
ul.aof .l_btn{
    width:auto;
}
/*donation*/
.concept{
    margin-bottom:100px;
}
ul.smpl{
    margin:100px auto;
}
ul.smpl h3{
    margin-bottom:10px;
    padding-bottom:10px;
    font-size:clamp(18px, 5vw, 26px);
    border-bottom:solid 1px #c0ba98;
}
ul.smpl li{
    margin-top:100px;
}
ul.smpl ul li{
    display: flex;
    align-items: baseline;
    margin-top:0;
}
ul.smpl ul li::before{
    content:'・';
}
/*training*/
section.training.concept .box02 .wrap{
    display: flex;
}
section.training.concept .box02 .wrap.reverse{
    flex-flow: row-reverse;
    margin-top:50px;
    padding-top:50px;
    border-top:solid 1px #c0ba98;
}
section.training.concept .box02 img{
    width:50%;
}
section.training.concept .box02 .cont01{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    width:100%;
    margin-left:2em;
}
section.training.concept .box02 .wrap.reverse .cont01{
    margin-left:inherit;
    margin-right:2em;
    word-break: keep-all;
    overflow-wrap: break-word;
}
section.training.concept .box02 h3{
    width:100%;
    margin-bottom:10px;
    padding-bottom:10px;
    font-size:clamp(18px, 3vw, 26px);
    font-weight: 500;
    border-bottom:solid 1px #4b7e2e;
}
section.training.concept .box02 h4{
    font-family: "yu-gothic-pr6n", sans-serif;
    font-weight: 500;
    margin:20px 0 5px;
}
section.fmap img.map{
    width:80vw;
    max-width:1200px;
    margin:50px auto 100px ;
}
section.fmap{
    padding-bottom:100px;
}
section.training.detail.type02 .box01{
    flex-flow: row nowrap;
    align-items: flex-start;
}
section.training.detail .cont01{
    width:50%;
    height:610px;
    position: relative;
}
section.training.detail .banner{
    position: absolute;
    top:10px;
    left:10px;
    z-index: 5;
    display: flex;
    justify-content: center;
    align-items: center;
    width:180px;
    height:100px;
    font-family: "Shippori Mincho", serif;
    font-size:22px;
    font-weight: 600;
    color:#fff;
    background-color:rgb(0,0,0,0.6);
}
section.training.detail .cont02{
    width:50%;
    margin-left:2em;
    text-align: left;
    word-break: keep-all;
    overflow-wrap: break-word;
}
section.training.detail .cont02 h3{
    display: flex;
    align-items: center;
    font-size:clamp(20px, 3vw, 26px);
}
section.training.detail .cont02 h3 span{
    margin-left:1em;
    font-size:16px;
    font-weight: 400;
}
section.training.detail .cont02 ul{
    margin-top:10px;
}
section.training.detail .cont02 ul li{
    display: flex;
    align-items: baseline;
    padding:20px 0;
    border-bottom:solid 1px #ECECEC;
}
section.training.detail .cont02 ul li:nth-last-of-type(1){
    flex-flow: column;
    border-bottom:none;
}
section.training.detail .cont02 ul li h4{
    width:20%;
    font-family: "yu-gothic-pr6n", sans-serif;
    font-weight: 500;
}
section.training.detail .cont02 ul li p{
    width:80%;
}
section.training.detail .cont02 ul li:nth-last-of-type(1) p{
    width:auto;
}
section.training.detail .cont02 ul .link-box_2{
    margin-top:1em;
}
section.training.detail .cont02 ul .l_btn{
    margin:0 1em 0 0;
}
/*slick*/
.slide-forwrap{
    margin-bottom:15px;
}
.slide-forwrap li{
    width:100%;
    height:460px;
}
.slide-navwrap{
    width:100%;
}
.slide-navwrap li{
    height:80px;
}
.slide-forwrap img, .slide-navwrap img{
    height:100%;
}
.slide-navwrap img{
    width:110px;
    margin:auto;
}
/*guestroom*/
section.guestroom.concept .box02{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
section.guestroom.concept .box02 .cont01{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width:270px;
    height:300px;
    text-align: center;
    white-space: nowrap;
    background-color:#f2f2f2;
}
section.guestroom.concept .box02 .cont01 h3{
    margin-bottom:20px;
    padding-bottom:20px;
    font-size:18px;
    border-bottom:solid 1px #4b7e2e;
    word-break:break-all;
}
section.guestroom.concept .box02 .cont01 img{
    height:70px;
    object-fit: contain;
    margin:0 auto 20px;
}
section.guestroom .overview{
    background-color:#f2f2f2;
    margin-bottom:50px;
}
section.guestroom .overview ul:nth-child(1){
    padding:50px;
}
section.guestroom .overview ul li{
    margin:35px 0;
}
section.guestroom .overview ul ul li:nth-child(1){
    margin:5px 0 35px;
}
section.guestroom .overview h4, section.guestroom .overview h5{
    font-family: "yu-gothic-pr6n", sans-serif;
}
section.guestroom .overview h5{
    font-weight: 400;
}
section.guestroom.points ul{
    margin:50px 0 0;
}
section.guestroom.points ul li{
    padding-left:1em;
    font-weight: 400;
    line-height: 2em;
}
section.guestroom.points ul li::before{
    content:'・';
    margin-left:-1em;
}
/*outdoor*/
/*meal*/
section.meal.type03 .box01 .wrap{
    margin-right:2em;
}
section.meal.type03 .box01 .wrap p.lw{
    word-break: keep-all;
}
section.meal.detail ul.type01{
    margin-bottom:50px;
}
ul.dining-time{
    margin:auto;
    padding:5px 1.6em;
    background-color:#f2f2f2;
}
ul.dining-time h4{
    font-family: "yu-gothic-pr6n", sans-serif;
}
ul.dining-time li{
    margin:15px 0;
    font-weight: 400;
    font-family: "yu-gothic-pr6n", sans-serif;
}
ul.dining-time li .clock{
    display: inline-block;
    text-align: right;
    width:2.8em;
}
ul.dining-time li .clock:nth-of-type(1){
    display: inline-block;
    margin:0 5px 0 0;
}
section.meal.s_smpl a.l_btn{
    width:380px;
    margin:50px auto;
    line-height: 1.3em;
}
section.meal.notes .box01{
    margin-bottom:50px;
}
section.meal.notes h3{
    margin-bottom:15px;
    padding:15px;
    font-size:clamp(18px, 3vw, 26px);
    background-color:#ececec;
}
/*information*/
.guide{
    margin-top:50px;
}
section.information h3{
    font-size:clamp(18px,3vw,26px);
}
/*contact*/
.alert{
    color:#9E2929;
    font-size:20px;
    font-weight: 800;
    margin:1em 0;
    padding:5px 10px;
    letter-spacing: 1.3px;
    text-shadow:0.1px 0.1px 0 #9E2929;
}
.con-anc{
    margin-top:35px;
    font-size:16px;
}
section.contact div.flow_row{
    width:100%;
}
section.contact div.flow_row h3{
    font-size:clamp(18px, 5vw, 26px);
    margin-bottom:35px;
    font-weight: 400;
}
ul.flow_row{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width:100%;
}
ul.flow_row li{
    display: flex;
    flex-flow: column;
    justify-content: center;
    width:18%;
    height:6em;
    background-color:#d8d7cd;
}
ul.flow_row li::after {
    content: '▶';
    color: #606060;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right:-11%;
}
ul.flow_row li:nth-last-of-type(1)::after, ul.flow_column li:nth-last-of-type(1)::after{
    content:inherit;
}
ul.flow_row li h4{
    font-size:18px;
}
ul.flow_row li span{
    margin-top:10px;
    font-family: "Shippori Mincho", serif;
    font-size:14px;
    font-weight: 600;
}
div.flow_column{
    width:100%;
}
ul.flow_column li{
    margin-bottom:100px;
    padding:35px;
    text-align: left;
    border:solid 1px #ECECEC;
}
ul.flow_column li::after {
    content: '';
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -90px;
    width: 50px;
    height: 50px;
    background-image: url(../img/arrow_bottom.png);
    background-repeat: no-repeat;
    background-size: contain;
}
ul.flow_column li h4{
    margin-bottom:10px;
    padding-bottom:10px;
    font-size:18px;
    border-bottom:solid 1px #C0BA98;
}
ul.flow_column li h4 span{
    font-size:16px;
    font-weight: 600;
    margin-left:1em;
}
section.form small{
    display: block;
    margin:35px 0;
    text-align: center;
}
form{
/*    width:80%;*/
    margin:100px auto;
    padding:50px;
    background-color:#f2f2f2;
}
form .cont01{
    display: flex;
    flex-flow: column;
    margin-bottom:35px;
}
form .cont02{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    margin-bottom:50px;
}
form .cont02 span{
    display: flex;
    align-items: center;
    margin-bottom:1em;
}
form .cont02 input{
    width:15px;
    height:15px;
}
form .cont02 label{
    margin-left:5px;
    padding-bottom:0;
    font-size:16px;
    font-weight: 500;
}
form .cont02 a{
    color:#4b7e2e;
    text-decoration: underline;
}
form label{
    padding-bottom:8px;
    font-size:18px;
    font-weight: 600;
}
form label span{
    color:#9E2929;
}
form input, form textarea{
    display: block;
    padding:10px;
    border:solid 1px #C0BA98;
    border-radius: 3px;
}
form button{
    cursor: pointer;
    border:none;
}
section.contact.tel .box01{
    flex-flow: row;
    justify-content: space-between;
    align-items: center;
    margin:50px auto;
    padding:50px;
    background-color:#f2f2f2;
}
section.contact.tel .box01 a{
    margin:0;
}
section.contact.tel .cont01{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    width:50%;
}
section.contact.tel .cont01 div{
    display: flex;
    width:100%;
    margin-bottom:15px;
    border-bottom:solid 1px #C0BA98;
}
section.contact.tel .cont01 p{
    font-size:26px;
    font-weight: 800;
}
section.contact.tel .cont01 img{
    width:25px;
    margin-right:10px;
    object-fit: contain;
}
section.contact.tel .cont01 span{
    margin-bottom:15px;
}
section.contact.tel .link-box_2{
    margin-top:100px;
}
div.thanks{
    text-align: center;
    margin-bottom:200px;
}
div.thanks p{
    margin-bottom:50px;
}
/*access*/
section.root h3{
    text-align: center;
    font-size:clamp(18px, 3vw, 26px);
    font-weight: 400;
}
section.root .box01{
    margin:50px 0;
    background-color:#f2f2f2;
}
section.root .box01 img{
    width:80vw;
    max-width:1000px;
    margin:auto;
    padding:80px 0;
}
/*hidamari*/
section.hidamari img.main{
    margin-bottom:35px;
}
section.hidamari img.sub{
    width:48%;
}
section.hidamari .box02 .cont01{
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
section.hidamari.detail .box01{
    text-align: center;
    margin-bottom:80px;
}
section.hidamari.detail .box01 h3{
    margin-bottom:15px;
    padding-bottom:15px;
    font-size:clamp(18px, 3vw, 26px);
    font-weight: 500;
    border-bottom: solid 1px #C0BA98;
}
section.hidamari div.detail img{
    width:18vw;
    max-width:260px;
}
section.hidamari div.detail .wrap{
    display: flex;
    justify-content: space-between;
    width:100%;
}
section.hidamari div.detail .cont01{
    margin-bottom:35px;
}
section.hidamari div.detail .cont02{
    width:75%;
    margin:auto;
}
iframe.hidamari{
    display: flex;
    width:50%;
    min-width:320px;
    max-width:1200px;
    aspect-ratio:16 / 9;
    margin:auto auto 100px;
}
/*blog*/
.pagination{
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: "yu-gothic-pr6n", sans-serif;
}
.pagination a{
    font-family: "yu-gothic-pr6n", sans-serif;
}
.page-numbers {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    margin-right: 10px;
    width: 45px;
    height: 45px;
    color: #4b7e2e;
    background: #fff;
    border: 1px solid #4b7e2e;
    border-radius: 50px;
}
.page-numbers.current{
    color:#fff;
    background: #4b7e2e;
}
.page-numbers.prev, .page-numbers.next{
    width: 40px;
    height: 40px;
    color: #4b7e2e;
    border-radius: 5px;
}
iframe.information-nav.news{
    width:100%;
    height:600px;
}
iframe.information-nav.sdgs{
    width:100%;
    height:700px;
}
iframe.information-nav.blog-news{
    width:100%;
    height:550px;
}
.link-title{
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}
section.news.aside .link-title{
    -webkit-line-clamp: 1;
}
ul.pnlink{
    display: flex;
    justify-content: space-between;
    border-top:solid 1.5px #C0BA98;
}
ul.pnlink li{
    display: flex;
    align-items: baseline;
    color:#4b7e2e;
    margin:8px 0;
}
ul.pnlink li a{
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    font-family: "yu-gothic-pr6n", sans-serif;
}
ul.pnlink li a:hover{
    text-decoration: underline;
}
.eyecatch.sub .box01 h2 a{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
}
ul.blog.nav{
    display: flex;
    justify-content: space-between;
    align-items: center;
    height:50px;
    margin:15px auto;
}
ul.blog.nav li{
    display: flex;
    justify-content: center;
    align-items: center;
    width:25%;
    height:100%;
    text-align: center;
    border-right:solid 2px #C0BA98;
}
ul.blog.nav li:nth-last-of-type(1){
    border-right:none;
}
ul.blog.nav li a{
    display: flex;
    justify-content: center;
    align-items: center;
    width:100%;
    height:100%;
    font-family: "yu-gothic-pr6n", sans-serif;
}
ul.blog.nav li a.current{
    color:#4b7e2e;
}
ul.blog.list{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap:0 3%;
    margin:50px auto 0;
}
ul.blog.list li{
    margin-bottom:80px;
}
ul.blog.list li img{
    height:240px;
    margin-bottom:15px
}
ul.blog.list li span.date, section.article span.date{
    display: flex;
    color:#808080;
    font-size:14px;
}
section.article a{
    color:#4b7e2e;
    text-decoration: underline;
}
section.article p img{
    width:auto;
    height:auto;
    max-width:100%;
}
span.category{
    color:#4b7e2e;
    margin-left:1em;
}
ul.blog.list li a:hover{
    opacity: 0.7;
    transition: .3s;
}
ul.blog.list li .link_title{
    margin:15px 0 30px;
}
ul.blog.list li h3{
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden;
    font-weight: 600;
}
section.article h2{
    margin:10px 0 20px;
    font-size:clamp(18px, 3vw, 26px);
    font-weight: 600;
}
section.article img{
    margin:15px 0;
}
/*slide*/
.slide-fade.top{
    background-color:#000;
}
.slide-fade.top img{
    height:100vh;
}
/*lp*/
body.lp, body.lp p{
    font-family: "Shippori Mincho", serif;
    font-weight: 600;
}
body.lp p.yu-g{
    font-family: "yu-gothic-pr6n", sans-serif;
}
.lp-wd01{
    width:90vw;
    max-width:1600px;
    margin:auto;
}
.lp-wd02{
    width:75vw;
    max-width:1200px;
    margin:auto;
}
.p-r{
    position: relative;
}
.lp-btn{
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-weight: 800;
    color:#fff;
}
.lp-btn.large{
    width:500px;
    height:55px;
    font-size: clamp(18px,5vw,28px);
    border-radius: 5px;
    box-shadow: 5px 5px 3px rgb(0,0,0,0.5);
}
.lp-btn.small{
    width:300px;
    height:35px;
    border-radius: 25px;
}
.lp-btn.orange{
    background-color:#a88039;
}
.lp-btn.orange:hover, .eyecatch.lp a:hover{
    background-color: #c7a15d;
    transition: .3s;
}
.lp-btn.green{
    background-color:#8caa91;
}
header.lp{
    background-color:#fff;
}
header.lp .lp-wd01, header.lp h1{
    display: flex;
    align-items: center;
}
header.lp .lp-wd01{
    justify-content: space-between;
}
header.lp h1{
    font-size:14px;
}
header.lp h1 img{
    margin-right:25px;
}
header.lp .box01{
    display: flex;
    align-items: center;
    font-weight: 700;
    color:#3b5f3a;
}
header.lp .box01 .text{
    display: flex;
    align-items: center;
}
header.lp .box01 i{
    font-size:22px;
}
header.lp a.tel{
    margin:0;
    padding:5px 10px;
    font-size:24px;
    color:#3b5f3a;
    border:none;
}
header.lp a.tel:hover{
    color:#3b5f3a;
    background-color:#fff;
    opacity: 0.7;
    transition: .3s;
}
header.lp a.form{
    margin:0 0 0 15px;
    padding:10px 25px;
    font-weight: 500;
    color:#fff;
    background-color: #3b5f3a;
    border-radius: 25px;
}
.eyecatch.lp .title_sp{
    display: none;
}
.eyecatch.lp{
    display: flex;
    flex-flow: column;
    justify-content: flex-start;
    height:90vh;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    position: relative;
}
.eyecatch.lp a{
    position: absolute;
    right:0;
    bottom:40px;
    z-index: 500;
    display: flex;
    align-items: center;
    width:35vw;
    height:55px;
    color:#fff;
    background-color: #a88039;
    border-radius: 10px 0 0 10px;
    box-shadow:3px 3px 2px rgb(0,0,0,0.7);
}
.eyecatch.lp a p{
    margin:0 10vw 0 3em;
    font-size:26px;
    font-weight: 700;
    white-space: nowrap;
}
.eyecatch.lp a img{
    position: absolute;
    top:-25px;
    left:-30px;
    width:120px;
    z-index: 5;
}
section.lp h2{
    font-size: clamp(22px,5vw,28px);
    color: #4b7e2e;
    font-weight: 600;
    line-height: 1.6em;
}
section.lp h2 span{
    font-size: clamp(22px,5vw,36px);
}
section.lp.concept ul li{
    display: flex;
    align-items: center; 
}
section.lp.concept ul li::before{
    content:"";
    width:20px;
    height:20px;
    margin:0 1em 0 0;
    background-image: url(../img/icon_check.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}
.lp.arrow{
    position: absolute;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width:100%;
    height:260px;
    text-align: center;
}
.lp.arrow .arrow-box{
    position: absolute;
    z-index: 2;
}
.lp.arrow .bg{
    position: absolute;
    width:100%;
    height:260px;
    clip-path: polygon(100% 0, 100% 75%, 50% 100%, 0 75%, 0 0, 50% 25%);
    z-index: 1;
}
.lp.arrow.blue .bg{
    background-color:#d1dcd3;
}
.lp.arrow.black .bg{
    background-color:#303534;
}
.lp.arrow.black{
    bottom:-160px;
    color:#fff;
}
.lp.arrow.black p, .lp.arrow.black p span{
    font-size:36px;
}
.lp.arrow.black p{
    margin-top:50px;
    font-size: clamp(18px,5vw,28px);
}
.lp.arrow.black p span{
    font-size: clamp(22px,5vw,36px);
}
.lp.arrow.black a{
    position: absolute;
    bottom:-25px;
    z-index: 5;
}
.lp.arrow.blue{
    margin-top:15px;
}
.lp.arrow.blue p{
    margin-top:35px;
    padding:0 1em;
    font-size:clamp(18px, 3vw, 28px);
    background:linear-gradient(transparent 50%, #fff 50%);
}
section.lp.reason .box01 p.md {
    margin: 25px 0 0;
}
section.lp .support{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-around;
}
section.lp .support .cont01 .wrap{
    position: relative;
    margin:1em;
    z-index: 0;
}
section.lp .support .cont01 img{
    width:auto;
    height:80px;
    margin:auto;
    padding:20px 0 0;
}
section.lp .support .cont01 h3{
    margin:1em;
    padding:0 0 15px;
    font-size:clamp(16px, 3vw, 20px);
    border-bottom:solid 1px #4b7e2e;
}
section.lp .support .cont01 p{
    font-family: "yu-gothic-pr6n", sans-serif;
}
section.lp .support .cont01 p span{
    font-size:14px;
}
section.lp .support .cont01 .tri{
    position: absolute;
    top:0;
    left:0;
    display: block;
    width:70px;
    aspect-ratio: 1/cos(30deg);
    clip-path: polygon(0 0, 100% 0, 0 100%);
    background-color: #fff;
    z-index: -1;
}
section.lp.reason{
    background-repeat: no-repeat;
}
section.lp.reason h2{
    width:100%;
    padding:50px 0;
    text-align: center;
}
section.lp.reason .dec, section.case .dec{
    display: flex;
    align-items: center;
    margin-bottom:25px;
    font-family: "sheila", sans-serif;
    font-size:clamp(16px, 3vw, 26px);
    letter-spacing: 3px;
}
section.case .dec{
    margin-bottom:15px;
    line-height: 0.5em;
    border-bottom:solid 1px;
}
section.lp.reason h3, section.lp.case h3{
    font-size:clamp(22px, 3vw, 36px);
}
section.lp.reason .dec, section.lp.reason h3, section.case .dec, section.case h3{
    color: #4b7e2e;
}
section.lp.reason .dec::after{
    content:"";
    flex-grow: 1;
    margin-left:15px;
    height:1px;
    background-color:#4b7e2e;
}
section.lp.reason p.lw{
    margin:35px 0 0;
    font-family: "yu-gothic-pr6n", sans-serif;
    font-weight: 500;
}
section.lp .ribbon{
    width:100%;
    padding:75px 0;
    text-align: center;
}
section.lp .ribbon.black{
    color:#fff;
    background-color:#303534;
}
section.lp .ribbon p{
    margin-bottom:35px;
    font-size:clamp(16px, 3vw, 28px);
}
section.lp .ribbon p span{
    font-size:clamp(18px, 6vw, 36px);
}
section.lp .ribbon.blown{
    display: flex;
    justify-content: space-between;
    margin-top:100px;
    background-color:#b4ae8c;
    position: relative;
}
section.lp .ribbon.blown .box{
    width:30%;
    position: relative;
}
section.lp .ribbon.blown .middle{
    width:40%;
    white-space: nowrap;
}
section.lp .ribbon.blown .middle a{
    width:100%;
}
section.lp .ribbon.blown img{
    position: absolute;
    right:0;
    width:180px;
}
.lp .h_type02{
    padding:0 0 25px;
}
.lp .h_type02 span{
    font-size: clamp(18px,5vw,28px);
    font-weight: normal;
    letter-spacing: 3px;
}
section.lp.case{
    padding:0 0 100px;
}
section.lp.case.gray{
    background-color: #f2f2f2;
}
section.lp.case.gray, section.lp.case.food{
    padding:100px 0;
}
section.lp.case .box01{
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding:25px 0;
    position: relative;
}
section.lp.case .box01.reverse{
    justify-content: flex-start;
}
section.lp.case .lp-btn.small{
    display: flex;
    margin:25px auto 0;
}
section.lp.case .box01 .wrap{
    width:35%;
    padding:45px;
    margin-right:10vw;
    background-color: rgb(255,255,255,0.7);
    z-index: 2;
}
section.lp.case .box01.reverse .wrap{
    margin-right:inherit;
    margin-left:10vw;
}
section.lp.case .box01 img{
    position: absolute;
    left:0;
    width:70%;
    height:100%;
    z-index: 1;
}
section.lp.case .box01 img.case01{
    object-position: 50% 30%;
}
section.lp.case .box01.reverse img{
    left:inherit;
    right:0;
}
section.lp.case .box02{
    display: flex;
    justify-content: space-between;
    padding:50px 0 0;
}
section.lp.case .box02 .ps-img{
    width:48%;
    position: relative;
}
section.lp.case .box02 .ps-img span{
    position: absolute;
    right:15px;
    bottom:15px;
    font-size:18px;
    text-align: right;
    line-height: 1.3em;
    color:#fff;
    text-shadow:1px 1px 2px rgb(0,0,0,0.8);
}
section.lp.case .box02 .ps-img img{
    height:320px;
}
section.lp.access{
    padding:100px 0;
    text-align: center;
}
section.lp1.access{
    background-color:#d1ddd3;
}
section.lp2.access{
    background-color:#d4e4d3;
}
section.lp3.access{
    background-color:#d9e2ec;
}
section.lp.access h3{
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width:320px;
    height:50px;
    margin:50px 0;
    font-size:18px;
    color:#fff;
    background-color:#747474;
    border-radius: 20px;
}
section.lp.access .link-box{
    display: flex;
    justify-content: space-between;
    margin:50px 0;
}
section.lp.flow{
    padding:100px 0;
    text-align: center;
}
section.lp.flow a{
    margin:50px 0;
}
section.lp.charge{
    padding:100px 0;
    background-color:#eae9df;
}
.bestrate-box{
    padding:50px 0 25px;
    background-color:#fff;
    position: relative;
}
.bestrate-box .cont01{
    margin:0 35px;
}
.bestrate-box .line{
    position: absolute;
    width:100%;
    height:15px;
    padding:0 5px;
    background-color:#95ae85;
    border-radius: 3px;
    left: 50%;
    transform: translateX(-50%);
}
.bestrate-box .line.top{
    top:0;
}
.bestrate-box .line.bottom{
    bottom:0;
}
.bestrate{
    display: flex;
    justify-content: center;
    align-items: center;
    width:125px;
    height:125px;
    margin:2em;
    color:#fff;
    background-color:#832154;
    border-radius: 50%;
}
.bestrate span{
    display: flex;
    justify-content: center;
    align-items: center;
    width:115px;
    height:115px;
    margin:3px;
    text-align: center;
    line-height: 1.6em;
    border:solid 1px;
    border-radius: 50%;
}
.bestrate p{
    margin-top:10px;
}
.bestrate-box table{
    width:100%;
    border-collapse: collapse;
}
.bestrate-box table th, section.lp.charge table td{
    text-align: center;
    vertical-align: middle;
    border:solid 1px #94ba91;
}
.bestrate-box table tr:nth-of-type(1) th:nth-of-type(1){
    border-bottom:solid 1px #fff;
}
.bestrate-box table tr:nth-of-type(1) th:nth-child(n+2){
    background-color:#dfeade;
}
.bestrate-box table tr th:nth-of-type(1){
    width:30%;
    padding:15px 1em;
    color:#fff;
    text-align: left;
    background-color:#94ba91;
}
.bestrate-box table td{
    text-align: center;
}
.bestrate-box .wrap{
    display: flex;
    justify-content: center;
    align-items: flex-start;
    margin-top:15px;
}
.bestrate-box ul{
    margin:1em;
    width:43%;
}
.bestrate-box ul li{
    display: flex;
    align-items: baseline;
}
.bestrate-box ul li::before{
    content:"◯";
    margin-right:2px;
}
.bestrate-box ul li p{
    font-family: "yu-gothic-pr6n", sans-serif;
    font-weight: normal;
}
section.information .bestrate-box{
    margin-bottom:100px;
    padding:25px 0;
}
section.lp.faq{
    padding:100px 0;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: 50% 105%;
}
section.faq.ct{
    width:75vw;
    max-width:1000px;
    margin:0 auto 100px;
    padding:0 0 100px;
}
section.lp1.faq{
    background-image: url(../img/forest_lp1.svg);
}
section.lp2.faq{
    background-image: url(../img/forest_lp2.svg);
}
section.lp3.faq{
    background-image: url(../img/forest_lp3.svg);
}
section.lp.faq .lp-wd02{
    padding:50px 0;
}
section.lp.faq details{
    border-top:solid 1px #e4e4e4;
    background-color:rgb(255,255,255,0.7);
}
section.lp.faq details:nth-last-of-type(1){
    border-bottom:solid 1px #e4e4e4;
}
section.lp.faq summary{
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding:20px 10px;
    font-weight: 600;
    cursor: pointer;
    position: relative;
}
section.lp.faq details summary::after{
    content:"+";
    font-size:36px;
    color:#888888;
}
section.lp.faq details[open] summary::after{
    transform: rotate(45deg);
    transition: .3s;
}
section.lp.faq summary h3{
    display: flex;
    align-items: center;
    font-size:18px;
}
section.lp.faq summary h3, section.lp.faq p, aside.lp.form form p{
    font-family: "yu-gothic-pr6n", sans-serif;
}
aside.lp.form form p{
    font-weight: normal;
}
section.lp.faq p{
    padding:1em 2em;
    font-weight: 500;
    text-indent: -1.6em;
    margin-left:1.6em;
    animation:fadeIn .5s ease;
}
section.lp.faq p::before{
    content:"A.";
    margin-right:10px;
}
section.lp.faq summary div{
    display: flex;
    justify-content: center;
    align-items: center;
    width:50px;
    height:50px;
    margin-right:10px;
    font-family: "yu-gothic-pr6n", sans-serif;
    font-size:36px;
}
section.lp.faq summary div span{
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width:40px;
    background-color:#e4e4e4;
    aspect-ratio: 1 / cos(30deg);
    clip-path: polygon(0 0, 100% 0, 0 100%);
    z-index: -1;
}
section.lp.faq a{
    font-family: "yu-gothic-pr6n", sans-serif;
}
aside.lp.form{
    padding:100px 0;
}
aside.lp.form h2{
    color:#fff;
}
aside.lp.form{
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center bottom;
}
aside.lp1.form{
    background-color:#464d4b;
    background-image: url(../img/lp1_form.svg);
}
aside.lp2.form{
    background-color:#444d43;
    background-image: url(../img/lp2_form.svg);
}
aside.lp3.form{
    background-color:#41464d;
    background-image: url(../img/lp3_form.svg);
}
aside.lp.form form{
    width:75%;
    max-width:1200px;
    margin:50px auto;
    background-color:#f2f2f2;
}
footer.lp{
    padding:15px 0;
    text-align: center;
    color:#303534;
    background-color:#fff;
    background-image: inherit;
}
/*lp1*/
.eyecatch.lp.company{
    background-image: url(../img/lp1_catch.jpg);
    background-position: top right;
    min-height:850px;
    justify-content: space-between;
    background-position: 28% 50%;
}
.eyecatch.lp.company .bg_white{
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width:70%;
    max-width:1200px;
    margin:100px 0 0 7vw;
    padding:25px 25px 0;
}
.eyecatch.lp.company .bg_white span{
    display: block;
    position: absolute;
    top:0;
    left:0;
    z-index: 1;
    width:100%;
    height:100%;
    background:rgb(255,255,255,0.6);
    filter:blur(10px);
    border-radius: 25px;
}
.eyecatch.lp.company .bg_white img{
    position: relative;
    z-index: 2;
}
.eyecatch.lp.company ul{
    display: flex;
    flex-flow: column;
    align-items: flex-start;
    justify-content: flex-start;
    margin:0 0 80px 10vw;
}
.eyecatch.lp.company ul li{
    display: flex;
    align-items: center;
    height:35px;
    margin:3px 0;
    padding:0 10px;
    font-size:20px;
    color:#fff;
    background-color: rgb(0,0,0,0.6);
    letter-spacing: 1px;
}
.eyecatch.lp.company ul li span{
    font-size:28px;
    margin:0 3px 2px;
}
section.lp1.concept .hougan{
    background-image: url(../img/bg-hougan.png);
    background-size: 75%;
    padding:0 0 160px;
}
section.lp1.concept h2{
    text-align: center;
    padding:100px 0 10px;
}
section.lp1.concept .box02{
    display: flex;
    justify-content: space-around;
    align-items: center;
    width:70%;
    max-width:1000px;
    margin:auto;
}
section.lp1.concept ul{
    margin-left:1em;
}
section.lp1.concept ul li{
    margin:1.2em 0;
    font-weight: 600;
    line-height: 1.6em;
}
section.lp1.concept .img01{
    width:320px;
    border-radius: 55%;
}
section.lp1.concept .box01{
    margin:280px 0 0 0;
    text-align: center;
}
section.lp1.concept .point{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width:80%;
    min-width:800px;
    margin: 35px auto 0;
}
section.lp1.concept .point .cont01{
    display: flex;
    justify-content: center;
    align-items: center;
    width:170px;
    height:170px;
    text-align: center;
    background-color: #eae9df;
    border-radius: 50%;
}
section.lp1.concept .point .cont01 h3{
    font-size:18px;
    letter-spacing: 1px;
}
section.lp1.concept .point .cont01 h3 span{
    display: inline-block;
    margin-top:5px;
    font-size:22px;
}
section.lp1.concept .point img{
    width:80px;
}
section.lp1 .support{
    margin-top:380px;
}
section.lp1.reason{
    background-color:#f2f2f2;
    background-image: url(../img/bg-forest_white.png);
    background-position: top right;
    background-size:40%;
    display: flex;
    flex-flow: row wrap;
}
section.lp1.reason .lp-wd02{
    position: relative;
    height:500px;
    margin-bottom:100px;
}
section.lp1.reason .lp-wd02.reverse{
    display: flex;
    flex-flow: row-reverse;
    align-items: flex-start;
}
section.lp1.reason .box01{
    position: relative;
    width:55%;
    background-color:rgb(255,255,255,0.75);
    z-index: 2;
}
section.lp1.reason .lp-wd02.half .box01{
    width:90%;
    max-width:600px;
    margin:auto 0 0 auto;
}
section.lp1.reason .lp-wd02.half.reverse .box01{
    margin:0 auto auto 0;
}
section.lp1.reason .box01 .wrap{
    padding:35px 45px;
}
section.lp1.reason .box01 .wrap p.md{
    margin:35px 0;
}
section.lp1.reason .lp-wd02 img{
    position: absolute;
    top:40px;
    z-index: 0;
    right:0;
    width:70%;
    height:460px;
}
section.lp1.reason .lp-wd02.reverse img{
    right:inherit;
    left:0;
}
section.lp1.reason .lp-wd02.half img{
    top:inherit;
    right:inherit;
    width:90%;
    max-width:850px;
}
section.lp1.reason .lp-wd02.half.reverse img{
    top:inherit;
    left:inherit;
    right:0;
    bottom:0;
}
section.lp1.reason .lp-wd02 img.hukidashi{
    position: absolute;
    top:-20px;
    left:-30px;
    width:200px;
    height:auto;
    object-fit: contain;
}
section.lp1.scene{
    display: flex;
    flex-flow: column;
    background-color:#eae9df;
}
section.lp1.scene h2{
    margin:50px auto;
    padding:0 1em;
    text-align: center;
    font-size:clamp(22px, 3vw, 28px);
    background:linear-gradient(transparent 50%, #fff 50%);
}
section.lp1.scene .wrap{
    display: flex;
    flex-flow: row wrap;
    justify-content: space-around;
    margin:auto auto 65px;
}
section.lp1.scene .wrap .box{
    width:45%;
    height:260px;
    margin-bottom:35px;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    position: relative;
}
section.lp1.scene .wrap .box.s01{
    background-image: url(../img/scene01.jpg);
}
section.lp1.scene .wrap .box.s02{
    background-image: url(../img/scene02.jpg);
}
section.lp1.scene .wrap .box.s03{
    background-image: url(../img/leader2.png);
}
section.lp1.scene .wrap .box.s04{
    background-image: url(../img/bbq02.jpg);
}
section.lp1.scene .wrap .box h3{
    position: absolute;
    bottom:0;
    left:0;
    width:100%;
    padding:10px 0;
    font-size:clamp(16px, 3vw, 24px);
    font-weight: 500;
    text-align: center;
    color:#fff;
    background-color:rgb(0,0,0,0.75);
}
/*lp2*/
.eyecatch.lp.school{
    background-image: url(../img/lp2_catch.jpg);
    min-height:700px;
}
.eyecatch.lp.school .box01{
    padding:140px 0 0 10vw;
    color:#fff;
}
.eyecatch.lp.school .box01 h2{
    margin-bottom:25px;
    font-size:clamp(24px, 5vw, 48px);
    line-height: 1.6em;
    text-shadow:3px 3px 10px #000, 1px 1px 7px rgb(0,0,0,0.6);
}
.eyecatch.lp.school .box01 h2 span{
    font-size:clamp(32px, 5vw, 62px);
}
.eyecatch.lp.school .box01 p{
    text-shadow:3px 1px 5px rgb(0,0,0,0.6), 1px 1px 3px rgb(0,0,0,1);
    font-size:clamp(16px, 3vw, 22px);
}
.eyecatch.lp.school ul{
    display: flex;
    margin:0 0 80px 10vw;
}
.eyecatch.lp.school ul li{
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width:185px;
    height:185px;
    text-align: center;
    color:#fff;
    border-radius: 50%;
    box-shadow:5px 5px 5px rgb(0,0,0,0.4);
}
.eyecatch.lp.school ul li.red{
    background-color:rgb(122,48,52,0.75);
    margin-right:7px;
}
.eyecatch.lp.school ul li.yellow{
    background-color:rgb(180,174,140,0.75);
    margin-right:7px;
}
.eyecatch.lp.school ul li.green{
    background-color:rgb(75,126,46,0.75);
}
.eyecatch.lp.school ul li p{
    font-family: "yu-gothic-pr6n", sans-serif;
    font-size:18px;
    font-weight: 500;
    line-height: 1.6em;
    text-shadow: 3px 3px 3px rgb(0,0,0,0.4);
}
.eyecatch.lp.school ul li:nth-of-type(3) p{
    margin-top:10px;
}
.eyecatch.lp.school ul li p:nth-of-type(2){
    font-size:12px;
}
.eyecatch.lp.school ul li p span{
    font-size:26px;
}
section.lp.lp2 h2{
    text-align: center;
}
section.lp2.concept{
    padding:100px 0;
}
section.lp2.concept .lp-wd02{
    text-align: center;
}
section.lp2.concept .box02{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin:35px 0;
}
section.lp2.concept .box02 img{
    width:45%;
}
section.lp2.concept ul{
    width:55%;
}
section.lp2.concept ul li{
    padding:5px 0 5px 3em;
    text-align: left;
}
section.lp2.concept ul li:nth-child(odd){
    background-color:#f2f2f2;
}
section.lp2.concept p{
    display: inline-block;
    font-size: clamp(18px,5vw,28px);
    color: #4b7e2e;
    border-top:solid 1px;
    border-bottom:solid 1px;
}
section.lp2.concept p span{
    width:80%;
    white-space: nowrap;
}
section.lp2.support{
    padding:100px 0;
    background-color:#eae9df;
}
section.lp2.safty{
    padding:100px 0 0;
}
section.lp .support .cont01, section.lp2.safty .support .cont01{
    width:32%;
    max-width:330px;
    min-width:300px;
    height:320px;
    margin-bottom:25px;
    background-color: #eae9df;
    text-align: center;
}
section.lp2.safty .support .cont01{
    width:320px;
}
section.lp2 .support .cont01{
    margin-top:25px;
    background-color:#fff;
}
section.lp2.safty .support .cont01{
    border-radius: 50%;
}
section.lp2.safty .support .cont01 .wrap{
    margin:2em 1em 1em;
}
section.lp2.safty .support .cont01 img{
    width:100px;
}
section.lp2.safty .support .cont01 h3{
    margin:0.6em 1em 1em;
}
section.lp2 .support .cont01 .tri{
    background-color: #eae9df;
}
section.lp2.reason{
    background-image: url(../img/bg-forest01.jpg);
}
section.lp2.reason .box01{
    display: flex;
    justify-content: flex-end;
    margin-bottom:100px;
}
section.lp2.reason .box01.reverse{
    flex-flow: row-reverse;
}
section.lp2.reason .box01 .wrap{
    width:40%;
    margin:25px 50px 0 10vw;
}
section.lp2.reason .box01.reverse .wrap{
    margin:25px 10vw 0 50px;
}
section.lp2.reason .box01 img{
    width:60%;
    height:480px;
}
section.lp2.reason .box01 img.point03{
    object-position: bottom;
}
/*lp3*/
.eyecatch.lp.work{
    min-height:768px;
    background-image: url(../img/lp3_catch.jpg);
}
.eyecatch.lp.work img.catch{
    width:80vw;
    max-width:1600px;
    max-height:530px;
    margin:130px auto 0;
    object-fit: contain;
}
.lp3.wrapper{
    background-image: url(../img/lp3_bg.png);
    background-repeat: no-repeat;
    background-size:cover;
    background-position: top;
}
section.lp3.concept{
    display: flex;
    padding:100px 0;
    position: relative;
}
section.lp3.concept .box01 .wrap{
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
}
section.lp3.concept .box01 p.md{
    margin:35px 0 0;
}
section.lp3.concept .box01 p.lw{
    width:70%;
    margin:35px 2em 50px 0;
    font-family: "yu-gothic-pr6n", sans-serif;
}
section.lp3.concept .box01 .wrap img{
    width:180px;
    margin-top:35px;
}
section.lp3.concept .box01{
    position: absolute;
    margin:0 50px 0 10vw;
    width:40%;
}
section.lp3.concept .box02{
    width:55%;
    height:auto;
    margin:0 0 0 auto;
}
section.lp3.concept .box02 img{
    height:460px;
}
section.lp.case .box01 p.md {
    margin: 35px 0 0;
    font-size: clamp(18px, 2vw, 24px);
}
section.lp.case .box01 p.lw{
    margin:35px 0 50px;
}
/*animation*/
.fadeUp_T{
    opacity: 0;
}
.fadeUp {
    animation-name: fadein-up;
    animation-duration: 1s;
    animation-fill-mode: forwards;
    opacity: 0;
}
@keyframes fadein-up {
    from {
        opacity: 0;
        transform: translateY(100px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.delay01 {
    animation-delay: 0.2s;
}