@charset "UTF-8";
/* 要素 フォントサイズ・マージン・パディングをリセット */
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;
}

/* 行の高=フォントサイズ */
body {
  line-height: 1;
  letter-spacing: 0.1em;
}

/* 新規追加要素をブロック要素化 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

/* ulのマーカー非表示 */
ol,
ul,
li {
  list-style: none;
}

/* 引用符の非表示 */
blockquote,
q {
  quotes: none;
}

/* blockquote要素、q要素の前後にコンテンツ非表示 */
blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

/* フォントサイズ　リセット フォントの縦方向 ベースライン揃え 点線削除 */
a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  outline: none;
}

/* ins要素 デフォルトセット 色を変える場合はここで変更 */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* mark要素 デフォルトセット 色やフォントスタイルを変える場合はここで変更 */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

/* テキスト 打ち消し線 */
del {
  text-decoration: line-through;
}

/* IE　デフォルトで点線を下線表示設定　下線設定 マウスオーバー時 ヘルプカーソル表示可 */
abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

/*　隣接するセルのボーダーを重ねて表示　*/
table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
}

/* 水平罫線デフォルトリセット */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
  border: 0;
}

/* 縦方向の揃え 中央揃え */
input,
select {
  vertical-align: middle;
}

/* 画像を縦に並べた時に余白0 */
img {
  vertical-align: top;
  font-size: 0;
  line-height: 0;
}

/*box-sizingを全ブラウザに対応*/
*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

.clearfix:after {
  overflow: hidden;
  visibility: hidden;
  height: 0;
  display: block;
  font-size: 0;
  content: " ";
  clear: both;
}

br {
  line-height: inherit;
}

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

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

section {
  position: relative;
  overflow-x: hidden;
}

