/* tajima village */
:root {
  --placeholder-color: #ddd;
  --main-green: #1E965B;
  --main-red: #E31616;
  --main-black: #1f1f1f;
}
::placeholder {
  color: var(--placeholder-color);
}

main.tajima-main {
  background-image: url("../img/bg-image.png");
  background-repeat: repeat-y;
  background-size: contain;
  background-position: center top;
  margin-top: 113px;
}

@media screen and (max-width: 740px) {
  main.tajima-main {
    background-image: url("../img/bg-image.png");
    margin-top: 0;
  }
}


figure {
  margin: 0;
}

div[class*="__container"] {
  margin-bottom: 113px;
}

@media screen and (max-width: 740px) {
  div[class*="__container"] {
    margin-bottom: 80px;
  }
}

@media screen and (max-width: 740px) {
  /* mv */
  /* 物件概要 リスト */
  .list-container .container .row.flow .margin0 {
    margin: 0 0 0 1em;
  }

  .list-container .container .row.flow p {
    font-size: 12px;
  }

  /* common */
  .btn {
    text-align: left;
  }
}

.roboto {
  font-family: "Roboto", serif;
  font-weight: 700;
  font-style: normal;
}

.heading-container {
  text-align: center;
  margin-bottom: 60px;
}

.sub-heading {
  display: inline-block;
  font-size: 56px;
  color: var(--main-green);
  font-weight: 300;
  line-height: 1;
  position: relative;
  margin-bottom: 17px;
}

.sub-heading.multiline {
  line-height: 1.25;
}

.sub-heading::before,
.sub-heading::after {
  content: "";
  width: 180px;
  height: 4px;
  position: absolute;
  background-color: #111;
  top: 50%;
  transform: translateY(-50%);
}

.sub-heading::before {
  left: -270px;
}

.sub-heading::after {
  right: -270px;
}

.sub-heading .sub-heading__roboto {
  display: inline-block;
  font-size: 58px;
  font-family: "Roboto", serif;
  font-weight: 700;
  font-style: normal;
  padding: 0 4px;
}

.sub-heading__small {
  display: block;
  text-align: center;
  font-family: "Roboto", serif;
  font-weight: normal;
  font-style: normal;
  font-size: 14px;
  line-height: 1;
  letter-spacing: .2em;
  color: var(--main-green);
  text-transform: uppercase;
}

@media (max-width:1199.98px) {
  .sub-heading {
    font-size: 46px;
  }

  .sub-heading::before,
  .sub-heading::after {
    width: 100px;
  }

  .sub-heading::before {
    left: -170px;
  }
  
  .sub-heading::after {
    right: -170px;
  }
}

@media (max-width:768px) {
  .heading-container {
    margin-bottom: 28px;
  }

  .sub-heading {
    font-size: 37px;
    margin-bottom: 12px;
  }

  .sub-heading .sub-heading__roboto {
    font-size: 47px;
  }

  .sub-heading::before,
  .sub-heading::after {
    display: none;
  }

  .sub-heading__small {
    font-size: 12px;
  }

}

/* ------------ サイド固定ボタン ------------ */
.floating-banner {
  display: none;
}

.floating-banner__link {
  text-decoration: none;
}

.floating-banner__link.pc-none {
  display: none;
}

@media (max-width:540px) {
  .floating-banner {
    width: 100vw;
    left: 0;
    bottom: 0;
    backdrop-filter: blur(10px);
    padding: 5px 0;
  }

  .floating-banner__inner {
    display: flex;
    justify-content: center;
  }

  .floating-banner__link {
    display: block;
    text-decoration: none;
    width: calc(48% - 4px);
    border: 2px solid transparent;
  }

  a.floating-banner__link .banner {
    width: 100%;
    height: auto;
    margin-bottom: 0;
  }

  a.floating-banner__link .copy {
    font-size: 17px;
    font-weight: 500;
  }
  
  

  .floating-banner__link.pc-none {
    display: block;
  }
}


/* ------------ mv ------------ */
.header {
  width: 100%;
  height: auto;
}

.mv-container {
  position: relative;
}

.mv-img-wrapper {
  width: 100%;
}

.mv-container__img,
.mv-container__img.sp {
  display: block;
  width: 100%;
}

.mv-container__txt-wrap {
  display: block;
  text-align: left;
  position: absolute;
  top: 60px;
  left: 60px;
  margin: 0 auto;
}
.mv-container__txt-wrap h1 {
  text-align: left;
  display: inline-block;
  padding: 10px 10px 10px 0;
  margin-bottom: 18px;
  white-space: nowrap;
}

.mv-container__txt-wrap h1 .main-heading-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.mv-container__txt-wrap h1 .main-heading {
  display: inline-block;
  color: #111;
  line-height: 1;
  background-color: #fff;
  padding: 10px;
  margin-bottom: 9px;
  font-weight: 900;
  font-size: 72px;
}

