@charset "UTF-8";
/*---レスポンシブサイズ---*/
/*---変数---*/
:root {
  --mc: #0f2131;
  --sc: #9d8c56;
}

/*---リセットCSS---*/
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font-weight: normal;
  vertical-align: baseline;
  background: transparent;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

ol,
ul,
li {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  outline: none;
}

img {
  vertical-align: top;
  font-size: 0;
  line-height: 0;
}

*,
*:before,
*:after {
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

br {
  line-height: inherit;
}

span {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

section {
  position: relative;
}

input[type="submit"],
input[type="button"] {
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]:focus,
input[type="button"]:focus {
  outline-offset: -2px;
}

main {
  display: block;
}

img {
  max-width: 100%;
  height: auto;
}

button {
  outline: none;
}

iframe {
  display: block;
}

/*---基本設定---*/
html {
  box-sizing: border-box;
  font-size: 62.5%;
}

body {
  -webkit-text-size-adjust: 100%;
  position: relative;
  color: #000;
  font-family: "游ゴシック", "游ゴシック体", YuGothic, "Yu Gothic", sans-serif;
}
@media all and (-ms-high-contrast: none) {
  body {
    font-family: "游ゴシック", "游ゴシック体", YuGothic, "Yu Gothic", sans-serif;
  }
}

html,
body {
  width: 100%;
}

*:focus {
  outline: none;
}

p,
li,
dl,
tr,
th,
td {
  font-size: 1.6rem;
  letter-spacing: 0;
}

span {
  font-weight: inherit;
  letter-spacing: inherit;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  letter-spacing: 0;
}

a,
a * {
  box-sizing: border-box;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
  letter-spacing: inherit;
  text-decoration: none;
  color: inherit;
  backface-visibility: hidden;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  cursor: pointer;
}

/*---display---*/
.pc {
  display: block;
}
@media screen and (max-width: 1024px) {
  .pc {
    display: none !important;
  }
}

.pc-tb {
  display: block;
}
@media screen and (max-width: 767px) {
  .pc-tb {
    display: none !important;
  }
}

.tb-sp {
  display: none !important;
}
@media screen and (max-width: 1024px) {
  .tb-sp {
    display: block !important;
  }
}

.tb {
  display: none !important;
}
@media screen and (max-width: 1024px) {
  .tb {
    display: block !important;
  }
}
@media screen and (max-width: 767px) {
  .tb {
    display: none !important;
  }
}

.sp {
  display: none !important;
}
@media screen and (max-width: 767px) {
  .sp {
    display: block !important;
  }
}

/*---cmn---*/
.cmn-wrap {
  position: relative;
  margin: 0 auto;
  padding-inline: 40px;
  width: 100%;
  max-width: 1280px;
}
@media screen and (max-width: 767px) {
  .cmn-wrap {
    padding-inline: 20px;
  }
}
.cmn-wrap.--full {
  padding: 0;
  max-width: none;
}

.cmn-ttl__main {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .cmn-ttl__main {
    gap: 10px;
  }
}
.cmn-ttl__main span {
  position: relative;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 3.2rem;
  letter-spacing: 0.08em;
  line-height: 1.875;
  color: var(--mc);
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .cmn-ttl__main span {
    font-size: 2.4rem;
    line-height: 1.5;
  }
}
.cmn-ttl__sub {
  display: block;
  font-family: "Red Hat Display", sans-serif;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 2;
  color: #000;
}
.cmn-ttl.--center {
  text-align: center;
}
.cmn-ttl.--center .cmn-ttl__main::before {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--mc);
}
.cmn-ttl.--center .cmn-ttl__main::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--mc);
}
.cmn-ttl.--left {
  margin-inline: 0 auto;
  text-align: left;
}
.cmn-ttl.--left .cmn-ttl__main span {
  padding-inline: 0 20px;
}
@media screen and (max-width: 767px) {
  .cmn-ttl.--left .cmn-ttl__main span {
    padding-inline: 0 10px;
  }
}
.cmn-ttl.--left .cmn-ttl__main::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--mc);
}
.cmn-ttl.--right {
  margin-inline: auto 0;
  text-align: right;
}
.cmn-ttl.--right .cmn-ttl__main::before {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--mc);
}
.cmn-ttl.--about .cmn-ttl__main::after {
  background: linear-gradient(0.25turn, var(--mc) 0, var(--mc) 14%, #fff 14%, #fff 100%);
}

.--en {
  font-family: "Red Hat Display", sans-serif;
}

.--main-color {
  color: var(--mc);
}

.--sub-color {
  color: var(--sc);
}

.hd {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 120px;
  background: linear-gradient(rgb(15, 33, 49) 0%, rgba(0, 0, 0, 0) 100%);
  line-height: 1;
  transition: all 0.4s;
  z-index: 1000;
}
.hd-cnt {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  margin: 0 auto;
  padding-inline: 40px;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1360px) {
  .hd-cnt {
    padding-inline: 20px;
  }
}
.hd-logo {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 16px;
  line-height: 1;
}
@media screen and (max-width: 1360px) {
  .hd-logo {
    gap: 5px;
  }
}
.hd-logo__ph {
  max-width: 160px;
}
@media screen and (max-width: 1360px) {
  .hd-logo__ph {
    max-width: 150px;
  }
}
.hd-logo__st {
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: 0.04em;
  line-height: 1.7142857143;
}
.hd-nav {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 38px;
}
@media screen and (max-width: 1360px) {
  .hd-nav {
    gap: 16px;
  }
}
.hd-nav__list {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: nowrap;
  gap: 24px;
}
@media screen and (max-width: 1360px) {
  .hd-nav__list {
    gap: 16px;
  }
}
.hd-nav__item {
  text-align: center;
}
.hd-nav__link {
  position: relative;
  display: block;
  color: #fff;
  transition: 0.4s;
}
.hd-nav__link-st {
  display: block;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 1360px) {
  .hd-nav__link-st {
    font-size: 1.5rem;
  }
}
@media screen and (min-width: 1025px) {
  .hd-nav__link:hover {
    opacity: 0.7;
  }
}
.hd-nav__btn-link {
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(17.1875vw, 22rem);
  height: 48px;
  background: var(--mc);
  border: 1px solid var(--mc);
  color: #fff;
  cursor: pointer;
  transition: 0.4s;
}
@media screen and (max-width: 767px) {
  .hd-nav__btn-link {
    width: 120px;
  }
}
.hd-nav__btn-link:hover {
  background: #fff;
  color: var(--mc);
}
.hd-nav__btn-st {
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  line-height: 1.75;
}
@media screen and (max-width: 1360px) {
  .hd-nav__btn-st {
    font-size: 1.5rem;
  }
}
.hd-toggle {
  display: none;
}
@media screen and (max-width: 1024px) {
  .hd {
    height: 60px;
  }
  .hd-logo {
    flex-direction: row;
    gap: 12px;
    width: auto;
    line-height: 1;
    z-index: 1001;
  }
  .hd-logo__ph {
    width: 100px;
  }
  .hd-logo__st {
    font-size: 1.2rem;
  }
  .hd-nav {
    position: fixed;
    top: 0;
    left: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-direction: column;
    padding-top: 120px;
    width: 100%;
    max-width: 460px;
    height: 100svh;
    background: linear-gradient(rgb(15, 33, 49) 0%, rgba(0, 0, 0, 0.75) 100%);
    overflow-y: auto;
    opacity: 0;
    transition: transform 0.2s, opacity 0.2s, visibility 0s 0.2s;
    visibility: hidden;
    z-index: 1000;
  }
  .hd-nav__list {
    display: block;
    margin-bottom: 25px;
  }
  .hd-nav__item {
    padding: 0;
    line-height: 1;
  }
  .hd-nav__link {
    display: block;
    padding: 16px 0;
  }
  .hd-nav__btn-link {
    width: 180px;
  }
  .hd-toggle {
    position: relative;
    display: block;
    width: 92px;
    height: 100%;
    cursor: pointer;
    z-index: 1002;
  }
  .hd-toggle div {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    display: block;
    width: 24px;
    height: 16px;
  }
  .hd-toggle span {
    position: absolute;
    left: 0;
    display: block;
    width: 100%;
    height: 1px;
    background: #fff;
    color: #fff;
    transition: 0.35s ease-in-out;
  }
  .hd-toggle span:nth-child(1) {
    top: 0;
  }
  .hd-toggle span:nth-child(2) {
    top: 8px;
  }
  .hd-toggle span:nth-child(3) {
    position: relative;
    top: 16px;
  }
}
.hd.open .sp-nav {
  opacity: 1;
  transform: translateX(-100%);
  transition: transform 0.4s, opacity 0.4s;
  visibility: visible;
}
.hd.open .hd-toggle__txt {
  color: #333;
  visibility: hidden;
}
.hd.open .hd-toggle__txt::after {
  visibility: visible;
}
.hd.open .hd-toggle span:nth-child(1) {
  top: 5px;
  transform: rotate(45deg);
}
.hd.open .hd-toggle span:nth-child(2) {
  left: 50%;
  width: 0;
}
.hd.open .hd-toggle span:nth-child(3) {
  top: 5px;
  transform: rotate(-45deg);
}

.ft {
  background: var(--mc);
}
.ft-inr {
  margin: 0 auto;
  padding: min(5.46875vw, 7rem) min(3.125vw, 4rem);
  width: 100%;
  max-width: 1280px;
}
@media screen and (max-width: 767px) {
  .ft-inr {
    padding: 40px 20px 80px;
  }
}
.ft-head {
  margin-bottom: min(5.46875vw, 7rem);
  padding-bottom: min(5.078125vw, 6.5rem);
  border-bottom: 1px solid #999;
}
.ft-logo {
  display: flex;
  justify-content: center;
  align-items: center;
}
.ft-logo__ph {
  display: block;
  width: 160px;
}
.ft-logo__st {
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .ft-logo__st {
    font-size: 1.4rem;
  }
}

.ft-endline {
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  line-height: 2.5;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .ft-endline {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .ft-endline {
    padding-bottom: 60px;
    font-size: 1.2rem;
  }
}
.ft-endline__inr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-inline: auto;
  padding: 0;
  width: 100%;
  max-width: 1280px;
}
@media screen and (max-width: 767px) {
  .ft-endline__inr {
    flex-direction: column-reverse;
    justify-content: center;
    gap: 20px;
    padding: 0;
  }
}

.ft-endline p {
  font-size: 1.6rem;
}
@media screen and (max-width: 1024px) {
  .ft-endline p {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .ft-endline p {
    font-size: 1.2rem;
  }
}

.fixed-nav {
  position: fixed;
  bottom: 15%;
  right: 0;
  transition: 0.4s;
  z-index: 1000;
}
@media screen and (max-width: 767px) {
  .fixed-nav {
    bottom: -70px;
    left: 0;
    right: 0;
    width: 100%;
    height: auto;
    opacity: 0;
    z-index: 1000;
  }
  .fixed-nav.fixed {
    bottom: 0;
    opacity: 1;
  }
}
.fixed-nav__list {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-direction: column;
  gap: 8px;
}
@media screen and (max-width: 767px) {
  .fixed-nav__list {
    flex-direction: row;
    gap: 0;
  }
}
@media screen and (max-width: 767px) {
  .fixed-nav__item {
    width: 50%;
    height: 60px;
  }
}
.fixed-nav__item.--item01 .fixed-nav__link {
  background: var(--sc);
  border: 1px solid var(--sc);
}
@media screen and (min-width: 1025px) {
  .fixed-nav__item.--item01 .fixed-nav__link:hover {
    background: #fff;
    color: var(--sc);
  }
  .fixed-nav__item.--item01 .fixed-nav__link:hover .fixed-nav__icon {
    aspect-ratio: 1;
  }
  .fixed-nav__item.--item01 .fixed-nav__link:hover .fixed-nav__icon img {
    opacity: 0;
  }
  .fixed-nav__item.--item01 .fixed-nav__link:hover .fixed-nav__icon::before {
    opacity: 1;
  }
}
.fixed-nav__item.--item01 .fixed-nav__link .fixed-nav__icon {
  width: 24px;
}
.fixed-nav__item.--item01 .fixed-nav__icon::before {
  background: url(../img/icon-modelhouse.svg) no-repeat center center/cover;
}
.fixed-nav__item.--item02 .fixed-nav__link {
  background: var(--mc);
  border: 1px solid var(--mc);
}
@media screen and (min-width: 1025px) {
  .fixed-nav__item.--item02 .fixed-nav__link:hover {
    background: #fff;
    color: var(--mc);
  }
  .fixed-nav__item.--item02 .fixed-nav__link:hover .fixed-nav__icon img {
    opacity: 0;
  }
  .fixed-nav__item.--item02 .fixed-nav__link:hover .fixed-nav__icon::before {
    opacity: 1;
  }
}
.fixed-nav__item.--item02 .fixed-nav__link .fixed-nav__icon {
  width: 20px;
  aspect-ratio: 20/26;
}
.fixed-nav__item.--item02 .fixed-nav__icon {
  background: url(../img/icon-phone.svg) no-repeat center center/cover;
}
.fixed-nav__item img {
  width: auto;
  height: 100%;
}
.fixed-nav__link {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 16px;
  width: 60px;
  height: 235px;
  color: #fff;
  text-align: center;
  cursor: pointer;
  transition: 0.4s;
}
@media screen and (max-width: 767px) {
  .fixed-nav__link {
    gap: 8px;
    flex-direction: row;
    width: 100%;
    height: 100%;
  }
}
.fixed-nav__icon {
  position: relative;
}
.fixed-nav__icon img {
  transition: 0.4s;
}
.fixed-nav__icon::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: 0.4s;
}
.fixed-nav__st {
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  writing-mode: vertical-rl;
}
@media screen and (max-width: 767px) {
  .fixed-nav__st {
    writing-mode: inherit;
  }
}

.main {
  background: #eee;
}

.cta {
  padding-block: min(6.25vw, 8rem);
  background: var(--mc);
}
@media screen and (max-width: 767px) {
  .cta {
    padding-block: 50px;
  }
}
.cta-box {
  margin-inline: auto;
  max-width: 1064px;
}
.cta-txt {
  margin-bottom: min(4.84375vw, 6.2rem);
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  letter-spacing: 0.08em;
  line-height: 2;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .cta-txt {
    margin-bottom: 30px;
    font-size: 1.8rem;
  }
}
.cta-anchor {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: min(3.125vw, 4rem);
}
@media screen and (max-width: 767px) {
  .cta-anchor {
    flex-direction: column;
    gap: 30px;
  }
}
.cta-anchor__item {
  width: calc(100% - min(3.125vw, 4rem));
  max-width: 445px;
}
.cta-anchor__item.--item01 .cta-anchor__link-btn {
  background: #fff;
  border: 1px solid #fff;
  color: var(--mc);
}
.cta-anchor__item.--item01 .cta-anchor__link-btn .--arrow {
  background: var(--mc);
}
.cta-anchor__item.--item01 .cta-anchor__link-btn .--arrow::after {
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}
/*.cta-anchor__item.--item02 .cta-anchor__link-btn::before {
  content: "";
  position: absolute;
  top: max(-2.03125vw, -2.6rem);
  left: 2px;
  width: min(6.25vw, 8rem);
  height: auto;
  aspect-ratio: 80/95;
  background: url(../img/icon-gift.svg) no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .cta-anchor__item.--item02 .cta-anchor__link-btn::before {
    width: 55px;
  }
}*/
@media screen and (min-width: 1025px) {
  .cta-anchor__item.--item01 .cta-anchor__link:hover .cta-anchor__link-btn {
    background: transparent;
    color: #fff;
  }
  .cta-anchor__item.--item01 .cta-anchor__link:hover .cta-anchor__link-btn .--arrow {
    background: #fff;
  }
  .cta-anchor__item.--item01 .cta-anchor__link:hover .cta-anchor__link-btn .--arrow::after {
    border-top: 2px solid var(--mc);
    border-right: 2px solid var(--mc);
  }
}
.cta-anchor__item.--item02 .cta-anchor__link-btn {
  background: var(--sc);
  border: 1px solid var(--sc);
  color: #fff;
}
.cta-anchor__item.--item02 .cta-anchor__link-btn .--arrow {
  background: #fff;
}
.cta-anchor__item.--item02 .cta-anchor__link-btn .--arrow::after {
  border-top: 2px solid var(--sc);
  border-right: 2px solid var(--sc);
}
@media screen and (min-width: 1025px) {
  .cta-anchor__item.--item02:hover .cta-anchor__link-btn {
    background: #fff;
    color: var(--sc);
  }
  .cta-anchor__item.--item02:hover .cta-anchor__link-btn .--arrow {
    background: var(--sc);
  }
  .cta-anchor__item.--item02:hover .cta-anchor__link-btn .--arrow::after {
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
}
.cta-anchor__link {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: min(0.9375vw, 1.2rem);
  width: 100%;
  cursor: pointer;
}
@media screen and (max-width: 1024px) {
  .cta-anchor__link {
    gap: 12px;
  }
}
.cta-anchor__link-icon {
  position: relative;
  width: 40px;
  height: 40px;
}
.cta-anchor__link-st {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 3.2rem;
  line-height: 2;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .cta-anchor__link-st {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .cta-anchor__link-st {
    font-size: 1.8rem;
  }
}
.cta-anchor__link-btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 70px;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  /*letter-spacing: 0.04em;*/
  line-height: 1.75;
  transition: 0.4s;
}
@media screen and (max-width: 1024px) {
  .cta-anchor__link-btn {
    padding-right: 20px;
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .cta-anchor__link-btn {
    font-size: 1.8rem;
  }
}
.cta-anchor__link-btn .--arrow {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  transition: 0.4s;
}
.cta-anchor__link-btn .--arrow::after {
  content: "";
  margin-right: 3px;
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
  transition: 0.4s;
}

.mv {
  position: relative;
}
.mv-txt {
  position: absolute;
  bottom: 3%;
  left: 3%;
  z-index: 2;
}
.mv-txt__st {
  font-family: "Forum", serif;
  font-size: 10rem;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .mv-txt__st {
    font-size: 7.5rem;
  }
}
@media screen and (max-width: 767px) {
  .mv-txt__st {
    font-size: 3.5rem;
  }
}
.mv-ttl {
  position: absolute;
  bottom: 17%;
  left: 3%;
  z-index: 2;
}
@media screen and (max-width: 1024px) {
  .mv-ttl {
    bottom: 12%;
  }
}
@media screen and (max-width: 767px) {
  .mv-ttl {
    top: 12%;
    bottom: auto;
  }
}
.mv-ttl__st {
  display: flex;
  justify-content: flex-start;
  align-items: flex-end;
  gap: 12px;
}
@media screen and (max-width: 767px) {
  .mv-ttl__st {
    align-items: flex-start;
  }
}
.mv-ttl__st .--st01 {
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-size: 4rem;
  letter-spacing: 0.2em;
  line-height: 1.2;
  color: #fff;
  writing-mode: vertical-rl;
  text-orientation: upright;
}
@media screen and (max-width: 767px) {
  .mv-ttl__st .--st01 {
    font-size: 2rem;
    letter-spacing: 0.12em;
  }
}
.mv-ttl__st .--st02 {
  font-family: "Zen Old Mincho", serif;
  font-size: 9rem;
  letter-spacing: 0.08em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .mv-ttl__st .--st02 {
    font-size: 4.5rem;
  }
}
.mv-ttl__st .--st02 small {
  display: block;
  margin-bottom: 5px;
  border-block: 1px solid #fff;
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-size: 2.4rem;
  letter-spacing: 0.08em;
  line-height: 2;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .mv-ttl__st .--st02 small {
    margin-bottom: 0;
    font-size: 1.6rem;
  }
}
.mv-slide__item {
  height: 100svh;
}
@media screen and (max-width: 767px) {
  .mv-slide__item {
    height: 100svh;
  }
}
.mv-slide__ph {
  width: 100%;
  height: 100%;
}
.mv-slide__ph img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}
.mv .swiper-slide-active .mv-slide__ph,
.mv .swiper-slide-duplicate-active .mv-slide__ph,
.mv .swiper-slide-prev .mv-slide__ph {
  animation: zoomUp 7s linear 0s normal both;
}

.concept {
  position: relative;
  padding-block: min(9.375vw, 12rem) min(9.21875vw, 11.8rem);
  background: #eee;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .concept {
    padding-block: 50px;
  }
}
.concept::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: min(68.75vw, 88rem);
  height: auto;
  aspect-ratio: 880/484;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .concept::before {
    width: 65%;
  }
}
.concept-block {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
@media screen and (max-width: 1024px) {
  .concept-block {
    flex-direction: column-reverse;
    gap: 30px;
    margin-bottom: 30px;
  }
}
.concept-block__ph {
  margin-left: calc((100% - 100vw) / 2);
  width: calc((100% - min(6.25vw, 8rem)) / 2 + (100vw - 100%) / 2);
}
@media screen and (max-width: 1024px) {
  .concept-block__ph {
    width: calc(100% + (100vw - 100%) / 2);
  }
}
.concept-block__info {
  margin-top: 72px;
  padding-bottom: 70px;
  width: calc((100% - min(6.25vw, 8rem)) / 2);
}
@media screen and (max-width: 1024px) {
  .concept-block__info {
    margin-top: 0;
    padding-bottom: 0;
    width: 100%;
  }
}
.concept-ttl {
  margin-bottom: min(5.078125vw, 6.5rem);
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 4.8rem;
  line-height: 1.6666666667;
}
@media screen and (max-width: 1024px) {
  .concept-ttl {
    font-size: 3.2rem;
  }
}
@media screen and (max-width: 767px) {
  .concept-ttl {
    font-size: 2.6rem;
  }
}
.concept-txt {
  font-size: 1.8rem;
  letter-spacing: 0.04em;
  line-height: 2.2222222222;
}
@media screen and (max-width: 767px) {
  .concept-txt {
    font-size: 1.6rem;
  }
}
.concept-ph {
  margin-top: max(-5.46875vw, -7rem);
  margin-left: auto;
  margin-right: calc((100% - 100vw) / 2);
  width: calc(100% - 120px + (100vw - 100%) / 2);
}
@media screen and (max-width: 1240px) {
  .concept-ph {
    margin-top: 0;
  }
}
@media screen and (max-width: 1024px) {
  .concept-ph {
    margin-top: 0;
    width: calc(100% + (100vw - 100%) / 2);
  }
}

.merit {
  padding-block: min(9.375vw, 12rem);
  background: #eee;
}
.merit-head {
  margin-bottom: min(3.75vw, 4.8rem);
  margin-inline: auto;
  max-width: 960px;
}
.merit-block {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
}
.merit-cnt {
  padding-right: min(6.25vw, 8rem);
  width: min(72.65625vw, 93rem);
}
@media screen and (max-width: 767px) {
  .merit-cnt {
    padding-right: 0;
    width: 100%;
  }
}
.merit-box {
  position: relative;
  padding: min(3.125vw, 4rem);
  max-width: 850px;
  background: #f8f8f8;
}
@media screen and (max-width: 1024px) {
  .merit-box {
    padding-top: 40px;
  }
}
.merit-box:not(:last-child) {
  margin-bottom: 77px;
}
.merit-box:last-child .merit-box__head {
  padding-bottom: 0;
}
.merit-box__num {
  position: absolute;
  top: max(-5.078125vw, -6.5rem);
  right: 25px;
  font-family: "Allura", cursive;
  font-size: min(10.15625vw, 13rem);
  color: #fff;
}
@media screen and (max-width: 767px) {
  .merit-box__num {
    top: -40px;
    font-size: 8rem;
  }
}
.merit-box__head {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 25px;
  margin-bottom: 28px;
  padding-bottom: 29px;
  border-bottom: 1px solid var(--mc);
}
@media screen and (max-width: 1024px) {
  .merit-box__head {
    padding-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .merit-box__head {
    flex-direction: column;
    gap: 16px;
  }
}
.merit-box__icon {
  width: 105px;
}
@media screen and (max-width: 767px) {
  .merit-box__icon {
    width: 50px;
  }
}
.merit-box__icon img {
  display: block;
  margin-inline: auto;
  max-width: 100%;
}
.merit-box__ttl {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  letter-spacing: 0.2em;
  line-height: 1.6666666667;
  color: var(--mc);
}
@media screen and (max-width: 767px) {
  .merit-box__ttl {
    font-size: 1.8rem;
    text-align: center;
  }
}
.merit-box__txt-st {
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 2;
  color: #000;
}
.merit-bgtxt {
  padding-top: 48px;
  width: calc(100% - min(72.65625vw, 93rem));
  border-left: 1px solid #707070;
}
@media screen and (max-width: 767px) {
  .merit-bgtxt {
    display: none;
  }
}
.merit-bgtxt__st {
  font-family: "Forum", serif;
  font-size: min(15.625vw, 20rem);
  color: #fff;
  transform: rotate(90deg);
}

.feature {
  position: relative;
  padding-block: min(4.6875vw, 6rem) min(14.453125vw, 18.5rem);
  background: #eee;
}
@media screen and (max-width: 767px) {
  .feature {
    padding-block: 50px;
  }
}
.feature::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - min(29.375vw, 37.6rem));
  height: calc(100% - min(9.375vw, 12rem));
  background: #f5f5f5;
}
.feature-head {
  margin-bottom: min(2.734375vw, 3.5rem);
  margin-inline: auto 0;
  max-width: 742px;
}
@media screen and (max-width: 767px) {
  .feature-head {
    margin-bottom: 30px;
  }
}
.feature-block {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
}
@media screen and (max-width: 767px) {
  .feature-block {
    flex-direction: column;
    gap: 30px;
  }
}
.feature-box {
  width: calc((100% - min(6.25vw, 8rem)) / 2);
}
@media screen and (max-width: 767px) {
  .feature-box {
    width: 100%;
  }
}
.feature-box:last-child {
  padding-top: min(5.46875vw, 7rem);
}
@media screen and (max-width: 767px) {
  .feature-box:last-child {
    padding-top: 0;
  }
}
.feature-box__ph {
  margin-bottom: min(3.515625vw, 4.5rem);
}
.feature-box__num {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: min(2.265625vw, 2.9rem);
  width: 150px;
  height: 40px;
  background: var(--sc);
  font-family: "Red Hat Display", sans-serif;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 2;
  color: #fff;
}
.feature-box__ttl {
  margin-bottom: min(3.515625vw, 4.5rem);
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  letter-spacing: 0.2em;
  line-height: 1.6666666667;
  color: #333;
}
@media screen and (max-width: 767px) {
  .feature-box__ttl {
    font-size: 1.8rem;
  }
}
.feature-box__txt {
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 2;
}

