@charset "UTF-8";
/*==========================================
変数 inc.scss
===========================================*/
/*==========================================
変数 fonts.scss
===========================================*/
/*===================================
userSS 追加
=====================================*/
@import url("https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,100..900;1,100..900&display=swap");
/*==========================================
　modelhouse
===========================================*/
#footer .footer-copy {
  text-align: right; }

.mhSec-MTB {
  margin: clamp(120px, 20vw, 250px) auto; }

.mhsec-MB_xs {
  margin-bottom: clamp(30px, 6vw, 60px); }

.font-jost {
  font-family: "Jost", "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif; }

.archive-modelhouse {
  padding-top: 0;
  background: #123646;
  color: #fff; }

.modelhouseWrap {
  padding-bottom: 55px;
  position: relative; }

.cnv-reserveBlock a {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(1.4rem, 1.8vw, 2rem);
  background: #fff;
  color: #ff443a;
  text-align: center;
  max-width: 570px;
  width: 92%;
  margin: 0 auto;
  padding: 1em 0;
  border: 1px solid #fff; }
  @media (hover: hover) {
    .cnv-reserveBlock a:hover {
      background: #000; } }
  .cnv-reserveBlock a .ttl-en {
    font-family: "Jost", "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
    letter-spacing: 0.15em;
    font-size: clamp(1.8rem, 2vw, 2.6rem);
    display: flex;
    justify-content: center;
    align-items: center; }
    .cnv-reserveBlock a .ttl-en::after {
      content: "";
      display: block;
      width: 1px;
      height: 1.2em;
      background: #ff443a;
      margin: 0 1em; }
  .cnv-reserveBlock a .ttl-ja {
    font-weight: bold;
    letter-spacing: 0.1em; }

.sec-ttlR {
  font-family: "Jost", "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
  font-size: clamp(1.4rem, 2vw, 2rem);
  line-height: 1.2; }
  .sec-ttlR .ttl-main {
    letter-spacing: 0.15em;
    font-size: clamp(2rem, 6vw, 8rem);
    font-weight: 400; }
    .sec-ttlR .ttl-main.mid {
      font-size: clamp(3.6rem, 7vw, 9rem); }
    .sec-ttlR .ttl-main.lrg {
      font-size: clamp(3rem, 10vw, 16rem); }
  .sec-ttlR .ttl-sub {
    letter-spacing: 0.1em;
    font-weight: 400; }
    .sec-ttlR .ttl-sub.sml {
      font-size: clamp(1.4rem, 1.6vw, 1.6rem); }

.basic-txtR {
  font-weight: bold;
  line-height: 1.75; }
  .basic-txtR.fs18 {
    font-size: clamp(1.6rem, 1.8vw, 1.8rem); }
  .basic-txtR p:not(:last-child) {
    margin-bottom: 1.75em; }

.ttl-typeR {
  max-width: 184px; }
  .ttl-typeR img {
    width: 100%;
    object-fit: contain;
    aspect-ratio: 1.0337078652;
    object-position: center bottom; }

/* ==========================
  モーダル（ポップアップ）
========================== */
.js_modalWrap {
  display: none;
  z-index: 1000;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%; }

.js_modalBG {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.79); }

.js_modalContInner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: 55%;
  max-width: 1360px; }
  @media screen and (max-width: 1360px) {
    .js_modalContInner {
      width: 76%; } }
  @media screen and (max-width: 960px) {
    .js_modalContInner {
      width: 92%; } }

.js_modalCont {
  max-height: 90vh;
  overflow-y: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none; }
  .js_modalCont::-webkit-scrollbar {
    display: none; }
  @media screen and (max-width: 576px) {
    .js_modalCont {
      max-height: 95vh; } }

.js_modalClose {
  font-family: "Jost", "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
  font-size: clamp(1.2rem, 1.4vw, 1, 4rem);
  letter-spacing: 0.15em;
  cursor: pointer;
  display: flex;
  justify-content: flex-end;
  align-items: center; }
  .js_modalClose .icon {
    margin-left: 0.6em;
    position: relative;
    border: 1px solid #fff;
    border-radius: 100vmax;
    width: 36px;
    aspect-ratio: 1/1;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center; }
    .js_modalClose .icon::before {
      content: "✕";
      line-height: 1; }

.js_modalCont .modal-mainimg img {
  width: 100%;
  object-fit: scale-down;
  aspect-ratio: 1.4994487321; }
@media screen and (max-width: 576px) {
  .js_modalCont .modal-mainimg.tate img {
    aspect-ratio: 1/1; } }
.js_modalCont .modal-dataWrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-top: -8em; }
  @media screen and (max-width: 767px) {
    .js_modalCont .modal-dataWrap {
      display: block; } }
  @media screen and (max-width: 576px) {
    .js_modalCont .modal-dataWrap {
      margin-top: -25%; } }
.js_modalCont .modal-data {
  display: flex;
  align-items: flex-end;
  width: 100%; }
  @media screen and (max-width: 576px) {
    .js_modalCont .modal-data {
      display: block; } }
  .js_modalCont .modal-data .ttl-typeR {
    display: flex;
    width: 20%; }
    @media screen and (max-width: 576px) {
      .js_modalCont .modal-data .ttl-typeR {
        max-width: 181px;
        width: 40%;
        margin: 0 auto; } }
  .js_modalCont .modal-data .basic-txtR {
    padding: 10em 0 0 1em;
    font-size: clamp(1.4rem, 1.4rem, 1.6rem);
    width: 80%; }
    @media screen and (max-width: 576px) {
      .js_modalCont .modal-data .basic-txtR {
        width: 100%;
        padding: 2em 0 0; } }
.js_modalCont .js_modalClose {
  min-width: fit-content; }
  @media screen and (max-width: 767px) {
    .js_modalCont .js_modalClose {
      margin: clamp(40px, 8vw, 80px) auto 0;
      justify-content: center; } }

/*==========================================
　FV
===========================================*/
#header:not(.scroll) .header_logo_block {
  position: absolute;
  width: clamp(200px, 20vw, 385px);
  left: 13vw;
  top: min(12vw, 200px);
  pointer-events: none; }
  @media screen and (min-width: 2301px) {
    #header:not(.scroll) .header_logo_block {
      left: calc(50% - clamp(400px, 30vw, 685px)); } }
  @media screen and (max-width: 1200px) {
    #header:not(.scroll) .header_logo_block {
      left: 11vw; } }
  @media screen and (max-width: 767px) {
    #header:not(.scroll) .header_logo_block {
      left: calc(50% - 100px);
      top: 150px;
      padding: 0; } }
  #header:not(.scroll) .header_logo_block .header_logo {
    width: 100%; }

