@charset "utf-8";
:root{
--jselif:"游明朝体", "Yu Mincho", YuMincho, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐ明朝", "MS PMincho", "メイリオ", Meiryo, sans-serif;
}
#wrap.top {width: 100%; overflow-x: hidden;}
#contents.top {width: 100%; overflow-x: hidden;}
.top_mv {padding: 30px 0px 40px; position: relative;}
.top_mv:before {	position: absolute;z-index: 0;top: 0;left: 50%;display: block;width: 200vw;height: 100%;background: #F5F5F5;content: "";transform: translateX(-50%);}
.top_mv > * {position: relative; z-index: 1;}
.tmswiper .swiper-slide {box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.4);width: 1200px; background-color: #FFF;}
.tmswiper .swiper-slide > div.cont {width: 100%; aspect-ratio: 16 / 9; overflow: hidden;}
.tmswiper .swiper-slide > div.cont img {width: 100%;}
.tmswiper .swiper-slide.is-video video {width: 100%; height: auto;}
.tmswiper .swiper-slide > div.cont.first {position: relative;}
.tmswiper .swiper-slide > div.cont.first p.head_img {position: absolute; top: 25px; width: 100%;}
.tmswiper .swiper-slide > div.cont.first p.head_img img {width: 100%;}
.tmswiper .swiper-slide > div.cont.first p.contact {position: absolute; right: 25px; bottom: 25px;}
.top_mv div.under {display: flex; flex-direction: row-reverse; margin-top: 40px;}
.top_mv div.under div.pagination {width: 640px;}
.top_mv div.under div.banner {width: calc(100% - 640px);}
.top_mv div.under div.banner ul:first-child {display: flex; justify-content: space-between;}
.top_mv div.under div.banner ul:first-child li {width: 48%;}
.top_mv div.under div.banner ul:nth-child(2) {display: flex; justify-content: space-between; margin-top: 24px;}
.top_mv div.under div.banner ul:nth-child(2) li {height: 75px; flex-shrink: 1;}
.top_mv div.under div.banner ul:nth-child(2) li img {height: 100%; width: auto;}
.top_mv div.under div.banner img {width: 100%; height: auto;}

.top_mv div.under div.pagination {display: flex; align-items: center; justify-content: center; margin-top: 30px;}
.tmswiper-button-prev,.tmswiper-button-next {width: 66px; height: 66px; background-color: #FFF; border-radius: 100% ;border: 1px solid #2E5437; cursor: pointer; flex-shrink: 0; display: flex; align-items: center; justify-content: center;}
.tmswiper-button-prev:before {content: '';width: 12px;height: 12px;border: 0;border-bottom: solid 4px #2E5437;border-right: solid 4px #2E5437;transform: rotate(135deg); margin-left: 5px;}
.tmswiper-button-next:before {content: '';width: 12px;height: 12px;border: 0;border-bottom: solid 4px #2E5437;border-right: solid 4px #2E5437;transform: rotate(-45deg); margin-right: 5px;}
.tmswiper-pagination {display: flex; align-items: center; width: auto; margin: 0px 20px;}
.tmswiper-pagination .swiper-pagination-bullet {width: 15px; height: 15px; margin: 0px 20px !important; background-color: #A8A8A8; opacity: 1; transition: all .2s; flex-shrink: 0;}
.tmswiper-pagination .swiper-pagination-bullet-active {background-color: #1B5A31; width: 26px; height: 12px; border-radius: 6px; transition: all .2s;}


.top_about {position: relative; padding: 100px 0px;}
.top_about:before {content: ""; width: 100vw; height: 100%; background: url(../../img/top/top_about_bg.webp) no-repeat center top; background-size: cover; position: absolute; left: 50%; top: 0; transform: translateX(-50%); z-index: 0;}
.top_about_cont {max-width: 1200px; margin: 0px auto; position: relative; z-index: 1; }
.top_about_cont > p.en {text-align: center; font-size: 34px; font-weight: 600; color: #FFF;font-family: var(--jselif);}
.top_about_cont > h2 {text-align: center; font-size: 14px; font-weight: 600; color: #FFF;font-family: var(--jselif);}
.top_about_cont > h3 {font-size: 43px;font-weight: 500; color: #FFF;font-family: var(--jselif); margin-top: 60px;}
.top_about_cont > div {margin-top: 70px;}
.top_about_cont > div figure {display: flex; justify-content: space-between;}
.top_about_cont > div figure picture {display: block; width: 48%;}
.top_about_cont > div figure picture img {width: 100%;}
.top_about_cont > div figure figcaption {width: 48%;}
.top_about_cont > div figure figcaption h4 span {color: #FFF; font-size: 30px; font-family: var(--jselif); font-weight: 600; position: relative; padding-bottom: 20px;}
.top_about_cont > div figure figcaption h4 span:after {content: ""; width: 100vw; height: 1px; background-color: #FFF; position: absolute; bottom: 0; left: 0;}
.top_about_cont > div figure figcaption h4 + p {margin-top: 30px;}
.top_about_cont > div figure figcaption p {font-size: 16px; font-family: var(--jselif);color: #FFF; line-height: 200%;}
.top_about_cont > div figure figcaption p + p {margin-top: 1em;}
.top_about_cont > div figure:nth-child(odd) {flex-direction: row-reverse;}
.top_about_cont > div figure:nth-child(odd) h4 span:after {position: absolute; bottom: 0; left: auto; right: 0;}

.top_about_cont > div figure + figure {margin-top: 70px;}


.top_modelhouse {margin-top: 100px;padding: 62px 0px 35px; position: relative;}
.top_modelhouse:before {	position: absolute;z-index: 0;top: 0;left: 50%;display: block;width: 100vw;height: 100%;background: #cedbd4;content: "";transform: translateX(-50%);}
.top_modelhouse > div {position: relative; z-index: 1;}
.top_modelhouse > div > h2 {text-align: center;}
.top_modelhouse > div > h2 span{ font-size: 34px; text-align: center; color: #000; font-weight: normal; font-family: var(--jselif);}
.top_modelhouse div.mh_list {margin-top: 40px;}
.top_modelhouse div.mh_list a {display: block; text-decoration: none;}
.top_modelhouse div.mh_list a figure {position: relative;}
.top_modelhouse div.mh_list a figure picture {display: block; aspect-ratio: 3 / 2; overflow: hidden;}
.top_modelhouse div.mh_list a figure picture img {max-width: 100%; height: auto;}
.top_modelhouse div.mh_list a figure figcaption {margin-top: 10px;}
.top_modelhouse div.mh_list a figure figcaption p.class {position: absolute; top: 0; left: 0; background-color:#2E5437 ; border-radius: 0px 0px 10px 0px; color: #FFF; font-size: 24px; font-family: var(--jselif); padding: 5px 10px; min-width: 122px; box-sizing: border-box; text-align: center;}
.top_modelhouse div.mh_list a figure figcaption p.txt {font-size: 20px; font-family: var(--jselif);}

.mhswiper {overflow: hidden;}
.pn_area {display: flex; justify-content: center; margin-top: 30px;}
.mhswiper-button-prev,.mhswiper-button-next {width: 66px; height: 66px; background-color: #FFF; border-radius: 100% ;border: 1px solid #2E5437; cursor: pointer; flex-shrink: 0; display: flex; align-items: center; justify-content: center;}
.mhswiper-button-prev:before {content: '';width: 12px;height: 12px;border: 0;border-bottom: solid 4px #2E5437;border-right: solid 4px #2E5437;transform: rotate(135deg); margin-left: 5px;}
.mhswiper-button-next:before {content: '';width: 12px;height: 12px;border: 0;border-bottom: solid 4px #2E5437;border-right: solid 4px #2E5437;transform: rotate(-45deg); margin-right: 5px;}
.mhswiper-pagination {display: flex; align-items: center; width: auto; margin: 0px 20px;}
.mhswiper-pagination .swiper-pagination-bullet {width: 15px; height: 15px; margin: 0px 20px !important; background-color: #FFF; opacity: 1; transition: all .2s; flex-shrink: 0;}
.mhswiper-pagination .swiper-pagination-bullet-active {background-color: #1B5A31; width: 26px; height: 12px; border-radius: 6px; transition: all .2s;}
.swiper-pagination-bullets.swiper-pagination-horizontal {width: auto !important;}

#modelhouse .modelButton_02 {width: 100% !important;}

.mhswiper-pagination.swiper-pagination-lock,.mhswiper-button-prev.swiper-button-lock,.mhswiper-button-next.swiper-button-lock {
  display: none;
}

.top_blog {padding: 100px 0px;}
.top_blog > p.en {text-align: center; font-size: 34px; font-weight: 600; color: #000;font-family: var(--jselif);}
.top_blog > h2 {text-align: center; font-size: 14px; font-weight: 600; color: #000;font-family: var(--jselif);}
.top_blog > h3 {font-size: 30px;font-weight: 500; color: #163428;font-family: var(--jselif); margin-top: 60px;}

.top_blog_list {display: flex; justify-content: space-between; margin-top: 80px;}
.top_blog_list div.left {width: 38%;}
.top_blog_list div.right {width: 53%;}
.top_blog_list a {display: block; text-decoration: none;}
.top_blog_list a + a {margin-top: 60px;}
.top_blog_list a figure {display: flex; align-items: flex-start; justify-content: space-between;}
.top_blog_list a figure picture {width: 183px; text-align: center;}
.top_blog_list a figure picture img {max-width: 100%;}
.top_blog_list a figure figcaption {width: calc(100% - 198px);}
.top_blog_list a figure figcaption h4 {font-size: 22px; font-weight: 500;display: -webkit-box;-webkit-box-orient: vertical;overflow: hidden;text-overflow: ellipsis;-webkit-line-clamp: 2;}
.top_blog_list a figure figcaption p.time {font-size: 12px; border-bottom: 1px solid #C3C3C3; margin-top: 10px; padding-bottom: 10px;}
.top_blog_list a figure figcaption p.txt {font-size: 16px; margin-top: 10px; line-height: 180%; display: -webkit-box;-webkit-box-orient: vertical;overflow: hidden;text-overflow: ellipsis;-webkit-line-clamp: 4;}
.top_blog_list a p.new {background-color: #008E55;width: fit-content; width: 85px; height: 25px; display: flex; align-items: center; justify-content: center; margin-bottom: 10px; border-radius: 15px;}
.top_blog_list a p.new span {font-size: 15px; font-weight: 700; color: #FFF; line-height: 100%;}
.top_blog_list a p.new.sp {display: none;}

.top_blog_list div.left a figure {flex-direction: column;}
.top_blog_list div.left a figure picture {width: 100%; text-align: center;}
.top_blog_list div.left a figure figcaption {width: 100%; margin-top: 10px;}
.top_blog_list div.left a figure figcaption p.txt {display: -webkit-box;-webkit-box-orient: vertical;overflow: hidden;text-overflow: ellipsis;-webkit-line-clamp: 3;}

.blog_link {width: 230px; height: 50px; margin: 90px auto 0px;}
.blog_link a {display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; border: 1px solid #163428; position: relative; text-decoration: none;}
.blog_link a span {font-size: 17px; font-weight: 700; color: #163428; font-family: var(--jselif); line-height: 100%;}
.blog_link a:after {content: '';width: 6px;height: 6px;border: 0;border-bottom: solid 2px #2E5437;border-right: solid 2px #2E5437;transform: rotate(-45deg); position: absolute; right: 22px; top: calc(50% - 3px);}

@media screen and (max-width: 1200px) {
.top_about_cont {max-width: 1200px; margin: 0px auto; position: relative; z-index: 1; padding: 0px 16px;}
.top_blog {padding: 100px 16px;}

.top_mv div.under {display: flex; flex-direction: column; margin-top: 40px;}
.top_mv div.under div.pagination {width: 100%;}
.top_mv div.under div.banner {width: 600px; margin: 40px auto 0px;}

.tmswiper .swiper-slide > div.cont.first p.contact {position: absolute; right: 25px; bottom: 25px;  width: 40%;}

}


@media screen and (max-width: 768px) {

.top_blog_list {display: flex; flex-direction: column; justify-content: space-between; margin-top: 80px;}
.top_blog_list div.left {width: 100%; display: contents;}
.top_blog_list div.right {width: 100%; display: contents;}

.top_blog_list div.left a {margin-bottom: 60px;}
.top_blog_list div.left a figure {flex-direction: row;}
.top_blog_list div.left a figure picture {width: 183px;}
.top_blog_list div.left a figure figcaption {width: calc(100% - 198px); margin-top: 0px;}
.top_blog_list div.left a figure figcaption p.txt {display: none;}

.top_blog_list a figure {align-items: center;}
.top_blog_list a p.new.pc {display: none;}
.top_blog_list a p.new.sp {display: flex;}
.top_blog_list a figure figcaption p.txt {display: none;}

}
@media screen and (max-width: 639px) {
.top_mv {padding: 0px 0px 40px; position: relative;}
.tmswiper .swiper-slide > div.cont.first p.contact {position: absolute; right: 10px; bottom: 10px;  width: 40%;}

.top_mv div.under div.pagination {display: flex; align-items: center; justify-content: center; margin-top: 0px;}
.tmswiper-button-prev,.tmswiper-button-next {width: 34px; height: 34px; background-color: #FFF; border-radius: 100% ;border: 1px solid #2E5437; cursor: pointer; flex-shrink: 0; display: flex; align-items: center; justify-content: center;}
.tmswiper-button-prev:before {content: '';width: 6px;height: 6px;border: 0;border-bottom: solid 2px #2E5437;border-right: solid 2px #2E5437;transform: rotate(135deg); margin-left: 5px;}
.tmswiper-button-next:before {content: '';width: 6px;height: 6px;border: 0;border-bottom: solid 2px #2E5437;border-right: solid 2px #2E5437;transform: rotate(-45deg); margin-right: 3px;}
.tmswiper-pagination {display: flex; align-items: center; width: auto; margin: 0px 10px;}
.tmswiper-pagination .swiper-pagination-bullet {width: 5px; height: 5px; margin: 0px 10px !important; background-color: #A8A8A8; opacity: 1; transition: all .2s; flex-shrink: 0;}
.tmswiper-pagination .swiper-pagination-bullet-active {background-color: #1B5A31; width: 16px; height: 8px; border-radius: 6px; transition: all .2s;}

.top_mv div.under {display: flex; flex-direction: column; margin-top: 20px; padding: 0px 15px; }
.top_mv div.under div.pagination {width: 100%;}
.top_mv div.under div.banner {width:100%; margin: 20px auto 0px;}

.top_mv div.under div.banner ul:first-child {display: flex; justify-content: space-between;}
.top_mv div.under div.banner ul:first-child li {width: 48%;}
.top_mv div.under div.banner ul:nth-child(2) {display: flex; justify-content: space-between; margin-top: 24px;gap:0 24px;}
.top_mv div.under div.banner ul:nth-child(2) li {height: auto; flex-shrink: 1;}
.top_mv div.under div.banner ul:nth-child(2) li:first-child {width: 66%;}
.top_mv div.under div.banner ul:nth-child(2) li:nth-child(2) {width: 30%;}
.top_mv div.under div.banner ul:nth-child(2) li img {height:auto; width: 100%;}

.top_about {position: relative; padding: 50px 0px;}
.top_about_cont > p.en {text-align: center; font-size: 28px; font-weight: 600; color: #FFF;font-family: var(--jselif);}
.top_about_cont > h2 {text-align: center; font-size: 12px; font-weight: 600; color: #FFF;font-family: var(--jselif);}
.top_about_cont > h3 {font-size: 18px;font-weight: 500; color: #FFF;font-family: var(--jselif); margin-top: 30px;}
.top_about_cont > div {margin-top: 35px;}
.top_about_cont > div figure {display: flex; flex-direction: column; justify-content: space-between;}
.top_about_cont > div figure picture {display: block; width: 100%;}
.top_about_cont > div figure picture img {width: 100%;}
.top_about_cont > div figure figcaption {width: 100%; margin-top: 20px;}
.top_about_cont > div figure figcaption h4 span {color: #FFF; font-size: 18px; font-family: var(--jselif); font-weight: 600; position: relative; padding-bottom: 15px;}
.top_about_cont > div figure figcaption h4 span:after {content: ""; width: 100vw; height: 1px; background-color: #FFF; position: absolute; bottom: 0; left: auto; right: 0;}
.top_about_cont > div figure figcaption h4 + p {margin-top: 20px;}
.top_about_cont > div figure figcaption p {font-size: 12px; font-family: var(--jselif);color: #FFF; line-height: 200%;}
.top_about_cont > div figure figcaption p + p {margin-top: 1em;}
.top_about_cont > div figure:nth-child(odd) {flex-direction: column;}
.top_about_cont > div figure:nth-child(odd) h4 span:after {position: absolute; bottom: 0; left: auto; right: 0;}

.top_about_cont > div figure + figure {margin-top: 60px;}

.top_blog {padding: 40px 16px;}
.top_blog > p.en {text-align: center; font-size: 28px; font-weight: 600; color: #000;font-family: var(--jselif);}
.top_blog > h2 {text-align: center; font-size: 12px; font-weight: 600; color: #000;font-family: var(--jselif);}
.top_blog > h3 {font-size: 18px;font-weight: 500; color: #163428;font-family: var(--jselif); margin-top: 40px;}

.top_blog_list {display: flex; flex-direction: column; justify-content: space-between; margin-top: 60px;}
.top_blog_list a figure figcaption h4 {font-size: 16px; font-weight: 500;display: -webkit-box;-webkit-box-orient: vertical;overflow: hidden;text-overflow: ellipsis;-webkit-line-clamp: 2;}
.top_blog_list a figure figcaption p.time {font-size: 10px; border-bottom: 1px solid #C3C3C3; margin-top: 5px; padding-bottom: 5px;}

.top_blog_list div.left a {margin-bottom: 35px;}
.top_blog_list a figure picture {width: 31%;}
.top_blog_list a figure figcaption {width: 63.8%;}
.top_blog_list div.left a figure picture {width: 31%;}
.top_blog_list div.left a figure figcaption {width: 63.8%;}
.top_blog_list a + a {margin-top: 35px;}

.blog_link {width: 230px; height: 50px; margin: 35px auto 0px;}

.mhswiper {position: relative;}
.mhswiper .swiper-slide {width: 70%;}
.pn_area {display: flex; justify-content: center; margin-top: 20px;}
.mhswiper-button-prev,.mhswiper-button-next {width: 48px; height: 48px; background-color: #FFF; border-radius: 100% ;border: 1px solid #2E5437; cursor: pointer; flex-shrink: 0; display: flex; align-items: center; justify-content: center; position: absolute;}
.mhswiper-button-prev {top: 70px; left: 40px; z-index: 3;}
.mhswiper-button-next {top: 70px; right: 40px; z-index: 3;}
.mhswiper-button-prev:before {content: '';width: 12px;height: 12px;border: 0;border-bottom: solid 4px #2E5437;border-right: solid 4px #2E5437;transform: rotate(135deg); margin-left: 5px;}
.mhswiper-button-next:before {content: '';width: 12px;height: 12px;border: 0;border-bottom: solid 4px #2E5437;border-right: solid 4px #2E5437;transform: rotate(-45deg); margin-right: 5px;}
.mhswiper-pagination {display: flex; align-items: center; width: auto; margin: 0px 10px;}
.mhswiper-pagination .swiper-pagination-bullet {width: 8px; height: 8px; margin: 0px 10px !important; background-color: #FFF; opacity: 1; transition: all .2s; flex-shrink: 0;}
.mhswiper-pagination .swiper-pagination-bullet-active {background-color: #1B5A31; width: 26px; height: 12px; border-radius: 6px; transition: all .2s;}
.swiper-pagination-bullets.swiper-pagination-horizontal {width: auto !important;}

}
@media screen and (max-width: 500px) {
.tmswiper .swiper-slide > div.cont.first p.head_img {position: absolute; top: 0px; width: 100%;}
.tmswiper .swiper-slide > div.cont.first p.contact {position: absolute; right: 10px; bottom: 10px;  width: 170px;}
}
@media screen and (max-width: 430px) {

.tmswiper .swiper-slide > div.cont.first p.contact {position: absolute; right: 10px; bottom: 10px;  width: 160px;}
}