@charset "utf-8"; 
a, abbr, acronym, address, applet, article, aside, audio,b, big, blockquote, body, caption, canvas, center, cite, code, dd, del, details, dfn, dialog, div, dl, dt, em, embed, fieldset, figcaption, figure, form, footer, header, hgroup, h1, h2, h3, h4, h5, h6, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, main, small, span, strike, strong, sub, summary, sup, tt, table, tbody, textarea, tfoot, thead, time, tr, th, td, u, ul, var, video{font-size:100%; vertical-align:baseline; white-space:normal; margin:0; padding:0; border:0; outline:0; background:transparent;}article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main{display:block;} ol, ul{list-style:none;} blockquote, q{quotes:none;}table{border-collapse:collapse; border-spacing:0;} *{-webkit-box-sizing:border-box; -moz-box-sizing:border-box; -o-box-sizing:border-box; -ms-box-sizing:border-box; box-sizing:border-box; -webkit-text-size-adjust:100%;} img{vertical-align:top; width: 100%;height: auto;} h1, h2, h3, h4, h5, h6{font-weight:normal;}


/*---------------------------
Link
---------------------------*/
a{outline:none; text-decoration: none; color: #000;}
a:hover{ opacity: 0.8;}
a img:hover{ opacity: 0.8;}
a:hover{-webkit-transition:all .5s ease; transition:all .5s ease;}


@media screen and (max-width: 450px) {
a:hover{ opacity:1;}
}


/*---------------------------
Body
---------------------------*/

html{scroll-behavior: smooth;}
body{font-family:"Zen Old Mincho", serif; font-style: normal; font-weight: 400; color: #000; word-wrap:break-word; font-kerning:normal;font-size:20px;letter-spacing: 0.1em;overflow-x: hidden;background: #fff;}







/*---------------------------
共通
---------------------------*/
.cf:before,
.cf:after {content: " ";display: table;}
.cf:after {clear: both;}
.cf{*zoom: 1;}

.pc{display:block;}
.sp{display:none;}

h2.tit{font-weight: 500; font-size:40px;text-align: center; line-height: 1; color: #B8956A;}
h2.tit span{display: block; font-size:18px;font-family:"Zen Old Mincho", serif; margin-top: 15px; font-weight: 500;}

h3.tit{font-weight: 500; font-size:35px;text-align: center; line-height: 1; color: #B8956A;}
h3.tit span{display: block; font-size:18px;font-family:"Zen Old Mincho", serif; margin-top: 10px;font-weight: 500;}



.lower{margin-top: 220px;}
.lower-tit-box{max-width: 1150px; width: 90%; margin: 0 auto;}
.lower-tit-box h2.tit {text-align: left; align-items: center;}
.lower-tit-box h2.tit span{display: inline-block; margin-left: 20px; margin-top: 0;}

@media screen and (max-width: 1200px) {
h2.tit{ font-size:calc(40/1200 * 100vw);}
h2.tit span{font-size:calc(18/1200 * 100vw);}

h3.tit{font-size:calc(35/1200 * 100vw);}
h3.tit span{font-size:calc(18/1200 * 100vw);}

.lower{margin-top: calc(220/1200 * 100vw);}
}

@media screen and (max-width: 750px) {
.pc{display:none;}
.sp{display:block;}

h2.tit{font-size:28px;}
h2.tit span{ font-size:13px;margin-top: 10px;}

.lower-tit-box h2.tit {text-align: center;}

h3.tit{font-size:25px;}
h3.tit span{font-size:13px;margin-top: 10px;}

.lower{margin-top: 100px;}
}



/*---------------------------
コンテンツ
---------------------------*/

.application-box{position: fixed; right: 0; top:35%; z-index: 1;}
.application-box a {display: block; padding:25px 15px; font-size: 15px; color: #fff;-ms-writing-mode: tb-rl;writing-mode: vertical-rl;letter-spacing: 0.15em;border-top-left-radius: 20px;border-bottom-left-radius: 20px; background: #B8956A; font-weight: 600;}
.application-box a.none{border-bottom-left-radius: 20px;border-top-left-radius: 0; border-top: 1px solid #fff;}

@media screen and (max-width: 750px) {
.application-box{right: 0; top:auto; bottom: 0; display: flex; width: 100%;}
.application-box a {padding:15px 10px; font-size: 15px; -ms-writing-mode: tb-rl;writing-mode: horizontal-tb;letter-spacing: 0.15em;border-top-left-radius: 0;border-bottom-left-radius: 0; width: 100%; text-align: center;}
.application-box a.none{border-bottom-left-radius: 0;border-top: none;border-left: 1px solid #fff;}
}
@media (hover: hover) and (pointer: fine) {
.application-box a:hover{background:#efd256; opacity: 1; color: #000;}
}

.hero{ background:url("../img/hero_bg.jpg") no-repeat; background-size: cover; position: relative; margin-top: 100px;}
.hero .copy{font-size:50px; color: #fff; position:absolute; bottom: 120px; left: 250px;}
.hero .copy span{font-size:60px; font-family: "Playfair Display", serif; font-weight: 300; display: block; letter-spacing: 0.15em;}
.hero .rights{font-size: 18px;font-family: "Playfair Display", serif; font-weight: 300;letter-spacing: 0.15em;-ms-writing-mode: tb-rl;writing-mode: vertical-rl;text-orientation: sideways;position: absolute;left: 45px; top: 35%; }


@media screen and (max-width: 1260px) {
.hero .copy{font-size:calc(40/1260 * 100vw); bottom: calc(120/1260 * 100vw); left: calc(200/1260 * 100vw);}
.hero .copy span{font-size:calc(50/1260 * 100vw);}
.hero .rights{font-size: calc(15/1260 * 100vw);left: calc(45/1260 * 100vw); top: calc(200/1260 * 100vw); }
}


@media screen and (max-width: 750px) {
.hero{margin-top:60px;}
.hero .copy{font-size:22px; color: #fff; position:absolute; bottom: 40px; left: 25px;}
.hero .copy span{font-size:24px; font-family: "Playfair Display", serif; font-weight: 300; display: block; letter-spacing: 0.15em;}
}

.top-bg{background:url("../img/bg_top.jpg") no-repeat bottom; background-size: cover; position: relative; }

.news{padding-top: 150px;}
.news .inner{max-width: 1150px;margin:0 auto; width: 90%;}
.news h2.tit {text-align: left; display: flex; align-items: center;}
.news h2.tit span{display: inline-block; margin-left: 20px; margin-top: 0;}
.news .news-box{display: flex; align-items: center; margin-top: 30px;}
.news .news-box ul{width: 70%;}
.news .news-box li{border-bottom: 1px solid #cecece; padding: 30px 20px;}
.news .news-box li:first-child{border-top: 1px solid #cecece;}
.news .news-box li div{ display: flex; align-items: center;}
.news .news-box li div time{font-family: "Montserrat", sans-serif; font-size: 13px; border-right:1px solid #000; padding-right: 10px; letter-spacing: 0.05em;}
.news .news-box li div dl{padding-left: 10px; display: flex; align-items: center;}
.news .news-box li div dd{color: #B8956A; font-size: 13px; margin-right: 10px; font-weight: 600; letter-spacing: 0.05em}
.news .news-box li div i{font-family: "Montserrat", sans-serif;background:#efd256; padding: 5px; font-size:10px; border-radius:5px; font-style: normal;}
.news .news-box li h3{font-size:18px; margin-top: 10px; font-weight: 600;}
.news .news-box .left{width: 25%; margin-right: 5%;}


@media screen and (max-width: 1200px) {
.news{padding-top: calc(150/1200 * 100vw);}
.news .news-box li h3{font-size:calc(18/1200 * 100vw);}
}

@media screen and (max-width: 750px) {
.top-bg{background:url("../img/bg_top.jpg") no-repeat bottom right; background-size: cover; position: relative; }

.news{padding-top: 75px;}
.news h2.tit {text-align: center; display: block; }
.news h2.tit span{display:block; margin-left: 9px; margin-top: 0; margin-top: 10px;}
.news .inner{max-width: 1150px; margin:0 auto;}
.news .news-box{display: block;margin-top: 40px;}
.news .news-box ul{width: 100%;}
.news .news-box li h3{font-size:15px;}
.news .news-box .right{float: right; margin-top: 20px;}
}


.about{padding-top: 150px; padding-bottom: 150px;}
.about .inner{max-width: 1150px;margin:0 auto;}
.about .txt-box{margin-top: 40px;}
.about .txt-box.right{margin-top: 80px; padding-top: 80px; border-top: 1px solid #cecece;}
.about .txt-box h3{font-size:30px; color:#B8956A; letter-spacing: 0.1em;font-weight: 600; margin-top: 80px; margin-bottom: 30px; text-align: center;}
.about .txt-box p{margin-top: 10px; font-size:18px; font-weight: 600; line-height:2.0; text-align: center;}
.about .txt-box h4{font-size:24px; margin-top: 40px;font-weight: 600; }
.about .txt-box p span{font-weight: 500; font-size: 16px; line-height: 1.6; display: block;}


@media screen and (max-width: 1200px) {
.about{padding-top: calc(150/1200 * 100vw); padding-bottom: calc(150/1200 * 100vw);}
.about .txt-box{margin-top: calc(80/1200 * 100vw);}
.about .txt-box h3{font-size:calc(35/1200 * 100vw); }
.about .txt-box p{font-size:calc(18/1200 * 100vw);}
.about .txt-box h4{font-size:calc(24/1200 * 100vw); margin-top: calc(40/1200 * 100vw);}
}

@media screen and (max-width: 750px) {
.about{padding-top: 75px; padding-bottom: 75px;}
.about .inner{max-width: 1150px; width: 92%; margin:0 auto; padding: 0 5px;}
.about .txt-box{margin-top: 40px; margin-left: 0;}
.about .txt-box.right{margin-top: 40px; padding-top: 40px;}
.about .txt-box h3{font-size:20px; color:#B8956A; letter-spacing: 0.05em;font-weight: 500;}
.about .txt-box p{margin-top: 10px; font-size:15px; font-weight: 700; line-height:1.8;letter-spacing: 0.05em;}
.about .txt-box h4{font-size:18px; margin-top: 30px;font-weight: 700; letter-spacing: 0.05em;}
}

.mvv{ padding-bottom: 150px;}
.mvv .inner{max-width:1500px; width: 100%; margin: 0 auto;}
.mvv .mvv-box{display: flex; justify-content: center;}
.mvv .box{border-right:1px solid #cecece; width: 33.3333%; padding:50px;}
.mvv .box:last-child{border-right:none;}
.mvv .box i{max-width: 104px; display: block; margin: 0 auto;}
.mvv .box h3{font-family: "Montserrat", sans-serif; font-size: 25px; text-align: center;font-style: normal; letter-spacing: 0.01em; margin-top: 20px; margin-bottom: 40px;}
.mvv .box h3 em{color: #B8956A;font-style: normal;}
.mvv .box h3 span{font-size:18px; font-family:"Zen Old Mincho", serif; display: block;margin-top: 5px;}
.mvv .box h4{font-size:18px; margin-top: 25px; line-height: 1.6; color: #B8956A; font-weight: 600;}
.mvv .box p{font-size:15px; line-height: 1.8; margin-top: 10px; font-weight: 600;}
.mvv .button-box{max-width:380px; margin: 80px auto 0;}

@media screen and (max-width: 1200px) {
.mvv{ padding-bottom: calc(150/1200 * 100vw);}
.mvv .box i{max-width: calc(104/1200 * 100vw); }
.mvv .box h3{font-size: calc(25/1200 * 100vw);margin-top: calc(20/1200 * 100vw); margin-bottom: calc(40/1200 * 100vw);}
.mvv .box h3 span{font-size:calc(18/1200 * 100vw);}
.mvv .box h4{font-size:calc(18/1200 * 100vw); margin-top: calc(25/1200 * 100vw);}
.mvv .box p{font-size:calc(15/1200 * 100vw);}
.mvv .button-box{max-width:calc(380/1200 * 100vw); margin: calc(80/1200 * 100vw) auto 0;}
}

@media screen and (max-width: 750px) {
.mvv{ padding-bottom: 75px; padding-top: 30px;}
.mvv .inner{max-width:1150px; width: 90%; margin: 0 auto;}
.mvv .mvv-box{display: block;}
.mvv .box{border-right:none; width:100%; padding:20px;}
.mvv .box:last-child{border-right:none;}
.mvv .button-box{max-width:360px;  width: 90%; margin: 80px auto 0;}
.mvv .box i{max-width:104px; }
.mvv .box h3{font-size: 24px; margin-top: 20px; margin-bottom: 20px;letter-spacing: 0;}
.mvv .box h3 span{font-size:15px;margin-top: 5px;}
.mvv .box h4{font-size: 18px; margin-top: 18px; line-height: 1.6; color: #B8956A;}
.mvv .box p{font-size:15px; line-height: 1.8; margin-top: 10px;letter-spacing: 0;}
.mvv .button-box{max-width:360px;  width: 90%; margin: 40px auto 0;}
}

.activite{background: #F5EDE0; padding-top: 150px; padding-bottom: 150px;}
.activite .copy{font-size:18px; margin-top: 60px; text-align: center; font-weight: 600;}
.activite .slider{width: 100%;margin-left: 200px; margin-top: 50px;}
.activite .slider-img {max-width: 320px; margin-right: 40px;}
.activite .slider-img img{border-radius:30px;object-fit:cover; height:400px;} 
.activite .slider-img .cat-box{ display: flex; align-items: center; margin-top: 20px;}
.activite .slider-img .cat-box time{font-family: "Montserrat", sans-serif; font-size: 13px; border-right:1px solid #000; padding-right: 10px; letter-spacing: 0.05em}
.activite .slider-img .cat-box dl{padding-left: 10px; display: flex; align-items: center;}
.activite .slider-img .cat-box dd{color: #B8956A; font-size: 13px; margin-right: 10px;font-weight: 600; letter-spacing: 0.05em}
.activite .slider-img .cat-box i{font-family: "Montserrat", sans-serif;background:#efd256; padding: 5px; font-size:10px; border-radius:5px; font-style: normal; margin-right: 10px;}
.activite .slider-img h3{font-size:18px; margin-top: 10px; font-weight: 600;}
.activite .button-box{max-width:380px; margin: 80px auto 0;}


@media screen and (max-width: 1200px) {
.activite{padding-top: calc(150/1200 * 100vw); padding-bottom: calc(150/1200 * 100vw);}
.activite .copy{font-size:calc(18/1200 * 100vw); margin-top: calc(60/1200 * 100vw);}
.activite .slider{margin-left: calc(200/1200 * 100vw); margin-top: calc(50/1200 * 100vw);}
.activite .slider-img {max-width: calc(320/1200 * 100vw); margin-right: calc(40/1200 * 100vw);}
.activite .slider-img img{border-radius:calc(30/1200 * 100vw);object-fit:cover; height:calc(400/1200 * 100vw);} 
.activite .slider-img h3{font-size:calc(18/1200 * 100vw);}
.activite .button-box{max-width:calc(380/1200 * 100vw); margin: calc(80/1200 * 100vw) auto 0;}
}

@media screen and (max-width: 750px) {
.activite{padding-top: 75px; padding-bottom: 75px;}
.activite .copy{font-size:15px; margin-top: 40px; text-align: center;}
.activite .slider{width: 100%;margin:30px auto 0;}
.activite .slider-img {margin-right: 10px; margin-left: 10px;max-width: 320px; }
.activite .slider-img img{border-radius:30px;object-fit:cover; height:400px;}
.activite .button-box{max-width:360px;  width: 80%; margin: 50px auto 0;}
.activite .slider-img h3{font-size:15px;}
}


.lower-hero{margin-top:50px; }

.lower-message{padding:150px 0;}
.lower-message .inner{width: 90%; margin: 60px auto 0; display: flex; justify-content:center; align-items: center;}
.lower-message .txt-box {width: 100%; max-width: 870px;}
.lower-message .txt-box h3:first-child{margin-top: 0;}
.lower-message .txt-box h3{font-size:24px; margin-top: 40px;font-weight: 600; }
.lower-message .txt-box p{margin-top: 10px; font-size:18px;  line-height:2.0; font-weight: 600;}
.lower-message .txt-box p span{text-align: right;font-weight: 500; display: block;}
.lower-message .pict-box {width: 35%;}

@media screen and (max-width: 1200px) {
.lower-message{padding:calc(150/1200 * 100vw) 0;}
.lower-message .inner{margin: calc(60/1200 * 100vw) auto 0;}
.lower-message .txt-box h3{font-size:calc(24/1200 * 100vw); margin-top: calc(40/1200 * 100vw);}
.lower-message .txt-box p{font-size:calc(18/1200 * 100vw); }
}

@media screen and (max-width: 750px) {
.lower-hero{margin-top:20px; }
.lower-message{padding:50px 0 75px;}
.lower-message .inner{ margin: 30px auto 0; display: block;}
.lower-message .txt-box {width: 100%; margin-right:0; padding: 0 20px;}
.lower-message .txt-box h3:first-child{margin-top: 0;}
.lower-message .txt-box h3{font-size:18px; margin-top: 40px;font-weight: 600; letter-spacing: 0.05em;}
.lower-message .txt-box p{margin-top: 10px; font-size:15px;letter-spacing: 0.05em;}
.lower-message .pict-box {width: 70%; margin: 0 auto 30px;}
}

.lower-outline{padding:150px 0; background:#F5EDE0;}
.lower-outline .inner{max-width: 1060px; width: 90%; margin: 0 auto;}
.lower-outline dl{border-top:1px solid #cecece; display: flex; flex-wrap: wrap;font-size:15px; align-items: center; margin-top: 60px; font-weight: 600;}
.lower-outline dt{width: 20%; padding: 30px 20px 30px 60px;border-bottom:1px solid #cecece;}
.lower-outline dd{width: 80%;padding: 30px 20px;border-bottom:1px solid #cecece;}

@media screen and (max-width: 1200px) {
.lower-outline{padding:calc(150/1200 * 100vw) 0;}
.lower-outline dl{ margin-top: calc(60/1200 * 100vw);font-size: calc(15/1200 * 100vw);}
.lower-outline dt{padding: 30px 20px 30px 60px;}
.lower-outline dd{padding: 30px 20px;}
}

@media screen and (max-width: 750px) {
.lower-outline{padding:75px 0; background:#F5EDE0;}
.lower-outline dl{border-top:none;display: block;font-size:15px; align-items: center; margin-top: 30px;}
.lower-outline dt{width:100%; padding:15px 15px 0 15px;border-bottom:none; font-weight: 600;}
.lower-outline dd{width:100%; padding:5px 15px 15px 15px; border-bottom:1px solid #cecece;}
}

.lower-activities{ padding-bottom: 90px;}
.lower-activities .inner{max-width: 1150px; width: 90%; margin: 60px auto 0;}
.lower-activities ul{ display: flex; flex-wrap: wrap; align-items: flex-start;}
.lower-activities li{width: 31.3333%; margin-right: 3%; margin-bottom: 60px;}
.lower-activities li:nth-child(3n){margin-right: 0;}
.lower-activities li img{object-fit:cover; height:200px;} 
.lower-activities li .cat-box{ display: flex; align-items: center; margin-top: 20px;}
.lower-activities li .cat-box time{font-family: "Montserrat", sans-serif; font-size: 13px; border-right:1px solid #000; padding-right: 10px; letter-spacing: 0.05em}
.lower-activities li .cat-box dl{padding-left: 10px; display: flex; align-items: center;}
.lower-activities li .cat-box dd{color: #B8956A; font-size: 13px; margin-right: 10px;font-weight: 600; letter-spacing: 0.05em;}
.lower-activities li .cat-box i{font-family: "Montserrat", sans-serif;background:#efd256; padding: 5px; font-size:10px; border-radius:5px; font-style: normal; margin-right: 10px;}
.lower-activities li h3{font-size:18px; margin-top: 10px; font-weight: 600;}
.lower-activities.details{margin-top: 100px;}
.lower-activities.details .inner{max-width: 1000px; width: 90%; margin: 60px auto 0;}


@media screen and (max-width: 1200px) {
.lower-activities{ padding-bottom: calc(90/1200 * 100vw);}
.lower-activities li{margin-bottom: calc(60/1200 * 100vw);}
.lower-activities li img{object-fit:cover; height:calc(200/1200 * 100vw);} 
.lower-activities li h3{font-size:calc(18/1200 * 100vw);}
}

@media screen and (max-width: 750px) {
.lower-activities{ padding-bottom: 75px;}
.lower-activities .inner{margin: 20px auto 0;}
.lower-activities li{width:100%; margin-right:0; margin-bottom: 50px;}
.lower-activities li:nth-child(3n){margin-right: 0;}
.lower-activities li img{object-fit:cover; height:200px;} 
.lower-activities li h3{font-size:15px;;}
.lower-activities li:last-child{margin-bottom: 0;}
.lower-activities.details{margin-top: 50px;}
.lower-activities.details .inner{margin: 30px auto 0;}
}


.lower-news{}
.lower-news .inner{max-width: 1000px; width: 90%; padding: 150px 0; margin: 0 auto;}
.lower-news li{border-bottom: 1px solid #cecece; padding: 30px 20px;}
.lower-news li:first-child{border-top: 1px solid #cecece;}
.lower-news li div{ display: flex; align-items: center;}
.lower-news li div time{font-family: "Montserrat", sans-serif; font-size: 13px; border-right:1px solid #000; padding-right: 10px; letter-spacing: 0.05em}
.lower-news li div dl{padding-left: 10px; display: flex; align-items: center;}
.lower-news li div dd{color: #B8956A; font-size: 13px; margin-right: 10px; font-weight: 600; letter-spacing: 0.05em}
.lower-news li div i{font-family: "Montserrat", sans-serif;background:#efd256; padding: 5px; font-size:10px; border-radius:5px; font-style: normal;}
.lower-news li h3{font-size:18px; margin-top: 10px; font-weight: 600; }
.lower-news.details{margin-top: 100px;}
.lower-news.details .inner{max-width: 1000px; width: 90%; margin: 60px auto 0; padding: 0 0 150px 0;}

@media screen and (max-width: 1200px) {
.lower-news .inner{ padding: calc(150/1200 * 100vw) 0;}
.lower-news li h3{font-size:calc(18/1200 * 100vw); }
}

@media screen and (max-width: 750px) {
.lower-news .inner{padding: 10px 0 75px; margin: 0 auto;}
.lower-news li:first-child{border-top:none;}
.lower-news li h3{font-size:15px; }
.lower-news.details{margin-top: 50px;}
.lower-news.details .inner{margin: 30px auto 0; padding: 0 0 75px 0;}
}


.lower-news_hero{max-width: 1000px; width: 90%; margin: 0 auto;}
.lower-news_hero img{object-fit:cover; height:525px;} 

.lower-news_hero .cat-box{ display: flex; align-items: center; margin-top: 30px;}
.lower-news_hero .cat-box time{font-family: "Montserrat", sans-serif; font-size: 13px; border-right:1px solid #000; padding-right: 10px; letter-spacing: 0.05em}
.lower-news_hero .cat-box dl{padding-left: 10px; display: flex; align-items: center;}
.lower-news_hero .cat-box dd{color: #B8956A; font-size: 13px; margin-right: 10px;font-weight: 600; letter-spacing: 0.05em;}
.lower-news_hero .cat-box i{font-family: "Montserrat", sans-serif;background:#efd256; padding: 5px; font-size:10px; border-radius:5px; font-style: normal; margin-right: 10px;}
.lower-news_hero h1{font-size:26px; margin-top: 15px; font-weight: 600; padding-bottom: 40px;}

@media screen and (max-width: 750px) {
.lower-news_hero img{object-fit:cover; height:300px;} 
.lower-news_hero .cat-box{margin-top: 20px;}
.lower-news_hero h1{font-size:22px; padding-bottom: 30px;}
}

.lower-news_details{max-width: 1000px; width: 90%; margin: 0 auto;padding: 80px 0; border-bottom: 1px solid #cecece;border-top: 1px solid #cecece; letter-spacing: 0.05em;}
.lower-news_details h1{font-size: 26px; font-weight: 600; margin-bottom: 20px;}
.lower-news_details h2{font-size: 24px; font-weight: 600; margin-bottom: 20px;}
.lower-news_details h3{font-size: 22px; font-weight: 600; margin-bottom: 20px;}
.lower-news_details h4{font-size: 20px; font-weight: 600; margin-bottom: 20px;}
.lower-news_details p{font-size: 18px;margin-top: 10px;line-height: 1.8;}
.lower-news_details img{max-width: 1000px; width: 70%;}
.lower-news_details a{text-decoration: underline; color: #B8956A;}

@media screen and (max-width: 750px) {
.lower-news_details{padding: 40px 0;}
.lower-news_details h1{font-size: 22px; margin-bottom: 10px;}
.lower-news_details h2{font-size: 20px; margin-bottom: 10px;}
.lower-news_details h3{font-size: 18px; margin-bottom: 10px;}
.lower-news_details h4{font-size: 16px; margin-bottom: 10px;}
.lower-news_details p{font-size: 15px;margin-top: 10px;line-height: 1.8;}
.lower-news_details img{max-width: 1000px; width: 100%;}
}



.lower-newsletter{max-width: 800px; width: 90%;margin: 60px auto 0;}
.lower-newsletter .copy{text-align: center; font-size: 18px; line-height: 1.8; font-weight: 600;}
.lower-newsletter .re{font-size: 13px; color: #dc3232; text-align: left; margin: 40px 0 0 15px;}

@media screen and (max-width: 750px) {
.lower-newsletter{margin: 30px auto 0;}
.lower-newsletter .copy{font-size: 15px; line-height: 1.8;}
.lower-newsletter .re{font-size: 13px; color: #ff0000; text-align: left; margin: 20px 0 0 15px;}
}


.lower-information{}
.lower-information .inner{max-width: 1000px; width: 90%; padding: 150px 0 70px; margin: 0 auto;}
.lower-information ul{display: flex; flex-wrap: wrap;align-items: center;}
.lower-information li{margin-right: 10%; width: 45%;box-sizing: border-box; margin-bottom: 80px;}
.lower-information li:nth-child(even){margin-right: 0;}
.lower-information li p{text-align: center;font-size: 18px;font-weight: 600; margin-bottom: 20px;}


@media screen and (max-width: 750px) {
.lower-information{}
.lower-information .inner{padding: 50px 0 30px; margin: 0 auto;}
.lower-information li{margin-right: 0%; width: 100%;box-sizing: border-box; margin-bottom: 40px;}
.lower-information li p{text-align: center;font-size: 15px; margin-bottom: 20px;}
}


footer{background:#333; padding: 50px 20px 60px;}
footer ul{display: flex; justify-content: center; align-items: center;}
footer li{ margin-right: 20px; font-size: 30px;}
footer li:last-child{margin-right: 0;}
footer li a{color: #fff;}
footer .copyright{font-size:12px;text-align: center; color: #fff; margin-top: 50px;}


.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.pill-button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;

  width: 100%;
  padding: 22px 28px;

  background-color: #B8956A;
  border: 2px solid #B8956A; /* ←枠追加 */
  border-radius: 999px;
  text-decoration: none;

  transition: all 0.3s ease;
}




/* テキスト */
.pill-text {
  color: #ffffff;
  transition: color 0.3s ease;
  font-size: 20px;
  font-weight: 500;
}

/* 矢印 */
.pill-arrow {
  position: absolute;
  right: 45px;

  width: 24px;
  height: 2px;
  background-color: #ffffff;

  transform-origin: left center;
  transition: transform 0.4s cubic-bezier(.19,1,.22,1),
              background-color 0.3s ease;
}

.pill-arrow::after {
  content: "";
  position: absolute;
  right: 0;
  top: -5px;
  width: 10px;
  height: 10px;
  border-top: 2px solid #ffffff;
  border-right: 2px solid #ffffff;
  transform: rotate(45deg);
  transition: border-color 0.3s ease;
}

@media screen and (max-width: 1200px) {
.pill-button {
  padding: calc(22/1200 * 100vw) calc(28/1200 * 100vw);
}

.pill-text {
  font-size:calc(20/1200 * 100vw);
}

.pill-arrow {
  right: calc(45/1200 * 100vw);

  width: calc(24/1200 * 100vw);
  height: 2px;
}

}

/* hoverはPCのみ有効 */
@media (hover: hover) and (pointer: fine) {

  .pill-button:hover {
    background-color: #ffffff;
  }

  .pill-button:hover .pill-text {
    color: #B8956A;
  }

  .pill-button:hover .pill-arrow {
    background-color: #B8956A;
    transform: scaleX(1.25);
  }

  .pill-button:hover .pill-arrow::after {
    border-color: #B8956A;
  }

}


@media screen and (max-width: 750px) {
.pill-button {
  width: 100%;
  padding: 18px;
}

.pill-arrow {
  width: 18px;
}

.pill-arrow::after {
  content: "";
  position: absolute;
  right: 0;
  top: -4px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #ffffff;
  border-right: 2px solid #ffffff;
  transform: rotate(45deg);
  transition: border-color 0.3s ease;
}



/* テキスト */
.pill-text {
  font-size: 18px;
}

}






.circle-button {
  width: 95px;
  height: 95px;
  border: 2px solid #dcc9a3;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  box-sizing: border-box;
  transition: background-color 0.3s ease;
  margin: 0 auto;
}

/* 矢印（横線） */
.circle-button .arrow {
  width: 26px;
  height: 2px;
  background-color: #dcc9a3;
  position: relative;
  transition: transform 0.3s ease, width 0.3s ease;
}

/* 矢印の先 */
.circle-button .arrow::after {
  content: "";
  position: absolute;
  right: 0;
  top: -5px;
  width: 10px;
  height: 10px;
  border-top: 2px solid #dcc9a3;
  border-right: 2px solid #dcc9a3;
  transform: rotate(45deg);
}

/* ホバー時 */
.circle-button:hover {
  background-color: rgba(216, 196, 154, 0.08);
}

.circle-button:hover .arrow {
  width: 32px;
  transform: translateX(6px);
}


/* =========================
   SP最適化（<=750px）
   ========================= */
@media (max-width: 750px) {
  .circle-button {
    width: 56px;
    height: 56px;
    border-width: 2px; /* 好みで 1px にしてもOK */
  }

  .circle-button .arrow {
    width: 18px;
    height: 2px;
  }

  .circle-button .arrow::after {
    top: -4px;
    width: 8px;
    height: 8px;
    border-top-width: 2px;
    border-right-width: 2px;
  }
}

/* hoverできる端末だけ hover を有効化（スマホ誤作動防止） */
@media (hover: hover) and (pointer: fine) {
  .circle-button:hover {
    background-color: rgba(216, 196, 154, 0.08);
  }

  .circle-button:hover .arrow {
    width: 22px;              /* SPでは伸び幅も控えめ */
    transform: translateX(4px);
  }
}





header{width: 100%; position: fixed; top: 0; z-index: 3; background: #B8956A;}
header .logo{max-width:300px; position: absolute; left: 25px; top: 9px; z-index: 1;}



#btn {
  display: none;
}

nav .box{display: flex;  justify-content:flex-end;align-items: center; margin: 0 auto;width: 95%;position: relative; height: 100px;}

nav ul {
  display: flex;
  align-items: center;

}
nav ul li {
  margin-left: 40px;
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0.05em;
  font-weight: 500;
  text-align: center;
}



nav ul li span{ font-size: 11px; margin-top: 5px; display: block;letter-spacing: 0.05em;}

nav ul li a{color: #fff;}

@media (hover: hover) and (pointer: fine) {
nav ul li a:hover{color:#000;} 
}






nav .sns-box{display: flex; justify-content: center; align-items: center; margin-left: 30px;}
nav .sns-box a{font-size: 30px; margin-left: 0; margin-right: 10px; color: #fff;}
nav .sns-box a:hover{color: #000;}


@media (max-width: 1200px) {
header .logo{max-width:calc(250px - 0.20vw);left: calc(25px - 0.20vw); top:calc(14px + 0.20vw);}
nav ul li {margin-left: calc(40px - 0.20vw);font-size: calc(20px - 0.20vw);}
nav ul li span{ font-size: calc(11px - 0.20vw);}
nav .sns-box a{font-size:  calc(30px - 0.20vw); margin-right:calc(10px - 0.20vw);}
}

@media (min-width: 751px) and (max-width: 1000px) {
nav ul li {margin-left: calc(25px - 0.40vw);font-size: calc(18px - 0.40vw);}
nav .sns-box{ margin-left: calc(15px - 0.40vw);}
nav .sns-box a{font-size:  calc(30px - 0.40vw); margin-right:calc(10px - 0.40vw);}
}





@media screen and (max-width: 750px) {
  /* =========================
     Header
     ========================= */
  header{
    height: 60px;
    position: fixed;
    z-index: 1000;
    top: 0;
    left: 0;
    width: 100%;
  }

  header .logo{
    max-width: 190px;
    position: absolute;
    left: 13px;
    top: 4px;
  }

  /* =========================
     Hamburger Button
     ========================= */
  #btn{
    position: fixed;
    top: 8px;
    right: 10px;
    width: 44px;
    height: 44px;
    z-index: 1100;
    display: flex;
    flex-direction: column;
    justify-content: space-evenly;
    align-items: center;
    cursor: pointer;
  }

  #btn span{
    display: block;
    background-color: #fff;
    width: 28px;
    height: 2px;
    transition: transform 0.35s ease, opacity 0.35s ease;
  }

  /* ×に変形 */
  #btn.on span:nth-of-type(1){
    transform: translateY(11px) rotate(45deg);
  }
  #btn.on span:nth-of-type(2){
    opacity: 0;
  }
  #btn.on span:nth-of-type(3){
    transform: translateY(-12px) rotate(-45deg);
  }

  /* =========================
     Nav (Overlay Menu)
     初期は非表示 → nav.on で表示
     ========================= */

  /* nav自体は固定の全画面メニューにする */
  nav{
    position: fixed;
    inset: 0;
    background: #B8956A;
    z-index: 1050;

    display: flex;
    flex-direction: column;
    align-items: center;

    padding: 110px 20px 30px;

    /* 初期：非表示 */
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity 0.3s ease, transform 0.3s ease;
    height: 100vh;
  }

  /* 開いた状態 */
  nav.on{
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  /* 余計な装飾を消す（元CSS互換） */
  nav::before{ display: none; }
  nav{ margin-top: 0; border: none; }

  /* 中のレイアウト */
  nav .box{
    display: block;
    padding: 0;
    margin: 0 auto;
    width: 100%;
    height: auto;
    border-bottom: none;
  }

  nav ul{
    display: flex;
    flex-direction: column;
    gap: 22px;
    align-items: center;
  }

  nav ul li{
    margin-left: 0;
    margin-bottom: 25px;
  }

  /* リンク */
  nav a{
    margin: 0;
    display: block;
    text-align: center;
    font-size: 20px;
    border: none;
    color: #fff;
    letter-spacing: 0.12em;
  }

  /* SNS */
  nav .box .sns-box{
    width: 120px;
    margin: 28px auto 0;
  }

  nav .box .sns-box a{
    margin: 0 auto;
  }
  body.menu-open { overflow: hidden; }
}

.form-box{max-width:800px; margin: 0 auto; padding-bottom: 150px;}
.form-box dl{margin:20px auto 0; display: flex; flex-wrap: wrap; background: #fff;}
.form-box dl.nomb{margin: 50px 0 0 0;}
.form-box dt{font-size: 15px; width: 35%; padding: 15px;font-weight: 600;display: flex; align-items: center; letter-spacing: 0.05em;}
.form-box i{font-size: 10px; color: #dc3232; font-style: normal;margin-left:5px;}
.form-box dd{width: 65%;padding: 15px;font-size: 15px; letter-spacing: 0.05em; }
.form-box dd .check-box{ margin-bottom: 10px;}
.form-box dd .check-box li{display: inline-block;}
.form-box dd .subtit{font-size: 16px;font-weight: 500; line-height: 1.8; margin-top: 10px;}
.form-box .note-box{height:300px; border: 1px solid #cecece; padding: 30px; overflow-y: scroll; font-size: 15px;}
.form-box .note-box h3{font-size:15px; font-weight: 600; text-align: center; margin-bottom: 20px;}
.form-box .note-box h4{font-size:13px; font-weight: 600; margin-top: 30px;}
.form-box .note-box p{font-size:13px;margin-top: 10px;}
.form-box .c-box{display: flex; align-items: center; margin-top: 30px;}
.form-box .button-box{max-width:380px; margin: 80px auto 0;}
.form-box .c-box p{display: flex; align-items: center;}
.form-box .c-box label{display: flex; align-items: center;}
.wpcf7-list-item{margin: 0;}
.wpcf7-list-item-label{padding-left: 5px;}

@media screen and (max-width: 750px) {
.form-box{padding-bottom: 75px;}
.form-box dl{margin:10px auto 0; display: block;}
.form-box dt{ width: 100%; padding:15px 10px 0 10px;}
.form-box dd{width: 100%;padding: 10px;}
.form-box .button-box{ margin: 40px auto 0;}
}

input, select, textarea {
  box-sizing: border-box;
  width:100%;
  color:inherit;
  font-size:13px;
  line-height: 1.6;
  border: 1px solid #cecece;
  background: #fff;
  outline: none;
  font-family:'Noto Sans JP', sans-serif;
}
input[type="text"], input[type="number"], input[type="url"], input[type="mail"], input[type="tel"], input[type="email"], input[type="password"] {
  padding:10px;
  font-family:"Zen Old Mincho", serif;
  font-size: 15px;
}

input[type="checkbox"]{width: 20px; height: 20px; padding: 0; margin: 0;}
input[type="radio"]{width: 16px; height: 16px; padding: 0;}



textarea{  padding:10px;  font-size: 15px;}

label{display: flex; align-items: center; margin-right: 10px;}


@media screen and (max-width: 750px) {
label{font-size: 14px;}
}

/*
@media (min-width: 1191px) and (max-width: 1500px) {
  #scale-wrap {
    transform: scale(0.8);
    transform-origin: left top;
    width: calc(100% / 0.8);
  }
}

@media (min-width: 1041px) and (max-width: 1190px) {
  #scale-wrap {
    transform: scale(0.7);
    transform-origin: left top;
    width: calc(100% / 0.7);
  }
}

@media (min-width: 751px) and (max-width: 1040px) {
  #scale-wrap {
    transform: scale(0.5);
    transform-origin: left top;
    width: calc(100% / 0.5);
  }
}
*/



/* WOW.js (prevent flash before animation) */
.wow{visibility:hidden;}
.wow.animated{visibility:visible;}



/* =========================================================
   Accessibility helpers
   ========================================================= */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.skip-link {
  position: absolute;
  left: 8px;
  top: 8px;
  padding: 10px 12px;
  background: #fff;
  color: #302210;
  border: 2px solid #302210;
  border-radius: 6px;
  z-index: 99999;
  transform: translateY(-140%);
  transition: transform .2s ease;
}
.skip-link:focus {
  transform: translateY(0);
}

/* =========================================================
   Hamburger button reset
   ========================================================= */
#btn {
  background: transparent;
  border: 0;
  padding: 0;
}


/* =========================
   Contact Form7 ボタン
   ========================= */

.btn-submit {
  display: block;
  width: 100%;
  padding: 22px 28px;

  background-color: #b89c6a;
  color: #fff;

  border: 2px solid #b89c6a;
  border-radius: 999px;

  font-size: 20px;
  letter-spacing: 0.1em;
  cursor: pointer;

  transition: all 0.3s ease;
  font-family:"Zen Old Mincho", serif;
}

/* PCだけ hover */
@media (hover: hover) and (pointer: fine) {
  .btn-submit:hover {
    background-color: #fff;
    color: #b89c6a;
    border: 2px solid #b89c6a;
  }
}

/* フォームの送信エリアを中央揃え */
.wpcf7 form .wpcf7-spinner {
  display: block;
  margin: 16px auto 0;
}

.wpcf7 form .wpcf7-response-output {
  text-align: center;
  letter-spacing: 0.05em;
}


@media (max-width: 750px) {
  .grecaptcha-badge {
    bottom: 50px !important;
  }
}


/* =========================
   reCAPTCHA 表示ページ制御
   ========================= */

/* 全ページで隠す */
.grecaptcha-badge {
  visibility: hidden;
}

/* フォームページだけ表示 */
.page-id-36 .grecaptcha-badge,
.page-id-28 .grecaptcha-badge {
  visibility: visible;
}



.youtube {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.youtube iframe {
  width: 100%;
  height: 100%;
}







/* =========================================
   WOW / animate.css – smoother & unified
========================================= */

/* 全体の速度を少し遅く */
.wow.animated {
  animation-duration: 3.0s !important;
  animation-fill-mode: both;
  will-change: transform, opacity;
}

/* fadeInUp の質感を統一（上品で自然なカーブ） */
.fadeInUp {
  animation-timing-function: cubic-bezier(.16, 1, .3, 1) !important;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate3d(0, 40px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}