.fv-block {
  display: flex;
  justify-content: space-between;
  padding: 0 2.5% 0 4%;
  position: relative;
  max-width: 1920px;
  width: 100%;
  margin: 0 auto; }
  .fv-block::after {
    content: "";
    display: block;
    background: url("../img/model/mainimg04.png") no-repeat bottom right/cover;
    position: absolute;
    width: 52%;
    bottom: 0;
    left: 0;
    aspect-ratio: 1085/549; }
  @media screen and (max-width: 767px) {
    .fv-block {
      display: block;
      padding: 0 4% 60px; }
      .fv-block::after {
        display: none; } }
  .fv-block .block-head {
    width: 40%;
    text-align: center;
    padding: min(8vw, 190px) 0 0; }
    @media screen and (max-width: 767px) {
      .fv-block .block-head {
        width: 100%;
        padding: 150px 0 40vw;
        position: relative; }
        .fv-block .block-head::after {
          content: "";
          display: block;
          background: url("../img/model/mainimg04.png") no-repeat bottom right/cover;
          position: absolute;
          width: 100%;
          bottom: 0;
          left: 0;
          aspect-ratio: 1085/549; } }
  .fv-block .fv-ttl {
    font-weight: bold;
    font-size: clamp(2rem, 2.2vw, 3.6rem);
    letter-spacing: 0.1em;
    margin-bottom: 1em; }
    @media screen and (max-width: 767px) {
      .fv-block .fv-ttl {
        font-size: clamp(2.2rem, 2.6vw, 3.6rem); } }
    .fv-block .fv-ttl .sml {
      font-size: clamp(1.4rem, 1.8vw, 2rem); }
  .fv-block .fv-ttlEn {
    width: 80%;
    margin: 0 auto; }
    .fv-block .fv-ttlEn img {
      width: 100%; }
  .fv-block .fv-mainimg {
    width: 55%;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end; }
    @media screen and (max-width: 767px) {
      .fv-block .fv-mainimg {
        margin-top: 4%;
        width: 100%; } }
    .fv-block .fv-mainimg .mainimg-item {
      overflow: hidden;
      width: 40%; }
      .fv-block .fv-mainimg .mainimg-item:first-child {
        width: 100%;
        margin-bottom: 4%; }
      .fv-block .fv-mainimg .mainimg-item:nth-of-type(3) {
        margin-left: 4%; }
      @media screen and (max-width: 767px) {
        .fv-block .fv-mainimg .mainimg-item {
          width: 48%; } }
      .fv-block .fv-mainimg .mainimg-item img {
        width: 100%; }