.plan {
  padding-block: min(8.59375vw, 11rem) min(7.8125vw, 10rem);
  background: #eee;
}
.plan-head {
  margin-bottom: min(5.46875vw, 7rem);
  margin-inline: auto;
  max-width: 1045px;
}
.plan-tab {
  margin-inline: auto;
  max-width: 965px;
}
.plan-tab__list {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  gap: min(2.5vw, 3.2rem);
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .plan-tab__list {
    gap: 8px;
  }
}
.plan-tab__item {
  display: flex;
  flex-direction: column;
  width: calc((100% - min(5vw, 6.4rem)) / 3);
  height: 140px;
}
@media screen and (max-width: 767px) {
  .plan-tab__item {
    width: calc((100% - 0.8rem) / 2);
    height: 100px;
  }
}
.plan-tab__btn {
  padding: 5px;
  width: 100%;
  height: 100%;
  background: transparent;
  border: none;
  border: 1px solid var(--mc);
  cursor: pointer;
  transition: 0.4s;
}
.plan-tab__btn.active {
  background: rgba(255, 255, 255, 0.6);
  border: none;
}
@media screen and (min-width: 1025px) {
  .plan-tab__btn:hover {
    background: rgba(255, 255, 255, 0.6);
    border: none;
  }
}
.plan-tab__num {
  margin-bottom: min(1.25vw, 1.6rem);
}
.plan-tab__num-st {
  border-block: 1px solid var(--mc);
  font-family: "Red Hat Display", sans-serif;
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 2;
  color: var(--mc);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .plan-tab__num-st {
    font-size: 1.4rem;
  }
}
.plan-tab__txt {
  font-family: "游ゴシック", "游ゴシック体", YuGothic, "Yu Gothic", sans-serif;
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 1.5;
  color: var(--mc);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .plan-tab__txt {
    font-size: 1.2rem;
  }
}
.plan-detail {
  padding-top: min(6.40625vw, 8.2rem);
}
.plan-cnt {
  height: auto;
}
.plan-cnt__box {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 30px;
  padding-block: min(9.375vw, 12rem) min(1.875vw, 2.4rem);
  padding-inline: min(9.375vw, 12rem);
  height: 100%;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .plan-cnt__box {
    justify-content: flex-start;
    flex-direction: column;
    padding: 40px 20px;
  }
}
.plan-cnt__info {
  width: 55%;
}
@media screen and (max-width: 767px) {
  .plan-cnt__info {
    width: 100%;
  }
}
.plan-cnt__num {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 136px;
  height: 25px;
  background: var(--mc);
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 2;
  color: #fff;
}
.plan-cnt__ttl {
  margin-bottom: min(4.6875vw, 6rem);
  border-block: 1px solid var(--mc);
}
.plan-cnt__ttl span {
  display: inline-block;
  padding-block: 9px;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  letter-spacing: 0.1em;
  line-height: 1.6666666667;
  color: var(--mc);
}
@media screen and (max-width: 1024px) {
  .plan-cnt__ttl span {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .plan-cnt__ttl span {
    font-size: 1.8rem;
  }
}
.plan-cnt__txt {
  margin-bottom: 25px;
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .plan-cnt__txt {
    font-size: 1.4rem;
  }
}
.plan-cnt__data {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 271px;
  height: 83px;
  border: 1px solid #707070;
}
@media screen and (max-width: 767px) {
  .plan-cnt__data {
    width: 100%;
  }
}
.plan-cnt__data-st {
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .plan-cnt__data-st {
    font-size: 1.4rem;
  }
}
.plan-cnt__ph {
  width: 37%;
}
@media screen and (max-width: 767px) {
  .plan-cnt__ph {
    width: 100%;
  }
}
.plan #plan4 .plan-cnt__ttl {
  width: calc(100% - 300px);
}
@media screen and (max-width: 1024px) {
  .plan #plan4 .plan-cnt__ttl {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .plan #plan4 .plan-cnt__box {
    position: relative;
    justify-content: flex-start;
    flex-direction: column;
  }
  .plan #plan4 .plan-cnt__info {
    width: 100%;
  }
  .plan #plan4 .plan-cnt__ph {
    margin-inline: auto;
    width: 100%;
    max-width: 782px;
  }
}
@media screen and (min-width: 1025px) {
  .plan #plan4 .plan-cnt__data {
    position: absolute;
    top: min(9.375vw, 12rem);
    right: min(9.375vw, 12rem);
  }
}
.plan .swiper-slide-thumb-active .plan-tab__btn {
  background: #fff;
  border: none;
}
.plan .swiper-button-prev::after,
.plan .swiper-button-next::after {
  content: "";
  width: 20px;
  height: auto;
  aspect-ratio: 1;
  border-top: 2px solid var(--sc);
  border-right: 2px solid var(--sc);
  transform: rotate(45deg);
  transition: 0.4s;
}
@media screen and (max-width: 767px) {
  .plan .swiper-button-prev::after,
  .plan .swiper-button-next::after {
    width: 10px;
  }
}
.plan .swiper-button-prev {
  left: 35px;
}
@media screen and (max-width: 767px) {
  .plan .swiper-button-prev {
    left: -2px;
  }
}
.plan .swiper-button-next {
  right: 35px;
}
@media screen and (max-width: 767px) {
  .plan .swiper-button-next {
    right: -2px;
  }
}
.plan .swiper-button-prev::after {
  transform: rotate(225deg);
}
.plan .swiper-button-next.swiper-button-disabled,
.plan .swiper-button-prev.swiper-button-disabled {
  opacity: 0;
}