.mv-container__txt-wrap h1 span.white {
  display: block;
  font-size: 40px;
  color: #fff;
  font-weight: bold;
  margin-bottom: 4px;
}

.mv-container__txt-wrap h1 img.white__icon {
  display: inline-block;
  position: absolute;
  top: -25px;
  right: -50px;
  width: 132px;
}

.mv-container__txt-wrap h1 .green {
  color: var(--main-green);
  font-size: 31px;
  font-weight: normal;
  text-shadow    : 
  2px  2px 1px #ffffff,
 -2px  2px 1px #ffffff,
  2px -2px 1px #ffffff,
 -2px -2px 1px #ffffff,
  2px  0px 1px #ffffff,
  0px  2px 1px #ffffff,
 -2px  0px 1px #ffffff,
  0px -2px 1px #ffffff;  
}

.mv-container__txt-wrap h1 .green span {
  font-size: 72px;
  font-family: "Roboto", serif;
  font-weight: 700;
  font-style: normal;
  padding: 0 4px;
  text-shadow    :
  3px  3px 1px #ffffff,
  -3px  3px 1px #ffffff,
  3px -3px 1px #ffffff,
  -3px -3px 1px #ffffff,
  3px  0px 1px #ffffff,
  0px  3px 1px #ffffff,
  -3px  0px 1px #ffffff,
  0px -3px 1px #ffffff; 
}

@media (max-width:1199.98px) {
  .mv-container__txt-wrap {
    top: 20px;
    left: 40px;
  }
  
  .mv-container__txt-wrap h1 .main-heading {
    font-size: 52px;
  }

  .mv-container__txt-wrap h1 span.white {
    font-size: 30px;
  }

  .mv-container__txt-wrap h1 .green {
    font-size: 24px;
  }
  
  .mv-container__txt-wrap h1 .green span {
    font-size: 52px;
  }

  .mv-container__txt-wrap h1 img.white__icon {
    top: -25px;
    right: -55px;
    width: 100px;
  }
}

@media (max-width:767px) {
  .mv-container__txt-wrap {
    top: 36px;
    left: 16px;
    margin: 0 auto;
  }

  .mv-container__txt-wrap h1 span.white {
    font-size: 19px;
  }

  .mv-container__txt-wrap h1 .main-heading {
    font-size: 39px;
    margin-bottom: 4px;
    padding: 7px;
  }

  .mv-container__txt-wrap h1 .green span {
    font-size: 38px;
  }

  .mv-container__txt-wrap h1 .green {
    font-size: 16px;
  }

  .mv-container__txt-wrap h1 img.white__icon {
    top: -25px;
    right: 10px;
    width: 73px;
  }
}



/* ------------ mv 右側の円形アイコン×２エリア ------------ */
.mv-container__right-container {
  position: absolute;
  top: 75px;
  right: 60px;
  font-size: 14px;
  line-height: 1;
  font-weight: normal;
  width: 195px;
  color: #111;
}

.right-container__top,
.right-container__bottom {
  width: 100%;
  height: 195px;
  background-size: cover;
  position: relative;
}

.right-container__top {
  background-image: url("../img/mv-right-circle-top.png");
  margin-bottom: 22px;
}

.right-container__bottom {
  background-image: url("../img/mv-right-circle-bottom.png");
}

.right-container-wrap {
  text-align: center;
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.right-container-wrap .small-text {
  display: block;
  font-size: 14px;
  margin-bottom: 8px;
}

.right-container-wrap .big-text {
  display: inline-block;
  font-size: 39px;
  margin-bottom: 8px;
}

.right-container-wrap .middle-text {
  display: block;
  font-size: 23px;
}

.right-container__icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: inline-block;
  width: 75px;
}



@media (max-width:1199.98px) {
  .mv-container__right-container {
    width: 150px;
    top: 20px;
    right: 40px;
  }
  .right-container__top,
  .right-container__bottom {
    height: 150px;
  }

  .right-container__icon {
    width: 50px;
  }

  .right-container-wrap .big-text {
    font-size: 21px;
  }

  .right-container-wrap .middle-text {
    font-size: 16px;
  }
}

@media (max-width:767px) {
  .mv-container__right-container {
    width: 115px;
    top: 246px;
    right: 16px;
  }

  .right-container-wrap {

  }

  .right-container__top,
  .right-container__bottom {
    height: 115px;
  }

  .right-container__icon {
    width: 50px;
  }

  .right-container-wrap .small-text {
    font-size: 9px;
    margin-bottom: 4px;
  }

  .right-container-wrap .big-text {
    font-size: 20px;
    margin-bottom: 4px;
  }

  .right-container-wrap .middle-text {
    font-size: 14px;
  }
}

/* ------------ mv 下ボタンエリア ------------ */
.mv-container__button-container {
  position: absolute;
  bottom: -45px;
  left: 50%;
  transform: translateX(-50%);
}