/*==========================================
　CONCEPT
===========================================*/
.sec-concept {
  max-width: 1920px;
  width: 100%;
  margin: 0 auto;
  position: relative; }
  @media screen and (min-width: 961px) {
    .sec-concept .concept-row {
      display: flex;
      justify-content: space-between; } }
  @media screen and (min-width: 961px) {
    .sec-concept .concept-side {
      width: 40%; } }
  .sec-concept .concept-side .side-inner {
    position: relative; }
    @media screen and (min-width: 961px) {
      .sec-concept .concept-side .side-inner {
        position: sticky;
        top: 0; } }
  .sec-concept .concept-side .sec-ttlR {
    position: absolute;
    z-index: 1;
    top: clamp(100px, 10vw, 200px);
    left: 0; }
  @media screen and (min-width: 961px) {
    .sec-concept .concept-main {
      width: 55%;
      padding: clamp(200px, 30vw, 400px) 0 0; } }
  @media screen and (min-width: 1201px) {
    .sec-concept .concept-main {
      width: 50%; } }
  .sec-concept .concept-main .main-row {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    flex-direction: row-reverse; }
    .sec-concept .concept-main .main-row .basic-txtR {
      width: 45%; }
      @media screen and (min-width: 1201px) {
        .sec-concept .concept-main .main-row .basic-txtR {
          padding-bottom: clamp(100px, 12vw, 150px); } }
      @media screen and (max-width: 576px) {
        .sec-concept .concept-main .main-row .basic-txtR {
          width: 100%; } }
  .sec-concept .concept-subImg {
    width: 50%; }
    @media screen and (max-width: 576px) {
      .sec-concept .concept-subImg {
        width: 100%;
        display: flex;
        justify-content: space-between;
        margin-bottom: clamp(30px, 4vw, 40px); } }
    .sec-concept .concept-subImg li {
      overflow: hidden; }
      .sec-concept .concept-subImg li:nth-of-type(n+2) {
        margin-top: clamp(15px, 4vw, 40px); }
      @media screen and (max-width: 576px) {
        .sec-concept .concept-subImg li {
          width: 49%; }
          .sec-concept .concept-subImg li:nth-of-type(n+2) {
            margin-top: 0; } }
  .sec-concept .concept-mainimg {
    width: 96%;
    margin: 0 0 0 auto;
    aspect-ratio: 3 / 2.5;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center top 65%; }
    @media screen and (min-width: 961px) {
      .sec-concept .concept-mainimg {
        aspect-ratio: 688/1073;
        background-position: bottom center; } }
  .sec-concept .concept-lead {
    letter-spacing: 0.1em;
    font-weight: bold;
    font-size: min(3.8vw, 7.2rem);
    margin-bottom: 1em; }
    @media screen and (max-width: 576px) {
      .sec-concept .concept-lead {
        margin-top: 1em;
        font-size: min(4.6vw, 7.2rem); } }
    .sec-concept .concept-lead .lrg {
      font-size: min(6vw, 10rem);
      display: block; }
      @media screen and (max-width: 576px) {
        .sec-concept .concept-lead .lrg {
          font-size: min(8vw, 10rem); } }
  .sec-concept .cnv-reserveBlock {
    margin-top: clamp(80px, 12vw, 120px); }
    @media screen and (min-width: 1201px) {
      .sec-concept .cnv-reserveBlock {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        margin-top: 0; } }