.works {
  padding-block: 0 min(9.375vw, 12rem);
}
@media screen and (max-width: 767px) {
  .works {
    padding-block: 50px 60px;
  }
}
.works-head {
  margin-bottom: min(6.25vw, 8rem);
  max-width: 752px;
}
@media screen and (max-width: 767px) {
  .works-head {
    margin-bottom: 40px;
  }
}
.works-box:first-child {
  margin-bottom: min(6.25vw, 8rem);
  padding-bottom: min(3.125vw, 4rem);
  border-bottom: 1px solid #999;
}
@media screen and (max-width: 767px) {
  .works-box:first-child {
    margin-bottom: 60px;
  }
}
.works-box__num {
  margin-bottom: 30px;
  margin-inline: auto;
}
.works-box__num span {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-inline: auto;
  width: 300px;
  height: 40px;
  background: var(--sc);
  font-family: "Red Hat Display", sans-serif;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .works-box__num span {
    width: 230px;
    font-size: 1.8rem;
  }
}
.works-box__ttl {
  margin-bottom: 35px;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .works-box__ttl {
    font-size: 1.8rem;
  }
}
.works-slide {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: min(2.5vw, 3.2rem);
  margin-bottom: min(3.125vw, 4rem);
  height: min(43.75vw, 56rem);
}
@media screen and (max-width: 767px) {
  .works-slide {
    flex-direction: column;
    gap: 10px;
    margin-bottom: 40px;
    height: auto;
  }
}
.works-slide__main {
  margin: 0;
  width: 66.5%;
}
@media screen and (max-width: 767px) {
  .works-slide__main {
    width: 100%;
  }
}
.works-slide__main-item {
  position: relative;
  height: auto;
  background: #fafafa;
}
@media screen and (max-width: 767px) {
  .works-slide__main-item {
    width: 100%;
    height: auto;
  }
}
.works-slide__main-item::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 40px;
  aspect-ratio: 40/40;
  background: url(../img/icon-zoom.svg) no-repeat center center/cover;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .works-slide__main-item::after {
    width: 40px;
  }
}
.works-slide__main img {
  display: block;
  margin: 0 auto;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}