.button-container__hukidashi {
  text-align: center;
  width: 462px;
  background-color: #fff;
  border: 4px solid var(--main-green);
  border-radius: 14px;
  padding: 8px 0 12px;
  margin: 0 auto 10px;
  position: relative;
}

.button-container__hukidashi::before {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: -10px;
  left: 50%;
  width: 12px;
  height: 10px;
  background-color: #fff;
  background-size: cover;
  transform: translateX(-50%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  z-index: 20;
}

.button-container__hukidashi::after {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: -17px;
  left: 50%;
  width: 25px;
  height: 17px;
  background-color: var(--main-green);
  background-size: cover;
  transform: translateX(-50%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
}

.button-container__hukidashi span {
  display: inline-block;
  font-size: 20px;
  color: #1f1f1f;
  font-weight: normal;
  line-height: 1;
}

.button-container__hukidashi span.big-text {
  display: inline-block;
  font-size: 46px;
  font-family: "Roboto", serif;
  font-weight: 700;
  font-style: normal;
  vertical-align: baseline;
  margin-right: 2px;
}

.button-container__hukidashi span.middle-text {
  font-size: 26px;
  display: block;
  margin-bottom: 6px;
}

.booking-link {
  display: block;
  font-weight: normal;
  text-decoration: none;
  text-align: center;
  font-size: 32px;
  line-height: 1;
  color: #fff;
  background-color: var(--main-red);
  border: 4px solid #fff;
  border-radius: 500px;
  padding: 25px 41px;
  transition: all ease-in-out .3s;
}

.booking-link::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 22px;
  background-image: url("../img/arrow-right.png");
  background-size: cover;
  margin-left: 30px;
}

a.booking-link:hover {
  color: #fff;
  opacity: .8;
}

@media (max-width:1199.98px) {

  .button-container__hukidashi {
    padding: 4px 0 8px;
  }

  .button-container__hukidashi span {
    display: inline-block;
    font-size: 16px;
    color: #1f1f1f;
    font-weight: normal;
    line-height: 1;
  }
  
  .button-container__hukidashi span.big-text {
    display: inline-block;
    font-size: 28px;
    font-family: "Roboto", serif;
    font-weight: 700;
    font-style: normal;
    vertical-align: baseline;
    margin-right: 2px;
  }
  
  .button-container__hukidashi span.middle-text {
    font-size: 20px;
    margin-bottom: 2px;
  }
  
  .booking-link {
    font-size: 20px;
    padding: 18px 41px;
  }
}

@media (max-width:767px) {
  .mv-container__button-container {
    bottom: 43px;
  }
  .button-container__hukidashi {
    width: 100%;
    padding: 8px;
  }
  .button-container__hukidashi span.middle-text {
    font-size: 18px;
    white-space: nowrap;
    margin-bottom: 0;
  }

  .button-container__hukidashi span {
    font-size: 13px;
    white-space: nowrap;
  }

  .booking-link {
    font-size: 19px;
    white-space: nowrap;
    padding: 18px 21px;
  }

  .booking-link::after {
    margin-left: 8px;
    width: 6px;
    height: 11px;
  }
}

/* ------------ 3つの特徴　吹き出し ------------ */
ul.lead {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 90px;
}

ul.lead .lead-item {
  list-style-type: none;
  width: 320px;
  height: 339px;
  text-align: center;
  background-color: #fff;
  border: 4px solid var(--main-black);
  border-radius: 16px;
  padding: 64px 24px 42px;
  position: relative;
  margin-right: 16px;
}

ul.lead .lead-item:last-child {
  margin-right: 0;
}

ul.lead .lead-item::before {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: -16px;
  left: 50%;
  width: 18px;
  height: 16px;
  background-color: #fff;
  background-size: cover;
  transform: translateX(-50%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  z-index: 20;
}

ul.lead .lead-item::after {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: -22px;
  left: 50%;
  width: 28px;
  height: 22px;
  background-color: var(--main-black);
  background-size: cover;
  transform: translateX(-50%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
}

ul.lead .lead-item img {
  display: block;
  height: 77px;
  margin: 0 auto 25px;
}

ul.lead .lead__no {
  position: absolute;
  top: 0;
  left: 50%;
  display: inline-block;
  line-height: 1;
  background-color: #fff;
  transform: translate(-50%, -55%);
  font-size: 88px;
  font-family: "Roboto", serif;
  font-weight: 700;
  font-style: normal;
  color: var(--main-green);
  z-index: 20;
}

ul.lead .lead__no::after {
  content: "";
  display: inline-block;
  background-color: #fff;
  width: 70px;
  height: 70px;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}

ul.lead .lead__title {
  display: block;
  font-size: 25px;
  font-weight: normal;
  color: var(--main-green);
  letter-spacing: -.6px;
}

ul.lead .lead__note {
  display: block;
  font-size: 18px;
  font-weight: normal;
  color: #1f1f1f;
  margin-bottom: 13px;
}

@media (max-width:1199.98px) {
  ul.lead .lead-item {
    width: 270px;
  }

  ul.lead .lead-item img {
    height: 60px;
  }
}

@media (max-width:768px) {
  ul.lead {
    flex-wrap: wrap;
    margin-bottom: 20px;
  }

  ul.lead .lead-item {
    width: 49%;
    height: auto;
    margin-right: 0;
    margin-bottom: 5px;
    padding: 18px 14px;
    border: 2px solid var(--main-black);
  }

  ul.lead .lead-item:first-child {
    margin-right: 5px;
  }

  ul.lead .lead__no,
  ul.lead .lead-item::before,
  ul.lead .lead-item::after {
    display: none;
  }

  ul.lead .lead-item img {
    height: 44px;
    margin-bottom: 11px;
  }

  ul.lead .lead__title {
    font-size: 16px;
    white-space: nowrap;
  }

  ul.lead .lead__note {
    font-size: 12px;
  }
}


/* ------------ ４つの区画の短い概要 ------------ */
.lead-detail__container {
  display: flex;
  justify-content: center;
  background-image: url("../img/lead-detail-img.png");
  background-position: center, center;
  background-repeat: no-repeat;
  background-size: 422px;
}
.lead-detail {
  display: grid;
  gap: 40px;
  grid-template-columns: repeat(2, 300px);
  grid-template-rows: auto;
}

.lead-detail__item {
  list-style-type: none;
  border: 1px solid var(--main-green);
  border-radius: 8px;
  letter-spacing: .04em;
  background-color: #fff;
}

.lead-detail__wrap {
  padding: 27px 54px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.lead-detail__title {
  font-size: 30px;
  font-weight: 500;
  letter-spacing: .2em;
  color: #fff;
  background-color: var(--main-green);
  text-align: center;
  border-radius: 8px 8px 0 0;
  margin-bottom: 0;
}

.lead-detail__price {
  display: inline-block;
  line-height: 1;
  font-size: 31px;
  color: var(--main-red);
  margin-bottom: 12px;
}

.lead-detail__price .price-text {
  display: inline-block;
  font-size: 48px;
  font-family: "Roboto", serif;
  font-weight: 700;
  font-style: normal;
}

.lead-detail__info {
  font-size: 25px;
  font-weight: bold;
  display: block;
  line-height: 1;
  margin-bottom: 10px;
}

@media (max-width:768px) {
  .lead-detail__container {
    background-image: none;
  }

  .lead-detail {
    gap: 1px;
    grid-template-columns: repeat(2, 1fr);
    background-color: #707070;
    border: 1px solid #707070;
  }
  
  .lead-detail__item {
    border: none;
    border-radius: 0;
  }
  
  .lead-detail__wrap {
    align-items: flex-start;
    padding: 17px;
  }
  
  .lead-detail__title {
    font-size: 17px;
    height: 44px;
    line-height: 44px;
    border-radius: 0;
  }
  
  .lead-detail__price {
    font-size: 22px;
    margin-bottom: 12px;
  }
  
  .lead-detail__price .price-text {
    font-size: 35px;
  }
  
  .lead-detail__info {
    font-size: 14px;
    font-weight: bold;
    display: block;
    line-height: 1;
    margin-bottom: 10px;
  }
}

/* ------------ 3つの特徴 ------------ */
.feature__container {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 113px;
}

.feature-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 16px;
  margin-bottom: 60px;
  text-align: center;
}

.feature-item:last-child {
  margin-bottom: 0;
}

.feature-sub-title {
  display: flex;
  align-items: flex-end;
  justify-self: center;
  margin-bottom: 30px;
}

.feature-prefix {
  display: inline-block;
  background-color: var(--main-green);
  color: #fff;
  font-size: 16px;
  line-height: 29px;
  height: 29px;
  border-radius: 500px;
  padding: 0 20px;
  letter-spacing: .2em;
  margin-bottom: 10px;
  text-transform: uppercase;
}

.feature-num {
  display: inline-block;
  line-height: 1;
  color: var(--main-green);
  font-style: italic;
  font-size: 72px;
  vertical-align: middle;
  margin-left: 10px;
}

.feature-num.narrow {
  margin-left: 0;
}

.feature-title {
  display: inline-block;
  font-size: 36px;
  font-weight: 300;
  /* background: linear-gradient(transparent 73%, #F1FFEB 23%); */
  text-decoration: underline;
  text-decoration-thickness: 15px;
  text-decoration-color: #F1FFEB;
  margin-bottom: 18px;
}

.feature-text {
  font-size: 16px;
  width: 100%;
  text-align: left;
  margin-bottom: 0;
}

.feature-list {
  display: inline-block;
  padding-left: 20px;
}

.feature-list li {
  text-align: left;
  list-style-type: square;
  list-style: square;
}

@media screen and (max-width: 767px) {
  .feature__container {
    padding: 0 16px;
  }

  .feature-title {
    white-space: nowrap;
  }
}

/* ------------ 立地の特徴 ------------ */
.location-features__list {
  width: 320px;
  margin: 0 auto;
}

.location-features__item {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 23px;
  font-weight: 400;
  white-space: nowrap;
}

.location-features__item span {
  display: inline-block;
  font-size: 37px;
  font-weight: 700;
}

.location-features__item img {
  display: block;
  height: 2px;
  margin: 0 12px;
}

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

}

/* ------------ 全体計画 ------------ */
.plan__container {
  max-width: 963px;
  margin: 0 auto 190px;
}

.plan__img {
  display: block;
  width: 100%;
  margin-bottom: 50px;
}

.plan__text {
  max-width: 634px;
  text-align: center;
  font-weight: bold;
  line-height: 2.06;
  margin: 0 auto 40px;
}

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

.plan__img-container {
  display: flex;
  justify-content: center;
}

.plan__grid {
  display: grid;
  gap: 40px;
  grid-template-columns: repeat(2, 333px);
  grid-template-rows: auto;
}

.plan__img-item img {
  display: block;
  width: 100%;
  margin-bottom: 6px;
}

.plan__img-item figcaption {
  font-weight: 500;
  text-align: left;
  font-size: 14px;
  line-height: 1.35;
}

@media screen and (max-width: 767px) {
  .plan__grid {
    gap: 20px;
    grid-template-columns: repeat(1, 333px);
  }

  .plan__text {
    padding: 0 16px;
    text-align: left;
    margin: 0 auto 25px;
  }
}

/* ------------ 間取りについて ------------ */
.floor__container {
  max-width: 825px;
  margin: 0 auto 147px;
}

.floor__img {
  display: block;
  width: 100%;
  margin-bottom: 30px;
}

.floor__img-container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.floor__grid-2col {
  display: grid;
  gap: 40px;
  grid-template-columns: repeat(2, 333px);
  grid-template-rows: auto;
  margin-bottom: 40px;
}

.floor__grid-3col {
  display: grid;
  gap: 40px;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto;
}

.floor__img-item img {
  display: block;
  width: 100%;
  margin-bottom: 6px;
}

.floor__img-item figcaption {
  font-weight: 500;
  text-align: left;
  font-size: 14px;
  line-height: 1.35;
}

@media screen and (max-width: 767px) {
  .floor__grid-2col {
    gap: 20px;
    grid-template-columns: repeat(1, 1fr);
    margin-bottom: 20px;
  }
  
  .floor__grid-3col {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(1, 1fr);
  }
}

/* ------------ 家のこと ------------ */
.about-house__container {
  max-width: 964px;
  background-color: #fff;
  border: 1px solid #363636;
  margin: 0 auto 113px;
}

.about-house__container .heading-container {
  display: none;
}

.about-house__inner {
  padding: 0 82px 82px;
}

.about-house__title {
  width: 100%;
  color: #fff;
  font-size: 39px;
  font-weight: 300;
  background-color: #363636;
  height: 95px;
  line-height: 95px;
  text-align: center;
  margin-bottom: 60px;
}

.about-house__catch {
  display: block;
  font-size: 19px;
  line-height: 1;
  text-align: center;
  margin-bottom: 40px;
}

.about-house__logo {
  display: block;
  max-width: 553px;
  margin: 0 auto 40px;
}

.about-house__list-wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.about-house__list {
  list-style: none;
  display: grid;
  gap: 15px;
  grid-template-columns: repeat(4, 170px);
  grid-template-rows: auto;
  margin-bottom: 40px;
}

.about-house__list li {
  background-color: #fff;
  height: 170px;
  border: 1px solid #707070;
  border-radius: 500px;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}

.about-house__list li span {
  display: inline-block;
  line-height: 1.52;
  font-size: 17px;
  font-weight: bold;
}

.about-house__desc {
  max-width: 798px;
  margin-bottom: 47px;
}

a.about-house__link {
  display: block;
  text-decoration: none;
  text-align: center;
  text-transform: uppercase;
  font-size: 23px;
  font-weight: 300;
  line-height: 90px;
  height: 90px;
  color: #fff;
  background-color: var(--main-black);
  border-radius: 500px;
  padding: 0 58px;
  letter-spacing: .05em;
  transition: all ease-in-out .3s;
  margin-bottom: 46px;
}

a.about-house__link::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 22px;
  background-image: url("../img/arrow-right.png");
  background-size: cover;
  margin-left: 30px;
}

a.about-house__link::hover {
  color: #fff;
  opacity: .8;
}

.about-house__num {
  display: inline-block;
  font-size: 23px;
  margin-right: 4px;
  color: #00563b;
  font-weight: 500;
  letter-spacing: 0.1rem;
}

.bg-grid {
  background-image: url("../img/grid.jpg");
  background-repeat: repeat;
  background-size: contain;
}

@media (max-width:1199.98px) {
  .about-house__list {
    list-style: none;
    display: grid;
    gap: 15px;
    grid-template-columns: repeat(4, 150px);
    grid-template-rows: auto;
    margin-bottom: 40px;
  }

  .about-house__list li {
    height: 150px;
    border: 1px solid #707070;
    border-radius: 500px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

@media (max-width:768px) {
  .about-house__container {
    border: none;
    background-color: transparent;
    margin: 0 auto 113px;
  }

  .about-house__inner {
    padding: 0 16px 16px 16px;
    text-align: center;
  }

  .about-house__title {
    display: none;
  }

  .about-house__container .heading-container {
    display: block;
  }

  .about-house__catch {
    display: inline-block;
    line-height: 20px;
    text-align: left;
  }

  .about-house__logo {
    display: block;
    max-width: 100%;
    margin: 0 auto 40px;
  }

  .about-house__list {
    gap: 12px;
    grid-template-columns: repeat(2, 133px);
    margin-bottom: 40px;
  }
  
  .about-house__list li {
    height: 133px;
  }
  
  .about-house__list li span {
    font-size: 14px;
  }

  .about-house__desc {
    margin-bottom: 28px;
  }

  a.about-house__link {
    text-align: left;
    font-size: 20px;
    line-height: 1.25;
    height: auto;
    padding: 23px 30px 23px 33px;
    margin-bottom: 28px;
    position: relative;
  }

  a.about-house__link::after {
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%);
    width: 6px;
    height: 11px;
  }

  .skeleton-house__title {
    font-size: 16px;
    text-align: left;
  }

  .skeleton-house__subtitle {
    font-size: 16px;
    text-align: left;
  }
}


/* ------------ 太陽光パネルについて ------------ */
.solar-panels__container {
  text-align: center;
}

.solar-panels__catch {
  font-size: 30px;
  line-height: 1.5;
}

.solar-panels__catch-img {
  display: inline-block;
  max-width: 420px;
  margin-bottom: 73px;
}

.solar-panels__catch .note-icon {
  display: inline-block;
  font-size: 19px;
  line-height: 1;
  vertical-align: top;
  margin: 0 3px;
}

.solar-panels__catch .note-icon:last-child {
  vertical-align: text-top;
}

.solar-panels__catch-num {
  font-size: 48px;
  margin: 0 3px;
}

.solar-panels__title {
  background-color: var(--main-green);
  border-radius: 8px;
  color: #fff;
  font-size: 40px;
  font-weight: 300;
  max-width: 768px;
  height: 66px;
  line-height: 66px;
  margin: 0 auto 20px;
}

.solar-panels__img {
  display: block;
  max-width: 599px;
  margin: 0 auto 70px;
}

.solar-panels__note {
  display: block;
  text-align: center;
  font-size: 14px;
  font-weight: 500;
}

@media (max-width:768px) {
  .solar-panels__catch {
    font-size: 20px;
  }

  .solar-panels__catch-num {
    font-size: 34px;
  }

  .solar-panels__img {
    display: block;
    max-width: 100%;
    margin: 0 auto 70px;
  }

  .solar-panels__catch-img {
    margin-bottom: 30px;
  }

  .solar-panels__title {
    font-size: 20px;
    height: 52px;
    line-height: 52px;
  }
}

/* ------------ アクセス ------------ */
.access__container {
  background-color: #fff;
}

/* ------------ 来場予約 ------------ */
.visitor-booking {
  margin: auto 0 113px;
  background-color: #f1ffeb;
  flex-direction: column;
  padding-bottom: 60px;
  
}
.visitor-booking__title {
  position: relative;
  font-size: 56px;
  color: #fff;
  font-weight: 300;
  padding: 52px;
  background-color: #1e965b;
  margin-bottom: 60px;
}

.visitor-booking__title::after {
  content: "";
  position: absolute;
  bottom: -38px;
  left: 50%;
  transform: translateX(-50%);
  border-width: 20px;
  border-style: solid;
  border-color: #1e965b transparent transparent transparent;
}

.visitor-booking__sub-title {
  line-height: 1;
  text-align: center;
  max-width: 375px;
  padding: 16px;
  font-size: 26px;
  font-weight: 400;
  color: var(--main-green);
  border-radius: 8px;
  border: 2px solid var(--main-green);
  background-color: #fff;
  margin: 0 auto 16px;
}

.visitor-booking__desc {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 40px;
}


.visitor-booking h2 img.title {
  width: 100%;
  max-width: 224px;
}
.visitor-booking .visitor-booking-lead {
  width: 100%;
  max-width: 696px;
  margin: 60px auto 0;
}
.visitor-booking .form-wrapper {
  margin: 40px auto 0;
  width: calc(100% - 2rem);
}
@media screen and (max-width: 740px) {
  .visitor-booking__title {
    font-size: 37px;
    padding: 20px;
    margin-bottom: 20px;
  }

  .visitor-booking__sub-title {
    font-size: 20px;
  }

  .visitor-booking__desc-wrap {
    padding: 0 16px;
  }

  .visitor-booking__desc {
    font-size: 16px;
    font-weight: normal;
  }

  .visitor-booking h2 img.title {
    width: 100%;
    max-width: 148px;
  }
  .visitor-booking h2::after {
    display: none;
  }
  .visitor-booking .visitor-booking-lead {
    width: 100%;
    max-width: 342px;
    margin: 20px auto 0;
  }
  .visitor-booking .form-wrapper {
    margin: 40px auto 0;
  }
}

/* ------------ エンジョイヴィレッジについて ------------ */
.about-village__container {}

.about-village__desc {
  max-width: 600px;
  line-height: 1.75;
  font-size: 16px;
  font-weight: 500;
  margin: 0 auto 37px;
}

.about-village__img {
  display: block;
  max-width: 800px;
  margin: 0 auto 40px;
}

a.about-village__link {
  text-transform: uppercase;
  max-width: 580px;
  margin: 0 auto;
  display: block;
  font-weight: normal;
  text-decoration: none;
  text-align: center;
  font-size: 32px;
  line-height: 1;
  color: #fff;
  background-color: var(--main-black);
  border: 4px solid #fff;
  border-radius: 500px;
  padding: 25px 41px;
  letter-spacing: .05em;
  transition: all ease-in-out .3s;
}

a.about-village__link::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 22px;
  background-image: url("../img/arrow-right.png");
  background-size: cover;
  margin-left: 30px;
}

a.about-village__link:hover {
  color: #fff;
  opacity: .8;
}

@media screen and (max-width: 768px) {
  .about-village__img {
    width: 100%;
  }

  a.about-village__link {
    font-size: 20px;
    width: 100%;
  }

  a.about-village__link::after {
    width: 8px;
    height: 14.66px;
    margin-left: 20px;
  }
}

/* 物件概要 */
.list-container {
  background-color: #fff;
}
.overview-container {
  position: relative;
  display: inline-block;
}

/* 概要 2カラムバージョンを追加 */
.two-column {
  display: flex;
}

.two-column-left {
  white-space: nowrap;
  padding-left: 16px;
}

.two-column-right {
  font-size: 14px;
  padding-left: 10%;
}

@media screen and (min-width: 992px) {
  .two-column-right {
    font-size: 14px;
    padding-left: 13%;
  }
}

@media screen and (max-width: 767px) {
  .two-column {
    flex-direction: column;
    padding-left: 14px;
  }

  .two-column-left {
    padding-left: 0;
  }

  .two-column-right {
    font-size: 12px;
    padding-left: 0;
  }
}

@media screen and (max-width: 540px) {
  .two-column-left {
    font-size: 12px;
    font-weight: 900;
  }
}

/* footer */
.footer-logo {
  display: block;
  width: 485px;
  font-weight: normal;
  text-decoration: none;
  margin: 0 auto;
  position: relative;
}

.footer-logo span {
  display: inline-block;
  font-weight: bold;
  position: absolute;
  bottom: -18px;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

@media screen and (max-width: 740px) {
  /* footer */
  .footer-logo {
    width: 100%;
  }

  .footer-logo span {
    position: static;
    display: block;
    transform: none;
    text-align: center;
    font-size: 12px;
  }
}

/* ここから 来場予約フォーム向け */
.form-wrapper {
  width: 100%;
  max-width: 970px;
  background-color: #fff;
  border-radius: 8px;
  border: solid 2px #1e965b;
  padding: 2rem;
}
#form {
  width: 100%;
}
#form legend {
  float: none;
  display: block;
  font-size: 1rem;
}
dl,
dt,
dd,
ul,
li {
  margin: 0;
  padding: 0;
}
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #fff;
  color: #000;
}
label,
input[type="checkbox"] {
  cursor: pointer;
}
input[type="checkbox"] {
  margin: 0 0.5rem 0 0;
}
input[type="submit"] {
  display: block;
  margin: 1rem auto 0;
  padding: 0.5rem 1.5rem;
  font-size: 1rem;
}
label span {
  display: inline-block;
}
h2 {
  font-weight: bold;
  font-size: 1.5rem;
  text-align: center;
}

