@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 {
  background: transparent;
  border: 0;
  font-size: 100%;
  margin: 0;
  outline: 0;
  padding: 0;
  vertical-align: baseline;
}

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

body {
  line-height: 1;
}

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

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

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

input,
button,
textarea,
select {
  font: inherit;
}

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

:focus {
  outline: 2px solid Highlight;
  outline-offset: 2px;
}

/* change colors to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colors to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border color to suit your needs */
hr {
  border: 0;
  border-top: 1px solid #cccccc;
  display: block;
  height: 1px;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: sub;
}

h1,
h2,
h3 {
  font-weight: normal;
}

html {
  font-size: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}
a:not([class]) {
  -webkit-text-decoration-skip: ink;
  text-decoration-skip-ink: auto;
}
a:hover {
  opacity: 0.7;
}

img {
  display: block;
  height: auto;
  width: 100%;
}

html {
  font-size: 16px;
}

body {
  color: #333;
  font-family: "Zen Kaku Gothic Antique", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", "Yu Gothic Medium", "Noto Sans JP", sans-serif;
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

.ib {
  display: inline-block;
}

.bold {
  font-weight: 900;
}

.color-orange {
  color: #f27d27;
}

.u-visually-hidden {
  clip: rect(0, 0, 0, 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

/* pcの電話番号発信対応 */
.l-footer {
  background-color: #f6f6f6;
  padding-bottom: 1.875rem;
}
.l-footer__inner {
  margin-inline: auto;
  max-width: 87.5rem;
  padding-inline: 1.5625rem;
}

.l-footer__upper {
  display: flex;
  gap: 2.5rem;
  justify-content: space-between;
  padding-bottom: 5rem;
}

.l-footer__info {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.l-footer__logo {
  height: 1.5625rem;
  width: 7.5rem;
}

.l-footer__logo img {
  height: auto;
}

.l-footer__txt {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  padding-top: 1rem;
}

.l-footer__company {
  font-size: 1rem;
  letter-spacing: 0.06em;
  line-height: 1.8;
  width: 22.0625rem;
}

.l-footer__address {
  font-size: 0.875rem;
  letter-spacing: 0.06em;
  line-height: 1.8;
  width: 22.0625rem;
}

.l-footer__link {
  align-items: center;
  display: flex;
  gap: 0.625rem;
}

.l-footer__link-txt {
  font-size: 0.875rem;
  letter-spacing: 0.06em;
  line-height: 1.8;
  text-decoration: none;
}

.l-footer__link img {
  height: 1rem;
  width: 1rem;
}

.l-footer__nav {
  display: flex;
  gap: 1.625rem;
}

.l-footer__nav-item {
  display: flex;
  flex-direction: column;
  flex-shrink: 1;
  gap: 0.75rem;
}

.l-footer__nav-head {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-decoration: none;
}

.l-footer__nav-en {
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.25rem;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.l-footer__nav-ttl {
  align-items: center;
  display: flex;
  gap: 0.5rem;
  padding-bottom: 0.25rem;
}

.l-footer__nav-line {
  background-color: #333;
  display: block;
  height: 0.0625rem;
  width: 0.875rem;
}

.l-footer__nav-ja {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.8125rem;
  line-height: 1.8;
  white-space: nowrap;
}

.l-footer__nav-list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  list-style: none;
}

.l-footer__nav-list-item {
  display: flex;
  gap: 0.5rem;
}

.l-footer__nav-list-item--indent {
  padding-left: 1.375rem;
  position: relative;
}

.l-footer__nav-list-item--indent::before {
  background-color: #333;
  content: "";
  height: 0.0625rem;
  left: 0;
  position: absolute;
  top: 0.6875rem;
  width: 0.875rem;
}

.l-footer__nav-list-link {
  display: flex;
  gap: 0.5rem;
  text-decoration: none;
}

.l-footer__nav-list-num {
  font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: 0.8125rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 1.9;
}

.l-footer__nav-list-txt {
  font-size: 0.8125rem;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.l-footer__copy {
  align-items: stretch;
  display: flex;
  justify-content: stretch;
  width: 100%;
}

.l-footer__copy-txt {
  text-align: center;
  width: 100%;
}

.l-header {
  -webkit-transform: translateY(-100%);
  left: 0;
  padding: 1.875rem 2.5rem;
  position: fixed;
  top: 0;
  transform: translateY(-100%);
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  width: 100%;
  z-index: 10000;
}
.l-header.UpMove {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}
.l-header.DownMove {
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
}

.l-header__inner {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.l-header__logo a {
  display: block;
}

.l-header__logo img {
  height: auto;
  width: 7.5rem;
}

.l-header__menu {
  cursor: pointer;
}

.l-header__menu img {
  height: auto;
  width: 3.8125rem;
}

.l-header__logo-white,
.l-header__menu-white {
  display: block !important;
}

.l-header__logo-black,
.l-header__menu-black {
  display: none !important;
}

.l-header.is-scrolled .l-header__logo-white,
.l-header.is-scrolled .l-header__menu-white {
  display: none !important;
}

.l-header.is-scrolled .l-header__logo-black,
.l-header.is-scrolled .l-header__menu-black {
  display: block !important;
}

.l-inner {
  margin-inline: auto;
  max-width: 1270px;
  padding-left: 1.5625rem;
  padding-right: 1.5625rem;
  width: 100%;
}

.l-single-wrap {
  display: flex;
  gap: 5rem;
  justify-content: space-between;
  margin-inline: auto;
  max-width: 73.75rem;
  padding-top: 1.25rem;
}

.l-under-wrap {
  display: flex;
  gap: 2.5rem;
  justify-content: space-between;
}

.l-under-content {
  max-width: 100%;
  width: 52.5rem;
}

.c-btn-fixed {
  bottom: 5rem;
  display: flex;
  flex-direction: column;
  gap: 0;
  position: fixed;
  right: 0;
  z-index: 100;
}

.c-btn-fixed--footer {
  flex-direction: row;
  height: 5rem;
  justify-content: flex-end;
  margin-bottom: 4rem;
  position: static;
  width: auto;
}

.c-btn-fixed__btn {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  align-items: center;
  display: flex;
  flex-direction: column;
  height: 10rem;
  justify-content: center;
  text-decoration: none;
  transition: background-color 0.3s ease;
  width: 4.125rem;
  writing-mode: vertical-rl;
}

.c-btn-fixed__btn:hover {
  opacity: 1;
}

.c-btn-fixed__btn--reserve {
  background-color: #b93e2a;
  gap: 0.25rem;
  padding: 1.125rem 0.5rem;
}

.c-btn-fixed__btn--reserve:hover {
  background-color: #922412;
}

.c-btn-fixed__btn--document {
  background-color: #2c3e50;
  gap: 0.25rem;
  padding: 1.125rem 0.5rem;
}

.c-btn-fixed__btn--document:hover {
  background-color: #1a2938;
}

.c-btn-fixed__btn--h-reserve {
  -webkit-writing-mode: horizontal-tb;
  -ms-writing-mode: lr-tb;
  background-color: #b93e2a;
  gap: 0.125rem;
  height: 4.125rem;
  padding: 0;
  width: 10rem;
  writing-mode: horizontal-tb;
}

.c-btn-fixed__btn--h-reserve:hover {
  background-color: #922412;
}

.c-btn-fixed__btn--h-document {
  -webkit-writing-mode: horizontal-tb;
  -ms-writing-mode: lr-tb;
  background-color: #2c3e50;
  gap: 0.125rem;
  height: 4.125rem;
  padding: 0;
  width: 10rem;
  writing-mode: horizontal-tb;
}

.c-btn-fixed__btn--h-document:hover {
  background-color: #1a2938;
}

.c-btn-fixed__btn-txt {
  color: #fff;
  font-weight: 700;
}

.c-btn-fixed__btn-txt--reserve {
  font-size: 0.875rem;
  line-height: 1.22;
}

.c-btn-fixed__btn-txt--document {
  font-size: 0.875rem;
  line-height: 1.22;
}

.c-btn-open-close {
  display: none;
}

.c-btn-open-close__txt {
  color: #333;
  font-size: 0.875rem;
}

.c-btn-open-close__icon {
  -webkit-transform: rotate(180deg);
  height: 0.6875rem;
  transform: rotate(180deg);
  width: 1.3125rem;
}

.c-btn-open-close__icon--up {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.c-btn-open-close--close {
  align-items: center;
  background-color: transparent;
  border: 1px solid #d5d5d5;
  cursor: pointer;
  display: none;
  flex-direction: row;
  gap: 0.75rem;
  justify-content: center;
  padding: 1rem;
}

.c-btn {
  align-items: center;
  border-bottom: 1px solid #333;
  display: inline-flex;
  font-size: 0.875rem;
  gap: 1.25rem;
  padding: 0.875rem 1.25rem;
  text-decoration: none;
}
.c-btn:hover {
  opacity: 1;
}

.c-btn span {
  white-space: nowrap;
}

.c-btn__arrow {
  height: auto;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  width: 1.390625rem;
}
.c-btn:hover .c-btn__arrow {
  -webkit-transform: translateX(3px);
  transform: translateX(3px);
}

.c-check-box {
  padding-top: 1.875rem;
}

.c-check-box__list {
  border: 1px solid #d5d5d5;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  padding: 1.25rem;
  position: relative;
}

.c-check-box__point {
  bottom: 0;
  color: #f6f6f6;
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 7.5rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 0.7em;
  position: absolute;
  right: 0;
  z-index: -1;
}

.c-check-box__items {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.c-check-box__item {
  align-items: center;
  display: flex;
  gap: 0.625rem;
}

.c-check-box__items > .c-check-box__item {
  align-items: flex-start;
  flex-direction: column;
  gap: 0;
}

.c-check-box__item-desc {
  font-size: 0.875rem;
  letter-spacing: 0.06em;
  line-height: 2em;
  padding-left: 1.625rem;
}

.c-check-box__item-ttl {
  letter-spacing: 0.06em;
  padding-left: 1.625rem;
  position: relative;
}

.c-check-box__item-ttl::before {
  background-image: url("../img/check.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 1rem;
  left: 0;
  position: absolute;
  top: 0.4375rem;
  width: 1rem;
}

.c-check-box__ttl {
  font-weight: 900;
  padding-left: 1.625rem;
  position: relative;
}

.c-check-box__ttl::before {
  -webkit-transform: translateY(-50%);
  background-color: #333;
  content: "";
  height: 0.0625rem;
  left: 0;
  position: absolute;
  top: 1.125rem;
  transform: translateY(-50%);
  width: 0.875rem;
}

.c-column2 {
  display: grid;
  gap: 2.5rem;
  grid-template-columns: repeat(2, 1fr);
}

.c-column2--gap60 {
  gap: 3.75rem;
}

.c-column3 {
  display: grid;
  gap: 2.5rem;
  grid-template-columns: repeat(3, 1fr);
}

.c-column4 {
  display: grid;
  gap: 2.5rem;
  grid-template-columns: repeat(4, 1fr);
}

.c-headline1__main {
  border-left: 2px solid #003c8c;
  font-size: 1.875rem;
  padding-left: 1.875rem;
}

.c-headline1__sub {
  font-size: 1rem;
  margin-top: 0.875rem;
}

.c-hoverRun {
  background-image: linear-gradient(90deg, #000, #000);
  background-position: left bottom;
  background-repeat: no-repeat;
  background-size: 0 1px;
  color: #000;
  display: inline;
  text-decoration: none;
  transition: background-size 0.5s;
}
.c-hoverUnderline {
  display: inline-block;
  position: relative;
}

.c-hoverUnderline::after {
  background: #000;
  bottom: 0;
  content: "";
  height: 1px;
  left: 0;
  opacity: 0;
  position: absolute;
  transition: opacity 0.5s ease-in-out;
  width: 100%;
}
.c-hoverUnderline {
  display: inline-block;
  position: relative;
}

.c-hoverUnderline::after {
  background: #000;
  bottom: 0;
  content: "";
  height: 1px;
  left: 0;
  opacity: 0;
  position: absolute;
  transition: opacity 0.3s ease-in-out;
  width: 100%;
}
.c-img-ttl {
  align-items: center;
  background-color: #f6f6f6;
  display: flex;
  font-size: 1.125rem;
  font-weight: 500;
  justify-content: center;
  letter-spacing: 0.06em;
  line-height: 1.6em;
  padding: 0.5rem 0rem;
}

.c-img-ttl--white {
  background-color: #fff;
}

.c-img-ttl--yellow {
  background-color: #f7f764;
  font-weight: 700;
}

.c-imgHover {
  position: relative;
}

.c-imgHover img {
  transition: 0.5s opacity;
  width: 2.25rem;
}

.c-imgHover img:nth-of-type(2) {
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  transition: 0.5s opacity;
}
.c-imgZoom {
  overflow: hidden;
  position: relative;
}
.c-imgZoom img {
  -o-object-fit: cover;
  object-fit: cover;
  transition: -webkit-transform 0.8s;
  transition: transform 0.8s;
  transition: transform 0.8s, -webkit-transform 0.8s;
}
.c-link-box {
  border: 1px solid #d9d9d9;
  display: flex;
  flex-direction: column;
  margin-inline: auto;
  padding: 2.25rem 1.875rem;
  width: 52.5rem;
}

.c-link-box__head {
  align-items: center;
  display: flex;
}

.c-link-box__head-txt {
  -webkit-padding-start: 1.5rem;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.8;
  padding-inline-start: 1.5rem;
  position: relative;
}

.c-link-box__head-txt::before {
  -webkit-transform: translateY(-50%);
  background-color: #333;
  content: "";
  height: 0.0625rem;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 0.875rem;
}

.c-link-box__list {
  align-items: center;
  display: flex;
  gap: 1.25rem;
  justify-content: space-between;
  padding-top: 1.125rem;
}

.c-link-box__btn {
  flex: 1;
  text-align: center;
}

.c-link-box__btn--white .c-btn {
  background-color: #fff;
  font-weight: 700;
}
.c-link {
  line-height: 1;
  position: relative;
}

.c-link::after {
  background: url(../img/common/link.svg) center center/contain no-repeat;
  content: "";
  height: 0.625rem;
  position: absolute;
  right: -0.9375rem;
  top: 0.3em;
  width: 0.625rem;
}

.c-marker {
  background: linear-gradient(transparent 70%, #FCF65F 0%);
  display: inline;
}

.yt-placeholder {
  aspect-ratio: 16/9;
  cursor: pointer;
  display: block;
  overflow: hidden;
  position: relative;
  width: 100%;
}

.yt-placeholder > img:first-child {
  display: block;
  height: auto;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  width: 100%;
}

.yt-placeholder:hover > img:first-child {
  -webkit-transform: scale(1.02);
  transform: scale(1.02);
}

.yt-play-button {
  -webkit-transform: translate(-50%, -50%);
  height: auto;
  left: 50%;
  opacity: 0.9;
  pointer-events: none;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: opacity 0.3s ease;
  width: clamp(5rem, 3.21rem + 8.95vw, 7.5rem);
}

.yt-placeholder:hover .yt-play-button {
  opacity: 1;
}

.yt-play-button--gallery {
  width: clamp(3rem, 1.89rem + 5.56vw, 5rem);
}

.c-normal__txt {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  width: 100%;
}

.c-normal__txt-item {
  font-size: 0.9375rem;
}
.c-normal__txt-item strong {
  font-weight: 700;
}

.c-normal__txt--concept {
  align-items: center;
  gap: 1.25rem;
}

.c-normal__txt-item--concept {
  font-size: 1rem;
  text-align: center;
}

.c-page-fv {
  width: 100%;
}

.c-page-fv__img {
  background-attachment: fixed;
  background-position: center;
  background-size: cover;
  height: 29.25rem;
  width: 100%;
}

.design-page .c-page-fv__img {
  background-image: url("../img/fv_design.webp");
}

.quality-page .c-page-fv__img {
  background-image: url("../img/fv_quality.webp");
}

.gallery-page .c-page-fv__img {
  background-image: url("../img/fv_gallery.webp");
}

.c-page-fv__img picture {
  display: none;
}

.c-page-fv__ttl-box {
  padding-bottom: clamp(3.75rem, 1.513rem + 11.19vw, 6.875rem);
  padding-top: clamp(6.25rem, 3.565rem + 13.42vw, 10rem);
}

.c-page-fv__ttl {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  padding-left: 6.875rem;
}

.c-page-fv__ttl-en {
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 3rem;
  letter-spacing: 0.06em;
  line-height: 1;
}

.c-page-fv__ttl-en--single {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  line-height: 1.2;
}

.c-page-fv__ttl-ja {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
  padding-left: 2.125rem;
  position: relative;
}

.c-page-fv__ttl-ja::before {
  background-color: #333;
  content: "";
  height: 0.0625rem;
  left: 0;
  position: absolute;
  top: 0.8125rem;
  width: 1.25rem;
}

.c-page-fv__breadcrumb {
  font-size: clamp(0.625rem, 0.401rem + 1.12vw, 0.938rem);
  padding: 0.625rem 6.25rem 0.625rem 0.625rem;
  text-align: right;
}

.c-page-fv__breadcrumb .breadcrumbs {
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; /* ←省略しないならこの3行は消してOK */
  display: -webkit-box; /* 複数行省略を使いたいなら */
  line-height: 1.5;
  overflow: hidden;
  text-overflow: ellipsis;
}

.c-parallax {
  /* サイド幅とギャップ（PCで上書き） */
  --aside: 240px;
  --gap: clamp(-120px, calc(15.625vw - 240px), -40px);
  /* ビューポート幅（JSで --vw を入れる。安全に 100vw の代替） */
  --vw: 100vw;
  isolation: isolate;
  /* セクション自体の枠 */
  position: relative;
  z-index: 5;
}

/* 画像の“台座”。ここがフルブリード */
.c-parallax__cover {
  align-items: flex-end; /* 任意。下寄せしたい時 */
  display: flex;
  /* 高さは好きに。固定 or アスペクト比 */
  height: 50rem; /* ←今はこれでOK。比率でやるなら下の1行に置換 */
  /* 中央基準で左右はみ出し分を相殺＋左カラム分だけさらに引く */
  margin-left: calc((var(--vw) - 100%) / -2 - (var(--aside) + var(--gap)));
  overflow: hidden;
  /* ここがフル幅の正体 */
  width: var(--vw);
}

/* 画像を cover でフィット */
.c-parallax__cover picture,
.c-parallax__cover img {
  -o-object-fit: cover;
  -o-object-position: center;
  display: block;
  height: 100%;
  object-fit: cover;
  object-position: center;
  width: 100%;
}

/* SPはサイド無し */
.c-top-ttl {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.c-top-ttl__en {
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: clamp(1.875rem, 1.071rem + 4.02vw, 3rem);
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1;
}

.c-top-ttl__ja {
  color: #919191;
  font-family: "Zen Kaku Gothic Antique", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", "Yu Gothic Medium", "Noto Sans JP", sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.c-top-ttl--left {
  align-items: flex-start;
}

.c-under-head {
  align-items: center;
  display: flex;
  gap: 1.25rem;
}

.c-under-head__number {
  font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: 1.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.2;
}

.c-under-head__ttl-wrap {
  align-items: center;
  display: flex;
  height: 1.8125rem;
}

.c-under-head__ttl {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1.2;
}

.c-under-head__ttl--outro-intro {
  font-weight: 700;
}

.c-under-menu {
  align-self: flex-start;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  position: sticky;
  top: 6.25rem;
  transition: top 0.3s ease;
  z-index: 3;
}

body.header-hidden .c-under-menu {
  top: 0.625rem;
}

.c-under-menu__head {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.c-under-menu__head-en {
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.25rem;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.c-under-menu__head-ja {
  -webkit-padding-start: 1.375rem;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.8125rem;
  line-height: 1.8;
  padding-bottom: 0.25rem;
  padding-inline-start: 1.375rem;
  position: relative;
}

.c-under-menu__head-ja::before {
  -webkit-transform: translateY(-50%);
  background-color: #333;
  content: "";
  height: 0.0625rem;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 0.875rem;
}

.c-under-menu__list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.c-under-menu__item {
  align-items: center;
  display: flex;
  gap: 0.5rem;
}

.c-under-menu__item-num {
  color: #a3a3a3;
  font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: 0.8125rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.c-under-menu__item-link {
  color: #a3a3a3;
  font-size: 0.8125rem;
  letter-spacing: 0.06em;
  line-height: 1.8;
  transition: color 0.3s ease;
}

.c-under-menu__item-link:hover {
  color: #333;
}

.c-under-menu__item--active .c-under-menu__item-num {
  color: #333;
}

.c-under-menu__item--active .c-under-menu__item-link {
  color: #333;
}

.c-under-sub {
  -webkit-padding-start: 1.5rem;
  align-items: center;
  display: flex;
  gap: 0.625rem;
  padding-inline-start: 1.5rem;
  padding-top: 1.25rem;
  position: relative;
}

.c-under-sub::before {
  -webkit-transform: translateY(-50%);
  background-color: #333;
  content: "";
  height: 0.0625rem;
  left: 0;
  position: absolute;
  top: 2.25rem;
  transform: translateY(-50%);
  width: 0.875rem;
}

.c-under-sub__ttl {
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1.8;
  position: relative;
}

.c-under-txt-box {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-top: 1.25rem;
}

.c-under-txt {
  font-size: 0.9375rem;
  letter-spacing: 0.06em;
  line-height: 2;
}

.c-under-txt--caution {
  font-size: 0.8125rem;
}

.c-underBar {
  display: inline-block;
  position: relative;
}
.c-underBar::before {
  -webkit-transform: translateX(-50%);
  background-color: #333;
  bottom: 0;
  content: "";
  height: 1px;
  left: 50%;
  opacity: 1;
  position: absolute;
  transform: translateX(-50%);
  transition: 0.5s;
  width: 100%;
}
.p-404 {
  padding-top: 2.5rem;
}

.p-404__inner {
  margin-inline: auto;
  max-width: 62.5rem;
  width: 100%;
}

.p-404__link {
  padding-top: 2.5rem;
}

.p-catalog-request {
  padding-top: 2.5rem;
}

.p-catalog-request__inner {
  margin-inline: auto;
  max-width: 62.5rem;
  width: 100%;
}

.p-catalog-request__ttl {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.6;
  margin-bottom: 1.25rem;
}

.p-catalog-request__flex {
  display: flex;
  gap: 3.125rem;
}

.p-catalog-request__img {
  flex-shrink: 0;
  width: 26.6875rem;
}

.p-catalog-request__img img {
  display: block;
  height: auto;
  width: 100%;
}

.p-catalog-request__form-box {
  padding-top: 5rem;
}

.p-catalog-request__form {
  background-color: #f6f6f6;
  display: flex;
  flex-direction: column;
  gap: 3.5rem;
  margin-inline: auto;
  max-width: 62.5rem;
  padding: 5rem 8.75rem;
  width: 100%;
}

.p-catalog-request__list {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  width: 100%;
}

.p-catalog-request__item {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  width: 100%;
}

.p-catalog-request__title {
  align-items: flex-start;
  display: flex;
  gap: 0.5rem;
}

.p-catalog-request__required {
  align-items: center;
  background-color: #f27d27;
  color: #fff;
  display: inline-flex;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  justify-content: center;
  line-height: 1.8;
  padding: 0 1rem;
  white-space: nowrap;
}

.p-catalog-request__optional {
  align-items: center;
  background-color: #333;
  color: #fff;
  display: inline-flex;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  justify-content: center;
  padding: 0 1rem;
}

.p-catalog-request__title__label {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.5;
}

.p-catalog-request__input {
  width: 100%;
}

.p-catalog-request__input input {
  background-color: #fff;
  border: none;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.8;
  padding: 0.625rem 0.75rem;
  width: 100%;
}
.p-catalog-request__input input::-webkit-input-placeholder {
  color: #a3a3a3;
}
.p-catalog-request__input input:-ms-input-placeholder {
  color: #a3a3a3;
}
.p-catalog-request__input input::-ms-input-placeholder {
  color: #a3a3a3;
}
.p-catalog-request__input input::placeholder {
  color: #a3a3a3;
}

.p-catalog-request__post {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem;
}

.p-catalog-request__post-label {
  color: #333;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.8;
  padding-top: 0.625rem;
}

.p-catalog-request__post-input {
  flex-shrink: 0;
  width: 10rem;
}

.p-catalog-request__post-input input {
  background-color: #fff;
  border: none;
  color: #333;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.8;
  padding: 0.625rem 0.75rem;
  width: 100%;
}
.p-catalog-request__post-input input::-webkit-input-placeholder {
  color: #a3a3a3;
}
.p-catalog-request__post-input input:-ms-input-placeholder {
  color: #a3a3a3;
}
.p-catalog-request__post-input input::-ms-input-placeholder {
  color: #a3a3a3;
}
.p-catalog-request__post-input input::placeholder {
  color: #a3a3a3;
}

.p-catalog-request__post-note {
  color: #333;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.8;
  padding-top: 0.625rem;
  width: 100%;
}

.p-catalog-request__textarea {
  width: 100%;
}

.p-catalog-request__textarea textarea {
  background-color: #fff;
  border: none;
  color: #333;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  height: 10.6875rem;
  line-height: 1.8;
  padding: 0.625rem 0.75rem;
  resize: vertical;
  width: 100%;
}
.p-catalog-request__textarea textarea::-webkit-input-placeholder {
  color: #a3a3a3;
}
.p-catalog-request__textarea textarea:-ms-input-placeholder {
  color: #a3a3a3;
}
.p-catalog-request__textarea textarea::-ms-input-placeholder {
  color: #a3a3a3;
}
.p-catalog-request__textarea textarea::placeholder {
  color: #a3a3a3;
}

.p-catalog-request__radio {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.p-catalog-request__radio label {
  align-items: center;
  color: #333;
  display: flex;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  gap: 0.625rem;
  line-height: 1.8;
  padding: 0 0.75rem;
}

.p-catalog-request__radio input[type=radio] {
  background-color: #fff;
  border: 1px solid #d5d5d5;
  height: 0.9375rem;
  margin: 0;
  width: 0.9375rem;
}

.p-catalog-request__privacy {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  width: 100%;
}

.p-catalog-request__privacy-txt {
  font-size: 0.8125rem;
  line-height: 1.8;
}

.p-catalog-request__acceptance {
  align-items: center;
  display: flex;
  gap: 1rem;
}

.p-catalog-request__acceptance label {
  align-items: center;
  display: flex;
  font-size: 0.875rem;
  gap: 1rem;
  line-height: 1.2;
}

.p-catalog-request__acceptance input[type=checkbox] {
  background-color: #fff;
  border: 1px solid #d5d5d5;
  height: 0.9375rem;
  margin: 0;
  width: 0.9375rem;
}

.p-catalog-request__submit {
  display: flex;
  justify-content: center;
  padding-top: 2.5rem;
}

.p-catalog-request__submit input[type=submit] {
  align-items: center;
  background-color: #2a686f;
  border: none;
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  font-size: 1rem;
  font-weight: 700;
  gap: 1.25rem;
  justify-content: center;
  letter-spacing: 0.04em;
  line-height: 2;
  padding: 0.875rem 2.5rem;
  transition: opacity 0.3s;
}
.p-catalog-request__submit input[type=submit]:hover {
  opacity: 0.8;
}

.wpcf7-spinner {
  position: absolute;
}

.p-catalog-request__privacy-link {
  text-decoration: underline;
}

.p-company__column {
  align-items: center;
  display: flex;
  gap: 7.8125rem;
  justify-content: center;
}

.p-company__txt {
  display: flex;
  flex-direction: column;
}

.p-company__content {
  display: flex;
  flex-direction: column;
  max-width: 24.6875rem;
  padding-top: 1.625rem;
}

.p-company__sub-ttl {
  color: #333;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: clamp(1.25rem, 1.071rem + 0.89vw, 1.5rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.6;
}

.p-company__desc {
  padding-top: 1.625rem;
}

.p-company__btn {
  display: flex;
  padding-top: 2.5rem;
}

.p-company__img {
  height: 25rem;
  width: 35rem;
}

.p-company__img img {
  -o-object-fit: cover;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.p-concept {
  display: flex;
  justify-content: center;
}

.p-concept__sec {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 1.125rem;
  width: 100%;
}

.p-concept__column {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 3.125rem;
}

.p-concept__ttl {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  text-align: center;
}

.p-concept__ttl-en {
  color: #919191;
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

.p-concept__ttl-ja {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: clamp(1.25rem, 0.893rem + 1.79vw, 1.75rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.4;
}

.p-concept__slider {
  overflow: hidden;
  width: 100%;
}

.p-concept__swiper {
  overflow: visible;
  width: 100%;
}

.p-concept__slide {
  height: 18.4375rem;
  width: 26.734375rem;
}
.p-concept__slide img {
  -o-object-fit: cover;
  object-fit: cover;
}

.p-concept__btn {
  display: flex;
  justify-content: center;
  margin-top: clamp(1.25rem, -1.5rem + 11.73vw, 4.125rem);
}

.p-concept__logo {
  align-items: flex-end;
  display: flex;
  margin-top: 1.125rem;
  width: 100%;
}

.p-concept__logo-img {
  height: auto;
  margin-left: auto;
  width: 43.375rem;
}

.js-p-gallery__swiper,
.js-p-concept__swiper {
  pointer-events: none;
}

.p-design-01__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem;
  padding-top: 1.875rem;
}

.p-design-01__item {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  width: 16.875rem;
}

/* 画像はデフォで普通（PC/タブレット） */
.p-design-01__img-list {
  -webkit-padding-after: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  padding-block-end: 2.5rem;
  padding-top: 1.875rem;
}

.p-design-01__img-item {
  /* ← PCは通常のコンテンツ幅 */
  width: 100%;
}

.p-design-01__img-item:last-child {
  padding-top: 1.25rem;
}

.p-design-01__img {
  display: block;
  height: auto;
  width: 100%;
}

/* テキスト側はそのまま */
.p-design-01__concept {
  display: flex;
  flex-direction: column;
  margin-inline: auto;
  max-width: 35rem;
  position: relative;
  width: 100%;
  z-index: 2;
}

.p-design-01__concept-bg {
  color: #f6f6f6;
  display: flex;
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 7.5rem;
  justify-content: flex-end;
  line-height: 0.8;
}

/* ========== ここが肝：SPだけフルブリード ========== */
/* フルブリードにしたい「画像の箱」にだけ、この修飾クラスを付ける */

.p-design-02__sousa-ttl {
  align-items: center;
  border: 0.0625rem solid #71a8a1;
  display: flex;
  font-weight: 900;
  justify-content: center;
  margin-bottom: 0.9375rem;
  margin-top: 1.875rem;
  padding: 0.625rem;
  position: relative;
}

.p-design-02__sousa-ttl::after {
  -webkit-transform: translateX(-50%) rotate(45deg);
  background-color: #fff;
  border-bottom: 0.0625rem solid #71a8a1;
  border-right: 0.0625rem solid #71a8a1;
  bottom: -0.375rem;
  content: "";
  display: block;
  height: 0.75rem;
  left: 50%;
  position: absolute;
  transform: translateX(-50%) rotate(45deg);
  width: 0.75rem;
  z-index: 1;
}

.p-design-02__main {
  align-items: center;
  display: flex;
  gap: 3.125rem;
  justify-content: space-between;
  padding-top: 2.5rem;
}

.p-design-02__main-img {
  flex-shrink: 0;
  max-width: 22.6875rem;
  width: 100%;
}

.p-design-02__main-img svg {
  height: 100%;
  width: 100%;
}

.p-design-02__main-content {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  max-width: 26.625rem;
  width: 100%;
}

.p-design-02__select-tag {
  background-color: #71a8a1;
  color: #fff;
  letter-spacing: 0.06em;
  line-height: 1;
  padding: 0.25rem 0.625rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.p-design-02__select-box {
  border: 0.0625rem solid #d5d5d5;
  padding: 1.25rem 1rem;
}

.p-design-02__select-head {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.p-design-02__select-ttl {
  letter-spacing: 0.06em;
  line-height: 1.4;
}

.p-design-02__style-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem;
  margin-top: 1rem;
}

.p-design-02__style-item {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  max-width: 7.5rem;
  padding-bottom: 0.625rem;
  width: 100%;
}

.p-design-02__style-img {
  padding: 0.3125rem 0.375rem;
  width: 100%;
}

.p-design-02__style-name {
  font-family: "Zen Kaku Gothic Antique", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", "Yu Gothic Medium", "Noto Sans JP", sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.1;
}

.p-design-02__style-desc {
  font-family: "Zen Kaku Gothic Antique", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", "Yu Gothic Medium", "Noto Sans JP", sans-serif;
  font-size: 0.625rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1.4;
  text-align: center;
}

.p-design-02__color-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem;
  margin-top: 1rem;
}

.p-design-02__color-item {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  max-width: 5.625rem;
  padding: 0.625rem;
  width: 100%;
}

.p-design-02__style-item:hover,
.p-design-02__color-item:hover {
  background-color: #f0f0f0;
  cursor: pointer;
}

/* クリックで色がつく用 */
.p-design-02__style-item.is-active,
.p-design-02__color-item.is-active {
  background-color: #f0f0f0;
}

.p-design-02__color-circle {
  border-radius: 50%;
  height: 1.5rem;
  width: 1.5rem;
}

.p-design-02__color-name {
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.625rem;
  font-weight: 400;
  line-height: 1.2;
}

.p-design-02__bottom-list {
  display: flex;
  gap: 0.625rem;
  padding-top: 2.5rem;
}

.p-design-02__bottom-item {
  max-width: 7.75rem;
  width: 100%;
}

.p-design-02__main-img svg {
  display: none;
}

.p-design-02__main-img svg.is-active {
  display: block;
}

.box-roof .item01 {
  background-image: url("../img/design_02_sample_box-roof-white.png");
}
.box-roof .item02 {
  background-image: url("../img/design_02_sample_box-roof-beige.png");
}
.box-roof .item03 {
  background-image: url("../img/design_02_sample_box-roof-gray.png");
}
.box-roof .item04 {
  background-image: url("../img/design_02_sample_box-roof-black.png");
}

.box-wall .item01 {
  background-image: url("../img/design_02_sample_box-wall-orange.png");
}
.box-wall .item02 {
  background-image: url("../img/design_02_sample_box-wall-brown.png");
}
.box-wall .item03 {
  background-image: url("../img/design_02_sample_box-wall-dark-brown.png");
}
.box-wall .item04 {
  background-image: url("../img/design_02_sample_box-wall-gray.png");
}

.gate-wall .item01 {
  background-image: url("../img/design_02_sample_gate-wall-white.png");
}
.gate-wall .item02 {
  background-image: url("../img/design_02_sample_gate-wall-gray.png");
}
.gate-wall .item03 {
  background-image: url("../img/design_02_sample_gate-wall-blue.png");
}
.gate-wall .item04 {
  background-image: url("../img/design_02_sample_gate-wall-black.png");
}

.gate-entrance .item01 {
  background-image: url("../img/design_02_sample_gate-en-green.png");
}
.gate-entrance .item02 {
  background-image: url("../img/design_02_sample_gate-en-orange.png");
}
.gate-entrance .item03 {
  background-image: url("../img/design_02_sample_gate-en-brown.png");
}
.gate-entrance .item04 {
  background-image: url("../img/design_02_sample_gate-en-black.png");
}

.pencil-wall .item01 {
  background-image: url("../img/design_02_sample_pencil-wall-white.png");
}
.pencil-wall .item02 {
  background-image: url("../img/design_02_sample_pencil-wall-beige.png");
}
.pencil-wall .item03 {
  background-image: url("../img/design_02_sample_pencil-wall-brown.png");
}
.pencil-wall .item04 {
  background-image: url("../img/design_02_sample_pencil-wall-blue.png");
}
.pencil-wall .item05 {
  background-image: url("../img/design_02_sample_pencil-wall-black.png");
}

.pencil-entrance .item01 {
  background-image: url("../img/design_02_sample_pencil-en-white.png");
}
.pencil-entrance .item02 {
  background-image: url("../img/design_02_sample_pencil-en-beige.png");
}
.pencil-entrance .item03 {
  background-image: url("../img/design_02_sample_pencil-en-brown.png");
}
.pencil-entrance .item04 {
  background-image: url("../img/design_02_sample_pencil-en-gray.png");
}
.pencil-entrance .item05 {
  background-image: url("../img/design_02_sample_pencil-en-blue.png");
}
.pencil-entrance .item06 {
  background-image: url("../img/design_02_sample_pencil-en-black.png");
}

.cube-wall .item01 {
  background-image: url("../img/design_02_sample_cube-wall-white.png");
}
.cube-wall .item02 {
  background-image: url("../img/design_02_sample_cube-wall-gray.png");
}
.cube-wall .item03 {
  background-image: url("../img/design_02_sample_cube-wall-blue.png");
}
.cube-wall .item04 {
  background-image: url("../img/design_02_sample_cube-wall-black.png");
}

.cube-entrance .item01 {
  background-image: url("../img/design_02_sample_cube-en-green.png");
}
.cube-entrance .item02 {
  background-image: url("../img/design_02_sample_cube-en-orange.png");
}
.cube-entrance .item03 {
  background-image: url("../img/design_02_sample_cube-en-brown.png");
}
.cube-entrance .item04 {
  background-image: url("../img/design_02_sample_cube-en-black.png");
}

.flat-wall .item01 {
  background-image: url("../img/design_02_sample_flat-wall-fukasumi.png");
}
.flat-wall .item02 {
  background-image: url("../img/design_02_sample_flat-wall-asasumi.png");
}

.flat-entrance .item01 {
  background-image: url("../img/design_02_sample_flat-en-white.png");
}
.flat-entrance .item02 {
  background-image: url("../img/design_02_sample_flat-en-silver.png");
}
.flat-entrance .item03 {
  background-image: url("../img/design_02_sample_flat-en-ivory.png");
}
.flat-entrance .item04 {
  background-image: url("../img/design_02_sample_flat-en-black.png");
}

.court-wall .item01 {
  background-image: url("../img/design_02_sample_court-wall-white.png");
}
.court-wall .item02 {
  background-image: url("../img/design_02_sample_court-wall-gray.png");
}
.court-wall .item03 {
  background-image: url("../img/design_02_sample_court-wall-beige.png");
}
.court-wall .item04 {
  background-image: url("../img/design_02_sample_court-wall-black.png");
}

.court-accent .item01 {
  background-image: url("../img/design_02_sample_court-accent-white.png");
}
.court-accent .item02 {
  background-image: url("../img/design_02_sample_court-accent-beige.png");
}
.court-accent .item03 {
  background-image: url("../img/design_02_sample_court-accent-light-brown.png");
}
.court-accent .item04 {
  background-image: url("../img/design_02_sample_court-accent-smoke.png");
}
.court-accent .item05 {
  background-image: url("../img/design_02_sample_court-accent-black.png");
}

.js-court-svg .court-wall-top {
  box-shadow: 4px 4px;
}

.p-design-03 {
  background: transparent;
  background-color: #f6f6f6;
  box-shadow: 0 0 0 100vmax #f6f6f6;
  clip-path: inset(0 -100vmax);
}

.p-design-03__slider {
  padding-top: 1.25rem;
}

.p-design-03__main {
  margin-inline: auto;
  max-width: 52.5rem;
  width: 100%;
}

.p-design-03__main-img {
  display: block;
  height: auto;
  width: 100%;
}

.p-design-03__main-txt {
  color: #333;
  font-size: 0.8125rem;
  letter-spacing: 0.06em;
  line-height: 1.8;
  padding-top: 1.25rem;
}

.p-design-03__thumb {
  margin-inline: auto;
  max-width: 52.5rem;
  padding-top: 1.25rem;
  width: 100%;
}

.p-design-03__thumb .swiper {
  max-width: 52.5rem;
  width: 100%;
}

.p-design-03__thumb-img {
  cursor: pointer;
  display: block;
  height: auto;
  width: 100%;
}

.p-design-03__thumb .swiper-slide {
  flex-shrink: 0;
  height: auto;
  transition: opacity 0.3s;
  width: 9.625rem;
}

.p-design-03__thumb .swiper-slide-thumb-active {
  opacity: 0.5;
}

.p-design-04__plan-ttl-box {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  padding-top: 3.125rem;
}

.p-design-04__plan-ttl {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: 0.625rem;
  justify-content: center;
  padding-block: 2.25rem;
  position: relative;
}

.p-design-04__plan-ttl-ja {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.2em;
  position: relative;
  z-index: 1;
}

.p-design-04__plan-ttl-en {
  -webkit-transform: translateX(-50%);
  color: #f6f6f6;
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 7.5rem;
  font-weight: 500;
  left: 50%;
  letter-spacing: 0.06em;
  line-height: 1em;
  position: absolute;
  top: -0.35125rem;
  transform: translateX(-50%);
  white-space: nowrap;
  z-index: 0;
}

.p-design-04__slider {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 5rem;
  padding-top: 2.5rem;
  width: 100%;
}

.p-design-04__slider .swiper {
  position: relative;
  width: 100%;
}

.p-design-04__item {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
}

.p-design-04__ttl {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: 0.625rem;
}

.p-design-04__ttl-img {
  display: block;
  height: auto;
  width: 15rem;
}

.p-design-04__ttl-txt {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.p-design-04__ttl-name {
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.4;
}

.p-design-04__ttl-area,
.p-design-04__ttl-room {
  font-size: 1rem;
  line-height: 1.6;
}

.p-design-04__ttl-price {
  align-items: flex-end;
  display: flex;
  flex-direction: row;
  gap: 0.25rem;
  justify-content: center;
  padding-top: 0.125rem;
}

.p-design-04__ttl-price-label,
.p-design-04__ttl-price-unit {
  font-size: 1rem;
  letter-spacing: 0.06em;
  line-height: 1.6;
}

.p-design-04__ttl-price-num {
  color: #2c3e50;
  font-family: "DIN Alternate", sans-serif;
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 0.92;
}

.p-design-04__ttl-price-comma {
  font-size: 1.375rem;
  letter-spacing: 0;
  margin-right: -0.8125rem;
}

.p-design-04__img-flex {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: 1.875rem;
  justify-content: center;
  padding-top: 3.125rem;
  width: 49.875rem;
}

.p-design-04__img-item {
  align-items: center;
  display: flex;
  flex-direction: column;
  position: relative;
}

.p-design-04__img--flat {
  display: block;
  height: auto;
  max-width: 25rem;
  width: 100%;
}

.p-design-04__img {
  display: block;
  height: auto;
  width: 22.5rem;
}

.p-design-04__slider .swiper-btn-prev,
.p-design-04__slider .swiper-btn-next {
  background: transparent;
  border: none;
  cursor: pointer;
  display: block;
  height: 1.9375rem;
  margin-top: -0.96875rem;
  padding: 0;
  position: absolute;
  top: 11.52375rem;
  width: 0.8125rem;
  z-index: 10;
}

.p-design-04__slider .swiper-btn-prev {
  left: -0.0625rem;
}

.p-design-04__slider .swiper-btn-next {
  right: -0.0625rem;
}

.p-design-04__slider .swiper-btn-prev img {
  -webkit-transform: scaleX(-1);
  transform: scaleX(-1);
}

.p-design-04__slider .swiper-btn-prev img,
.p-design-04__slider .swiper-btn-next img {
  pointer-events: none;
}

.p-design-04__slider .swiper-btn-prev:after,
.p-design-04__slider .swiper-btn-next:after {
  display: none;
}

.p-design-04__slider .swiper-pagination {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: 0.5rem;
  justify-content: center;
  margin-top: 1.875rem;
  position: relative;
}

.p-design-04__slider .swiper-pagination-bullet {
  background-color: #d5d5d5;
  border-radius: 50%;
  height: 0.546875rem;
  opacity: 1;
  width: 0.546875rem;
}

.p-design-04__slider .swiper-pagination-bullet-active {
  background-color: #333;
}

.p-design-04__pay {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding-top: 1.875rem;
}

.p-design-04__pay-tbl {
  border-collapse: collapse;
  width: 60%;
}

.p-design-04__pay-th {
  border: 0.03125rem solid #333;
  display: table-cell;
  padding: 0.375rem 0.875rem;
  vertical-align: middle;
  width: clamp(7.5rem, -5rem + 62.5vw, 10.625rem);
}

.p-design-04__pay-td {
  border: 0.03125rem solid #333;
  display: table-cell;
  padding: 0.375rem 0.75rem;
  vertical-align: top;
}

.p-design-04__pay-txt {
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.p-design-04__pay-sub {
  font-size: 0.75rem;
  line-height: 1.6;
}

.p-design-04__pay-note {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.p-design-04__pay-note-sec {
  display: flex;
  flex-direction: column;
  gap: 0.3125rem;
}

.p-design-04__pay-note-ttl {
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.p-design-04__pay-note-txt {
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.p-design-04__pay-note-caution {
  display: flex;
  flex-direction: column;
  gap: 0.3125rem;
  padding-top: 0.625rem;
}

.p-design-04__pay-note-caution-item {
  color: #848484;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.p-design-04__base {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding-top: 1.875rem;
}

.p-design-04__base-list {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(5, 1fr);
}

.p-design-04__base-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.p-design-04__base-img {
  display: block;
  height: auto;
  width: 9.5rem;
}

.p-design-04__base-txt {
  display: flex;
  flex-direction: column;
}

.p-design-04__base-ttl {
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.6;
  text-align: center;
}

.p-design-04__base-desc {
  font-size: 0.8125rem;
  letter-spacing: 0.06em;
  line-height: 1.6;
  text-align: center;
}

.p-design-05__list {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding-top: 3.125rem;
}

.p-design-05__item {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.p-design-05__img-box {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding-top: 1.875rem;
}

.p-design-05__img-txt {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
}

.p-design-05__img-txt-content {
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.6em;
}

.p-design-05__qa-list {
  border: 1px solid #d5d5d5;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
  padding: 1.25rem;
}

.p-design-05__qa-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.p-design-05__qa-q {
  display: flex;
  flex-direction: row;
  gap: 1rem;
}

.p-design-05__qa-a {
  display: flex;
  flex-direction: row;
  gap: 1rem;
}

.p-design-05__qa-label {
  color: #2a686f;
  font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1.6em;
}

.p-design-05__qa-a .p-design-05__qa-label {
  color: #f27d27;
}

.p-design-05__qa-ttl {
  font-size: 0.9375rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 2em;
}

.p-design-05__qa-txt {
  letter-spacing: 0.06em;
  line-height: 2em;
}

.p-features__column {
  display: flex;
  flex-direction: column;
  gap: 3.75rem;
}

.p-features__list {
  display: flex;
  flex-direction: column;
  gap: 5rem;
  list-style: none;
  margin-top: 3.75rem;
}

.p-features__item {
  display: flex;
  gap: 0.625rem;
  justify-content: space-between;
}

.p-features__item:nth-child(even) {
  flex-direction: row-reverse;
}

.p-features__txt {
  display: flex;
  flex: 0 1 auto;
  flex-direction: column;
  max-width: 33.75rem;
  width: 100%;
}

.p-features__ttl {
  align-items: center;
  display: flex;
  gap: 3.125rem;
  position: relative;
}

.p-features__num {
  font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: 5.25rem;
  font-weight: 400;
  line-height: 0.9;
  position: relative;
}

.p-features__num::after {
  -webkit-transform: translateY(-50%) rotate(20deg);
  background-color: #919191;
  content: "";
  height: 4.1375rem;
  position: absolute;
  right: -1.5rem;
  top: 50%;
  transform: translateY(-50%) rotate(20deg);
  width: 0.0625rem;
}

.p-features__ttl-txt {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1.3;
}

.p-features__desc {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding-top: 1.625rem;
}

.p-features__desc-lead {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.8;
}

.p-features__desc-txt {
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 2;
}

.p-features__btn {
  padding-top: 2.5rem;
}

.p-features__img {
  flex: 0 0 36.25rem;
  height: 27.5rem;
  width: 36.25rem;
}

.p-features__img img {
  -o-object-fit: contain;
  height: 100%;
  object-fit: contain;
  width: 100%;
}

.p-fv {
  height: 100vh;
  overflow: hidden;
  position: relative;
  width: 100%;
}

.p-fv__bg {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.p-fv__video {
  -webkit-transform: translate(-50%, -50%);
  -o-object-fit: cover;
  height: auto;
  left: 50%;
  min-height: 100%;
  min-width: 100%;
  object-fit: cover;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  vertical-align: bottom;
  width: auto;
}

.p-fv__overlay {
  background-color: rgba(0, 0, 0, 0.2);
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.p-fv__content {
  align-items: center;
  display: flex;
  flex-direction: column;
  height: auto;
  inset: 0;
  justify-content: center;
  position: absolute;
  z-index: 2;
}

.p-fv__main-text {
  align-items: flex-start;
  display: flex;
  gap: 5rem;
  justify-content: space-between;
  max-width: 45rem;
  width: 100%;
}

.p-fv__catch {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.p-fv__catch-text {
  color: #fff;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
  text-shadow: 0px 0px 30px rgba(0, 0, 0, 0.2);
}

.p-fv__logo {
  -webkit-filter: drop-shadow(0px 0px 30px rgba(0, 0, 0, 0.2));
  filter: drop-shadow(0px 0px 30px rgba(0, 0, 0, 0.2));
  height: auto;
  width: 7.5rem;
}

.p-fv__lead {
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.8;
  text-shadow: 0px 0px 30px rgba(0, 0, 0, 0.2);
}

.p-fv__scroll {
  -webkit-transform: translateX(-50%);
  align-items: center;
  bottom: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
}

.p-fv__scroll-text {
  color: #fff;
  font-family: "Raleway", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 1.174;
}

.p-fv__scroll-line {
  background-color: #fff;
  display: block;
  height: 4.375rem;
  width: 0.0625rem;
}

.p-gallery-01 {
  --aside: 240px;
  --gap: clamp(-120px, calc(15.625vw - 240px), -40px);
  --vw: 100vw;
  isolation: isolate;
  position: relative;
  z-index: 5;
}

.p-gallery-01__slider {
  background: #fff;
  margin-left: calc((var(--vw) - 100%) / -2 - (var(--aside) + var(--gap)));
  margin-top: 3.125rem;
  overflow: hidden;
  width: var(--vw);
}

.p-gallery-01__slider-top {
  overflow: hidden;
  width: 100%;
}

.p-gallery-01__slider-bottom {
  overflow: hidden;
  width: 100%;
}

.js-p-gallery-01__swiper-top {
  overflow: visible;
  width: 100%;
}

.js-p-gallery-01__swiper-bottom {
  overflow: visible;
  padding-top: 0.5rem;
  width: 100%;
}

.js-p-gallery-01__swiper-top .swiper-slide {
  height: auto;
  width: auto;
}

.js-p-gallery-01__swiper-bottom .swiper-slide {
  height: auto;
  width: auto;
}

.js-p-gallery-01__swiper-top .swiper-slide img {
  -o-object-fit: cover;
  display: block;
  height: clamp(8.75rem, 0.07rem + 43.4vw, 20.875rem);
  object-fit: cover;
  width: auto;
}

.js-p-gallery-01__swiper-bottom .swiper-slide img {
  -o-object-fit: cover;
  display: block;
  height: clamp(8.75rem, 0.07rem + 43.4vw, 20.875rem);
  object-fit: cover;
  width: auto;
}

.p-gallery-01__popup {
  padding-top: 5rem;
}

.p-gallery-01-popup__list {
  align-self: stretch;
  display: flex;
  flex-wrap: wrap;
  gap: 0rem;
  justify-content: space-between;
}

.p-gallery-01-popup__item {
  display: flex;
  flex-direction: column;
  gap: 0.70625rem;
  margin-bottom: 2.25rem;
  width: 25rem;
}

.p-gallery-01-popup__img {
  height: auto;
  overflow: hidden;
  width: 100%;
}
.p-gallery-01-popup__img img {
  -o-object-fit: cover;
  display: block;
  height: auto;
  object-fit: cover;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  width: 100%;
}

.p-gallery-01-popup__item:hover .p-gallery-01-popup__img img {
  -webkit-transform: scale(1.02);
  transform: scale(1.02);
}

.p-gallery-01-popup__txt {
  font-size: clamp(0.938rem, 0.848rem + 0.45vw, 1.063rem);
  letter-spacing: 0.06em;
  line-height: 1.5;
  width: 100%;
}

.p-gallery-01-popup__item {
  cursor: pointer;
}

.p-gallery-01-modal {
  display: none;
  height: 100%;
  left: 0;
  opacity: 0;
  position: fixed;
  top: 0;
  transition: opacity 0.3s ease;
  width: 100%;
  z-index: 101;
}
.p-gallery-01-modal.is-open {
  display: block;
  opacity: 1;
}

.p-gallery-01-modal__overlay {
  background-color: rgba(0, 0, 0, 0.9);
  cursor: pointer;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.p-gallery-01-modal__content {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  height: 100%;
  justify-content: center;
  padding: 3.75rem 5rem;
  pointer-events: none;
  position: relative;
  width: 100%;
  z-index: 2;
}
.p-gallery-01-modal__content button,
.p-gallery-01-modal__content img,
.p-gallery-01-modal__content p {
  pointer-events: auto;
}

.p-gallery-01-modal__img-wrap {
  align-items: center;
  display: flex;
  justify-content: center;
  max-height: 90vh;
  max-width: 90vw;
  position: relative;
}

.p-gallery-01-modal__img {
  -o-object-fit: contain;
  display: block;
  height: auto;
  max-height: 90vh;
  max-width: 90%;
  object-fit: contain;
  width: auto;
}

.p-gallery-01-modal__close {
  align-items: center;
  background-color: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  height: 3.125rem;
  justify-content: center;
  position: absolute;
  right: 1.875rem;
  top: 1.875rem;
  transition: opacity 0.3s ease;
  width: 3.125rem;
  z-index: 10;
}
.p-gallery-01-modal__close:hover {
  opacity: 0.7;
}

.p-gallery-01-modal__close-icon {
  display: block;
  height: 1.875rem;
  position: relative;
  width: 1.875rem;
}
.p-gallery-01-modal__close-icon::before, .p-gallery-01-modal__close-icon::after {
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
  background-color: #fff;
  content: "";
  height: 1.875rem;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  width: 0.125rem;
}
.p-gallery-01-modal__close-icon::after {
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
  transform: translate(-50%, -50%) rotate(-45deg);
}

.p-gallery-01-modal__prev,
.p-gallery-01-modal__next {
  -webkit-transform: translateY(-50%);
  align-items: center;
  background-color: rgba(255, 255, 255, 0.2);
  border: 0.125rem solid #fff;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  height: 3.75rem;
  justify-content: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: background-color 0.3s ease, opacity 0.3s ease;
  width: 3.75rem;
  z-index: 10;
}
.p-gallery-01-modal__prev:hover,
.p-gallery-01-modal__next:hover {
  background-color: rgba(255, 255, 255, 0.3);
}

.p-gallery-01-modal__prev {
  left: 1.875rem;
}

.p-gallery-01-modal__next {
  right: 1.875rem;
}

.p-gallery-01-modal__arrow-icon {
  border-right: 0.125rem solid #fff;
  border-top: 0.125rem solid #fff;
  display: block;
  height: 1.25rem;
  width: 1.25rem;
}

.p-gallery-01-modal__arrow-icon--prev {
  -webkit-transform: rotate(-135deg) translateX(-0.25rem) translateY(0.1875rem);
  transform: rotate(-135deg) translateX(-0.25rem) translateY(0.1875rem);
}

.p-gallery-01-modal__arrow-icon--next {
  -webkit-transform: rotate(45deg) translateX(-0.25rem) translateY(0.1875rem);
  transform: rotate(45deg) translateX(-0.25rem) translateY(0.1875rem);
}

.p-gallery-01-modal__description {
  color: #fff;
  font-size: 1rem;
  letter-spacing: 0.06em;
  line-height: 1.75;
  max-width: 50rem;
  padding-inline: 1.25rem;
  text-align: center;
  white-space: pre-line;
}

.js-p-gallery-01__swiper-bottom {
  -webkit-transform: scaleX(-1);
  transform: scaleX(-1);
}

.js-p-gallery-01__swiper-bottom .swiper-slide {
  -webkit-transform: scaleX(-1);
  transform: scaleX(-1);
}

.p-gallery-02 {
  background: transparent;
  background-color: #f6f6f6;
  box-shadow: 0 0 0 100vmax #f6f6f6;
  clip-path: inset(0 -100vmax);
}

.p-gallery-02__list {
  display: flex;
  flex-wrap: wrap;
  gap: 1.875rem;
  padding-top: 3.125rem;
}

.p-gallery-02__item {
  width: 25.3125rem;
}

.p-gallery-02__placeholder {
  width: 100%;
}

.l-page-sec {
  overflow-x: clip;
}

.p-gallery-house__img {
  padding-top: 1.875rem;
  width: 100%;
}

.p-gallery-house__img img {
  display: block;
  height: auto;
  width: 100%;
}

.p-gallery-house__ttl-box {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  padding-top: 1.25rem;
}

.p-gallery-house__ttl {
  color: #333;
  font-family: "Zen Kaku Gothic Antique", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", "Yu Gothic Medium", "Noto Sans JP", sans-serif;
  font-size: 1.375rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.6;
  text-align: center;
}

.p-gallery-house__note {
  color: #333;
  font-family: "Zen Kaku Gothic Antique", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", "Yu Gothic Medium", "Noto Sans JP", sans-serif;
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 2;
  text-align: center;
}

.p-gallery-house__btn-box {
  align-items: center;
  display: flex;
  flex-direction: column;
  padding-top: 1.25rem;
}

.p-gallery-house__btn {
  align-items: center;
  background-color: #e59c58;
  display: flex;
  gap: 1.25rem;
  justify-content: center;
  padding: 0.875rem 2.5rem;
  text-decoration: none;
  transition: opacity 0.3s;
}
.p-gallery-house__btn:hover {
  opacity: 0.8;
}

.p-gallery-house__btn-txt {
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  white-space: nowrap;
}

.p-gallery-house__list {
  align-items: stretch;
  display: flex;
  flex-wrap: wrap;
  margin-top: 4.375rem;
}

.p-gallery-house__item-label {
  align-items: center;
  border-bottom: 2px solid #e5ae7a;
  display: flex;
  font-weight: 700;
  padding: 1.5rem 0;
  width: 11.25rem;
}

.p-gallery-house__item-content {
  border-bottom: 2px solid #d5d5d5;
  padding: 1.5rem 0;
  width: calc(100% - 11.25rem);
}

.p-gallery-house__item-content img {
  width: 6.25rem;
}

.p-gallery-house__item-content--type {
  align-items: center;
  display: flex;
  gap: 1.25rem;
}

.p-gallery-house__item-txt--midokoro {
  margin-top: 1rem;
}

.p-gallery-house__map {
  padding-top: 2.5rem;
}

.p-gallery-house__more-btn-box {
  display: none;
  flex-direction: column;
  gap: 0.625rem;
  padding-top: 1.25rem;
}

.p-gallery-house__map iframe {
  height: 21.4375rem;
  width: 100%;
}

.p-gallery-house--anjo {
  margin-top: 2.5rem;
}

.p-gallery-house--anjo .p-gallery-house__btn {
  background-color: #2a686f;
}

.p-gallery-house--anjo .p-gallery-house__item-label {
  border-bottom: 2px solid #2a686f;
}

.p-gallery {
  background-color: #f6f6f6;
}

.p-gallery__sec {
  align-items: center;
  display: flex;
  flex-direction: column;
  width: 100%;
}

.p-gallery__column {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.p-gallery__txt {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding-top: 2.5rem;
}

.p-gallery__desc {
  text-align: center;
}

.p-gallery__slider {
  overflow: hidden;
  padding-top: 3.125rem;
  width: 100%;
}

.p-gallery__swiper {
  overflow: visible;
  width: 100%;
}

.p-gallery__slide {
  flex: 0 0 auto;
  height: 18.4375rem;
  margin-right: 1.75rem;
  width: 26.734375rem;
}
.p-gallery__slide img {
  -o-object-fit: cover;
  object-fit: cover;
}

.p-gallery__btn {
  display: flex;
  justify-content: center;
  margin-top: 4.125rem;
}

.p-menu {
  background-color: #fff;
  height: 100vh;
  left: 0;
  opacity: 0;
  overflow-y: auto;
  position: fixed;
  top: 0;
  transition: opacity 0.3s, visibility 0.3s;
  visibility: hidden;
  width: 100%;
  z-index: 9999;
}

.p-menu__header {
  background-color: #fff;
  padding: 1.875rem 2.5rem;
  width: 100%;
}

.p-menu__header-inner {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.p-menu__header-logo a {
  display: block;
}

.p-menu__header-logo img {
  display: block;
  height: auto;
  width: 7.5rem;
}

.p-menu__header-close {
  cursor: pointer;
}

.p-menu__header-close img {
  display: block;
  height: auto;
  width: 3.8125rem;
}

.p-menu.is-open {
  opacity: 1;
  visibility: visible;
}

.p-menu__inner {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 4.375rem;
  justify-content: center;
  margin-inline: auto;
  max-width: 90rem;
  min-height: calc(95vh - 6.25rem);
  padding-bottom: 1.875rem;
  width: 100%;
}

.p-menu__catch {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
  max-width: 87.5rem;
  padding-inline: 1.5625rem;
  width: 100%;
}

.p-menu__catch-txt {
  color: #333;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1;
}

.p-menu__logo {
  height: 1.5625rem;
  width: 7.5rem;
}

.p-menu__logo img {
  height: 100%;
  width: 100%;
}

.p-menu__content {
  display: flex;
  flex-direction: row;
  gap: 1.875rem;
  justify-content: space-between;
  max-width: 87.5rem;
  padding-inline: 1.5625rem;
  width: 100%;
}

.p-menu__nav {
  display: flex;
  flex-direction: row;
  gap: 2.5rem;
}

.p-menu__nav-item {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.p-menu__nav-head {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-decoration: none;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.p-menu__nav-en {
  color: #333;
  font-family: "Raleway", sans-serif;
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.p-menu__nav-ttl {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: 0.5rem;
  padding-bottom: 0.25rem;
}

.p-menu__nav-line {
  background-color: #333;
  flex-shrink: 0;
  height: 0.0625rem;
  width: 0.875rem;
}

.p-menu__nav-ja {
  color: #333;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.8;
}

.p-menu__nav-list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.p-menu__nav-list-item {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.p-menu__nav-list-item--indent {
  padding-left: 1.3125rem;
}

.p-menu__nav-list-link {
  display: flex;
  flex-direction: row;
  gap: 0.5rem;
  text-decoration: none;
}

.p-menu__nav-list-num {
  color: #333;
  font-family: "Open Sans", sans-serif;
  font-size: 0.8125rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 1.95;
}

.p-menu__nav-list-txt {
  color: #333;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.p-menu__nav-list-item--indent .p-menu__nav-list-txt::before {
  -webkit-margin-end: 0.5rem;
  background-color: #333;
  content: "";
  display: inline-block;
  height: 0.0625rem;
  margin-inline-end: 0.5rem;
  vertical-align: middle;
  width: 0.875rem;
}

.p-menu__nav-list-item--last .p-menu__nav-list-txt {
  color: #333;
}

.c-btn-fixed--menu {
  display: flex;
  flex-direction: row;
  gap: 0;
  height: 5rem;
  position: static;
}

.p-modal {
  background: rgba(255, 255, 255, 0.7);
  display: none;
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 100;
}

.p-modal__block {
  -webkit-transform: translate(-50%, -50%);
  background-color: #feaebb;
  border-radius: 0.625rem;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 27.5rem;
}

.p-modal__wrap {
  padding: 3.75rem 0 2.5rem;
  position: relative;
}

.p-modelhouse__column {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.p-modelhouse__ttl {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.p-modelhouse__ttl-sub {
  color: #919191;
  letter-spacing: 0.06em;
  line-height: 1.5;
  text-align: center;
}

.p-modelhouse__ttl-main {
  color: #333;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 2.25rem;
  letter-spacing: 0.06em;
  line-height: 1.1;
  text-align: center;
}

.p-modelhouse__list {
  align-items: flex-start;
  display: flex;
  gap: 3.75rem;
  justify-content: center;
  padding-top: 3.125rem;
}

.p-modelhouse__item {
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: 1.125rem;
  justify-content: center;
  max-width: 27.375rem;
  text-decoration: none;
  width: 100%;
}

.p-modelhouse__img {
  aspect-ratio: 1/1;
  overflow: hidden;
  width: 100%;
}

.p-modelhouse__img img {
  -o-object-fit: cover;
  object-fit: cover;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

.p-modelhouse__item:hover {
  opacity: 1;
}

.p-modelhouse__item:hover .p-modelhouse__img img {
  -webkit-transform: scale(1.02);
  transform: scale(1.02);
}

.p-modelhouse__txt {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.p-modelhouse__txt-ttl {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
}

.p-modelhouse__txt-tag {
  color: #919191;
  line-height: 1.7;
}

.p-modelhouse__no-post {
  color: #919191;
  padding-block: 2.5rem;
  text-align: center;
  width: 100%;
}

.p-movie {
  background-color: #f6f6f6;
}

.p-movie__column {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.p-movie__video {
  margin-top: clamp(1.25rem, -1.142rem + 10.2vw, 3.75rem);
  max-width: 46.875rem;
  width: 100%;
}

.p-movie__btn {
  margin-top: clamp(1.25rem, -0.424rem + 7.14vw, 3rem);
}

.p-pageTop {
  bottom: 1.875rem;
  cursor: pointer;
  position: fixed;
  right: 1.875rem;
  z-index: 50;
}

.p-pageTop__wrap {
  position: relative;
}

.p-pageTop__wrap img {
  width: 3.125rem;
}

.p-pageTop__wrap img:nth-of-type(2) {
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  transition: 0.5s opacity;
}
.p-privacy {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 3.125rem;
  padding-top: 3.125rem;
}

.p-privacy__item {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.p-privacy__main-ttl {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1.2;
}

.p-privacy__box {
  align-items: center;
  border: 0.0625rem solid #333;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin-top: 2.5rem;
  max-width: 62.5rem;
  padding-block: 3.75rem;
  padding-inline: 3.75rem;
  width: 100%;
}

.p-privacy__box-item {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.p-privacy__box-ttl {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1.2;
  text-align: center;
}

.p-privacy__list-item {
  font-size: 0.9375rem;
  letter-spacing: 0.06em;
  line-height: 2;
  padding-left: 1em;
  text-indent: -1em;
}

.p-privacy .c-under-txt a {
  text-decoration: underline;
}

.p-quality-01__image1 {
  width: 100%;
}

.p-quality-01__image1 img {
  display: block;
  height: auto;
  width: 100%;
}

.p-quality-01__image2 {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-top: 2.5rem;
  padding-top: 1.25rem;
}

.p-quality-01__image2__item:first-child {
  width: 19.375rem;
}

.p-quality-01__image2__item:last-child {
  width: 30rem;
}

.p-quality-02__image {
  align-items: center;
  display: flex;
  gap: 1.25rem;
  justify-content: space-between;
  margin-top: 2.5rem;
  padding-top: 1.25rem;
}

.p-quality-02__image__item:first-child {
  width: 19.375rem;
}

.p-quality-02__image__item:last-child {
  width: 30rem;
}

.p-quality-02__image__item img {
  display: block;
  height: auto;
  width: 100%;
}

.p-quality-03 {
  background: transparent;
  background-color: #f6f6f6;
  box-shadow: 0 0 0 100vmax #f6f6f6;
  clip-path: inset(0 -100vmax);
}

.p-quality-03__content {
  align-items: center;
  display: flex;
  gap: 2.5rem;
}

.p-quality-03__txt-wrap {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
}

.p-quality-03__note {
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  line-height: 2em;
}

.p-quality-03__graph {
  display: flex;
  justify-content: center;
}

.p-quality-03__graph img {
  height: auto;
  max-width: 19.75rem;
  width: 100%;
}

.p-quality-03__movie {
  margin-top: 3.125rem;
  width: 100%;
}

.p-quality-03__txt {
  letter-spacing: 0.06em;
  line-height: 2em;
  margin-top: 1rem;
  text-align: center;
}

.p-quality-03__compare {
  align-items: center;
  display: flex;
  gap: 2.5rem;
  margin-top: 2.5rem;
}

.p-quality-03__compare-item {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 1.1875rem;
  max-width: 23.75rem;
}

.p-quality-03__compare-item img {
  height: auto;
  width: 100%;
}

.p-quality-03__compare-desc {
  font-size: 0.875rem;
  letter-spacing: 0.06em;
  line-height: 1.6em;
  text-align: center;
}

.p-quality-03__compare-icon img {
  height: 3.5rem;
  width: 3.5rem;
}

.p-quality-03__summary {
  color: #333;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.8em;
  margin-top: 1.25rem;
  text-align: center;
}

.p-quality-04__list {
  display: flex;
  flex-direction: column;
  list-style: none;
}

.p-quality-04__item {
  border-bottom: 0.0625rem solid #d5d5d5;
  display: flex;
  flex-direction: column;
  padding-block: 2rem;
}
.p-quality-04__item--large {
  gap: 1.25rem;
}

.p-quality-04__head {
  align-items: center;
  display: flex;
  gap: 1.25rem;
}
.p-quality-04__number {
  color: #d3d3d3;
  flex-shrink: 0;
  font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: 5rem;
  font-weight: 400;
  line-height: 1.2em;
}
.p-quality-04__content {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.p-quality-04__ttl {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.2em;
}
.p-quality-04__ttl-sub {
  display: inline;
}
.p-quality-04__sub {
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.8em;
}
.p-quality-04__body {
  align-items: center;
  display: flex;
  gap: 1rem;
  padding-top: 1.25rem;
}
.p-quality-04__img {
  flex-shrink: 0;
  height: auto;
  width: 10.5625rem;
}

.p-quality-04__txt-wrap {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.p-quality-04__txt {
  letter-spacing: 0.06em;
  line-height: 2em;
}
.p-quality-04__item--medium {
  gap: 0.75rem;
  padding-inline: 1rem;
}
.p-quality-04__medium-head {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.p-quality-04__medium-ttl {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.2em;
}

.p-quality-04__medium-sub {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.8em;
}

.p-quality-04__medium-body {
  align-items: center;
  display: flex;
  gap: 1rem;
}

.p-quality-04__medium-icon {
  flex-shrink: 0;
  height: 5.75rem;
  width: 5.75rem;
}

.p-quality-04__medium-txt {
  letter-spacing: 0.06em;
  line-height: 2em;
}

.p-quality-04__small-wrap {
  display: none;
  list-style: none;
}
.p-quality-04__item-small {
  align-items: center;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  gap: 0.75rem;
  padding-block: 1rem;
}
.p-quality-04__small-content {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.p-quality-04__small-icon {
  flex-shrink: 0;
  height: 3.375rem;
  width: 3.375rem;
}

.p-quality-04__small-ttl {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.5em;
  text-align: center;
}

.p-quality-04__schedule {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding-top: 1.875rem;
}
.p-quality-04__schedule-ttl {
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 2em;
}
.p-quality-04__schedule-wrap {
  -webkit-overflow-scrolling: touch;
  overflow-x: auto;
  position: relative;
}

.p-quality-04__schedule-img {
  min-width: 52.5rem;
}

.p-quality-04__schedule-img img {
  display: block;
  height: auto;
  width: 100%;
}

.p-quality-05__img-sec {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-top: 2.5rem;
}

.p-quality-05__img-box {
  display: flex;
  flex-direction: row;
  gap: 2.5rem;
  justify-content: space-between;
  max-width: 100%;
  width: 52.5rem;
}

.p-quality-05__img-item {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  width: 25rem;
}

.p-quality-05__img-item img {
  height: auto;
  width: 100%;
}

.p-quality-05__total {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
}

.p-quality-05__total-txt {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.8em;
  text-align: center;
}

.p-quality-05__smart-sec {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding-top: 2.5rem;
}

.p-quality-05__smart-head {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
}

.p-quality-05__sarani {
  align-items: center;
  display: flex;
  justify-content: center;
}
.p-quality-05__sarani img {
  height: auto;
  width: 9.3125rem;
}

.p-quality-05__smart-box {
  align-items: center;
  border: 0.0625rem solid #71a8a1;
  display: flex;
  justify-content: center;
  padding: 0.625rem;
}

.p-quality-05__smart-box-txt {
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.6em;
  text-align: center;
}

.p-quality-05__smart-img-sec {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  justify-content: center;
  padding-top: 2.5rem;
}

.p-quality-05__smart-img-box {
  display: flex;
  flex-direction: row;
  gap: 3rem;
  max-width: 100%;
  width: 52.5rem;
}

.p-quality-05__smart-house {
  position: relative;
  width: 24.5rem;
}
.p-quality-05__smart-house img {
  height: auto;
  width: 100%;
}

.p-quality-05__smart-house-note {
  bottom: 0.9375rem;
  color: #fff;
  font-size: 0.625rem;
  line-height: 1.5em;
  position: absolute;
  right: 1.25rem;
}

.p-quality-05__gx-sec {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-top: 2.5rem;
}

.p-quality-05__gx-img {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: 1.25rem;
}
.p-quality-05__gx-img img {
  height: auto;
  max-width: 100%;
  width: 34.5625rem;
}

.p-quality-05__gx-note {
  color: #848484;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
}

.p-quality-06__img {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: 2.25rem;
  padding-top: 1.25rem;
}

.p-quality-06__hyokasho {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.p-quality-06__hyokasho img {
  height: auto;
  width: 11.875rem;
}

.p-quality-06__hyokasho-txt {
  font-size: 0.8125rem;
  letter-spacing: 0.06em;
}

.p-quality-06__gekkeikan {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
  width: 100%;
}

.p-quality-06__list {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  width: 100%;
}

.p-quality-06__item {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.p-quality-06__item-ttl {
  padding-block: 0.5rem;
}

.p-quality-06__item-txt {
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background: linear-gradient(180deg, rgb(194, 136, 36) 24%, rgb(163, 117, 43) 79%);
  background-clip: text;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  line-height: 1.6;
  text-align: center;
}

.p-quality-06__item img {
  height: auto;
  width: 8.5625rem;
}

.p-quality-07__table-wrap {
  -webkit-overflow-scrolling: touch;
  margin-top: 1.25rem;
  overflow-x: auto;
  position: relative;
}

.p-quality-07__table {
  border-collapse: collapse;
  min-width: 40.28375rem;
  width: 100%;
}

.p-quality-07__th {
  background-color: #f6f6f6;
  display: table-cell;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.448em;
  padding-block: 0.75rem;
  padding-inline: 0.5rem;
  text-align: center;
  vertical-align: middle;
}

.p-quality-07__th--empty {
  background-color: #fff;
  min-width: 7.5rem;
}

.p-quality-07__th--primary {
  background-color: #f27d27;
  border-right: 0.0625rem solid #f27d27;
  color: #fff;
  min-width: 13.428125rem;
}

.p-quality-07__th--secondary {
  background-color: #2a686f;
  border-right: 0.0625rem solid #2a686f;
  color: #fff;
  min-width: 13.428125rem;
}

.p-quality-07__th--gray {
  background-color: #999999;
  border-right: none;
  color: #fff;
  min-width: 13.428125rem;
}

.p-quality-07__head-main {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1rem;
  letter-spacing: 0.06em;
  line-height: 1.448em;
}

.p-quality-07__head-sub {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  line-height: 1.448em;
}

.p-quality-07__row-header {
  background-color: #f6f6f6;
  border-bottom: 0.0625rem solid #d5d5d5;
  border-right: 0.0625rem solid #d5d5d5;
  display: table-cell;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.448em;
  min-width: 7.5rem;
  padding-block: 1rem;
  padding-inline: 0.75rem;
  text-align: center;
  vertical-align: middle;
}

.p-quality-07__td {
  border-bottom: 0.0625rem solid #d5d5d5;
  border-right: 0.0625rem solid #d5d5d5;
  display: table-cell;
  min-height: 5.625rem;
  min-width: 13.428125rem;
  padding-block: 0.75rem;
  padding-inline: 0.5rem;
  text-align: center;
  vertical-align: middle;
}

.p-quality-07__td--primary {
  border-right: 0.0625rem solid #f27d27;
  color: #f27d27;
}

.p-quality-07__td--secondary {
  border-right: 0.0625rem solid #2a686f;
  color: #2a686f;
}

.p-quality-07__cell-content {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.p-quality-07__cell-icon {
  flex-shrink: 0;
  height: 2.019375rem;
  width: 2.019375rem;
}

.p-quality-07__cell-txt {
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1.4em;
}

.p-quality-07__cell-txt--multiline {
  word-wrap: break-word;
  white-space: normal;
}

.p-quality-07__cell-sub {
  font-size: 0.625rem;
  line-height: 1.4em;
}

.p-quality-07__note {
  margin-top: 0.5rem;
}

.p-quality-07__note-txt {
  color: #848484;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
}

.p-single__art {
  max-width: 45.625rem;
  width: 100%;
}

.p-single__art-ttl {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.6;
}

.p-single__free {
  color: #7c7c7c;
  font-size: clamp(0.813rem, 0.633rem + 0.77vw, 1rem);
  line-height: 1.6;
  margin-top: 1rem;
}

.p-single__thumbnail {
  -o-object-fit: cover;
  aspect-ratio: 1/1;
  height: auto;
  margin-top: 1.25rem;
  object-fit: cover;
  width: 100%;
}

.p-single__calender {
  align-self: flex-start;
  max-width: 25rem;
  padding-top: 0.625rem;
  position: sticky;
  top: 0rem;
  width: 100%;
}

.p-single__calendar-ttl {
  font-size: 1.375rem;
  font-weight: 700;
  text-align: center;
}

.p-single__calendar-form {
  height: auto;
  width: 100%;
}

.p-single__calendar-form iframe {
  height: 800px;
  width: 100%;
}

.p-single__content p {
  margin-top: 1rem;
}
.p-single__content .wp-block-embed {
  margin-top: 1.875rem;
}
.p-single__content .wp-block-embed iframe {
  aspect-ratio: 16/9;
  height: auto;
  width: 100%;
}
.p-single__content .wp-block-image {
  margin-top: 1.875rem;
}
.p-single__content .wp-block-buttons .wp-block-button a {
  border-radius: 0.25rem;
  font-weight: 700;
}
.p-single__content .wp-block-gallery {
  margin-top: 1.875rem;
}
.p-single__content iframe {
  height: 18.75rem;
  margin-top: 1.875rem;
  width: 100%;
}
.p-single__content h2 {
  border-bottom: 1px solid #333;
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium", "Meiryo", "Noto Sans JP", "Segoe UI", Arial, sans-serif;
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.6;
  margin-top: 4.25rem;
  padding: 0 0.625rem;
  padding-bottom: 0.625rem;
}
.p-single__content h3 {
  background-color: #f5f5f5;
  font-size: 1.125rem;
  font-weight: 700;
  margin-top: 2.25rem;
  padding: 0 0.625rem;
}
.p-single__content ul {
  margin-top: 1rem;
}
.p-single__content ul li::before {
  content: "・";
  margin-right: 0.625rem;
}
.p-single__content ol {
  counter-reset: number;
  margin-top: 1rem;
}
.p-single__content ol li {
  counter-increment: number;
  margin-top: 0.5rem;
  padding-left: 1.5rem;
  position: relative;
}
.p-single__content ol li::before {
  content: counter(number) ". ";
  font-weight: bold;
  left: 0.3125rem;
  position: absolute;
  top: 0;
}

.calender-yoyaku-box {
  margin-top: 1.875rem;
}

.u-base1 {
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  line-height: 1.2;
}

.u-base2 {
  font-size: 1.125rem;
  letter-spacing: 0.02em;
  line-height: 1.5;
}

.u-flex {
  display: flex;
}

.u-font14 {
  font-size: 0.875rem;
}

.u-font16 {
  font-size: 1rem;
}

.u-font18 {
  font-size: 1.125rem;
}

.u-font20 {
  font-size: 1.25rem;
}

.u-font22 {
  font-size: 1.375rem;
}

.u-font24 {
  font-size: 1.5rem;
}

.u-font28 {
  font-size: 1.75rem;
}

.u-font32 {
  font-size: 2rem;
}

.u-font40 {
  font-size: 2.5rem;
}

.u-hover {
  transition: opacity 0.5s;
}

.u-hover:hover {
  opacity: 0.6;
  transition: opacity 0.5s;
}

.u-lh10 {
  line-height: 1;
}

.u-lh13 {
  line-height: 1.3;
}

.u-lh15 {
  line-height: 1.5;
}

.u-lh16 {
  line-height: 1.6;
}

.u-lh20 {
  line-height: 2;
}

.u-ls05 {
  letter-spacing: 0.05em;
}

.u-ls10 {
  letter-spacing: 0.1em;
}

.u-ls15 {
  letter-spacing: 0.15em;
}

.u-ls20 {
  letter-spacing: 0.2em;
}

.u-mt10 {
  margin-top: 10px !important;
  margin-top: 0.625rem !important;
}

.u-mt20 {
  margin-top: 20px !important;
  margin-top: 1.25rem !important;
}

.u-mt30 {
  margin-top: 30px !important;
  margin-top: 1.875rem !important;
}

.u-mt40 {
  margin-top: 40px !important;
  margin-top: 2.5rem !important;
}

.u-mt50 {
  margin-top: 50px !important;
  margin-top: 3.125rem !important;
}

.u-mt60 {
  margin-top: 60px !important;
  margin-top: 3.75rem !important;
}

.u-mt70 {
  margin-top: 70px !important;
  margin-top: 4.375rem !important;
}

.u-mt80 {
  margin-top: 80px !important;
  margin-top: 5rem !important;
}

.u-mt90 {
  margin-top: 90px !important;
  margin-top: 5.625rem !important;
}

.u-mt100 {
  margin-top: 100px !important;
  margin-top: 6.25rem !important;
}

.u-mt110 {
  margin-top: 110px !important;
  margin-top: 6.875rem !important;
}

.u-mt120 {
  margin-top: 120px !important;
  margin-top: 7.5rem !important;
}

.u-mt130 {
  margin-top: 130px !important;
  margin-top: 8.125rem !important;
}

.u-mt140 {
  margin-top: 140px !important;
  margin-top: 8.75rem !important;
}

.u-mt150 {
  margin-top: 150px !important;
  margin-top: 9.375rem !important;
}

.u-mt160 {
  margin-top: 160px !important;
  margin-top: 10rem !important;
}

.u-mt170 {
  margin-top: 170px !important;
  margin-top: 10.625rem !important;
}

.u-mt180 {
  margin-top: 180px !important;
  margin-top: 11.25rem !important;
}

.u-mt190 {
  margin-top: 190px !important;
  margin-top: 11.875rem !important;
}

.u-mt200 {
  margin-top: 200px !important;
  margin-top: 12.5rem !important;
}

.u-shadow {
  box-shadow: 6px 6px 16px rgba(0, 0, 0, 0.16);
}

.u-sp {
  display: none;
}

.space-xs-pt {
  padding-top: clamp(3.75rem, 1.956rem + 7.65vw, 5.625rem);
}

.space-xs-pt--bottom {
  padding-bottom: clamp(3.75rem, 1.956rem + 7.65vw, 5.625rem);
}

.space-sm-pt {
  padding-top: clamp(5rem, 3.804rem + 5.1vw, 6.25rem);
}

.space-md-pt {
  padding-top: clamp(4.375rem, 1.983rem + 10.2vw, 6.875rem);
}

.space-lg-pt {
  padding-top: clamp(5rem, 2.608rem + 10.2vw, 7.5rem);
}

.space-lg-pt--bottom {
  padding-bottom: clamp(5rem, 2.608rem + 10.2vw, 7.5rem);
}

.space-xl-pt {
  padding-top: clamp(7.5rem, 5.108rem + 10.2vw, 10rem);
}

.space-xxl-pt {
  padding-top: 11.25rem;
}

.space-xs-mt {
  margin-top: clamp(3.75rem, 1.956rem + 7.65vw, 5.625rem);
}

.space-sm-mt {
  margin-top: 6.25rem;
}

.space-md-mt {
  margin-top: 6.875rem;
}

.space-lg-mt {
  margin-top: 7.5rem;
}

.space-xl-mt {
  margin-top: 10rem;
}

.space-xxl-mt {
  margin-top: 11.25rem;
}

.u-w300 {
  font-weight: 300;
}

.u-w400 {
  font-weight: 400;
}

.u-w500 {
  font-weight: 500;
}

.u-w600 {
  font-weight: 600;
}

.u-w700 {
  font-weight: 700;
}

.u-w900 {
  font-weight: 900;
}

@media screen and (min-width: 768px) {
  .c-hoverRun:hover {
    background-size: 100% 1px;
  }
  .c-hoverUnderline:hover::after {
    opacity: 1;
  }
  .c-hoverUnderline:hover::after {
    opacity: 1;
  }
  .c-underBar:hover:before {
    opacity: 0;
    transition: 0.5s all;
  }
  .p-pageTop__wrap:hover img:nth-of-type(1) {
    opacity: 0;
    transition: 0.5s opacity;
  }
  .p-pageTop__wrap:hover img:nth-of-type(2) {
    opacity: 1;
    transition: 0.5s opacity;
  }
}

@media screen and (min-width: 769px) {
  .c-imgHover:hover img:nth-of-type(1) {
    opacity: 0;
    transition: 0.5s opacity;
  }
  .c-imgHover:hover img:nth-of-type(2) {
    opacity: 1;
    transition: 0.5s opacity;
  }
  .c-imgZoom:hover img {
    -webkit-transform: scale(1.2);
    transform: scale(1.2);
    transition: -webkit-transform 0.8s;
    transition: transform 0.8s;
    transition: transform 0.8s, -webkit-transform 0.8s;
  }
}

@media screen and (max-width: 1270px) {
  html {
    font-size: 1.2598425197vw;
  }
}

@media (max-width: 767px) {
  .c-parallax {
    --aside: 0px;
    --gap: 0px;
  }
}

@media screen and (max-width: 767px) {
  html {
    font-size: 16px;
  }
  .l-footer__upper {
    flex-direction: column;
  }
  .l-footer__company {
    width: 100%;
  }
  .l-footer__address {
    width: 100%;
  }
  .l-footer__nav {
    flex-direction: column;
    gap: 1.875rem;
  }
  .l-footer__copy {
    padding-bottom: 3.75rem;
  }
  .l-header {
    padding: 1.25rem;
  }
  .l-header__menu img {
    height: auto;
    width: 2.8125rem;
  }
  .l-inner {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
  .l-single-wrap {
    flex-direction: column;
    gap: 1.25rem;
  }
  .l-under-wrap {
    flex-direction: column;
    gap: 1.875rem;
  }
  .l-under-content {
    width: 100%;
  }
  .c-btn-fixed {
    bottom: -1px;
    flex-direction: row;
    left: 0;
    right: auto;
    width: 100%;
  }
  .c-btn-fixed--footer {
    display: none;
  }
  .c-btn-fixed__btn {
    -webkit-writing-mode: horizontal-tb;
    -ms-writing-mode: lr-tb;
    height: 3.75rem;
    width: 50%;
    writing-mode: horizontal-tb;
  }
  .c-btn-fixed__btn--reserve {
    padding: 0.5rem 1.125rem;
  }
  .c-btn-fixed__btn--document {
    padding: 0.5rem 1.125rem;
  }
  .c-btn-fixed__btn--h-reserve {
    height: 3.75rem;
    width: 50%;
  }
  .c-btn-fixed__btn--h-document {
    height: 3.75rem;
    width: 50%;
  }
  .c-btn-open-close {
    align-items: center;
    background-color: transparent;
    border: 1px solid #d5d5d5;
    color: #333;
    cursor: pointer;
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    padding-block: 1rem;
    padding-block: 1rem;
    width: 100%;
  }
  .c-check-box__point {
    font-size: 5rem;
  }
  .c-check-box__items {
    gap: 0.1875rem;
  }
  .c-check-box__item-desc {
    font-size: 0.8125rem;
    padding-left: 1.375rem;
  }
  .c-check-box__item-ttl {
    font-size: 0.8125rem;
    padding-left: 1.375rem;
  }
  .c-check-box__item-ttl::before {
    height: 0.75rem;
    width: 0.75rem;
  }
  .c-check-box__ttl {
    padding-left: 1.375rem;
  }
  .c-column2 {
    gap: 1.875rem;
    grid-template-columns: repeat(1, 1fr);
  }
  .c-column2--gap60 {
    gap: 2.5rem;
  }
  .c-column2--gapSp20 {
    gap: 1.25rem;
  }
  .c-column3 {
    grid-template-columns: repeat(1, 1fr);
  }
  .c-column4 {
    grid-template-columns: repeat(1, 1fr);
  }
  .c-column4--sp2 {
    grid-template-columns: repeat(2, 1fr);
  }
  .c-headline1__main {
    font-size: 1.25rem;
    padding-left: 1.375rem;
  }
  .c-headline1__sub {
    margin-top: 1.625rem;
    padding-left: 1.375rem;
  }
  .c-img-ttl {
    font-size: clamp(1rem, 0.911rem + 0.45vw, 1.125rem);
    padding: 0.5rem 0rem;
  }
  .c-link-box__head {
    justify-content: center;
  }
  .c-link-box {
    max-width: 27.5rem;
    padding: 1.875rem 1.25rem;
    width: 90%;
  }
  .c-link-box__list {
    flex-direction: column;
    gap: 0.75rem;
  }
  .c-link-box__btn {
    flex: none;
  }
  .c-normal__txt-item {
    font-size: 0.875rem;
  }
  .c-normal__txt-item--concept {
    font-size: 0.9375rem;
  }
  .c-page-fv__img {
    background-image: none;
    height: clamp(12.5rem, 3.551rem + 44.74vw, 25rem);
  }
  .c-page-fv__img picture {
    display: block;
  }
  .c-page-fv__img img {
    -o-object-fit: cover;
    -o-object-position: center;
    height: clamp(12.5rem, 3.551rem + 44.74vw, 25rem);
    object-fit: cover;
    object-position: center;
  }
  .c-page-fv__ttl {
    gap: 0.625rem;
    padding-left: 1.25rem;
  }
  .c-page-fv__ttl-en {
    font-size: 2rem;
  }
  .c-page-fv__ttl-en--single {
    font-size: clamp(1.375rem, 0.205rem + 3.75vw, 2rem);
  }
  .c-page-fv__ttl-ja {
    font-size: clamp(0.75rem, 0.528rem + 1.11vw, 0.875rem);
    padding: 0 1.25rem;
  }
  .c-page-fv__ttl-ja::before {
    top: 0.625rem;
    width: 0.9375rem;
  }
  .c-page-fv__breadcrumb {
    padding: 0.5rem;
  }
  .c-parallax__cover {
    height: clamp(18.75rem, 9.801rem + 44.74vw, 31.25rem);
    width: calc(var(--vw) + var(--aside) + var(--gap) - 10px);
  }
  .c-under-head {
    gap: clamp(0.375rem, 0.286rem + 0.45vw, 0.5rem);
  }
  .c-under-head__number {
    font-size: clamp(3.125rem, 2.527rem + 2.55vw, 3.75rem);
    font-weight: 400;
  }
  .c-under-head__ttl {
    font-size: clamp(1.125rem, 1.036rem + 0.45vw, 1.25rem);
    line-height: 1.4;
  }
  .c-under-menu {
    position: static;
  }
  body.header-hidden .c-under-menu {
    top: auto;
  }
  .c-under-sub__ttl {
    font-size: 0.9375rem;
  }
  .p-404__link {
    padding-top: 1.25rem;
  }
  .p-catalog-request__ttl {
    font-size: 1.25rem;
  }
  .p-catalog-request__flex {
    flex-direction: column;
  }
  .p-catalog-request__img {
    margin-inline: auto;
    max-width: 26.6875rem;
    width: 100%;
  }
  .p-catalog-request__form {
    gap: 1.875rem;
    padding: 2.5rem 1.25rem;
  }
  .p-catalog-request__list {
    gap: 1.5rem;
  }
  .p-catalog-request__post-note {
    margin-top: 0.3125rem;
    width: 100%;
  }
  .p-catalog-request__submit {
    padding-top: 1.875rem;
  }
  .p-catalog-request__submit input[type=submit] {
    font-size: 0.875rem;
    padding: 0.875rem 1.875rem;
  }
  .p-company {
    overflow-x: clip;
  }
  .p-company__column {
    flex-direction: column;
    gap: 2.5rem;
  }
  .p-company__btn {
    justify-content: center;
  }
  .p-company__img {
    aspect-ratio: 374/267;
    height: auto;
    margin-inline: calc(50% - 50vw);
    margin-inline: calc(50% - 50svw);
    max-width: none;
    width: 100vw;
    width: 100svw;
  }
  .p-company__img img {
    height: auto;
  }
  .p-concept__column {
    padding: 0 1.25rem;
  }
  .p-concept__slide {
    margin-top: 2.5rem;
  }
  .p-concept__logo {
    display: none;
  }
  .p-design-01__item {
    width: calc((100% - 1.25rem) / 3);
  }
  .p-design-01__concept {
    max-width: 100%;
  }
  .p-design-01__concept-bg {
    font-size: clamp(2.5rem, 0.71rem + 8.95vw, 5rem);
  }
  .p-design-01__img-item--bleed {
    margin-left: calc(50% - 50dvw - 0.625rem);
    margin-right: calc(50% - 50dvw - 0.625rem);
    max-width: none;
    overflow: hidden; /* 念のための保険 */
    /* SPは .l-inner の左右 padding が rem(20) → 半分を相殺 */
    width: 100dvw;
  }
  .p-design-02__sousa-ttl {
    font-size: 0.875rem;
    text-align: center;
  }
  .p-design-02__main {
    flex-direction: column;
    padding-top: 1.25rem;
  }
  .p-design-02__main-img {
    width: 50%;
  }
  .p-design-02__main-content {
    gap: 1.875rem;
    max-width: 100%;
  }
  .p-design-02__select {
    width: 100%;
  }
  .p-design-02__select-tag {
    font-size: 0.75rem;
  }
  .p-design-02__select-head {
    gap: 0.75rem;
  }
  .p-design-02__select-ttl {
    font-size: 0.875rem;
  }
  .p-design-02__style-list {
    gap: 0.5rem;
    margin-top: 0.75rem;
  }
  .p-design-02__style-item {
    gap: 0.3125rem;
    max-width: calc((100% - 1rem) / 3);
  }
  .p-design-02__style-name {
    font-size: 0.8125rem;
  }
  .p-design-02__style-desc {
    font-size: clamp(0.5rem, 0.125rem + 1.6vw, 0.625rem);
  }
  .p-design-02__color-list {
    gap: 0.5rem;
    margin-top: 0.75rem;
  }
  .p-design-02__color-item {
    gap: 0.3125rem;
    max-width: 3.75rem;
  }
  .p-design-02__color-circle {
    height: 1.25rem;
    width: 1.25rem;
  }
  .p-design-02__color-name {
    font-size: 0.5625rem;
    text-align: center;
  }
  .p-design-02__bottom-list {
    display: none;
  }
  .p-design-02__bottom-item {
    max-width: calc((100% - 1rem) / 3);
  }
  .p-design-03__main-txt {
    font-size: 0.75rem;
    letter-spacing: 0.06em;
    line-height: 1.8;
  }
  .p-design-03__thumb .swiper-slide {
    width: 7.5rem;
  }
  .p-design-04__plan-ttl-ja {
    font-size: 1.25rem;
  }
  .p-design-04__plan-ttl-en {
    font-size: 5rem;
  }
  .p-design-04__ttl {
    flex-direction: column;
    gap: 0.9375rem;
  }
  .p-design-04__ttl-img {
    width: 12.5rem;
  }
  .p-design-04__ttl-txt {
    text-align: center;
  }
  .p-design-04__ttl-name {
    font-size: 1.5rem;
  }
  .p-design-04__ttl-area,
  .p-design-04__ttl-room {
    font-size: 0.875rem;
  }
  .p-design-04__ttl-price-label,
  .p-design-04__ttl-price-unit {
    font-size: 0.875rem;
  }
  .p-design-04__ttl-price-num {
    font-size: 1.75rem;
  }
  .p-design-04__img-flex {
    flex-direction: column;
    gap: 1.25rem;
    padding-inline: 1.25rem;
    width: 100%;
  }
  .p-design-04__img {
    max-width: 22.5rem;
    width: 100%;
  }
  .p-design-04__slider .swiper-btn-prev,
  .p-design-04__slider .swiper-btn-next {
    display: none;
  }
  .p-design-04__pay-tbl {
    width: 100%;
  }
  .p-design-04__base-list {
    grid-template-columns: repeat(2, 1fr);
  }
  .p-design-04__base-img {
    width: 100%;
  }
  .p-design-05__list {
    gap: 0.625rem;
    padding-top: 1.875rem;
  }
  .p-design-05__item {
    gap: 1.25rem;
  }
  .p-design-05__img-box {
    gap: 0.75rem;
    padding-top: 1.25rem;
  }
  .p-design-05__img-txt {
    gap: 1rem;
  }
  .p-design-05__img-txt-content {
    font-size: 1rem;
  }
  .p-design-05__qa-list {
    display: none;
    gap: 0.625rem;
    padding: 1rem 0rem;
  }
  .p-design-05__item.is-open .p-design-05__qa-list {
    display: flex;
  }
  .p-design-05__qa-item {
    padding: 0rem 1rem;
  }
  .p-design-05__qa-q {
    gap: 0.625rem;
  }
  .p-design-05__qa-a {
    gap: 0.625rem;
  }
  .p-design-05__qa-label {
    font-size: 1rem;
    line-height: 1.6em;
  }
  .p-design-05__qa-ttl {
    font-size: 0.875rem;
  }
  .p-design-05__qa-txt {
    font-size: 0.875rem;
  }
  .p-design-05__item.is-open .c-btn-open-close {
    display: none;
  }
  .p-design-05__item.is-open .c-btn-open-close--close {
    display: flex;
  }
  .p-features {
    overflow-x: clip;
    padding-block: 3.75rem;
  }
  .p-features__column {
    gap: 2.5rem;
  }
  .p-features__list {
    gap: 3.75rem;
    margin-top: 3.125rem;
  }
  .p-features__item {
    flex-direction: column;
    gap: clamp(1.25rem, 0.054rem + 5.1vw, 2.5rem);
  }
  .p-features__item:nth-child(even) {
    flex-direction: column;
  }
  .p-features__txt {
    max-width: 100%;
  }
  .p-features__ttl {
    gap: clamp(1.5rem, 0.963rem + 2.68vw, 2.25rem);
  }
  .p-features__num {
    font-size: clamp(3.375rem, 2.928rem + 2.24vw, 4rem);
  }
  .p-features__num::after {
    height: 2.873125rem;
    right: clamp(-16px, -0.89vw - 9.14px, -12px);
  }
  .p-features__num--01::after {
    right: -0.625rem;
  }
  .p-features__ttl-txt {
    font-size: 1.375rem;
  }
  .p-features__desc {
    gap: 0.625rem;
    padding-top: 1rem;
  }
  .p-features__desc-lead {
    font-size: 1.125rem;
    line-height: 1.6;
  }
  .p-features__desc-txt {
    font-size: 0.875rem;
  }
  .p-features__btn {
    padding-top: 1rem;
    text-align: center;
  }
  .p-features__img {
    aspect-ratio: 374/237;
    flex: none;
    height: auto;
    margin-inline: calc(50% - 50vw);
    margin-inline: calc(50% - 50svw);
    max-width: none;
    width: 100vw;
    width: 100svw;
  }
  .p-features__img img {
    height: auto;
  }
  .p-fv {
    height: auto;
  }
  .p-fv__bg {
    height: auto;
    position: relative;
  }
  .p-fv__video {
    -webkit-transform: none;
    -o-object-fit: cover;
    height: auto;
    min-height: 0;
    min-width: 0;
    object-fit: cover;
    position: static;
    transform: none;
    width: 100%;
  }
  .p-fv__main-text {
    align-items: flex-start;
    flex-direction: column;
    gap: 0.875rem;
    width: unset;
  }
  .p-fv__catch {
    gap: 0.875rem;
  }
  .p-fv__catch-text {
    font-size: 1.75rem;
  }
  .p-fv__logo {
    width: 6.625rem;
  }
  .p-fv__lead {
    font-size: 0.875rem;
    line-height: 1.6;
    text-shadow: 0px 0px 30px rgba(0, 0, 0, 0.3);
  }
  .p-fv__scroll {
    -webkit-transform: none;
    bottom: 0;
    left: 0.5rem;
    transform: none;
  }
  .p-fv__scroll-text {
    -webkit-transform: rotate(90deg);
    font-size: 0.8125rem;
    line-height: 1.366;
    margin-bottom: 0.625rem;
    transform: rotate(90deg);
  }
  .p-fv__scroll-line {
    height: 1.6875rem;
  }
  .p-gallery-01 {
    --aside: 0px;
    --gap: 0px;
  }
  .p-gallery-01__slider {
    width: calc(var(--vw) + var(--aside) + var(--gap) - 10px);
  }
  .p-gallery-01-popup__item {
    margin-inline: auto;
    width: 90%;
  }
  .p-gallery-01-modal__content {
    gap: 0.9375rem;
    padding: 2.5rem 1.25rem;
  }
  .p-gallery-01-modal__close {
    height: 2.5rem;
    right: 1.25rem;
    top: 1.25rem;
    width: 2.5rem;
  }
  .p-gallery-01-modal__close-icon {
    height: 1.5rem;
    width: 1.5rem;
  }
  .p-gallery-01-modal__close-icon::before, .p-gallery-01-modal__close-icon::after {
    height: 1.5rem;
  }
  .p-gallery-01-modal__prev,
  .p-gallery-01-modal__next {
    height: 2.5rem;
    width: 2.5rem;
  }
  .p-gallery-01-modal__prev {
    left: 0.625rem;
  }
  .p-gallery-01-modal__next {
    right: 0.625rem;
  }
  .p-gallery-01-modal__arrow-icon {
    height: 0.75rem;
    width: 0.75rem;
  }
  .p-gallery-01-modal__description {
    font-size: 0.75rem;
    max-width: 90vw;
    padding-inline: 0.625rem;
  }
  .p-gallery-02__list {
    gap: 1.75rem;
    padding-top: 2.5rem;
  }
  .p-gallery-02__item {
    margin-inline: auto;
    width: 97%;
  }
  .p-gallery-house__img {
    aspect-ratio: 840/640;
    margin-inline: calc(50% - 50vw);
    margin-inline: calc(50% - 50svw);
    max-width: none;
    width: 100vw;
    width: 100svw;
  }
  .p-gallery-house__img img {
    -o-object-fit: cover;
    height: 100%;
    object-fit: cover;
  }
  .p-gallery-house__ttl {
    font-size: 1.125rem;
  }
  .p-gallery-house__btn {
    gap: 1rem;
    padding: 0.75rem 1.875rem;
  }
  .p-gallery-house__btn-txt {
    font-size: 0.875rem;
  }
  .p-gallery-house__list {
    flex-direction: column;
    margin-top: 2.5rem;
  }
  .p-gallery-house__item-label {
    border-bottom: none;
    padding: 1.5rem 0 0 0;
    width: 100%;
  }
  .p-gallery-house__item-content {
    border-bottom: 2px solid #e5ae7a;
    width: 100%;
  }
  .p-gallery-house__more-item {
    display: none;
  }
  .p-gallery-house.is-open .p-gallery-house__more-item {
    display: block;
  }
  .p-gallery-house.is-open .p-gallery-house__item-content--type {
    display: flex;
  }
  .p-gallery-house__map {
    display: none;
  }
  .p-gallery-house.is-open .p-gallery-house__map {
    display: block;
  }
  .p-gallery-house__more-btn-box {
    display: flex;
  }
  .p-gallery-house.is-open .c-btn-open-close {
    display: none;
  }
  .p-gallery-house.is-open .c-btn-open-close--close {
    display: flex;
  }
  .p-gallery-house--anjo .p-gallery-house__item-label {
    border-bottom: none;
  }
  .p-gallery-house--anjo .p-gallery-house__item-content {
    border-bottom: 2px solid #2a686f;
  }
  .p-gallery__column {
    padding: 0 1.25rem;
  }
  .p-gallery__txt {
    padding-top: 1.875rem;
  }
  .p-gallery__desc {
    font-size: 0.875rem;
    line-height: 1.8;
  }
  .p-gallery__slider {
    padding-top: clamp(0.75rem, -0.924rem + 7.14vw, 2.5rem);
  }
  .p-gallery__slide {
    margin-top: 2.5rem;
  }
  .p-gallery__btn {
    margin-top: 2.5rem;
  }
  .p-menu__header {
    padding: 1.25rem;
  }
  .p-menu__header-close img {
    width: 2.8125rem;
  }
  .p-menu__inner {
    align-items: flex-start;
    gap: 2.5rem;
    min-height: calc(95vh - 5.625rem);
  }
  .p-menu__catch {
    gap: 0.75rem;
    padding-inline: 1.25rem;
    padding-top: 3.75rem;
  }
  .p-menu__catch-txt {
    font-size: 1.25rem;
  }
  .p-menu__logo {
    height: auto;
    width: 5.625rem;
  }
  .p-menu__content {
    flex-direction: column;
    gap: 2.5rem;
    padding-inline: 1.25rem;
  }
  .p-menu__nav {
    flex-direction: column;
    gap: 1.875rem;
  }
  .p-menu__nav-item {
    gap: 0.625rem;
  }
  .p-menu__nav-en {
    font-size: 1.125rem;
  }
  .p-menu__nav-ja {
    font-size: 0.75rem;
  }
  .p-menu__nav-list {
    gap: 0.5rem;
  }
  .p-menu__nav-list-item--indent {
    padding-left: 1.125rem;
  }
  .p-menu__nav-list-num {
    font-size: 0.75rem;
  }
  .p-menu__nav-list-txt {
    font-size: 0.75rem;
  }
  .c-btn-fixed--menu {
    height: 3.75rem;
  }
  .p-modal__block {
    width: 80%;
  }
  .p-modal__wrap {
    padding: 2.5rem 0 1.875rem;
  }
  .p-modelhouse__list {
    flex-direction: column;
    gap: 1.875rem;
  }
  .p-pageTop {
    bottom: 1.25rem;
    right: 1.5625rem;
  }
  .p-privacy {
    gap: 1.875rem;
    padding-top: 1.875rem;
  }
  .p-privacy__main-ttl {
    font-size: 1.125rem;
  }
  .p-privacy__box {
    gap: clamp(0.875rem, -0.082rem + 4.08vw, 1.875rem);
    margin-top: 1.25rem;
    padding-block: 2.875rem;
    padding-inline: 1.25rem;
  }
  .p-privacy__box-ttl {
    font-size: 1.125rem;
  }
  .c-under-head__number--privacy {
    font-size: 1.75rem;
  }
  .p-quality-01__image1 {
    margin-left: calc(50% - 50dvw - 0.625rem);
    margin-right: calc(50% - 50dvw - 0.625rem);
    margin-top: 1.25rem;
    max-width: none;
    overflow: hidden;
    width: 100dvw;
  }
  .p-quality-01__image2 {
    flex-direction: column;
    gap: 1.25rem;
  }
  .p-quality-01__image2__item:first-child {
    display: none;
  }
  .p-quality-01__image2__item:last-child {
    margin-inline: auto;
    max-width: 35rem;
    width: 100%;
  }
  .p-quality-02__image {
    display: block;
  }
  .p-quality-02__image__item:first-child {
    width: 100%;
  }
  .p-quality-02__image__item:last-child {
    margin-left: calc(50% - 50dvw - 0.625rem);
    margin-right: calc(50% - 50dvw - 0.625rem);
    margin-top: 1.875rem;
    max-width: none;
    overflow: hidden;
    width: 100dvw;
  }
  .p-quality-03__content {
    flex-direction: column;
    gap: 1.25rem;
  }
  .p-quality-03__txt-wrap {
    gap: 1rem;
  }
  .p-quality-03__note {
    font-size: 0.75rem;
  }
  .p-quality-03__graph {
    justify-content: center;
  }
  .p-quality-03__graph img {
    max-width: 35rem;
  }
  .p-quality-03__movie {
    margin-top: 2.5rem;
  }
  .p-quality-03__txt {
    font-size: 0.9375rem;
    margin-top: 1rem;
  }
  .p-quality-03__compare {
    flex-direction: column;
    gap: 1.5rem;
    margin-top: 2.5rem;
  }
  .p-quality-03__compare-item {
    gap: 0.9375rem;
    max-width: 100%;
  }
  .p-quality-03__compare-item img {
    max-width: 35rem;
  }
  .p-quality-03__compare-desc {
    font-size: 0.875rem;
  }
  .p-quality-03__compare-icon {
    -webkit-transform: rotate(90deg);
    padding-top: 0rem;
    transform: rotate(90deg);
  }
  .p-quality-03__compare-icon img {
    height: 2.5rem;
    width: 2.5rem;
  }
  .p-quality-03__summary {
    font-size: 1.25rem;
  }
  .p-quality-04__item {
    padding-block: 1.5rem;
  }
  .p-quality-04__head {
    align-items: center;
    flex-direction: column;
    gap: 0.625rem;
  }
  .p-quality-04__number {
    font-size: 4.375rem;
  }
  .p-quality-04__content {
    align-items: center;
    gap: 0.625rem;
  }
  .p-quality-04__ttl {
    font-size: 1.125rem;
    text-align: center;
  }
  .p-quality-04__ttl-sub {
    display: block;
  }
  .p-quality-04__sub {
    font-size: 0.875rem;
    text-align: center;
  }
  .p-quality-04__body {
    align-items: center;
    flex-direction: column;
    padding-top: 0.625rem;
  }
  .p-quality-04__img {
    width: clamp(10rem, 5.526rem + 22.37vw, 16.25rem);
  }
  .p-quality-04__txt-wrap {
    gap: 0.5rem;
  }
  .p-quality-04__txt {
    font-size: 0.875rem;
  }
  .p-quality-04__item--medium {
    display: none;
  }
  .p-quality-04__small-wrap {
    border-bottom: 0.0625rem solid #d5d5d5;
    display: flex;
    gap: 1rem;
    justify-content: center;
    padding-bottom: 1.5rem;
  }
  .p-quality-04__item-small {
    padding-bottom: 0;
    padding-top: 1rem;
  }
  .p-quality-04__schedule {
    gap: 0.625rem;
    padding-top: 1.125rem;
  }
  .p-quality-04__schedule-ttl {
    font-size: 0.9375rem;
  }
  .p-quality-05__img-sec {
    gap: 0.625rem;
    padding-top: 1.875rem;
  }
  .p-quality-05__img-box {
    flex-direction: column;
    width: 100%;
  }
  .p-quality-05__img-item {
    gap: 1rem;
    margin-inline: auto;
    max-width: 35rem;
    width: 100%;
  }
  .p-quality-05__total {
    gap: 0.625rem;
  }
  .p-quality-05__total-txt {
    font-size: clamp(1.25rem, 0.892rem + 1.79vw, 1.75rem);
    line-height: 1.6em;
  }
  .p-quality-05__smart-sec {
    gap: 1rem;
    padding-top: 1.875rem;
  }
  .p-quality-05__smart-head {
    gap: 0.75rem;
  }
  .p-quality-05__sarani img {
    width: clamp(6.25rem, 1.776rem + 22.37vw, 12.5rem);
  }
  .p-quality-05__smart-box {
    padding-block: 0.5rem;
  }
  .p-quality-05__smart-box-txt {
    font-size: clamp(1.125rem, 0.903rem + 1.11vw, 1.25rem);
    line-height: 1.4em;
  }
  .p-quality-05__smart-img-sec {
    gap: 0.625rem;
    padding-top: 1.875rem;
  }
  .p-quality-05__smart-img-box {
    flex-direction: column;
    gap: 1.875rem;
    width: 100%;
  }
  .p-quality-05__smart-house {
    margin-inline: auto;
    max-width: 35rem;
    width: 100%;
  }
  .p-quality-05__smart-house-note {
    bottom: 0.625rem;
    right: 0.9375rem;
  }
  .p-quality-05__gx-sec {
    gap: 0.75rem;
    padding-top: 1.875rem;
  }
  .p-quality-05__gx-img {
    padding-top: 1rem;
  }
  .p-quality-05__gx-img img {
    width: 100%;
  }
  .p-quality-05__gx-note {
    font-size: 0.6875rem;
  }
  .p-quality-06__img {
    flex-direction: column;
    gap: 1rem;
    padding-top: 1rem;
  }
  .p-quality-06__item-txt {
    font-size: 0.875rem;
  }
  .p-single__art {
    max-width: 100%;
  }
  .p-single__thumbnail {
    margin-inline: auto;
    max-width: 90%;
  }
  .p-single__calender {
    max-width: 100%;
    padding-top: 3.75rem;
    position: static;
  }
  .p-single__calendar-form iframe {
    height: 700px;
  }
  .p-single__content h2 {
    line-height: 1.4;
  }
  .p-single__content ul li {
    line-height: 1.8;
  }
  .p-single__content ol li {
    line-height: 1.8;
  }
  .wp-block-columns .wp-block-column:nth-of-type(2) .wp-block-image {
    margin-top: unset;
  }
  .calender-yoyaku-txt {
    display: none;
  }
  .u-font18 {
    font-size: 1rem;
  }
  .u-font20 {
    font-size: 1rem;
  }
  .u-font22 {
    font-size: 1.125rem;
  }
  .u-font24 {
    font-size: 1.125rem;
  }
  .u-mt100 {
    margin-top: 1.875rem;
  }
  .u-mtSp10 {
    margin-top: 10px !important;
    margin-top: 0.625rem !important;
  }
  .u-mtSp20 {
    margin-top: 20px !important;
    margin-top: 1.25rem !important;
  }
  .u-mtSp30 {
    margin-top: 30px !important;
    margin-top: 1.875rem !important;
  }
  .u-mtSp40 {
    margin-top: 40px !important;
    margin-top: 2.5rem !important;
  }
  .u-mtSp50 {
    margin-top: 50px !important;
    margin-top: 3.125rem !important;
  }
  .u-mtSp60 {
    margin-top: 60px !important;
    margin-top: 3.75rem !important;
  }
  .u-mtSp70 {
    margin-top: 70px !important;
    margin-top: 4.375rem !important;
  }
  .u-mtSp80 {
    margin-top: 80px !important;
    margin-top: 5rem !important;
  }
  .u-mtSp90 {
    margin-top: 90px !important;
    margin-top: 5.625rem !important;
  }
  .u-mtSp100 {
    margin-top: 100px !important;
    margin-top: 6.25rem !important;
  }
  .u-mtSp110 {
    margin-top: 110px !important;
    margin-top: 6.875rem !important;
  }
  .u-mtSp120 {
    margin-top: 120px !important;
    margin-top: 7.5rem !important;
  }
  .u-mtSp130 {
    margin-top: 130px !important;
    margin-top: 8.125rem !important;
  }
  .u-mtSp140 {
    margin-top: 140px !important;
    margin-top: 8.75rem !important;
  }
  .u-mtSp150 {
    margin-top: 150px !important;
    margin-top: 9.375rem !important;
  }
  .u-mtSp160 {
    margin-top: 160px !important;
    margin-top: 10rem !important;
  }
  .u-mtSp170 {
    margin-top: 170px !important;
    margin-top: 10.625rem !important;
  }
  .u-mtSp180 {
    margin-top: 180px !important;
    margin-top: 11.25rem !important;
  }
  .u-mtSp190 {
    margin-top: 190px !important;
    margin-top: 11.875rem !important;
  }
  .u-mtSp200 {
    margin-top: 200px !important;
    margin-top: 12.5rem !important;
  }
  .u-pc {
    display: none;
  }
  .u-sp {
    display: block;
  }
}

@media screen and (max-width: 375px) {
  html {
    font-size: 4.2666666667vw;
  }
  .p-single__thumbnail {
    margin-inline: auto;
    max-width: 100%;
  }
}
/*# sourceMappingURL=sourcemaps/style.css.map */