@media screen and (max-width: 767px) {
  .works-slide__main img {
    width: 100%;
  }
}
.works-slide__thumbs {
  margin: 0;
  width: calc(33.5% - min(3.125vw, 4rem));
  max-height: 100%;
  overflow-y: auto;
}
@media screen and (max-width: 767px) {
  .works-slide__thumbs {
    width: 100%;
  }
}
.works-slide__thumbs-list {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 768px) {
  .works-slide__thumbs-list {
    display: flex;
    flex-wrap: wrap;
    gap: min(0.625vw, 0.8rem);
  }
}
.works-slide__thumbs-item {
  aspect-ratio: 176/123;
}
@media screen and (min-width: 768px) {
  .works-slide__thumbs-item {
    margin: 0 !important;
    width: calc((100% - min(0.78125vw, 1rem)) / 2) !important;
  }
}
@media screen and (max-width: 767px) {
  .works-slide__thumbs-item {
    height: auto;
  }
}
.works-slide__thumbs-item img {
  width: 100%;
  aspect-ratio: 176/123;
  -o-object-fit: cover;
  object-fit: cover;
}
.works-info {
  padding: min(2.34375vw, 3rem) min(5.859375vw, 7.5rem);
  background: #f5f5f5;
}
@media screen and (max-width: 767px) {
  .works-info {
    padding: 24px 20px 25px;
  }
}
.works-ttl {
  margin-bottom: min(1.953125vw, 2.5rem);
  font-weight: 700;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  line-height: 2;
}
@media screen and (max-width: 1024px) {
  .works-ttl {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .works-ttl {
    margin-bottom: 12px;
    font-size: 1.8rem;
    line-height: 1.5;
  }
}
.works-data {
  margin-bottom: min(2.34375vw, 3rem);
}
@media screen and (max-width: 767px) {
  .works-data {
    margin-bottom: 15px;
  }
}
.works-data__st {
  font-weight: 700;
  font-size: 1.8rem;
  letter-spacing: 0.04em;
  line-height: 1.7777777778;
}
@media screen and (max-width: 767px) {
  .works-data__st {
    font-size: 1.6rem;
  }
}
.works-txt {
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  line-height: 2;
}

/* 2025/07/08 追加 */
.gallery-info {
  padding: min(2.890625vw, 3.7rem) min(3.125vw, 4rem);
  background: #fff;
}
.modelhouse-info2 {
  margin-top: -2vw;
  margin-bottom: min(5.4375vw, 7.8rem);
}
@media screen and (max-width: 767px) {
  .gallery-info {
    padding: 24px 20px 25px;
  }
}
.gallery-data__st {
  font-weight: 700;
  font-size: 1.8rem;
  letter-spacing: 0.04em;
  line-height: 1.7777777778;
}
@media screen and (max-width: 767px) {
  .gallery-data__st {
    font-size: 1.6rem;
  }
}
.gallery-txt {
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .gallery-txt {
    font-size: 1.3rem;
  }
}

.modelhouse {
  position: relative;
  padding-bottom: min(6.25vw, 8rem);
}
@media screen and (max-width: 767px) {
  .modelhouse {
    padding-bottom: 50px;
  }
}
.modelhouse::before {
  /*content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: calc(100% - min(4.296875vw, 5.5rem));
  height: calc(100% - 80px);
  background: #f5f5f5;*/
}
@media screen and (max-width: 767px) {
  .modelhouse::before {
    height: 100%;
  }
}
.modelhouse-top {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  /*gap: 30px 0;*/
  margin-bottom: 15px;
}
@media screen and (max-width: 1024px) {
  .modelhouse-top {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 767px) {
  .modelhouse-top {
    flex-direction: column-reverse;
  }
}
.modelhouse-top__ph {
  margin-left: calc((100% - 100vw + 40px) / 2);
  width: calc((100% - min(6.25vw, 8rem)) / 2 + (100vw - 100% - 40px) / 2);
}
@media screen and (max-width: 767px) {
  .modelhouse-top__ph {
    margin-left: calc((100% - 100vw) / 2);
    width: calc(100% + (100vw - 100%) / 2);
  }
}
.modelhouse-top__info {
  width: calc((100% - min(6.25vw, 8rem)) / 2);
}
@media screen and (max-width: 767px) {
  .modelhouse-top__info {
    width: 100%;
  }
}
.modelhouse-head {
  margin-bottom: min(2.5vw, 3.2rem);
  margin-inline: auto 0;
  max-width: 572px;
}
@media screen and (max-width: 767px) {
  .modelhouse-head {
    margin-bottom: 0;
  }
}
.modelhouse-hall {
  margin-right: -12px;
}
@media screen and (max-width: 1024px) {
  .modelhouse-hall {
    margin-right: 0;
  }
}
.modelhouse-hall__name {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-inline: auto 0;
  padding-right: min(1.5625vw, 2rem);
  max-width: 434px;
  height: 50px;
  background: var(--mc);
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 3.2rem;
  letter-spacing: 0.04em;
  line-height: 1.5;
  color: #fff;
  text-align: right;
}
@media screen and (max-width: 1024px) {
  .modelhouse-hall__name {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .modelhouse-hall__name {
    height: 40px;
    font-size: 2rem;
  }
}
.modelhouse-hall__location {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-inline: auto 0;
  padding-right: min(1.5625vw, 2rem);
  max-width: 434px;
  height: 40px;
  background: #fff;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #000;
  text-align: right;
}
@media screen and (max-width: 1024px) {
  .modelhouse-hall__location {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .modelhouse-hall__location {
    height: 30px;
    font-size: 1.8rem;
  }
}
.modelhouse-block {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: min(3.125vw, 4rem);
}
@media screen and (max-width: 1024px) {
  .modelhouse-block {
    flex-direction: column;
    gap: 30px;
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 767px) {
  .modelhouse-block {
    gap: 30px;
    margin-bottom: 30px;
  }
}
.modelhouse-block__ph {
  width: 50%;
}
@media screen and (max-width: 1024px) {
  .modelhouse-block__ph {
    width: 100%;
  }
}
.modelhouse-block__info {
  width: calc(50% - min(3.125vw, 4rem));
}
@media screen and (max-width: 1024px) {
  .modelhouse-block__info {
    width: 100%;
  }
}
.modelhouse-txt__st {
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #000;
}
.modelhouse-layout {
	width: 70%;
	margin: auto;
}
@media screen and (max-width: 767px) {
	/*.layout-box {
		overflow-x: auto;
		padding-bottom: 2rem;
	}*/
    .modelhouse-layout {
        /*width: 180%;*/
        width: 100%;
    }
}
.modelhouse-box {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 30px 0;
  padding: min(3.75vw, 4.8rem) min(3.125vw, 4rem) min(3.125vw, 4rem);
  background: #fff;
}
@media screen and (max-width: 1024px) {
  .modelhouse-box {
    flex-direction: column-reverse;
    padding: 40px;
  }
}
@media screen and (max-width: 767px) {
  .modelhouse-box {
    padding: 30px 20px;
  }
}
.modelhouse-map {
  width: 480px;
  height: auto;
  aspect-ratio: 480/320;
}
@media screen and (max-width: 1024px) {
  .modelhouse-map {
    width: 100%;
  }
}
.modelhouse-map iframe {
  width: 100%;
  height: 100%;
}
.modelhouse-data {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: min(1.171875vw, 1.5rem) 0;
  width: calc(100% - 480px - 25px);
}
@media screen and (max-width: 1024px) {
  .modelhouse-data {
    width: 100%;
  }
}
.modelhouse-data__name {
  width: 100%;
}
.modelhouse-data__name-st {
  border-bottom: 1px solid #707070;
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 2;
}
.modelhouse-data__ttl {
  width: 90px;
}
@media screen and (max-width: 767px) {
  .modelhouse-data__ttl {
    width: 100%;
  }
}
.modelhouse-data__ttl-st {
  font-size: 1.8rem;
  letter-spacing: 0.04em;
  line-height: 1.7777777778;
}
@media screen and (max-width: 767px) {
  .modelhouse-data__ttl-st {
    font-size: 1.6rem;
  }
}
.modelhouse-data__list {
  width: calc(100% - 90px);
}
@media screen and (max-width: 767px) {
  .modelhouse-data__list {
    width: 100%;
  }
}
.modelhouse-data__item {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: min(1.71875vw, 2.2rem);
}
.modelhouse-data__item-name {
  width: 70px;
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 2;
}
.modelhouse-data__item-txt {
  flex: 1;
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 2;
}

.gift {
  padding-block: min(8.59375vw, 11rem) min(9.375vw, 12rem);
}
.gift-head {
  margin-bottom: min(2.5vw, 3.2rem);
}
@media screen and (max-width: 767px) {
  .gift-head {
    margin-bottom: 16px;
  }
}
.gift-ttl {
  font-weight: 500;
  font-size: 4rem;
  letter-spacing: 0.04em;
  line-height: 1.6;
  text-align: center;
  font-family: "Zen Old Mincho", serif;
}
@media screen and (max-width: 1024px) {
  .gift-ttl {
    font-size: 3.2rem;
  }
}
@media screen and (max-width: 767px) {
  .gift-ttl {
    font-size: 2.4rem;
  }
}
.gift-cnt {
  padding-block: min(6.25vw, 8rem);
  background: url(../img/bg-gift.jpg) no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .gift-cnt {
    padding-block: 40px;
  }
}
.gift-box {
  margin-inline: auto;
  padding: min(4.375vw, 5.6rem) min(8.59375vw, 11rem);
  width: calc(100% - 20px);
  max-width: 1040px;
  background: rgba(255, 255, 255, 0.9);
}
@media screen and (max-width: 767px) {
  .gift-box {
    padding: 28px 10px;
  }
}
@media screen and (max-width: 400px) {
  .gift-box {
    width: 100%;
  }
}
.gift-box__txt {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: min(3.90625vw, 5rem);
  margin-inline: auto;
  max-width: 550px;
  height: 40px;
  background: var(--sc);
  border-radius: 20px;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  /*letter-spacing: 0.04em;*/
  line-height: 1.3333333333;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .gift-box__txt {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .gift-box__txt {
    margin-bottom: 25px;
    margin-inline: auto;
    max-width: 360px;
    font-size: 1.6rem;
  }
}
.gift-box__name {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: min(2.96875vw, 3.8rem);
  margin-bottom: min(3.59375vw, 4.6rem);
  margin-inline: auto;
  /*max-width: 730px;*/
}
@media screen and (max-width: 767px) {
  .gift-box__name {
    justify-content: center;
    gap: 19px;
    margin-bottom: 21px;
  }
}
.gift-box__name-icon {
  width: 222px;
}
@media screen and (max-width: 1024px) {
  .gift-box__name-icon {
    width: 210px;
  }
}
@media screen and (max-width: 767px) {
  .gift-box__name-icon {
    width: 140px;
  }
}
.gift-box__name-st {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 3.2rem;
  letter-spacing: 0.04em;
  line-height: 1;
}
@media screen and (max-width: 1024px) {
  .gift-box__name-st {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .gift-box__name-st {
    font-size: 1.8rem;
  }
}
.gift-box__name-st .--red {
  color: #e95504;
}
.gift-box__name-st strong {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 6.4rem;
  letter-spacing: 0.04em;
  line-height: 1.5;
}
@media screen and (max-width: 1024px) {
  .gift-box__name-st strong {
    font-size: 5rem;
  }
}
@media screen and (max-width: 767px) {
  .gift-box__name-st strong {
    font-size: 3.2rem;
    line-height: 1;
  }
}
.gift-box__name-st small {
  font-weight: 500;
  font-size: 1.8rem;
  letter-spacing: 0.04em;
  line-height: 1.7777777778;
  vertical-align: text-top;
}
@media screen and (max-width: 1024px) {
  .gift-box__name-st small {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .gift-box__name-st small {
    font-size: 1.2rem;
  }
}
.gift__note {
	/*color: #fff;*/
	line-height: 1.6;
	padding-bottom: min(1.5625vw, 2rem);
}
@media screen and (max-width: 767px) {
  .gift__note {
    font-size: 1.4rem;
  }
}
.gift-box__note {
  padding: min(2.109375vw, 2.7rem) min(3.28125vw, 4.2rem);
  width: 100%;
  max-width: 820px;
  height: 160px;
  background: #fff;
  border: 1px solid #999;
  overflow: auto;
}
@media screen and (max-width: 767px) {
  .gift-box__note {
    padding: 10px;
  }
}
.gift-box__note-txt-st {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .gift-box__note-txt-st {
    font-size: 1.4rem;
  }
}

.contact {
  padding-bottom: min(8.59375vw, 11rem);
}
@media screen and (max-width: 767px) {
  .contact {
    padding-bottom: 50px;
  }
}
.contact-block {
  padding-block: min(5.078125vw, 6.5rem);
  padding-inline: 40px;
  background: #f5f5f5;
}
@media screen and (max-width: 767px) {
  .contact-block {
    padding-block: 50px;
    padding-inline: 20px;
  }
}
.contact-head {
  margin-bottom: min(5.625vw, 7.2rem);
  margin-inline: auto;
  max-width: 860px;
}
@media screen and (max-width: 767px) {
  .contact-head {
    margin-bottom: 40px;
  }
}
.contact-txt {
  margin-bottom: min(8.984375vw, 11.5rem);
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  line-height: 1.6666666667;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .contact-txt {
    margin-bottom: 30px;
    font-size: 1.8rem;
  }
}
.contact .contact-form {
  margin-inline: auto;
  max-width: 1000px;
}
.contact .contact-form__tab {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: min(3.125vw, 4rem);
  margin-bottom: min(7.8125vw, 10rem);
  margin-inline: auto;
  height: 100px;
}
@media screen and (max-width: 767px) {
  .contact .contact-form__tab {
    gap: 10px;
    margin-bottom: 50px;
    height: 100px;
  }
}
.contact .contact-form__tab-item {
  width: calc((100% - 40px) / 2);
  max-width: 580px;
  height: 100%;
  transition: 0.4s;
}
@media screen and (max-width: 767px) {
  .contact .contact-form__tab-item {
    width: calc((100% - 10px) / 2);
  }
}
.contact .contact-form__tab-item.--item01 .contact-form__icon::before {
  background: url(../img/icon-consultation_w.svg) no-repeat center center/cover;
}
.contact .contact-form__tab-item.--item02 .contact-form__icon::before {
  background: url(../img/icon-modelhouse_w.svg) no-repeat center center/cover;
}
.contact .contact-form__select {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(1.25vw, 1.6rem);
  width: 100%;
  height: 100%;
  background: #fff;
  border: none;
  border: 1px solid var(--mc);
  cursor: pointer;
  transition: 0.4s;
}
@media screen and (max-width: 767px) {
  .contact .contact-form__select {
    flex-direction: column;
    gap: 4px;
    padding: 0;
  }
}
.contact .contact-form__select.active {
  background: var(--mc);
}
.contact .contact-form__select.active .contact-form__icon::before {
  opacity: 1;
}
.contact .contact-form__select.active .contact-form__txt {
  color: #fff;
}
.contact .contact-form__select.active .contact-form__arrow {
  color: #fff;
}
@media screen and (min-width: 1025px) {
  .contact .contact-form__select:hover {
    background: var(--mc);
  }
  .contact .contact-form__select:hover .contact-form__icon img {
    opacity: 0;
  }
  .contact .contact-form__select:hover .contact-form__icon::before {
    opacity: 1;
  }
  .contact .contact-form__select:hover .contact-form__txt {
    color: #fff;
  }
  .contact .contact-form__select:hover .contact-form__arrow {
    color: #fff;
  }
}
.contact .contact-form__icon {
  position: relative;
}
@media screen and (max-width: 767px) {
  .contact .contact-form__icon {
    width: 20px;
  }
}
.contact .contact-form__icon img {
  transition: 0.4s;
}
.contact .contact-form__icon::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: 0.4s;
}
.contact .contact-form__txt {
  font-family: "游ゴシック", "游ゴシック体", YuGothic, "Yu Gothic", sans-serif;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  line-height: 1.75;
  text-align: center;
  color: var(--mc);
  transition: 0.4s;
}
@media screen and (max-width: 1024px) {
  .contact .contact-form__txt {
    margin-right: 20px;
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .contact .contact-form__txt {
    margin-right: 0;
    font-size: 1.6rem;
  }
}
.contact .contact-form__arrow {
  font-weight: 500;
  font-size: 2rem;
  letter-spacing: 0.04em;
  line-height: 1;
  color: var(--mc);
  transform: translateX(2px) rotate(90deg);
  transition: 0.4s;
}
@media screen and (min-width: 768px) {
  .contact .contact-form__arrow {
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) rotate(90deg);
    font-size: 4rem;
  }
}

.promise {
  padding-bottom: min(8.984375vw, 11.5rem);
}
@media screen and (max-width: 767px) {
  .promise {
    padding-block: 50px 55px;
  }
}
.promise-head {
  margin-bottom: min(5.625vw, 7.2rem);
  max-width: 942px;
}
@media screen and (max-width: 767px) {
  .promise-head {
    margin-bottom: 40px;
  }
}
.promise-txt {
  margin-bottom: min(2.34375vw, 3rem);
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  line-height: 1.6666666667;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .promise-txt {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .promise-txt {
    margin-bottom: 15px;
    font-size: 1.8rem;
  }
}
.promise-none {
  margin-bottom: min(6.25vw, 8rem);
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 2;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .promise-none {
    margin-bottom: 40px;
  }
}
.promise-block {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  padding-block: min(2.734375vw, 3.5rem) min(3.125vw, 4rem);
  background: #fff;
  border: 1px solid #999;
}
@media screen and (max-width: 1024px) {
  .promise-block {
    gap: 20px;
    background: transparent;
    border: none;
  }
}
.promise-box {
  padding-block: min(1.875vw, 2.4rem) min(2.5vw, 3.2rem);
  width: 33.3333333333%;
  background: #fff;
}
@media screen and (max-width: 1024px) {
  .promise-box {
    width: calc((100% - 20px) / 2);
    border: 1px solid #999;
  }
}
@media screen and (max-width: 767px) {
  .promise-box {
    padding-block: 36px;
    width: 100%;
  }
}
.promise-box:not(:last-child) {
  border-right: 1px solid #999;
}
.promise-box__num {
  position: relative;
  margin-bottom: min(0.625vw, 0.8rem);
}
@media screen and (max-width: 767px) {
  .promise-box__num {
    margin-bottom: 6px;
  }
}
.promise-box__num span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Lato", sans-serif;
  font-size: 1.8rem;
  letter-spacing: 0.04em;
  line-height: 2.6666666667;
  color: #666;
}
@media screen and (max-width: 767px) {
  .promise-box__num span {
    font-size: 1.6rem;
  }
}
.promise-box__num strong {
  display: block;
  font-family: "Lato", sans-serif;
  font-size: 10rem;
  letter-spacing: 0.04em;
  color: #f5f3f1;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .promise-box__num strong {
    font-size: 8rem;
  }
}
@media screen and (max-width: 767px) {
  .promise-box__num strong {
    font-size: 6rem;
  }
}
.promise-box__ph {
  margin-bottom: min(2.5vw, 3.2rem);
  margin-inline: auto;
  width: auto;
}
@media screen and (max-width: 767px) {
  .promise-box__ph {
    margin-bottom: 17px;
  }
}
.promise-box__ph img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}
.promise-box__ttl {
  margin-bottom: min(1.875vw, 2.4rem);
  padding-inline: 20px;
  font-weight: 700;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  line-height: 1.6666666667;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .promise-box__ttl {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .promise-box__ttl {
    margin-bottom: 12px;
    font-size: 1.8rem;
  }
}
.promise-box__txt {
  padding-inline: min(2.734375vw, 3.5rem);
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .promise-box__txt {
    padding-inline: 17px;
  }
}

.about-head {
  margin-bottom: min(3.515625vw, 4.5rem);
  max-width: 760px;
}
.about-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-inline: auto;
  padding-bottom: min(9.375vw, 12rem);
  max-width: 1113px;
}
@media screen and (max-width: 767px) {
  .about-top {
    flex-direction: column;
    gap: 30px;
  }
}
.about-top__info {
  margin-top: min(4.21875vw, 5.4rem);
  width: calc(50% - min(12.890625vw, 16.5rem));
}
@media screen and (max-width: 767px) {
  .about-top__info {
    padding-top: 0;
    width: 100%;
  }
}
.about-top__ttl {
  margin-bottom: min(6.09375vw, 7.8rem);
}
@media screen and (max-width: 767px) {
  .about-top__ttl {
    margin-bottom: 30px;
  }
}
.about-top__ttl-st {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 3.2rem;
  letter-spacing: 0.05em;
  line-height: 1.875;
}
@media screen and (max-width: 1024px) {
  .about-top__ttl-st {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .about-top__ttl-st {
    font-size: 1.8rem;
  }
}
.about-top__ph {
  width: calc(50% + min(3.90625vw, 5rem));
}
@media screen and (max-width: 767px) {
  .about-top__ph {
    width: 100%;
  }
}
.about-cnt {
  padding-block: min(6.25vw, 8rem);
  background: url(../img/bg-about-cnt.jpg) no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .about-cnt {
    padding-block: 50px;
  }
}
.about-block {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .about-block {
    flex-direction: column;
    gap: 30px;
  }
}
.about-block:not(:last-child) {
  margin-bottom: min(6.875vw, 8.8rem);
}
@media screen and (max-width: 767px) {
  .about-block:not(:last-child) {
    margin-bottom: 50px;
  }
}
.about-block__info {
  padding-top: min(5.9375vw, 7.6rem);
  width: 50%;
}
@media screen and (max-width: 1024px) {
  .about-block__info {
    padding-top: min(1.3020833333vw, 6rem);
  }
}
@media screen and (max-width: 767px) {
  .about-block__info {
    width: 100%;
  }
}
.about-block__ttl {
  margin-bottom: min(3.125vw, 4rem);
}
@media screen and (max-width: 767px) {
  .about-block__ttl {
    margin-bottom: 15px;
  }
}
.about-block__ttl-st {
  border-bottom: 1px solid #fff;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.4rem;
  letter-spacing: 0.08em;
  line-height: 1.2;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .about-block__ttl-st {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 767px) {
  .about-block__ttl-st {
    font-size: 1.8rem;
  }
}
.about-block__txt {
  padding-right: min(3.125vw, 4rem);
}
@media screen and (max-width: 767px) {
  .about-block__txt {
    padding-right: 0;
  }
}
.about-block__txt-st {
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
  line-height: 2.5;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .about-block__txt-st {
    line-height: 2;
  }
}
.about-block__ph {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .about-block__ph {
    width: 100%;
  }
}
.about-block.--reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .about-block.--reverse {
    flex-direction: column;
    gap: 30px;
  }
}
.about-block.--reverse .about-block__ttl-st {
  padding-left: min(3.125vw, 4rem);
}
@media screen and (max-width: 767px) {
  .about-block.--reverse .about-block__ttl-st {
    padding-left: 0;
  }
}
.about-block.--reverse .about-block__txt {
  padding-left: min(3.125vw, 4rem);
  padding-right: 0;
}
@media screen and (max-width: 767px) {
  .about-block.--reverse .about-block__txt {
    padding-left: 0;
  }
}

.company {
  padding-block: min(9.375vw, 12rem);
}
@media screen and (max-width: 767px) {
  .company {
    padding-block: 50px;
  }
}
.company-head {
  margin-bottom: min(1.875vw, 2.4rem);
  max-width: 588px;
}
.company-cnt {
  background: #fff;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 767px) {
  .company-cnt {
    padding-block: 32px;
  }
}
.company-overview {
  padding-block: min(6.25vw, 8rem);
  padding-inline: min(3.125vw, 4rem);
  background: #fff;
}
@media screen and (max-width: 767px) {
  .company-overview {
    padding-block: 40px 8px;
    padding-inline: 20px;
  }
}
.company-overview__data {
  position: relative;
  margin-inline: auto;
  width: 100%;
  max-width: 1040px;
  border-top: 1px solid #999;
}
.company-overview__data-row {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: min(3.75vw, 4.8rem);
  padding-block: min(1.640625vw, 2.1rem) min(1.40625vw, 1.8rem);
  padding-inline: min(6.25vw, 8rem);
  border-bottom: 1px solid #999;
}
@media screen and (max-width: 767px) {
  .company-overview__data-row {
    flex-direction: column;
    gap: 0;
    padding-block: 10px;
    padding-inline: 20px;
  }
}
.company-overview__data-ttl {
  width: 150px;
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 2.5;
  color: #333;
}
@media screen and (max-width: 767px) {
  .company-overview__data-ttl {
    width: 100%;
    line-height: 2;
  }
}
.company-overview__data-txt {
  position: relative;
  flex: 1;
  font-weight: 500;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 2.5;
  color: #333;
}
@media screen and (max-width: 767px) {
  .company-overview__data-txt {
    width: 100%;
    line-height: 2;
  }
}

.examples-btn a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 90%;
  max-width: 450px;
  height: 70px;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.0rem;
  /*letter-spacing: 0.04em;*/
  line-height: 1.75;
  transition: 0.4s;
  background: #000;
  border: 1px solid #000;
  color: #fff;
	margin: auto;
}
@media screen and (max-width: 1024px) {
  .examples-btn a {
    padding-right: 20px;
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .examples-btn a {
    font-size: 1.8rem;
  }
}
.examples-btn a .arrow {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  transition: 0.4s;
	background: #000;
}
.examples-btn a .arrow::after {
  content: "";
  margin-right: 3px;
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
  transition: 0.4s;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}
.examples-btn a:hover {
  background: #fff;
  color: #000;
}
.examples-btn a:hover .arrow {
  background: #fff;
  color: #000;
}
.examples-btn a:hover .arrow::after {
  border-top: 2px solid #000;
  border-right: 2px solid #000;
}
.examples-link-p {
	padding-top: 50px;
}
@media screen and (max-width: 767px) {
	.examples-link-p {
        padding-top: 30px;
    }
}
.contBoxBunjo {
	margin: 30px auto 0;
}
@media screen and (max-width: 767px) {
    .contBoxBunjo {
        width: 94%;
    }
}
.shosanLp {
	font-size: 180% !important;
}