.form-wrapper {
  margin: 0 auto 2rem;
}
.description {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 2rem auto 0;
}
.description dl {
  width: 70%;
}
@media screen and (max-width: 599px) {
  .description dl {
    width: 100%;
  }
}
.description dt {
  font-weight: bold;
}
.description dd {
  margin-bottom: 20px;
}
.description dd span {
  display: inline-block;
}
.description ul {
  list-style: none;
  margin: 0.5rem 0 0;
  font-size: 0.8rem;
}
.form-area {
  margin: 2rem 0 auto;
}
fieldset {
  border: none;
  margin: 1rem 0 0;
  padding: 0;
}
legend {
  font-weight: normal;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: baseline;
}
.required {
  color: red;
}
.name-set {
  display: flex;
}
.form-set {
  margin: 1rem auto 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.name-set {
  margin: 1rem auto 0;
  display: flex;
  flex-direction: row;
  gap: 1rem;
}
.name-set .form-set {
  margin: 0;
  width: 50%;
}
.text-box,
.textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  box-sizing: border-box;
  border-radius: 2px;
  border: 2px solid var(--placeholder-color);
}
.select-wrapper {
  display: inline-block;
  position: relative;
  vertical-align: middle;
  width: 100%;
  border-radius: 2px;
  border: 2px solid var(--placeholder-color);
  cursor: pointer;
}
.select-wrapper::before {
  position: absolute;
  top: calc(50% - 5px);
  right: 16px;
  width: 0;
  height: 0;
  border-width: 10px 5px 0 5px;
  border-style: solid;
  border-color: var(--placeholder-color) transparent transparent transparent;
  content: "";
  pointer-events: none;
}
.select-wrapper select {
  width: 100%;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  border: none;
  box-sizing: border-box;
}
.select-wrapper .placeholder {
  color: var(--placeholder-color);
}
.select-wrapper option[value=""] {
  color: var(--placeholder-color);
}
.annotation {
  margin: 0 0 0 0.25rem;
  font-size: 0.75rem;
  color: #666;
}
.submit-area {
  text-align: center;
}
.privacy {
  font-size: 0.75rem;
  color: #666;
  margin: 1rem 0 0;
  width: 100%;
  text-align: left;
  padding: 0 1rem;
  border-radius: 2px;
  border: 2px solid #ddd;
  box-sizing: border-box;
}
.privacy .form-set {
  display: block;
  margin: 2rem auto 1rem;
  text-align: center;
  font-size: 1rem;
  color: initial;
}
.error {
  color: red;
}
.error-result {
  display: none;
  margin: 2rem auto 0;
  text-align: center;
}
.error-contact-message {
  margin: 0.5rem auto 0;
}
#preview {
  display: none;
}
#preview .field-set {
  display: flex;
  flex-wrap: wrap;
}
#preview .field-set .field-label {
  min-width: 30%;
  font-weight: bold;
  text-align: left;
  padding: 0 1rem 0 0;
}
#preview .field-set .field-value {
  margin: 0;
}
#preview .multi-line-field-set {
  display: flex;
  flex-direction: column;
  width: 100%;
}
#preview .multi-line-field-set .field-label {
  display: flex;
  justify-content: flex-start;
  width: 100%;
  flex-wrap: wrap;
  font-weight: bold;
}
#preview .multi-line-field-set .field-value {
  margin: 0.5rem 0 0;
}
#preview .multi-line-field-set .field-multi-line-value {
  margin: 0.5rem 0 0;
  text-align: left;
  white-space: pre-wrap;
}
#preview .empty {
  color: #ccc;
}
#preview #cancel-button {
  width: 150px;
  margin: 2rem 0.5rem 0 0;
  padding: 0.25rem 1rem;
  font-size: 1rem;
}
#preview #submit-button {
  width: 150px;
  margin: 2rem 0 0 0.5rem;
  padding: 0.25rem 1rem;
  font-size: 1rem;
  background-color: #383535;
  color: #fff;
}
.thunks-message {
  display: none;
  margin: 2rem auto 0;
  text-align: center;
  font-size: 1.25rem;
  line-height: 2;
}
#overlay {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  height: 100%;
  display: none;
  background: rgba(0, 0, 0, 0.6);
}
.cv-spinner {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.spinner {
  width: 40px;
  height: 40px;
  border: 4px #ddd solid;
  border-top: 4px #2e93e6 solid;
  border-radius: 50%;
  animation: sp-anime 0.8s infinite linear;
}
@keyframes sp-anime {
  100% {
    transform: rotate(360deg);
  }
}
.is-hide {
  display: none;
}
/* reCAPTCHAがあるので引き上げ */
#pagetop {
  bottom: 90px;
}
/* ここまで 来場予約フォーム向け */

/* MV キャンペーンバナー */
.mv-container__campaign {
  position: absolute;
  top: 75px;
  right: 60px;
  width: 300px;
}

.campaign__link {
  display: block;
  text-decoration: none;
  width: 100%;
  transition: all ease-in-out .3s;
}

.campaign__link:hover {
  filter: brightness(1.2);
}

.campaign__link img {
  display: block;
  width: 100%;
}

@media screen and (max-width: 992px) {
  .mv-container__campaign {
    width: 180px;
  }
}

@media screen and (max-width: 768px) {
  .mv-container__campaign {
    top: 272px;
    right: 21px;
  }
}

/* ここまでMV キャンペーンバナー */