/*==========================================
　POINT
===========================================*/
.sec-point {
  max-width: 1920px;
  width: 100%;
  margin: 0 auto; }
  .sec-point .point-row {
    display: flex;
    justify-content: space-between; }
    @media screen and (max-width: 960px) {
      .sec-point .point-row {
        display: block; } }
  .sec-point .point-side {
    width: 25%;
    min-width: 460px;
    position: relative;
    padding: clamp(60px, 12vw, 120px) 0 clamp(80px, 10vw, 120px) 4%;
    /*&::before{
    	content: "";
    	display: block;
    	background:$navy;
    	width: 100%;
    	height: 100%;
    	position: absolute;
    	left: 0;
    	top: 0;
    	z-index: 1;
    }*/ }
    @media screen and (min-width: 1201px) {
      .sec-point .point-side {
        min-width: 510px; } }
    @media screen and (max-width: 960px) {
      .sec-point .point-side {
        width: 100%;
        padding: clamp(80px, 15vw, 150px) 4% 0; } }
    .sec-point .point-side .side-inner {
      z-index: 2;
      position: relative; }
      @media screen and (min-width: 961px) {
        .sec-point .point-side .side-inner {
          position: sticky;
          top: 100px; } }
  .sec-point .point-main {
    width: 70%; }
    @media screen and (max-width: 960px) {
      .sec-point .point-main {
        width: 92%;
        margin: 0 auto; } }
  .sec-point .point-ttl {
    display: flex;
    align-items: center; }
    .sec-point .point-ttl .ttl-num {
      width: clamp(50px, 8vw, 80px);
      min-width: clamp(50px, 8vw, 80px); }
    .sec-point .point-ttl .sec-ttlR {
      width: 100%;
      padding: 0 0 0 3%; }
      @media screen and (min-width: 961px) {
        .sec-point .point-ttl .sec-ttlR {
          padding: 0 0 0 6%; } }
  .sec-point .point-nav {
    max-width: 370px;
    margin: clamp(40px, 8vw, 80px) 0 0; }
    @media screen and (max-width: 960px) {
      .sec-point .point-nav {
        display: none; } }
    .sec-point .point-nav li {
      position: relative;
      border: 1px solid #fff;
      font-family: "Jost", "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
      letter-spacing: 0.15em;
      font-size: clamp(1.4rem, 1.6vw, 2rem);
      background: #123646;
      padding: 0.1em 0 0.1em 3em; }
      .sec-point .point-nav li:not(:last-child) {
        margin-bottom: 15px; }
      .sec-point .point-nav li p .num {
        position: absolute;
        bottom: 0.5em;
        left: 1em; }
  .sec-point .point-list {
    display: flex;
    padding: clamp(25px, 10vw, 120px) 0 clamp(80px, 10vw, 120px);
    overflow-y: hidden; }
    .sec-point .point-list .point-item {
      width: clamp(260px, 20vw, 470px);
      text-align: center;
      margin-right: clamp(30px, 6vw, 60px); }
      .sec-point .point-list .point-item .item-img {
        overflow: hidden;
        border-radius: 100vmax; }
      .sec-point .point-list .point-item .item-body {
        position: relative;
        margin-top: calc(0px - clamp(25px,3vw,30px)); }
      .sec-point .point-list .point-item .item-ttl {
        font-family: "Jost", "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
        font-size: clamp(2.2rem, 3vw, 4rem);
        letter-spacing: 0.15em;
        font-weight: 400; }
        .sec-point .point-list .point-item .item-ttl .num {
          display: block;
          margin-bottom: 0.7em; }
          .sec-point .point-list .point-item .item-ttl .num img {
            object-fit: contain;
            aspect-ratio: 62 / 95;
            width: clamp(30px, 6vw, 40px); }
      .sec-point .point-list .point-item .item-ttlJa {
        font-weight: bold;
        font-size: clamp(1.6rem, 1.8vw, 2.2rem);
        letter-spacing: 0.1em;
        word-break: keep-all;
        overflow-wrap: anywhere; }
      .sec-point .point-list .point-item .item-img img {
        width: 100%; }