input[type=submit],
input[type=button] {
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  border: none;
  -webkit-box-sizing: border-box;
  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 {
  image-rendering: -webkit-optimize-contrast;
  max-width: 100%;
  height: auto;
}

sup {
  position: relative;
  top: -1ex;
  vertical-align: baseline;
}

button {
  outline: none;
}

iframe {
  display: block;
}

/*import*/
html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  -webkit-text-size-adjust: 100%;
  position: relative;
  color: #333;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
@media all and (-ms-high-contrast: none) {
  body {
    font-family: "Zen Kaku Gothic New", sans-serif;
  }
}

body.fix {
  position: fixed;
  width: 100%;
}

html,
body {
  width: 100%;
}

*:focus {
  outline: none;
}

p,
li,
dl,
tr,
th,
td {
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 2.28;
}
@media screen and (max-width: 640px) {
  p,
  li,
  dl,
  tr,
  th,
  td {
    font-size: 0.9375rem;
  }
}

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

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

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

.pc-tb {
  display: block;
}
@media screen and (max-width: 640px) {
  .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: 640px) {
  .tb {
    display: none !important;
  }
}

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

.cmn-wrap {
  position: relative;
  margin: 0 auto;
  padding: min(7.8125vw, 6.25rem) clamp(1.5625rem, 3.125vw, 2.5rem) min(10.15625vw, 8.125rem);
  width: 100%;
  max-width: 80rem;
}
.cmn-wrap.--full {
  padding: 0;
  max-width: none;
}
.cmn-wrap.--concept {
  padding-top: min(10.9375vw, 8.75rem);
}
@media screen and (max-width: 640px) {
  .cmn-wrap.--concept {
    padding-top: 0;
  }
}
.cmn-wrap.--worry {
  padding-top: 0;
  padding-bottom: min(9.765625vw, 7.8125rem);
}
.cmn-wrap.--architect {
  padding-top: min(10.703125vw, 8.5625rem);
  padding-bottom: min(12.1875vw, 9.75rem);
}
.cmn-wrap.--plan {
  padding-top: min(10.546875vw, 13.5rem);
  /*padding-bottom: min(15.234375vw, 19.5rem);*/
  padding-bottom: 0;
}
.cmn-wrap.--features {
  padding-top: min(14.453125vw, 11.5625rem);
  padding-bottom: min(7.421875vw, 5.9375rem);
}
.cmn-wrap.--time {
  padding-block: 0;
}
.cmn-wrap.--access {
  padding-top: min(11.09375vw, 8.875rem);
  padding-bottom: min(9.140625vw, 7.3125rem);
}
.cmn-wrap.--contact {
  padding-top: min(12.65625vw, 10.125rem);
  padding-bottom: min(9.375vw, 7.5rem);
}
.cmn-wrap.--company {
  padding-top: min(14.84375vw, 11.875rem);
  padding-bottom: min(13.125vw, 10.5rem);
}

.cmn-ttl {
  position: relative;
  margin-bottom: min(3.59375vw, 2.875rem);
}
@media screen and (max-width: 640px) {
  .cmn-ttl {
    margin-bottom: 1.5rem;
  }
}
.cmn-ttl__en {
  display: block;
  margin-bottom: min(3.671875vw, 2.9375rem);
  font-family: "Jost", sans-serif;
  font-weight: 500;
  font-size: 2.5rem;
  letter-spacing: 0.25em;
  color: #555;
}
@media screen and (max-width: 1024px) {
  .cmn-ttl__en {
    font-size: 2rem;
  }
}
@media screen and (max-width: 640px) {
  .cmn-ttl__en {
    font-size: 2.125rem;
  }
}
.cmn-ttl__jp {
  display: block;
  font-family: "Shippori Mincho", serif;
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  line-height: 1.33;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 1024px) {
  .cmn-ttl__jp {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 640px) {
  .cmn-ttl__jp {
    font-size: 1.05rem;
  }
}
.cmn-ttl.--white .cmn-ttl__en {
  color: #fff;
  opacity: 1;
}
.cmn-ttl.--white .cmn-ttl__jp {
  color: #fff;
}
.cmn-ttl.--center {
  text-align: center;
}
.cmn-ttl.--architect {
  margin-bottom: min(3.90625vw, 3.125rem);
}
.cmn-ttl.--architect .cmn-ttl__en {
  letter-spacing: 0.16em;
}
.cmn-ttl.--plan {
  margin-bottom: min(4.0625vw, 3.25rem);
}
.cmn-ttl.--plan .cmn-ttl__en {
  letter-spacing: 0.16em;
}
.cmn-ttl.--features {
  margin-bottom: min(4.0625vw, 3.25rem);
}
.cmn-ttl.--features .cmn-ttl__en {
  letter-spacing: 0.16em;
}
.cmn-ttl.--time {
  margin-bottom: min(4.53125vw, 3.625rem);
}
.cmn-ttl.--time .cmn-ttl__en {
  letter-spacing: 0.16em;
}
.cmn-ttl.--access {
  margin-bottom: min(6.40625vw, 5.125rem);
}
.cmn-ttl.--access .cmn-ttl__en {
  letter-spacing: 0.16em;
}
.cmn-ttl.--contact {
  margin-bottom: min(10.546875vw, 8.4375rem);
}
.cmn-ttl.--contact .cmn-ttl__en {
  letter-spacing: 0.16em;
}
.cmn-ttl.--company {
  margin-bottom: min(15.390625vw, 12.3125rem);
}
.cmn-ttl.--company .cmn-ttl__en {
  letter-spacing: 0.16em;
}

.hd {
  position: fixed;
  top: 0;
  left: 0;
  padding-top: 1.375rem;
  width: 100%;
  height: 4.8125rem;
  line-height: 1;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  z-index: 1000;
}
@media screen and (max-width: 1024px) {
  .hd {
    padding-top: 0;
  }
}
.hd-cnt {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  margin: 0 auto;
  padding-inline: min(1.875vw, 1.5rem);
  width: 100%;
  height: 100%;
}
.hd-logo {
  width: auto;
  height: 100%;
}
.hd-logo__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 1.75rem;
  width: auto;
  height: 100%;
}
.hd-logo__link img {
  height: 100%;
  width: auto;
  -o-object-fit: contain;
  object-fit: contain;
}
.hd-logo__name {
  display: inline-block;
  padding-block: 0.625rem;
  height: 2.6875rem;
}
.hd-logo__hill {
  display: inline-block;
  height: 100%;
}
.hd-nav {
  margin-right: 1.5rem;
}
.hd-nav__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-flex-wrap: nowrap;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  gap: min(3.125vw, 2.5rem);
}
.hd-nav__item {
  text-align: center;
}
.hd-nav__link {
  display: block;
  position: relative;
}
.hd-nav__link-st {
  display: block;
  font-family: "Jost", sans-serif;
  font-weight: 500;
  font-size: 1.25rem;
  letter-spacing: 0.16em;
  line-height: 1.6;
  color: #000;
}
.hd-nav__link::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #000;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
  -webkit-transform-origin: left top;
  transform-origin: left top;
}
@media screen and (min-width: 1025px) {
  .hd-nav__link:hover {
    opacity: 1;
  }
  .hd-nav__link:hover::after {
    opacity: 1;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
}
.hd-nav__name {
  display: none;
}
.hd-toggle {
  display: none;
}
@media screen and (max-width: 1024px) {
  .hd-cnt {
    padding-inline: 0;
  }
  .hd-menu {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 0.625rem;
  }
  .hd-logo__link {
    gap: 0.9375rem;
  }
  .hd-logo__name {
    padding-block: 0;
    width: 4.5rem;
    height: 1.6875rem;
  }
  .hd-nav {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    position: fixed;
    gap: 1.125rem;
    top: 0;
    left: 100%;
    padding-top: 14.6666666667vw;
    width: 100%;
    height: 100svh;
    background: #000;
    overflow-y: scroll;
    opacity: 0;
    -webkit-transition: opacity 0.2s, visibility 0s 0.2s, -webkit-transform 0.2s;
    transition: opacity 0.2s, visibility 0s 0.2s, -webkit-transform 0.2s;
    transition: transform 0.2s, opacity 0.2s, visibility 0s 0.2s;
    transition: transform 0.2s, opacity 0.2s, visibility 0s 0.2s, -webkit-transform 0.2s;
    visibility: hidden;
    z-index: 1000;
  }
  .hd-nav__list {
    display: block;
    margin-bottom: 1.5625rem;
  }
  .hd-nav__item {
    padding: 0;
    line-height: 1;
  }
  .hd-nav__link {
    display: block;
    padding: 0.875rem 0;
  }
  .hd-nav__link-st {
    font-size: 1.25rem;
    color: #fff;
  }
  .hd-nav__name {
    display: block;
    width: 4.625rem;
    margin-bottom: 1.0625rem;
  }
  .hd-toggle {
    position: relative;
    display: block;
    margin-right: 1.5625rem;
    width: 1.375rem;
    height: 100%;
    cursor: pointer;
    z-index: 1002;
  }
  .hd-toggle div {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 22px;
    height: 16px;
  }
  .hd-toggle span {
    display: block;
    position: absolute;
    left: 0;
    -webkit-transition: 0.35s ease-in-out;
    transition: 0.35s ease-in-out;
    width: 100%;
    height: 1px;
    background: #332f2b;
    color: #332f2b;
  }
  .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;
  }
}
@media screen and (max-width: 640px) {
  .hd {
    height: 2.25rem;
  }
}
.hd.fixed {
  background: rgba(255, 255, 255, 0.3);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}
.hd.open .sp-nav {
  opacity: 1;
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%);
  -webkit-transition: opacity 0.4s, -webkit-transform 0.4s;
  transition: opacity 0.4s, -webkit-transform 0.4s;
  transition: transform 0.4s, opacity 0.4s;
  transition: transform 0.4s, opacity 0.4s, -webkit-transform 0.4s;
  visibility: visible;
}
.hd.open .hd-toggle span {
  background: #fff;
  color: #fff;
}
.hd.open .hd-toggle span:nth-child(1) {
  top: 7px;
  -webkit-transform: rotate(315deg);
  transform: rotate(315deg);
}
.hd.open .hd-toggle span:nth-child(2) {
  left: 50%;
  width: 0;
}
.hd.open .hd-toggle span:nth-child(3) {
  top: 7px;
  -webkit-transform: rotate(-315deg);
  transform: rotate(-315deg);
}