/*==========================================
　MOVIE
===========================================*/
.sec-movie .movie-area {
  width: 100%;
  background: #000;
  text-align: center;
  font-size: 0; }
  .sec-movie .movie-area iframe {
    aspect-ratio: 16 / 9;
    max-width: 1370px;
    width: 80%;
    height: auto;
    margin: 0 auto; }

/*==========================================
　DESIGN
===========================================*/
.sec-design {
  margin-top: clamp(120px, 20vw, 250px); }
  .sec-design .design-head {
    position: relative;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center; }
    @media screen and (max-width: 767px) {
      .sec-design .design-head {
        height: 70vw; } }
    .sec-design .design-head .head-bg {
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%; }
      .sec-design .design-head .head-bg::before {
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        position: absolute;
        background: rgba(0, 0, 0, 0);
        transition: 0.5s ease-in-out;
        top: 0;
        left: 0;
        scale: 0.8; }
    .sec-design .design-head > .wrapW {
      position: relative; }
    .sec-design .design-head.show .head-bg::before {
      background: rgba(0, 0, 0, 0.48);
      transition-delay: .5s;
      scale: 1; }
    .sec-design .design-head.show .sec-ttlR {
      transition-delay: .7s; }
  .sec-design .basic-txtR {
    font-size: clamp(1.6rem, 1.8vw, 1.8rem); }

/*==========================================
　INTERIOR
===========================================*/
.sec-interior {
  margin-top: clamp(60px, 12vw, 150px); }
  .sec-interior .interior-img {
    margin: clamp(25px, 4vw, 40px) auto clamp(40px, 6vw, 60px);
    display: flex;
    justify-content: space-between; }
    @media screen and (max-width: 767px) {
      .sec-interior .interior-img {
        flex-wrap: wrap; } }
    .sec-interior .interior-img li {
      width: calc(99% * 1/5);
      overflow: hidden; }
      @media screen and (max-width: 767px) {
        .sec-interior .interior-img li {
          width: calc(98.5% * 1/3); }
          .sec-interior .interior-img li:nth-of-type(-n+2) {
            width: calc(99% * 1/2);
            margin-bottom: 1%; } }
  .sec-interior .interior-lead {
    text-align: center;
    font-size: clamp(2.2rem, 4vw, 6rem);
    font-weight: bold;
    letter-spacing: 0.1em;
    margin: 0 auto 1em; }
    .sec-interior .interior-lead .font-jost {
      font-weight: 400; }
  @media screen and (min-width: 961px) {
    .sec-interior .basic-txtR {
      text-align: center; } }

/*==========================================
　living
===========================================*/
.sec-living .sec-ttlR {
  margin-bottom: -4em;
  z-index: 1;
  position: relative; }
  @media screen and (max-width: 960px) {
    .sec-living .sec-ttlR {
      margin-bottom: -2em; } }
.sec-living .living-list .living-item {
  display: flex;
  justify-content: space-between; }
  .sec-living .living-list .living-item:not(:last-child) {
    margin-bottom: clamp(40px, 5vw, 50px); }
  @media screen and (max-width: 960px) {
    .sec-living .living-list .living-item {
      display: block; } }
  .sec-living .living-list .living-item .item-head {
    min-width: clamp(400px, 43vw, 520px);
    padding: clamp(40px, 4vw, 80px) 0 0; }
    @media screen and (max-width: 960px) {
      .sec-living .living-list .living-item .item-head {
        width: 100%;
        min-width: inherit;
        padding: 0; } }
  .sec-living .living-list .living-item .item-body {
    width: 100%; }
    @media screen and (max-width: 960px) {
      .sec-living .living-list .living-item .item-body {
        width: 100%;
        margin-top: 25px; } }
  @media screen and (max-width: 960px) {
    .sec-living .living-list .living-item .ttl-typeR {
      width: 30%; } }
  .sec-living .living-list .living-item .item-txtBlock {
    border-top: 1px solid #fff;
    padding: clamp(25px, 4vw, 60px) 25px 0 0; }
    @media screen and (max-width: 960px) {
      .sec-living .living-list .living-item .item-txtBlock {
        padding: clamp(25px, 4vw, 60px) 0 0; } }
  .sec-living .living-list .living-item .item-lead {
    font-weight: bold;
    font-size: clamp(2.2rem, 3vw, 3rem);
    letter-spacing: 0.1em;
    margin-bottom: 1em; }
  .sec-living .living-list .living-item .basic-txtR {
    max-width: 370px; }
    @media screen and (max-width: 960px) {
      .sec-living .living-list .living-item .basic-txtR {
        max-width: none; } }
  .sec-living .living-list .living-item .item-img.hiraya {
    overflow: hidden; }
  .sec-living .living-list .living-item .item-img.nikai {
    display: flex;
    justify-content: space-between; }
    .sec-living .living-list .living-item .item-img.nikai .left-box {
      width: 55%;
      overflow: hidden; }
    .sec-living .living-list .living-item .item-img.nikai .right-box {
      width: 42%;
      display: flex;
      flex-direction: column;
      justify-content: space-between; }
      .sec-living .living-list .living-item .item-img.nikai .right-box li {
        overflow: hidden;
        position: relative;
        height: 31%; }
        .sec-living .living-list .living-item .item-img.nikai .right-box li img {
          object-fit: cover;
          width: 100%;
          height: 100%; }
    .sec-living .living-list .living-item .item-img.nikai .img-cap {
      position: absolute;
      left: 0.5em;
      bottom: 0.5em;
      font-size: clamp(1.2rem, 1.4vw, 1.4rem); }

/*==========================================
　KITCHEN
===========================================*/
.sec-kitchen .kitchen-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; }
  .sec-kitchen .kitchen-list .kitchen-item {
    width: 49%; }
    .sec-kitchen .kitchen-list .kitchen-item:nth-of-type(2n) {
      margin-top: clamp(40px, 7vw, 150px); }
    @media screen and (max-width: 767px) {
      .sec-kitchen .kitchen-list .kitchen-item {
        width: 100%; } }
    .sec-kitchen .kitchen-list .kitchen-item .item-img {
      overflow: hidden; }
    .sec-kitchen .kitchen-list .kitchen-item .item-body {
      position: relative;
      margin-top: calc(0px - clamp(15px,2vw,50px));
      display: flex;
      justify-content: space-between; }
      .sec-kitchen .kitchen-list .kitchen-item .item-body .ttl-typeR {
        width: 30%; }
      .sec-kitchen .kitchen-list .kitchen-item .item-body .basic-txtR {
        width: 65%;
        padding: clamp(40px, 8vw, 80px) clamp(25px, 4vw, 100px) 0 0; }
        @media screen and (max-width: 767px) {
          .sec-kitchen .kitchen-list .kitchen-item .item-body .basic-txtR {
            padding: clamp(40px, 8vw, 80px) 0 0; } }