.banner {
  display: block;
  position: fixed;
  bottom: 0;
  right: 0;
  width: 22.5rem;
  z-index: 1001;
}
@media screen and (max-width: 640px) {
  .banner {
    width: auto;
    height: 4.1875rem;
  }
}
.banner-link {
  -webkit-filter: drop-shadow(-3px -1px 6px rgba(0, 0, 0, 0.16));
  filter: drop-shadow(-3px -1px 6px rgba(0, 0, 0, 0.16));
}
@media screen and (max-width: 640px) {
  .banner-link {
    -webkit-filter: drop-shadow(0px 0px 6px rgba(0, 0, 0, 0.16));
    filter: drop-shadow(0px 0px 6px rgba(0, 0, 0, 0.16));
  }
}

.ft {
  background: #11150d;
}
.ft-inr {
  position: relative;
  margin: 0 auto;
  padding: min(4.296875vw, 3.4375rem) min(3.125vw, 2.5rem) min(7.8125vw, 6.25rem);
  width: 100%;
  max-width: 80rem;
}
@media screen and (max-width: 1024px) {
  .ft-inr {
    padding: 5% 4% 15%;
  }
}
@media screen and (max-width: 640px) {
  .ft-inr {
    padding: 5% 4% 30%;
  }
}
.ft-name {
  margin: 0 auto 2rem;
  width: 3.125rem;
}
.ft-nav__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 2.5rem;
}
@media screen and (max-width: 1024px) {
  .ft-nav__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 1.25rem;
  }
}
.ft-nav__item {
  text-align: center;
}
.ft-nav__link {
  position: relative;
  display: block;
}
.ft-nav__link::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #332f2b;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
  -webkit-transform-origin: left top;
  transform-origin: left top;
}
@media screen and (min-width: 1025px) {
  .ft-nav__link:hover {
    opacity: 1;
  }
  .ft-nav__link:hover::after {
    opacity: 1;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
}
.ft-nav__st {
  font-family: "Noto Serif Display", serif;
  font-size: 1.25rem;
  letter-spacing: 0.16em;
  line-height: 1.6;
  text-align: center;
  color: #fff;
}

.mv-ph img {
  width: 100%;
  height: 100dvh;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: right bottom;
  object-position: right bottom;
}
.mv-slide {
  position: relative;
}
.mv-slide__ttl {
  position: absolute;
  top: 7.1875rem;
  left: min(24.21875vw, 19.375rem);
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  line-height: 1;
  color: #332f2b;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.39);
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}
@media screen and (max-width: 1024px) {
  .mv-slide__ttl {
    left: clamp(1.5625rem, 3.125vw, 2.5rem);
  }
}
@media screen and (max-width: 640px) {
  .mv-slide__ttl {
    top: 5.75rem;
    left: 0.75rem;
  }
}
.mv-slide__ttl-main {
  font-size: 3.4375rem;
  letter-spacing: 0.3em;
  line-height: 1.6;
}
@media screen and (max-width: 1024px) {
  .mv-slide__ttl-main {
    font-size: 2.75rem;
  }
}
@media screen and (max-width: 640px) {
  .mv-slide__ttl-main {
    font-size: 2.40625rem;
    letter-spacing: 0.35em;
    line-height: 1.55;
  }
}
.mv-slide__ttl-sub {
  font-size: 1.875rem;
  letter-spacing: 0.15em;
  line-height: 1.7;
}
@media screen and (max-width: 1024px) {
  .mv-slide__ttl-sub {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 640px) {
  .mv-slide__ttl-sub {
    font-size: 1.3125rem;
    letter-spacing: 0.2em;
    line-height: 1.45;
  }
}
.mv-slide__ttl.--white {
  color: #fff;
}

.concept-bg {
  width: 100%;
}
.concept-bg img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.concept-catch__txt {
  position: absolute;
  font-family: "Shippori Mincho", serif;
  font-size: 1.5rem;
  line-height: 2.21;
  text-align: right;
  color: #3a3a3a;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .concept-catch__txt {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 640px) {
  .concept-catch__txt {
    font-size: 1rem;
    line-height: 2.12;
  }
}
.concept-catch__txt:nth-child(1) {
  top: min(31.25vw, 25rem);
  right: 8.5%;
}
@media screen and (max-width: 640px) {
  .concept-catch__txt:nth-child(1) {
    top: 35.7333333333vw;
    right: 15.5%;
  }
}
.concept-catch__txt:nth-child(2) {
  bottom: min(24.21875vw, 19.375rem);
  left: 10.5%;
}
@media screen and (max-width: 1024px) {
  .concept-catch__txt:nth-child(2) {
    bottom: min(16.9270833333vw, 18.75rem);
    left: 5%;
  }
}
@media screen and (max-width: 640px) {
  .concept-catch__txt:nth-child(2) {
    top: 124.5333333333vw;
    bottom: auto;
    left: 6.5%;
  }
}
.concept-catch__txt:nth-child(3) {
  bottom: min(-5.46875vw, -4.375rem);
  right: 14%;
}
@media screen and (max-width: 1024px) {
  .concept-catch__txt:nth-child(3) {
    right: 5%;
  }
}
@media screen and (max-width: 640px) {
  .concept-catch__txt:nth-child(3) {
    bottom: 136.5333333333vw;
    right: 6%;
  }
}
.concept-ph {
  z-index: 1;
}
.concept-ph img:nth-child(1) {
  position: absolute;
  top: min(12.5vw, 10rem);
  left: 0;
  width: min(27.734375vw, 22.1875rem);
  aspect-ratio: 355/254;
}
@media screen and (max-width: 640px) {
  .concept-ph img:nth-child(1) {
    width: 32.5333333333vw;
    top: 93.3333333333vw;
    left: 6.6666666667vw;
  }
}
.concept-ph img:nth-child(2) {
  position: absolute;
  top: min(12.65625vw, 10.125rem);
  left: 60%;
  width: min(14.609375vw, 11.6875rem);
  aspect-ratio: 187/187;
}
@media screen and (max-width: 640px) {
  .concept-ph img:nth-child(2) {
    width: 24vw;
    top: 6.9333333333vw;
    left: 25%;
  }
}
.concept-ph img:nth-child(3) {
  position: absolute;
  top: min(8.359375vw, 6.6875rem);
  right: 0;
  width: min(23.984375vw, 19.1875rem);
  aspect-ratio: 307/208;
}
@media screen and (max-width: 640px) {
  .concept-ph img:nth-child(3) {
    top: -4vw;
    width: 39.4666666667vw;
  }
}
.concept-ph img:nth-child(4) {
  position: absolute;
  top: min(47.65625vw, 38.125rem);
  left: 10%;
  width: min(24.921875vw, 19.9375rem);
  aspect-ratio: 319/201;
}
@media screen and (max-width: 640px) {
  .concept-ph img:nth-child(4) {
    top: auto;
    bottom: 105.0666666667vw;
    left: auto;
    right: 0;
    width: 41.0666666667vw;
  }
}
.concept-ph img:nth-child(5) {
  position: absolute;
  top: min(50.78125vw, 40.625rem);
  right: 0;
  width: min(36.40625vw, 29.125rem);
  aspect-ratio: 466/326;
}
@media screen and (max-width: 640px) {
  .concept-ph img:nth-child(5) {
    top: 159.2vw;
    left: 0;
    right: auto;
    width: 50.1333333333vw;
  }
}
.concept-ph img:nth-child(6) {
  position: absolute;
  top: min(84.765625vw, 67.8125rem);
  left: 37.5%;
  width: min(12.265625vw, 9.8125rem);
  aspect-ratio: 157/220;
}
@media screen and (max-width: 640px) {
  .concept-ph img:nth-child(6) {
    top: 149.3333333333vw;
    left: auto;
    right: 0;
    width: 25.8666666667vw;
  }
}
.concept-ph img:nth-child(7) {
  position: absolute;
  top: min(62.109375vw, 49.6875rem);
  left: 44.5%;
  width: min(15.9375vw, 12.5625rem);
  aspect-ratio: 201/321;
}
@media screen and (max-width: 640px) {
  .concept-ph img:nth-child(7) {
    top: 183.2vw;
    left: 61.5%;
    width: 20.2666666667vw;
  }
}
.concept-box {
  position: relative;
}
@media screen and (max-width: 1024px) {
  .concept-box {
    padding-top: 4.375rem;
  }
}
@media screen and (max-width: 640px) {
  .concept-box {
    margin-top: -13.25rem;
    padding-top: 0;
  }
}
.concept-box__ph img:nth-child(1) {
  position: absolute;
  top: min(4.453125vw, 3.5625rem);
  left: 6.5%;
  width: min(14.6875vw, 11.75rem);
  aspect-ratio: 188/257;
}
@media screen and (max-width: 640px) {
  .concept-box__ph img:nth-child(1) {
    top: -16.875rem;
    left: 0;
    width: 9.125rem;
  }
}
.concept-box__ph img:nth-child(2) {
  position: absolute;
  top: min(4.453125vw, 3.5625rem);
  right: 6.5%;
  width: min(14.6875vw, 11.75rem);
  aspect-ratio: 188/257;
}
@media screen and (max-width: 640px) {
  .concept-box__ph img:nth-child(2) {
    top: -68.125rem;
    left: -1.5625rem;
    width: 6.6875rem;
  }
}
.concept-ttl {
  margin-bottom: min(2.5vw, 2rem);
  font-family: "Shippori Mincho", serif;
  font-size: 2rem;
  letter-spacing: 0;
  line-height: 1.5;
  text-align: center;
  color: #3a3a3a;
}
@media screen and (max-width: 1024px) {
  .concept-ttl {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 640px) {
  .concept-ttl {
    margin-bottom: 1.875rem;
    font-size: 1.4375rem;
  }
}
.concept-txt {
  margin: 0 auto;
  max-width: 32.75rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-size: 1rem;
  line-height: 2.56;
  text-align: center;
  color: #3a3a3a;
}
@media screen and (max-width: 640px) {
  .concept-txt {
    margin-bottom: 1.75rem;
    font-size: 0.875rem;
    line-height: 2;
  }
}

.worry-ttl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  height: clamp(7.5rem, 21.09375vw, 16.875rem);
  background: url(../../img/plan/bg-ttl-worry.jpg) no-repeat center center/cover;
}
@media screen and (max-width: 640px) {
  .worry-ttl {
    height: 9.625rem;
  }
}
.worry-ttl__st {
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 2.375rem;
  line-height: 1.26;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .worry-ttl__st {
    font-size: 1.9rem;
  }
}
@media screen and (max-width: 640px) {
  .worry-ttl__st {
    font-size: 1.54375rem;
  }
}
.worry-cnt {
  padding-top: min(14.375vw, 11.5rem);
  background: url(../../img/plan/bg-worry.jpg) no-repeat center bottom/cover;
}
.worry-block {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: min(6.875vw, 5.5rem);
}
@media screen and (max-width: 640px) {
  .worry-block {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 3.125rem;
  }
}
.worry-box {
  width: 33.3333333333%;
}
@media screen and (max-width: 640px) {
  .worry-box {
    width: 100%;
  }
}
.worry-box__ph {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: min(4.375vw, 3.5rem);
}
.worry-box__txt {
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 1.5rem;
  line-height: 2.21;
  text-align: center;
  color: #3a3a3a;
}
@media screen and (max-width: 1024px) {
  .worry-box__txt {
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 640px) {
  .worry-box__txt {
    font-size: 1.05rem;
  }
}
.worry-answer {
  text-align: center;
}
.worry-answer__st {
  padding-bottom: 0.9375rem;
  border-bottom: 1px solid #707070;
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 3.25rem;
  line-height: 1.58;
  text-align: center;
  color: #332f2b;
}
@media screen and (max-width: 1024px) {
  .worry-answer__st {
    font-size: 2.6rem;
  }
}
@media screen and (max-width: 640px) {
  .worry-answer__st {
    padding: 0;
    font-size: 2.1125rem;
  }
}

.architect {
  background: #332f2b;
}
.architect-txt {
  margin-bottom: min(10.9375vw, 8.75rem);
  font-weight: 500;
  font-size: 1rem;
  line-height: 2.56;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 640px) {
  .architect-txt {
    line-height: 2;
    text-align: left;
  }
}
.architect-block {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: min(7.8125vw, 6.25rem) 2.8125rem;
  margin: 0 auto;
  max-width: 67rem;
}
@media screen and (max-width: 640px) {
  .architect-block {
    gap: 3.125rem;
  }
}
.architect-box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
}
@media screen and (max-width: 640px) {
  .architect-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.architect-box__ph {
  width: min(23.75vw, 19rem);
}
@media screen and (max-width: 640px) {
  .architect-box__ph {
    margin-bottom: 1.875rem;
    width: 100%;
  }
}
.architect-box__info {
  width: calc(100% - 2.8125rem - min(23.75vw, 19rem));
}
@media screen and (max-width: 640px) {
  .architect-box__info {
    width: 100%;
  }
}
.architect-box__head {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
  margin-bottom: min(1.40625vw, 1.125rem);
  padding-bottom: min(1.5625vw, 1.25rem);
  border-bottom: 1px solid #fff;
}
@media screen and (max-width: 640px) {
  .architect-box__head {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.architect-box__name {
  width: 16.25rem;
}
@media screen and (max-width: 1024px) {
  .architect-box__name {
    width: 11.875rem;
  }
}
@media screen and (max-width: 640px) {
  .architect-box__name {
    margin-bottom: 0.9375rem;
    width: 100%;
  }
}
.architect-box__name-en {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 0.875rem;
  letter-spacing: 0.08em;
  color: #fff;
}
.architect-box__name-jp {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 2.125rem;
  letter-spacing: 0.08em;
  line-height: 1.75;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .architect-box__name-jp {
    font-size: 1.7rem;
  }
}
@media screen and (max-width: 640px) {
  .architect-box__name-jp {
    font-size: 1.4875rem;
  }
}
.architect-box__position {
  width: calc(100% - 18.125rem);
  font-family: "Noto Serif JP", serif;
  font-size: 1rem;
  line-height: 1.75;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .architect-box__position {
    width: calc(100% - 13.125rem);
  }
}
@media screen and (max-width: 640px) {
  .architect-box__position {
    width: 100%;
  }
}
.architect-box__txt {
  min-height: 7.5rem;
  font-weight: 500;
  font-size: 1rem;
  line-height: 2.56;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .architect-box__txt {
    line-height: 1.75;
  }
}

.plan-txt {
  margin-bottom: min(8.515625vw, 6.8125rem);
  font-weight: 500;
  font-size: 1rem;
  line-height: 2.56;
  text-align: center;
  color: #332f2b;
}
.plan-block {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: min(3.4375vw, 2.75rem) min(5.234375vw, 4.1875rem);
  margin-bottom: min(5.859375vw, 4.6875rem);
  margin-inline: auto;
  max-width: 66.6875rem;
}
@media screen and (max-width: 640px) {
  .plan-block {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.plan-box {
  position: relative;
  width: calc((100% - min(5.234375vw, 4.1875rem)) / 2);
}
@media screen and (max-width: 640px) {
  .plan-box {
    width: 100%;
  }
}
.plan-box__ph {
  position: relative;
  margin-bottom: min(0.78125vw, 0.625rem);
}
.plan-box__ph-search {
  position: absolute;
  bottom: 0;
  right: 0;
  width: clamp(10rem, 15.234375vw, 12.1875rem);
  aspect-ratio: 195/51;
}
.plan-btn {
  position: relative;
  text-align: center;
  cursor: pointer;
}
.plan-btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 100%;
  border-bottom: 1px solid #707070;
}
.plan-btn__txt {
  position: relative;
  display: inline-block;
  width: 17.25rem;
  height: 3.875rem;
  background: #332f2b;
  font-family: "Noto Serif Display", serif;
  font-weight: 600;
  font-size: 1.5rem;
  letter-spacing: 0.15em;
  line-height: 3.75rem;
  text-align: center;
  color: #fff;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .plan-btn__txt {
    width: 15rem;
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 640px) {
  .plan-btn__txt {
    width: 12.5rem;
    font-size: 1.05rem;
  }
}
.plan-btn__txt.--close {
  display: none;
}
.plan-btn.selected .--open {
  display: none;
}
.plan-btn.selected .--close {
  display: inline-block;
}
.plan-modal__item {
  position: relative;
  margin: 0 auto;
  padding: min(4.84375vw, 3.875rem) min(3.90625vw, 4.375rem);
  max-width: 75rem;
  width: 90%;
  min-height: 38.625rem;
  max-height: 90vh;
  background: #fff;
  overflow-y: auto;
}
@media screen and (max-width: 1024px) {
  .plan-modal__item {
    width: 95%;
  }
}
@media screen and (max-width: 640px) {
  .plan-modal__item {
    min-height: 80vh;
  }
}
.plan-modal__head {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: min(1.171875vw, 0.9375rem);
  padding-bottom: min(3.28125vw, 2.625rem);
  padding-inline: 0.5rem;
  border-bottom: 1px solid #707070;
}
@media screen and (max-width: 1024px) {
  .plan-modal__head {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.plan-modal__ttl {
  padding-right: min(3.515625vw, 2.8125rem);
  min-width: 17.5rem;
  border-right: 1px solid #707070;
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 2.375rem;
  line-height: 1.26;
  color: #332f2b;
}
@media screen and (max-width: 1024px) {
  .plan-modal__ttl {
    font-size: 1.9rem;
    margin-bottom: 1.875rem;
    width: 100%;
    border-right: none;
  }
}
@media screen and (max-width: 640px) {
  .plan-modal__ttl {
    font-size: 1.6625rem;
  }
}
.plan-modal__point {
  padding-left: min(3.515625vw, 2.8125rem);
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 1.6875rem;
  line-height: 1.44;
  color: #3a3a3a;
  word-break: keep-all;
  overflow-wrap: break-word;
  white-space: pre;
}
@media screen and (max-width: 1024px) {
  .plan-modal__point {
    padding-left: 0;
    width: 100%;
    font-size: 1.35rem;
    white-space: pre-wrap;
  }
}
@media screen and (max-width: 640px) {
  .plan-modal__point {
    font-size: 1.18125rem;
  }
}
.plan-modal__txt {
  margin-bottom: min(3.515625vw, 2.8125rem);
  padding-bottom: min(1.640625vw, 1.3125rem);
  border-bottom: 1px solid #707070;
  font-weight: 500;
  font-size: 1rem;
  line-height: 2.56;
  color: #3a3a3a;
}
@media screen and (max-width: 640px) {
  .plan-modal__txt {
    line-height: 2;
  }
}
.plan-modal__box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: min(4.84375vw, 3.875rem);
}
@media screen and (max-width: 640px) {
  .plan-modal__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.plan-modal__ph {
  width: calc(100% - 20rem - 0.9375rem);
  width: calc(100% - min(25vw, 20rem) - 0.9375rem);
}
@media screen and (max-width: 640px) {
  .plan-modal__ph {
    margin-bottom: 0.9375rem;
    width: 100%;
  }
}
.plan-modal__ph img {
  width: 100%;
  height: 100%;
}
.plan-modal__data {
  width: min(25vw, 20rem);
}
@media screen and (max-width: 640px) {
  .plan-modal__data {
    margin: 0 auto;
    width: 100%;
    max-width: 15rem;
  }
}
.plan-modal__data.--name {
  width: min(22.96875vw, 18.375rem);
  padding-left: min(2.34375vw, 1.875rem);
}
@media screen and (max-width: 640px) {
  .plan-modal__data.--name {
    padding-left: 0;
    width: 100%;
  }
}
.plan-modal__layout {
  margin-bottom: min(1.171875vw, 0.9375rem);
}
.plan-modal__info {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0.9375rem 0;
  margin: 0 auto min(5.625vw, 4.5rem);
  width: 100%;
}
.plan-modal__info-item {
  width: 25%;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .plan-modal__info-item {
    width: 50%;
  }
}
.plan-modal__info-item:not(:last-child) {
  border-right: 1px solid #707070;
}
@media screen and (max-width: 640px) {
  .plan-modal__info-item:nth-child(2) {
    border-right: none;
  }
}
.plan-modal__info-txt {
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.5;
  text-align: center;
  color: #332f2b;
  word-break: keep-all;
  overflow-wrap: break-word;
}
.plan-modal__video {
  margin: 0 auto;
  width: 100%;
  max-width: 52.1875rem;
  aspect-ratio: 834/504;
}
.plan-modal__video iframe {
  width: 100%;
  height: 100%;
}

.mfp-close-btn-in .mfp-close {
  top: 1%;
  right: 1%;
  width: 1.5625rem;
  height: 1.5625rem;
  line-height: 1.6875rem;
  background: #000;
  border-radius: 50%;
  font-size: 1.125rem;
  color: #fff;
}

.features {
  background: url(../../img/plan/bg-features.jpg) no-repeat top center/cover;
}
.features-txt {
  margin-bottom: min(10.9375vw, 8.75rem);
  font-weight: 500;
  font-size: 1rem;
  line-height: 2.56;
  text-align: center;
  color: #332f2b;
}
.features-tab__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: min(5.3125vw, 4.25rem) min(5.3125vw, 4.25rem);
  margin: 0 auto min(12.265625vw, 9.8125rem);
}
@media screen and (max-width: 1024px) {
  .features-tab__list {
    max-width: 40.625rem;
  }
}
.features-tab__item {
  width: calc((100% - min(15.9375vw, 12.75rem)) / 4);
}
@media screen and (max-width: 1024px) {
  .features-tab__item {
    width: calc((100% - min(15.9375vw, 12.75rem)) / 2);
    text-align: center;
  }
}
.features-tab__btn {
  width: 100%;
  border: none;
  border-top: 1px solid #3a3a3a;
  border-right: 1px solid #3a3a3a;
  opacity: 0.5;
  padding: 0;
  background: transparent;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  cursor: pointer;
}
.features-tab__btn.active {
  opacity: 1;
}
@media screen and (min-width: 1025px) {
  .features-tab__btn:hover {
    opacity: 1;
  }
}
.features-tab__num {
  margin-top: -1.4375rem;
  margin-bottom: min(2.890625vw, 2.3125rem);
  width: 8.5rem;
  height: 2.875rem;
  background: #000;
  font-family: "Jost", sans-serif;
  font-weight: 500;
  font-size: 1.125rem;
  letter-spacing: 0.16em;
  line-height: 2.875rem;
  color: #fff;
}
@media screen and (max-width: 640px) {
  .features-tab__num {
    width: 5.625rem;
    font-size: 1rem;
  }
}
.features-tab__ttl {
  margin-bottom: 0.4375rem;
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 1.75rem;
  letter-spacing: 0;
  line-height: 1.64;
  text-align: center;
  color: #3a3a3a;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
@media screen and (max-width: 1024px) {
  .features-tab__ttl {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 640px) {
  .features-tab__ttl {
    font-size: 1.05rem;
  }
}
.features-tab__icon {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding-inline: 0.625rem;
  max-width: 15.5625rem;
  width: 85%;
  height: min(14.53125vw, 11.625rem);
}
.features-tab__icon img {
  width: 100%;
  height: 100%;
}
.features-cnt {
  position: relative;
  margin-right: calc((100% - 100vw) / 2);
  z-index: 1;
}
.features-cnt.--reverse {
  margin-left: calc((100% - 100vw) / 2);
  margin-right: 0;
}
.features-cnt.--reverse .features-cnt__box {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
@media screen and (max-width: 640px) {
  .features-cnt.--reverse .features-cnt__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.features-cnt.--reverse .features-cnt__ph-txt {
  left: calc(100vw - 100%);
  right: auto;
}
.features-cnt.--reverse .features-cnt__link {
  margin-left: calc(100vw - 100%);
  margin-right: 0;
}
.features-cnt:nth-child(2) .features-cnt__box-info::before {
  width: min(30.625vw, 24.5rem);
  aspect-ratio: 392/236;
  background: url(../../img/plan/features-tab02-img01.svg) no-repeat center center/cover;
}
@media screen and (max-width: 640px) {
  .features-cnt:nth-child(2) .features-cnt__box-info::before {
    width: 36vw;
  }
}
.features-cnt:nth-child(3) .features-cnt__box-info::before {
  width: min(30.234375vw, 24.1875rem);
  aspect-ratio: 387/183;
  background: url(../../img/plan/features-tab03-img01.svg) no-repeat center center/cover;
}
@media screen and (max-width: 640px) {
  .features-cnt:nth-child(3) .features-cnt__box-info::before {
    width: 36vw;
  }
}
.features-cnt:nth-child(4) .features-cnt__box-info::before {
  width: min(23.671875vw, 18.9375rem);
  aspect-ratio: 303/245;
  background: url(../../img/plan/features-tab04-img01.svg) no-repeat center center/cover;
}
@media screen and (max-width: 640px) {
  .features-cnt:nth-child(4) .features-cnt__box-info::before {
    width: 36vw;
  }
}
.features-cnt__ph {
  position: relative;
  margin-bottom: min(4.21875vw, 3.375rem);
}
.features-cnt__ph-txt {
  position: absolute;
  bottom: 0;
  right: calc(100vw - 100%);
  font-family: "Jost", sans-serif;
  font-weight: 500;
  font-size: 5.625rem;
  letter-spacing: 0.05em;
  line-height: 1.4;
  text-align: right;
  color: transparent;
  background-color: rgba(255, 255, 255, 0.5);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (max-width: 1024px) {
  .features-cnt__ph-txt {
    font-size: 4.5rem;
  }
}
@media screen and (max-width: 640px) {
  .features-cnt__ph-txt {
    font-size: 2.25rem;
  }
}
.features-cnt__box {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin-bottom: min(6.25vw, 5rem);
  margin-inline: auto 0;
}
@media screen and (max-width: 640px) {
  .features-cnt__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.features-cnt__box-info {
  position: relative;
  width: min(50.859375vw, 40.6875rem);
}
@media screen and (max-width: 640px) {
  .features-cnt__box-info {
    width: 100%;
  }
}
.features-cnt__box-info::before {
  content: "";
  position: absolute;
  top: -1.875rem;
  right: 1.25rem;
  width: min(27.34375vw, 21.875rem);
  aspect-ratio: 355/300;
  background: url(../../img/plan/features-tab01-img01.svg) no-repeat center center/cover;
  opacity: 0.2;
}
@media screen and (max-width: 1024px) {
  .features-cnt__box-info::before {
    top: 0;
  }
}
@media screen and (max-width: 640px) {
  .features-cnt__box-info::before {
    width: 36vw;
  }
}
.features-cnt__box-ph {
  width: calc(100% - min(4.6875vw, 3.75rem) - min(50.859375vw, 40.6875rem));
}
@media screen and (max-width: 640px) {
  .features-cnt__box-ph {
    width: 100%;
  }
}
.features-cnt__box-ph img {
  width: 100%;
}
.features-cnt__box-num {
  margin-bottom: min(2.578125vw, 2.0625rem);
  width: 7.1875rem;
  height: 2.5rem;
  background: #000;
  font-family: "Jost", sans-serif;
  font-weight: 500;
  font-size: 1.125rem;
  letter-spacing: 0.16em;
  line-height: 2.875rem;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 640px) {
  .features-cnt__box-num {
    font-size: 1rem;
  }
}
.features-cnt__box-ttl {
  margin-bottom: min(7.03125vw, 5.625rem);
  font-family: "Shippori Mincho", serif;
  font-size: 2.5rem;
  line-height: 1.25;
  color: #3a3a3a;
}
@media screen and (max-width: 1024px) {
  .features-cnt__box-ttl {
    font-size: 2rem;
  }
}
@media screen and (max-width: 640px) {
  .features-cnt__box-ttl {
    font-size: 1.75rem;
  }
}
.features-cnt__box-point {
  margin-bottom: min(3.28125vw, 2.625rem);
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 1.6875rem;
  letter-spacing: 0;
  line-height: 1.44;
}
@media screen and (max-width: 1024px) {
  .features-cnt__box-point {
    font-size: 1.35rem;
  }
}
@media screen and (max-width: 640px) {
  .features-cnt__box-point {
    font-size: 1.18125rem;
  }
}
.features-cnt__box-txt {
  font-weight: 500;
  font-size: 1rem;
  line-height: 2.56;
  text-align: left;
  color: #3a3a3a;
}
.features-cnt__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  gap: min(2.5vw, 2rem);
  margin-right: calc(100vw - 100%);
}
@media screen and (max-width: 1024px) {
  .features-cnt__link {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-inline: min(3.41796875vw, 2.1875rem);
  }
}
@media screen and (max-width: 640px) {
  .features-cnt__link {
    padding-inline: 0;
  }
}
.features-cnt__link-item {
  width: calc((100% - min(2.5vw, 2rem)) / 4);
  height: 3.875rem;
  max-width: 17.1875rem;
}
@media screen and (max-width: 1100px) {
  .features-cnt__link-item {
    gap: min(1.1707317073vw, 0.75rem);
  }
}
@media screen and (max-width: 1024px) {
  .features-cnt__link-item {
    width: calc((100% - min(2.5vw, 2rem)) / 2);
  }
}
.features-cnt__link-btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0.875rem;
  width: 100%;
  height: 100%;
  background: #332f2b;
  border: 1px solid #707070;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  cursor: pointer;
}
@media screen and (max-width: 640px) {
  .features-cnt__link-btn {
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}
.features-cnt__link-btn.active {
  background: #fff;
}
.features-cnt__link-btn.active .features-cnt__link-ttl {
  color: #332f2b;
}
.features-cnt__link-btn.active .features-cnt__link-arrow {
  display: none;
}
@media screen and (min-width: 1025px) {
  .features-cnt__link-btn:hover {
    opacity: 0.8;
  }
}
.features-cnt__link-ttl {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 1.25rem;
  letter-spacing: 0.08em;
  line-height: 1.77;
  text-align: center;
  color: #fff;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
@media screen and (max-width: 1170px) {
  .features-cnt__link-ttl {
    font-size: 1rem;
  }
}
@media screen and (max-width: 640px) {
  .features-cnt__link-ttl {
    font-size: 0.8125rem;
  }
}
.features-cnt__link-num {
  font-family: "Jost", sans-serif;
  font-weight: 600;
  font-size: 1.375rem;
  letter-spacing: 0.08em;
  line-height: 1.77;
  text-align: center;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
@media screen and (max-width: 1170px) {
  .features-cnt__link-num {
    font-size: 1rem;
  }
}
.features-cnt__link-arrow {
  position: relative;
  width: 1.5rem;
  height: 1.4375rem;
}

.time-block {
  padding-top: min(15.078125vw, 12.0625rem);
  padding-bottom: min(9.0625vw, 7.25rem);
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
}
.time-txt {
  margin: 0 auto min(7.578125vw, 6.0625rem);
  max-width: 48.75rem;
  font-weight: 500;
  font-size: 1rem;
  line-height: 2.56;
  text-align: center;
  color: #332f2b;
}
@media screen and (max-width: 640px) {
  .time-txt {
    line-height: 2;
    text-align: left;
  }
}
.time-box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media screen and (max-width: 640px) {
  .time-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 3.125rem;
  }
}
.time-item {
  width: calc((100% - min(5.859375vw, 4.6875rem)) / 2);
}
@media screen and (max-width: 640px) {
  .time-item {
    width: 100%;
  }
}
.time-item__ph {
  margin-bottom: min(3.515625vw, 2.8125rem);
}
.time-item__ttl {
  margin-bottom: min(1.953125vw, 1.5625rem);
  font-family: "Shippori Mincho", serif;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 2;
  text-align: center;
  color: #332f2b;
}
@media screen and (max-width: 1024px) {
  .time-item__ttl {
    font-size: 1.125rem;
  }
}
@media screen and (max-width: 640px) {
  .time-item__ttl {
    font-size: 1.0625rem;
  }
}
.time-item__txt {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: 0.05em;
  line-height: 2;
  color: #332f2b;
}

.access-map {
  margin-bottom: min(6.40625vw, 5.125rem);
  width: 100%;
  height: auto;
  aspect-ratio: 1200/468;
}
.access-map iframe {
  width: 100%;
  height: 100%;
}
.access-data {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: 1.3125rem;
  margin-inline: auto 0;
  max-width: 47.8125rem;
}
@media screen and (max-width: 640px) {
  .access-data {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
    -ms-flex-align: end;
    align-items: flex-end;
  }
}
.access-data__add {
  font-family: "Shippori Mincho", serif;
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  line-height: 1.78;
  text-align: right;
  color: #332f2b;
}
@media screen and (max-width: 640px) {
  .access-data__add {
    font-size: 1rem;
  }
}
.access-data__phone {
  font-family: "Shippori Mincho", serif;
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  line-height: 1.78;
  text-align: right;
  color: #332f2b;
}
@media screen and (max-width: 640px) {
  .access-data__phone {
    font-size: 1rem;
  }
}
.access-data__fax {
  font-family: "Shippori Mincho", serif;
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  line-height: 1.78;
  text-align: right;
  color: #332f2b;
}
@media screen and (max-width: 640px) {
  .access-data__fax {
    font-size: 1rem;
  }
}
.access-data__ph {
  max-width: 25.625rem;
}

.contact {
  background: #efefef;
}
.contact-form {
  min-height: 109.375rem;
}
.contact-form__tab {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  gap: min(11.71875vw, 9.375rem);
  margin: 0 auto min(9.609375vw, 7.6875rem);
  max-width: 43.75rem;
}
@media screen and (max-width: 640px) {
  .contact-form__tab {
    gap: 2rem;
  }
}
.contact-form__tab-item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  width: calc((100% - 2rem) / 2);
}
@media screen and (max-width: 640px) {
  .contact-form__tab-item img {
    height: 10vw;
  }
}
.contact-form__cnt {
  padding: min(9.375vw, 7.5rem) 0;
}
.contact-form__select {
  padding: 0;
  height: 3.875rem;
  background: #fff;
  border: 1px solid #707070;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  cursor: pointer;
}
.contact-form__select span {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 300;
  font-size: 1.375rem;
  letter-spacing: 0.08em;
  line-height: 3.875rem;
  text-align: center;
  color: #332f2b;
}
@media screen and (max-width: 1024px) {
  .contact-form__select span {
    font-size: 1.1rem;
  }
}
@media screen and (max-width: 640px) {
  .contact-form__select span {
    font-size: 0.9625rem;
  }
}
.contact-form__select.active {
  background: #332f2b;
  border: 1px solid #707070;
}
.contact-form__select.active span {
  color: #fff;
}
.contact-form__block {
  display: none;
}

.company-data {
  margin: 0 auto;
  max-width: 61.875rem;
}
@media screen and (max-width: 1024px) {
  .company-data {
    margin: 0 auto;
  }
}
.company-data__row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid #707070;
}
@media screen and (max-width: 640px) {
  .company-data__row:last-child {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .company-data__row:last-child .company-data__ttl {
    padding-bottom: 0;
    width: 100%;
  }
  .company-data__row:last-child .company-data__txt {
    width: 100%;
  }
}
.company-data__ttl {
  width: min(14.84375vw, 11.875rem);
  width: clamp(9.375rem, 14.84375vw, 11.875rem);
  padding-block: 2.25rem 2rem;
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 1.125rem;
  letter-spacing: 0.08em;
  text-align: left;
  color: #332f2b;
  vertical-align: top;
}
@media screen and (max-width: 640px) {
  .company-data__ttl {
    display: block;
    width: 21.8666666667vw;
    font-size: 1rem;
  }
}
.company-data__txt {
  padding-block: 2.25rem 2rem;
  width: calc(100% - min(14.84375vw, 11.875rem));
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 1.1875rem;
  letter-spacing: 0.08em;
  color: #332f2b;
  vertical-align: top;
}
@media screen and (max-width: 640px) {
  .company-data__txt {
    display: block;
    width: calc(100% - 21.8666666667vw);
    font-size: 0.9375rem;
  }
}
.company-data__item {
  margin-bottom: 1.25rem;
  font-family: "Shippori Mincho", serif;
  font-weight: bold;
  font-size: 1.125rem;
  line-height: 1.75;
  color: #332f2b;
}
@media screen and (max-width: 1024px) {
  .company-data__item {
    line-height: 1.6;
  }
}
@media screen and (max-width: 640px) {
  .company-data__item {
    font-size: 0.9375rem;
  }
}