/*==========================================
　EXTERIOR
===========================================*/
.sec-exterior .exterior-list {
  padding: clamp(40px, 8vw, 80px) 0;
  display: flex; }
  @media screen and (max-width: 767px) {
    .sec-exterior .exterior-list {
      padding: 80px 0 0; } }
  .sec-exterior .exterior-list .exterior-item {
    position: relative;
    width: 100%; }
    .sec-exterior .exterior-list .exterior-item:not(:last-child) {
      margin-right: clamp(50px, 12vw, 140px); }
    @media screen and (max-width: 767px) {
      .sec-exterior .exterior-list .exterior-item {
        min-height: inherit;
        height: auto; }
        .sec-exterior .exterior-list .exterior-item:not(:last-child) {
          margin-right: 4%; } }
    .sec-exterior .exterior-list .exterior-item .item-inner {
      position: relative;
      width: 100%; }
    .sec-exterior .exterior-list .exterior-item .item-img {
      position: relative;
      top: 0;
      left: 0;
      width: 100%;
      height: calc(100vh - 250px);
      background-position: center;
      background-repeat: no-repeat;
      background-size: cover; }
      @media screen and (max-width: 767px) {
        .sec-exterior .exterior-list .exterior-item .item-img {
          position: relative;
          height: 60vw; } }
    .sec-exterior .exterior-list .exterior-item .item-dataBlock {
      position: absolute;
      top: 0;
      left: 0;
      width: 20%;
      max-width: 200px;
      background: #123646;
      padding: 2%;
      margin-top: -1px;
      margin-left: -1px; }
    .sec-exterior .exterior-list .exterior-item .item-dataBlock_bottom {
      display: flex;
      justify-content: space-between;
      padding: 40px 0 0; }
      @media screen and (max-width: 767px) {
        .sec-exterior .exterior-list .exterior-item .item-dataBlock_bottom {
          display: block;
          padding: 40px 4% 0; } }
    @media screen and (max-width: 767px) {
      .sec-exterior .exterior-list .exterior-item .ttl-typeR {
        max-width: 130px; } }
    @media screen and (max-width: 375px) {
      .sec-exterior .exterior-list .exterior-item .ttl-typeR {
        max-width: 100px; } }
    .sec-exterior .exterior-list .exterior-item .item-ttl {
      min-width: 13em;
      font-weight: bold;
      font-size: clamp(2rem, 2.8vw, 3rem);
      letter-spacing: 0.1em; }
      @media screen and (max-width: 767px) {
        .sec-exterior .exterior-list .exterior-item .item-ttl {
          min-width: inherit;
          margin: 0 0 1em; } }
      @media screen and (max-width: 375px) {
        .sec-exterior .exterior-list .exterior-item .item-ttl {
          margin: 1.5em 0 0.7em; } }
    .sec-exterior .exterior-list .exterior-item .basic-txtR {
      padding: 0 2%; }
      @media screen and (max-width: 767px) {
        .sec-exterior .exterior-list .exterior-item .basic-txtR {
          padding: 0; } }

/*==========================================
　OTHERS
===========================================*/
.sec-others .others-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }
  .sec-others .others-list::before, .sec-others .others-list::after {
    content: "";
    display: block;
    width: calc(25% - clamp(3px,1vw,10px)); }
  .sec-others .others-list::before {
    order: 1; }
  .sec-others .others-list .others-item {
    width: calc(25% - clamp(3px,1vw,10px)); }
    .sec-others .others-list .others-item:nth-of-type(n+5) {
      margin-top: clamp(3px, 1vw, 10px); }
    .sec-others .others-list .others-item .item-thum {
      overflow: hidden; }
      .sec-others .others-list .others-item .item-thum a img {
        transition: all 1s ease;
        width: 100%;
        object-fit: cover;
        aspect-ratio: 1; }
      @media (hover: hover) {
        .sec-others .others-list .others-item .item-thum a:hover img {
          transform: scale(1.1, 1.1); } }

/*==========================================
　PLAN
===========================================*/
.sec-plan .plan_tab-container {
  display: flex;
  justify-content: center; }
  .sec-plan .plan_tab-container .plan_tab {
    border: 1px solid #fff;
    border-bottom: none;
    text-align: center;
    font-family: "Jost", "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
    font-size: clamp(1.6rem, 2vw, 2rem);
    letter-spacing: 0.15em;
    max-width: 323px;
    width: 49.5%;
    padding: 0.3em 0;
    cursor: pointer;
    transition: 0.3s ease-in-out; }
    .sec-plan .plan_tab-container .plan_tab:nth-of-type(2n) {
      margin-left: 1%; }
    @media (hover: hover) {
      .sec-plan .plan_tab-container .plan_tab:hover {
        background: rgba(255, 255, 255, 0.7);
        color: #123646; } }
    .sec-plan .plan_tab-container .plan_tab.active {
      background: #fff;
      color: #123646; }
.sec-plan .plan_content {
  display: none;
  background: #fff;
  color: #123646;
  padding: clamp(25px, 4vw, 90px); }
  @media screen and (max-width: 960px) {
    .sec-plan .plan_content {
      padding: clamp(40px, 7vw, 90px) 4%; } }
  .sec-plan .plan_content.show {
    display: block; }
.sec-plan .plan_contentRow .cts-ttl {
  font-weight: bold;
  font-size: clamp(2.2rem, 3vw, 3.8rem);
  letter-spacing: 0.11em;
  margin-bottom: 1em; }
.sec-plan .plan_contentRow .cts-img {
  padding: 0 0 25px; }
.sec-plan .plan_contentRow .cts-txtBox {
  border-top: 1px solid #123646;
  padding-top: 25px; }
@media screen and (min-width: 961px) {
  .sec-plan .plan_contentRow.hiraya {
    display: flex;
    justify-content: space-between; } }
@media screen and (min-width: 961px) {
  .sec-plan .plan_contentRow.hiraya .cts-img {
    width: 65%;
    padding: 0 clamp(25px, 4vw, 100px) 25px 0; } }
@media screen and (min-width: 961px) {
  .sec-plan .plan_contentRow.hiraya .cts-txtBox {
    width: 35%;
    border-top: none;
    border-left: 1px solid #123646;
    display: flex;
    justify-content: flex-end;
    flex-direction: column;
    padding-left: clamp(25px, 4vw, 100px); } }
@media screen and (min-width: 961px) {
  .sec-plan .plan_contentRow.nikai .cts-ttl {
    margin-bottom: 0;
    min-width: 12em; } }
@media screen and (min-width: 961px) {
  .sec-plan .plan_contentRow.nikai .cts-txtBox {
    display: flex;
    justify-content: space-between; } }

/*==========================================
　INFO
===========================================*/
.sec-info .info-row {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  position: relative; }
.sec-info .info-side {
  width: 30%;
  padding: 0 25px 0 0; }
  @media screen and (max-width: 960px) {
    .sec-info .info-side {
      width: 100%;
      padding: 0; } }
.sec-info .info-main {
  width: 70%;
  font-size: 0; }
  @media screen and (max-width: 960px) {
    .sec-info .info-main {
      width: 100%; } }
  .sec-info .info-main iframe {
    width: 100%; }
    @media screen and (max-width: 960px) {
      .sec-info .info-main iframe {
        height: 320px; } }
.sec-info .info-ttl {
  font-size: clamp(2rem, 3vw, 4rem);
  font-weight: 400;
  font-family: "Jost", "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
  letter-spacing: 0.15em;
  margin-bottom: 1.75em; }
@media screen and (min-width: 961px) {
  .sec-info .info-img {
    position: absolute;
    width: 40%;
    max-width: 612px;
    left: 0;
    bottom: 0; } }
.sec-info .info-img img {
  width: 100%; }
.sec-info .info-list .info-item {
  display: flex; }
  .sec-info .info-list .info-item:not(:last-child) {
    margin-bottom: 0.7em; }
  .sec-info .info-list .info-item dt {
    min-width: fit-content; }
  .sec-info .info-list .info-item dd {
    width: 100%; }
.sec-info .cnv-reserveBlock {
  margin-top: clamp(60px, 12vw, 120px); }

/*==========================================
　EVENT
===========================================*/
.sec-event .event-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  max-width: 1358px;
  width: 100%;
  margin: 0 auto; }
  .sec-event .event-list .event-item {
    width: 49%; }
    .sec-event .event-list .event-item a {
      display: block;
      position: relative;
      overflow: hidden; }
      @media (hover: hover) {
        .sec-event .event-list .event-item a:hover .item-more-wrap {
          opacity: 1;
          scale: 1.0; }
        .sec-event .event-list .event-item a:hover .item-img img {
          transform: scale(1.1, 1.1); } }
    .sec-event .event-list .event-item .item-img {
      overflow: hidden; }
      .sec-event .event-list .event-item .item-img img {
        transition: all 1s ease;
        width: 100%;
        object-fit: cover;
        aspect-ratio: 0.8; }
    .sec-event .event-list .event-item .item-more-wrap {
      position: absolute;
      z-index: 2;
      inset: 0;
      width: 100%;
      height: 100%;
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      background: rgba(0, 0, 0, 0.4);
      opacity: 0;
      transition: 0.3s ease-in-out;
      scale: 1.1; }
      .sec-event .event-list .event-item .item-more-wrap .item-more {
        font-size: 1.6rem;
        border-radius: 500px;
        border: 2px solid #fff;
        padding: 0px 2rem;
        font-weight: bold;
        color: #fff; }

/*# sourceMappingURL=modelhouse_new.css.map */
