@charset "UTF-8";
:where(h1, h2, h3, h4, h5, h6) {
  margin: unset;
}

:where(p) {
  margin: unset;
}

html {
  font-size: 100%;
}

a[href^=tel] {
  text-decoration: none;
}

a[x-apple-data-detectors] {
  color: inherit !important;
  text-decoration: none !important;
}

a {
  color: inherit;
  -webkit-tap-highlight-color: transparent;
  /* 強調をなくす */
}

a:hover {
  text-decoration: none;
}

img,
svg {
  vertical-align: middle;
}

img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

:where(:any-link, button, [type=button], [type=reset], [type=submit], label[for], select, summary, [role=tab], [role=button]) {
  cursor: pointer;
}

:where(button, [type=button], [type=reset], [type=submit]) {
  touch-action: manipulation;
}

:is(h1, h2, h3, h4, h5, h6) {
  margin-block: unset;
  font-size: unset;
}

:focus:not(:focus-visible) {
  outline: none;
}

input[type=text] {
  font-size: 1rem;
  /* = 16px */
}

textarea {
  field-sizing: content;
}

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  color: var(--color-text);
  font-family: var(--gothic-antique);
  font-weight: var(--fw-regular);
}

main {
  flex: 1;
}

@property --root-font-size {
  syntax: "<length>";
  inherits: false;
  initial-value: 16px;
}
:root {
  /* inner */
  --inner: min(1090px, 100%);
  --inner-sp: min(500px, 100%);
  --padding-inner: 20px;
  --padding-inner-sp: 35px;
  /* 流体タイポグラフィ */
  --min: 10;
  --max: 16;
  --min-vw: 340;
  --max-vw: 370;
  --fluid-size: clamp(calc(var(--min) * 1px), calc(var(--min) * 1px + (var(--max) - var(--min)) * ((100vw - var(--min-vw) * 1px) / (var(--max-vw) - var(--min-vw)))), calc(var(--max) * 1px));
  /*  フォントサイズ  */
  --base-size: var(--fluid-size);
  /* z-index */
  --z-index-header: 30;
  --z-index-fixed: 20;
  /* color */
  --color-white: #fff;
  --color-black: #000;
  --color-text: #344855;
  --color-primary: #344855;
  --color-gray-text: #5d6d77;
  --color-secondary: #008ca0;
  --color-navy: #233642;
  --color-border: #99a3aa;
  --color-border-gray: #c2c8cc;
  --color-badge-gray: #e1e4e5;
  --color-category-text: #8b9aad;
  --color-category: #859199;
  --color-border-light: #d6dadd;
  --color-bg-light-gray: #f9fafa;
  --color-bg-light-gray2: #f5f6f6;
  --color-bg-gray: #ebeef0;
  --color-bg-gray2: #ebedee;
  /* font-weight */
  --fw-light: 300;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  /* font-family */
  --gothic-antique: "Zen Kaku Gothic Antique", sans-serif;
  --gothic-new: "Zen Kaku Gothic New", sans-serif;
  --old-mincho: "Zen Old Mincho", serif;
  --to-rem: calc(tan(atan2(1px, var(--root-font-size))) * 1rem);
  /* transition duration */
  --duration: 0.3s;
  /* opacity */
  --opacity: 0.7;
  /* header height */
  --header-height: 60px;
}
@media screen and (width >= 768px) {
  :root {
    --min: 12;
    --max: 16;
    --min-vw: 800;
    --max-vw: 1400;
    --fluid-size: clamp(calc(var(--min) * 1px), calc(var(--min) * 1px + (var(--max) - var(--min)) * ((100vw - var(--min-vw) * 1px) / (var(--max-vw) - var(--min-vw)))), calc(var(--max) * 1px));
  }
}
@media screen and (width >= 768px) {
  :root {
    --header-height: 80px;
  }
}

.l-detail {
  margin-block-start: calc(-45 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .l-detail {
    margin-block-start: calc(-130 * var(--to-rem));
  }
}

.l-header {
  position: fixed;
  inset: 0;
  z-index: var(--z-index-header);
  height: var(--header-height);
}

.l-inner {
  max-width: calc(var(--inner-sp) + var(--padding-inner-sp) * 2);
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .l-inner {
    max-width: calc(var(--inner) + var(--padding-inner) * 2);
    padding-inline: var(--padding-inner);
  }
}

.l-main {
  overflow-x: clip;
  margin-block-start: var(--header-height);
}

.l-privacy {
  margin-block-start: calc(-70 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .l-privacy {
    margin-block-start: calc(-60 * var(--to-rem));
  }
}

.c-breadcrumb {
  padding-inline: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-breadcrumb {
    padding-inline: calc(60 * var(--to-rem));
  }
}

.c-breadcrumb__list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(2 * var(--to-rem)) calc(4 * var(--to-rem));
  align-items: center;
}

.c-breadcrumb__item {
  color: var(--color-text);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.7857142857;
  text-decoration: none;
}

.c-breadcrumb__item a {
  display: inline-block;
  margin-block: calc((1em - 1lh) / 2);
  transition: opacity var(--duration) ease;
}
@media (any-hover: hover) {
  .c-breadcrumb__item a:hover {
    opacity: var(--opacity);
  }
}

.c-breadcrumb__item a:first-child {
  padding-block-end: calc(6 * var(--to-rem));
}

.c-breadcrumb__item:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  white-space: nowrap;
}

.c-breadcrumb__item:not(:last-child) {
  position: relative;
  padding-inline-end: calc(16 * var(--to-rem));
}

.c-breadcrumb__item:not(:last-child)::after {
  content: "＞";
  position: absolute;
  inset-inline-end: 0;
  padding-block-start: 1px;
  color: var(--color-text);
}

.c-button {
  position: relative;
  display: inline-flex;
  gap: calc(10 * var(--to-rem));
  justify-content: center;
  align-items: center;
  width: 100%;
  min-block-size: calc(60 * var(--to-rem));
  padding-inline: calc(20 * var(--to-rem));
  border: 1px solid var(--color-border-light);
  border-radius: 999px;
  background-color: transparent;
  color: var(--color-primary);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1;
  letter-spacing: 0.05em;
}
.c-button::after {
  content: "";
  position: absolute;
  inset-block-end: 50%;
  inset-inline-end: calc(30 * var(--to-rem));
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transform: translateY(50%);
  transition: transform var(--duration) ease;
}
@media (any-hover: hover) {
  .c-button:hover::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
}

.c-button:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ── バリエーション ────────────────────────────── */
.c-button[data-theme=primary] {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
  color: var(--color-white);
}

.c-concept {
  overflow: hidden;
  padding-block: calc(86 * var(--to-rem)) 0;
  border-radius: 6px;
  background-image: url("../images/philosophy_back.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
  .c-concept {
    margin-inline: calc(15 * var(--to-rem));
    padding-block: calc(178 * var(--to-rem)) calc(68 * var(--to-rem));
  }
}

.c-concept__inner.l-inner {
  position: relative;
}
@media screen and (min-width: 768px) {
  .c-concept__inner.l-inner {
    max-inline-size: calc(1260 * var(--to-rem));
    margin-inline: auto;
  }
}

.c-concept__sub-wrap {
  max-inline-size: calc(300 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .c-concept__sub-wrap {
    max-inline-size: calc(380 * var(--to-rem));
  }
}

.c-concept__sub {
  padding-block-end: calc(18 * var(--to-rem));
  border-block-end: 1px solid var(--color-border);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.5;
  letter-spacing: 0.01em;
  text-align: center;
}

.c-concept__title {
  max-inline-size: calc(300 * var(--to-rem));
  margin-block-start: calc(52 * var(--to-rem));
  margin-inline: auto;
  font-size: calc(1.5 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.625;
  letter-spacing: 0.01em;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .c-concept__title {
    max-inline-size: initial;
    margin-block-start: calc(72 * var(--to-rem));
    font-size: calc(1.875 * var(--base-size));
  }
}

.c-concept__text {
  margin-block-start: calc(28 * var(--to-rem));
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  .c-concept__text {
    max-inline-size: calc(850 * var(--to-rem));
    margin-block-start: calc(65 * var(--to-rem));
    margin-inline: auto;
  }
}

.c-concept__cards {
  display: grid;
  overflow: hidden;
  margin-block-start: calc(80 * var(--to-rem));
  margin-inline: calc(50% - 50vi);
  border-radius: 6px;
  list-style: none;
}
@media screen and (min-width: 768px) {
  .c-concept__cards {
    margin-block-start: calc(110 * var(--to-rem));
    margin-inline: auto;
  }
}

.c-concept__card {
  position: relative;
  display: block;
  overflow: hidden;
  min-block-size: calc(170 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-concept__card {
    min-block-size: calc(140 * var(--to-rem));
  }
}

.c-concept__card img {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.c-concept__card-body {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: calc(28 * var(--to-rem));
  justify-content: center;
  align-items: center;
  inline-size: 100%;
  block-size: 100%;
  padding-block: calc(40 * var(--to-rem));
  padding-inline: calc(6 * var(--to-rem));
  color: var(--color-white);
  text-align: center;
}
@media screen and (min-width: 768px) {
  .c-concept__card-body {
    gap: calc(32 * var(--to-rem));
    padding-block: calc(56 * var(--to-rem));
  }
}

.c-concept__card-title {
  font-size: calc(1.375 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.01em;
}

.c-concept__card-text {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  text-align: center;
}

.c-concept__card-button {
  width: 100%;
  max-inline-size: calc(300 * var(--to-rem));
  margin-inline: auto;
}
.c-concept__card-button .c-button {
  width: 100%;
  color: var(--color-white);
}

/* ── card-expand: 初期はタイトルのみ、スクロール時に展開 ── */
.c-concept__card.js-card-expand .c-concept__card-body {
  gap: 0;
  padding-block: calc(44 * var(--to-rem));
  transition: gap 0.7s ease-in-out, padding-block 0.7s ease-in-out;
}
@media screen and (min-width: 768px) {
  .c-concept__card.js-card-expand .c-concept__card-body {
    padding-block: calc(56 * var(--to-rem));
  }
}

.c-concept__card.js-card-expand .c-concept__card-text,
.c-concept__card.js-card-expand .c-concept__card-button {
  overflow: hidden;
  max-block-size: 0;
  opacity: 0;
  pointer-events: none;
  transform: translateY(calc(12 * var(--to-rem)));
  transition: opacity 0.7s ease-in-out 0.15s, transform 0.7s ease-in-out 0.15s, max-block-size 0.7s ease-in-out;
}

.c-concept__card.js-card-expand.is-expanded .c-concept__card-body {
  gap: calc(28 * var(--to-rem));
  padding-block: calc(50 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-concept__card.js-card-expand.is-expanded .c-concept__card-body {
    gap: calc(32 * var(--to-rem));
    padding-block: calc(81 * var(--to-rem));
  }
}

.c-concept__card.js-card-expand.is-expanded .c-concept__card-text,
.c-concept__card.js-card-expand.is-expanded .c-concept__card-button {
  max-block-size: calc(240 * var(--to-rem));
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.c-cta-button {
  position: fixed;
  inset-inline: auto 0;
  inset-block-end: 0;
  z-index: var(--z-index-fixed);
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-inline-size: calc(260 * var(--to-rem));
  min-block-size: calc(60 * var(--to-rem));
  padding-inline: calc(10 * var(--to-rem));
  border-radius: 30px 0 0;
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: calc(1.125 * var(--base-size));
  line-height: 1;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .c-cta-button {
    min-inline-size: calc(18.75 * var(--base-size));
  }
}
.c-cta-button::after {
  content: "";
  position: absolute;
  inset-block-start: 45%;
  inset-inline-end: calc(20 * var(--to-rem));
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transition: transform var(--duration) ease;
}
@media (any-hover: hover) {
  .c-cta-button:hover::after {
    transform: translate(calc(4 * var(--to-rem)), calc(-4 * var(--to-rem)));
  }
}

.c-cta-button:focus-visible {
  outline: 2px solid var(--color-white);
  outline-offset: -2px;
}

.c-cta-card {
  padding-block: calc(30 * var(--to-rem)) calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-cta-card {
    padding-block: calc(80 * var(--to-rem)) calc(10 * var(--to-rem));
  }
}

.c-cta-card__inner {
  padding-inline: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-cta-card__inner {
    max-inline-size: calc(1380 * var(--to-rem));
    margin-inline: auto;
  }
}

.c-cta-card__wrap {
  display: grid;
  gap: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-cta-card__wrap {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.c-cta-card__link {
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
  min-block-size: calc(110 * var(--to-rem));
  border-radius: 6px;
  color: var(--color-white);
  font-family: var(--base-font-family);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.45;
  letter-spacing: 0.06em;
  text-decoration: none;
}
@media screen and (min-width: 768px) {
  .c-cta-card__link {
    min-block-size: calc(160 * var(--to-rem));
  }
}
@media (any-hover: hover) {
  .c-cta-card__link:hover .c-cta-card__media {
    transform: scale(1.08);
  }
  .c-cta-card__link:hover::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
}

.c-cta-card__link::after {
  content: "";
  position: absolute;
  inset-block-start: calc(20 * var(--to-rem));
  inset-inline-end: calc(20 * var(--to-rem));
  z-index: 2;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transition: transform var(--duration) ease;
}
@media screen and (min-width: 768px) {
  .c-cta-card__link::after {
    inset-block-start: calc(28 * var(--to-rem));
    inset-inline-end: calc(28 * var(--to-rem));
  }
}

.c-cta-card__link:focus-visible {
  outline: 2px solid var(--color-secondary);
  outline-offset: 2px;
}

.c-cta-card__media {
  position: absolute;
  inset: 0;
  z-index: 0;
  transition: transform var(--duration) ease;
}

.c-cta-card__media img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 350/110;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .c-cta-card__media img {
    aspect-ratio: 675/160;
  }
}

.c-cta-card__label {
  position: relative;
  z-index: 2;
  max-inline-size: calc(280 * var(--to-rem));
  margin: 0;
  text-align: center;
  text-wrap: balance;
}

@media (prefers-reduced-motion: reduce) {
  .c-cta-card__media,
  .c-cta-card__link::after {
    transition: none;
  }
  .c-cta-card__link:hover .c-cta-card__media {
    transform: none;
  }
  .c-cta-card__link:hover::after {
    transform: none;
  }
}
.c-detail-nav {
  display: flex;
  justify-content: center;
  align-items: center;
}

.c-detail-nav__block {
  max-width: calc(720 * var(--to-rem));
}

.c-detail-nav__wrap {
  display: flex;
  gap: calc(10 * var(--to-rem));
  justify-content: space-between;
  align-items: flex-start;
}
@media screen and (min-width: 768px) {
  .c-detail-nav__wrap {
    gap: calc(40 * var(--to-rem));
    justify-content: center;
  }
}

.c-detail-nav__item {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.c-detail-nav__btn {
  position: relative;
  display: flex;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: calc(60 * var(--to-rem));
  height: calc(60 * var(--to-rem));
  border: 1px solid var(--color-primary);
  border-radius: 50%;
  background-color: var(--color-primary);
  transition: background-color var(--duration), border-color var(--duration);
}
.c-detail-nav__btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(7 * var(--to-rem));
  height: calc(7 * var(--to-rem));
  border-top: 1px solid var(--color-white);
  border-right: 1px solid var(--color-white);
  transition: border-color var(--duration) ease;
}
@media (any-hover: hover) {
  .c-detail-nav__btn:hover {
    background-color: var(--color-white);
  }
  .c-detail-nav__btn:hover::before {
    border-color: var(--color-primary);
  }
}

.c-detail-nav__item[data-direction=prev] .c-detail-nav__btn::before {
  transform: translate(-25%, -50%) rotate(-135deg);
}

.c-detail-nav__item[data-direction=next] .c-detail-nav__btn::before {
  transform: translate(-75%, -50%) rotate(45deg);
}

.c-detail-nav__back {
  display: flex;
  flex: 1;
  justify-content: center;
  align-items: center;
  min-inline-size: calc(160 * var(--to-rem));
  min-block-size: calc(60 * var(--to-rem));
  padding-block: calc(7 * var(--to-rem));
  padding-inline: calc(6 * var(--to-rem));
  border: 1px solid var(--color-border-light);
  border-radius: 999px;
  color: var(--color-text);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.375;
  text-align: center;
  text-decoration: none;
  transition: background-color var(--duration), color var(--duration);
}
@media screen and (min-width: 768px) {
  .c-detail-nav__back {
    min-inline-size: calc(220 * var(--to-rem));
  }
}
@media (any-hover: hover) {
  .c-detail-nav__back:hover {
    background-color: var(--color-primary);
    color: var(--color-white);
  }
}

.c-dual-cta {
  display: grid;
  gap: calc(12 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-dual-cta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.c-dual-cta__link {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  max-block-size: calc(5.25 * var(--base-size));
  border-radius: 999px;
}
.c-dual-cta__link::after {
  content: "";
  position: absolute;
  inset-block-end: 50%;
  inset-inline-end: calc(1.75 * var(--base-size));
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transform: translateY(50%);
  transition: transform var(--duration) ease;
}
@media (any-hover: hover) {
  .c-dual-cta__link:hover::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
}

.c-dual-cta__link:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.c-dual-cta__link[data-theme=dark]:focus-visible {
  outline-color: var(--color-white);
}

.c-dual-cta__link[data-theme=light] {
  gap: calc(0.5 * var(--base-size));
  padding-inline-start: calc(32 * var(--to-rem));
  border: 1px solid var(--color-border-light);
  background-color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .c-dual-cta__link[data-theme=light] {
    gap: calc(1.25 * var(--base-size));
  }
}

.c-dual-cta__link[data-theme=dark] {
  gap: calc(0.625 * var(--base-size));
  padding-inline-start: calc(10 * var(--to-rem));
  border: 1px solid var(--color-primary);
  background-color: var(--color-primary);
  color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .c-dual-cta__link[data-theme=dark] {
    gap: calc(2.5 * var(--base-size));
  }
}

.c-dual-cta__thumb[data-size=sm] {
  position: relative;
  bottom: 3px;
  inline-size: calc(5.5 * var(--base-size));
}

.c-dual-cta__thumb[data-size=md] {
  position: relative;
  bottom: 3px;
  inline-size: calc(8.75 * var(--base-size));
}

.c-dual-cta__thumb img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
  object-position: bottom;
}

.c-dual-cta__text {
  min-inline-size: 0;
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.375;
  letter-spacing: 0.05em;
  text-align: center;
}

.c-en-title {
  position: relative;
  margin: 0;
  padding-top: calc(20 * var(--to-rem));
  writing-mode: vertical-rl;
  font-size: calc(14 * var(--to-rem));
  line-height: 1;
  letter-spacing: 0.1em;
}

.c-en-title::before {
  content: "";
  position: absolute;
  top: 0;
  left: auto;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: var(--color-badge-gray);
  transform: translateX(-50%);
}

.c-en-title[data-theme=white] {
  color: var(--color-white);
}

.c-faq-accordion {
  --color-active-bg: var(--color-border-gray);
  --color-disabled-bg: #ebedee;
  --color-bg-gray: #f5f6f6;
  margin: 0;
  padding: 0;
  border-block-start: 1px solid var(--color-border);
  list-style: none;
}

.c-faq-accordion__item {
  display: flex;
  flex-direction: column;
  padding-block: calc(34 * var(--to-rem)) calc(35 * var(--to-rem));
  border-block-end: 1px solid var(--color-border);
}
@media screen and (min-width: 768px) {
  .c-faq-accordion__item {
    padding-block-end: calc(32 * var(--to-rem));
    padding-inline: calc(3.75 * var(--base-size)) calc(4.0625 * var(--base-size));
  }
}

.c-faq-accordion__question {
  display: flex;
  gap: calc(30 * var(--to-rem));
  justify-content: space-between;
  inline-size: 100%;
  min-block-size: calc(74 * var(--to-rem));
  margin: 0;
  padding: 0;
  border: none;
  background-color: transparent;
  text-align: left;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .c-faq-accordion__question {
    min-block-size: calc(74 * var(--to-rem));
  }
}

.c-faq-accordion__question-text {
  font-size: calc(1.125 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  text-align: justify;
}

.c-faq-accordion__icon {
  position: relative;
  flex-shrink: 0;
  inline-size: calc(60 * var(--to-rem));
  block-size: calc(60 * var(--to-rem));
  margin-block-start: calc(5 * var(--to-rem));
  border-radius: 50%;
  background-color: var(--color-disabled-bg);
}

.c-faq-accordion__icon::before,
.c-faq-accordion__icon::after {
  content: "";
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  inline-size: calc(20 * var(--to-rem));
  block-size: 1px;
  background-color: var(--color-primary);
  translate: -50% -50%;
  transition: rotate 0.4s ease;
}

.c-faq-accordion__icon::after {
  rotate: 90deg;
}

.c-faq-accordion__item.is-open {
  gap: calc(32 * var(--to-rem));
}

.c-faq-accordion__item.is-open .c-faq-accordion__icon {
  background-color: var(--color-active-bg);
}

.c-faq-accordion__item.is-open .c-faq-accordion__icon::before {
  background-color: var(--color-white);
}

.c-faq-accordion__item.is-open .c-faq-accordion__icon::after {
  background-color: var(--color-white);
  rotate: 0deg;
}

.c-faq-accordion__answer {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s ease;
}

.c-faq-accordion__item.is-open .c-faq-accordion__answer {
  grid-template-rows: 1fr;
  padding-block-end: calc(4 * var(--to-rem));
}

.c-faq-accordion__answer-inner {
  overflow: hidden;
  min-block-size: 0;
  border-radius: 6px;
  background-color: var(--color-white);
}

.c-faq-accordion__answer-inner[data-bg=gray] {
  background-color: var(--color-bg-gray);
}

.c-faq-accordion__answer-text {
  margin: 0;
  padding-block: calc(24 * var(--to-rem)) calc(26 * var(--to-rem));
  padding-inline: calc(30 * var(--to-rem));
  font-size: calc(1 * var(--base-size));
  line-height: 1.8;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  .c-faq-accordion__answer-text {
    inline-size: 100%;
    max-inline-size: calc(540 * var(--to-rem));
    margin-inline: auto;
    padding-block: calc(48 * var(--to-rem)) calc(54 * var(--to-rem));
    padding-inline: calc(20 * var(--to-rem));
  }
}

@media (prefers-reduced-motion: reduce) {
  .c-faq-accordion__answer {
    transition: none;
  }
  .c-faq-accordion__icon::before,
  .c-faq-accordion__icon::after {
    transition: none;
  }
}
.c-land-card {
  display: flex;
  flex-direction: column;
  block-size: 100%;
}
@media (any-hover: hover) {
  .c-land-card:hover .c-land-card__image img {
    transform: scale(1.05);
  }
  .c-land-card:hover .c-land-card__more::after {
    transform: translate(calc(2 * var(--to-rem)), calc(-2 * var(--to-rem)));
  }
}

.c-land-card__image {
  overflow: hidden;
  border-radius: 6px;
}

.c-land-card__image img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 300/200;
  object-fit: cover;
  transition: transform var(--duration) ease;
}

.c-land-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-block-start: calc(28 * var(--to-rem));
  padding-block-end: calc(16 * var(--to-rem));
  border-block-end: 1px solid var(--color-border);
}
@media screen and (min-width: 768px) {
  .c-land-card__head {
    margin-block-start: calc(26 * var(--to-rem));
    padding-block-end: calc(24 * var(--to-rem));
  }
}

.c-land-card__body {
  display: flex;
  flex-grow: 1;
  flex-direction: column;
  margin-block-start: calc(20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-land-card__body {
    margin-block-start: calc(24 * var(--to-rem));
  }
}

.c-land-card__title {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-bold);
}

.c-land-card__title[data-color=white] {
  color: var(--color-white);
}

.c-land-card__more {
  display: inline-flex;
  gap: calc(6 * var(--to-rem));
  align-items: center;
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-medium);
  letter-spacing: 0.05em;
}

.c-land-card__more[data-color=white] {
  color: var(--color-white);
}

.c-land-card__more::after {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(10 * var(--to-rem));
  block-size: calc(10 * var(--to-rem));
  background-color: currentcolor;
  transition: transform var(--duration) ease;
}

.c-land-card__detail {
  display: flex;
  gap: calc(8 * var(--to-rem));
  justify-content: space-between;
  align-items: flex-end;
}

.c-land-card__badge {
  display: inline-flex;
  padding: calc(2 * var(--to-rem)) calc(8 * var(--to-rem));
  border-radius: 4px;
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-medium);
  letter-spacing: 0.05em;
}

.c-land-card__badge[data-color=white] {
  background-color: var(--color-white);
  color: var(--color-primary);
}

.c-land-card__value-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: calc(10 * var(--to-rem));
  align-items: flex-end;
}

.c-land-card__size {
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
}

.c-land-card__size[data-color=white] {
  color: var(--color-white);
}

.c-land-card__value {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
}

.c-land-card__value[data-color=white] {
  color: var(--color-white);
}

.c-land-card__value > em {
  font-size: calc(1.625 * var(--base-size));
  font-style: normal;
  font-weight: var(--fw-medium);
}

.c-land-card__access {
  inline-size: fit-content;
  margin-block-start: calc(10 * var(--to-rem));
  margin-inline-start: auto;
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
}
@media screen and (min-width: 768px) {
  .c-land-card__access {
    margin-block-start: calc(16 * var(--to-rem));
  }
}

.c-land-card__access[data-color=white] {
  color: var(--color-white);
}

.c-lower-mv {
  position: relative;
  min-block-size: calc(400 * var(--to-rem) + var(--header-height));
  padding-block: 0 calc(54 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-lower-mv {
    min-block-size: calc(500 * var(--to-rem) + var(--header-height));
    padding-block: calc(30 * var(--to-rem)) calc(120 * var(--to-rem));
  }
}

.c-lower-mv__bg-text {
  position: absolute;
  inset-block-start: calc(360 * var(--to-rem));
  inset-inline-start: 50%;
  z-index: -1;
  width: 100%;
  max-inline-size: calc(350 * var(--to-rem));
  opacity: 0;
  filter: blur(14px);
  transform: translateX(-50%) scale(1);
  will-change: opacity, filter, transform;
  animation: lower-mv-load-blur 2.2s cubic-bezier(0.215, 0.61, 0.355, 1) forwards;
  animation-delay: 0.42s;
}
@media screen and (min-width: 768px) {
  .c-lower-mv__bg-text {
    inset-block-start: calc(400 * var(--to-rem));
    max-inline-size: calc(1100 * var(--to-rem));
  }
}

@media (prefers-reduced-motion: reduce) {
  .c-lower-mv__bg-text {
    opacity: 1;
    filter: blur(2px);
    transform: translateX(-50%) scale(1.2);
    animation: none;
  }
}
@keyframes lower-mv-load-blur {
  to {
    opacity: 1;
    filter: blur(2.2px);
    transform: translateX(-50%) scale(1.2);
  }
}
.c-lower-mv__bg-text img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.c-lower-mv__inner {
  padding-block-start: calc(95 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-lower-mv__inner {
    position: relative;
    padding-block-start: calc(128 * var(--to-rem));
  }
}

.c-lower-mv__body {
  position: relative;
  inset-inline-start: 42%;
  z-index: 2;
  display: grid;
  grid-template-columns: auto auto;
  column-gap: calc(35 * var(--to-rem));
  justify-content: center;
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .c-lower-mv__body {
    inset-inline-start: calc(-22 * var(--to-rem));
    transform: none;
  }
}

.c-lower-mv__title {
  writing-mode: vertical-rl;
  font-family: var(--old-mincho);
  font-size: calc(1.875 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.6666666667;
  letter-spacing: 0.05em;
}

.c-lower-mv__lead {
  margin-block-start: calc(92 * var(--to-rem));
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  .c-lower-mv__lead {
    position: absolute;
    inset-block-start: 40%;
    inset-inline-end: calc(-12 * var(--to-rem));
    margin-block-start: 0;
    transform: translateY(-50%);
  }
}

.c-lower-mv__lead[data-page=concept] {
  margin-block-start: calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .c-lower-mv__lead[data-page=concept] {
    inset-block-start: 51.4%;
    inset-inline-end: calc(11 * var(--base-size));
    margin-block-start: 0;
  }
}

@media screen and (min-width: 768px) {
  .c-lower-mv__lead[data-page=renovation] {
    inset-block-start: 52%;
    inset-inline-end: calc(13.125 * var(--base-size));
    margin-block-start: 0;
    transform: translateY(-50%);
  }
}

@media screen and (min-width: 768px) {
  .c-lower-mv__lead[data-page=aboutus] {
    inset-block-start: 61%;
    inset-inline-end: 0;
    margin-block-start: 0;
    transform: translateY(-50%);
  }
}

.c-lower-mv__side-label[data-animation=mask],
.c-lower-mv__title[data-animation=mask],
.c-lower-mv__lead[data-animation=mask] {
  clip-path: inset(0 100% 0 0);
  will-change: clip-path;
  animation: lower-mv-text-reveal 0.85s ease-in-out forwards;
}

.c-lower-mv__title[data-animation=mask] {
  animation-delay: 0.14s;
}

.c-lower-mv__lead[data-animation=mask] {
  animation-delay: 0.28s;
}

@media (prefers-reduced-motion: reduce) {
  .c-lower-mv__side-label[data-animation=mask],
  .c-lower-mv__title[data-animation=mask],
  .c-lower-mv__lead[data-animation=mask] {
    clip-path: inset(0);
    animation: none;
  }
}
@keyframes lower-mv-text-reveal {
  from {
    clip-path: inset(0 100% 0 0);
  }
  to {
    clip-path: inset(0);
  }
}
/**
 * ページネーション共通コンポーネント
 *
 * 親（プロジェクト）から上書きする場合:
 *   - 呼び出し元で親クラスで wrap する（例: <div class="p-topics__pagination">...</div>）
 *   - プロジェクトの SCSS ではその wrapper クラスに --_pagination-* を設定する
 *   - 親の CSS ファイルに c-pagination のクラス名は書かない（コンポーネントのカプセル化）
 *
 */
.c-pagination {
  --_pagination-border: #d6dadd;
  --_pagination-arrow: var(--color-text);
  display: flex;
  gap: calc(6 * var(--to-rem));
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .c-pagination {
    gap: calc(2.1875 * var(--base-size));
  }
}

.c-pagination__item[data-sp-state=hidden] {
  display: none;
}
@media screen and (min-width: 768px) {
  .c-pagination__item[data-sp-state=hidden] {
    display: inline-flex;
  }
}

@media screen and (min-width: 768px) {
  .c-pagination__item[data-visible=sp-only] {
    display: none;
  }
}

.c-pagination__item {
  display: inline-flex;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: calc(2.5 * var(--base-size));
  height: calc(2.5 * var(--base-size));
  padding: 0;
  border: 1px solid transparent;
  border-radius: 50%;
  background-color: var(--color-white);
  color: var(--color-text);
  font-size: calc(0.875 * var(--base-size));
  line-height: 1;
  text-decoration: none;
  transition: background-color var(--duration) ease, border-color var(--duration) ease, color var(--duration) ease;
}
@media (any-hover: hover) {
  .c-pagination__item:hover:not([data-state=current], [data-state=dots], [data-state=disabled]) {
    border-color: var(--color-black);
    background-color: var(--color-black);
    color: var(--color-white);
  }
}

.c-pagination__item[data-state=current] {
  border-color: var(--color-black);
  background-color: var(--color-black);
  color: var(--color-white);
}

.c-pagination__item[data-state=dots] {
  width: auto;
  height: auto;
  border: none;
  color: var(--color-text-sub);
  font-weight: var(--fw-light);
  cursor: default;
}

.c-pagination__item[data-state=prev],
.c-pagination__item[data-state=next] {
  position: relative;
  width: calc(3.75 * var(--base-size));
  height: calc(3.75 * var(--base-size));
  border: 1px solid var(--_pagination-border);
  transition: background-color var(--duration) ease, border-color var(--duration) ease, color var(--duration) ease;
}
.c-pagination__item[data-state=prev]::before,
.c-pagination__item[data-state=next]::before {
  content: "";
  display: block;
  width: calc(6 * var(--to-rem));
  height: calc(6 * var(--to-rem));
  border-top: 1px solid var(--_pagination-arrow);
  border-right: 1px solid var(--_pagination-arrow);
}

@media (any-hover: hover) {
  .c-pagination__item[data-state=prev]:hover:not([data-state=disabled]),
  .c-pagination__item[data-state=next]:hover:not([data-state=disabled]) {
    border-color: var(--color-black);
    background-color: var(--color-black);
    color: var(--color-white);
  }
  .c-pagination__item[data-state=prev]:hover:not([data-state=disabled])::before,
  .c-pagination__item[data-state=next]:hover:not([data-state=disabled])::before {
    border-top: 1px solid var(--color-white);
    border-right: 1px solid var(--color-white);
  }
}
.c-pagination__item[data-state=prev]::before {
  transform: rotate(-135deg) translate(-15%, 15%);
}

.c-pagination__item[data-state=next]::before {
  transform: rotate(45deg) translate(-15%, 15%);
}

.c-pagination__item[data-state=disabled] {
  opacity: 0.6;
  cursor: default;
}
@media (any-hover: hover) {
  .c-pagination__item[data-state=disabled]:hover {
    border-color: transparent;
    background-color: var(--color-white);
    color: var(--color-text);
  }
}

.c-section-title {
  display: grid;
  gap: calc(1.875 * var(--base-size));
}
@media screen and (min-width: 768px) {
  .c-section-title {
    gap: calc(2.75 * var(--base-size));
  }
}

.c-section-title__main {
  color: var(--color-text);
  font-family: var(--gothic-antique);
  font-size: calc(1.875 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.01em;
}

.c-section-title__main[data-size=small] {
  font-size: calc(1.5 * var(--base-size));
}
@media screen and (min-width: 768px) {
  .c-section-title__main[data-size=small] {
    font-size: calc(1.875 * var(--base-size));
  }
}

.c-section-title__sub {
  color: var(--color-text);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  text-align: justify;
}

.c-triangle {
  display: inline-block;
  width: calc(64 * var(--to-rem));
  aspect-ratio: 1/1;
  background-color: var(--color-black);
}

.c-triangle[data-direction=top] {
  clip-path: var(--clip-triangle-top);
}

.c-triangle[data-direction=bottom] {
  clip-path: var(--clip-triangle-bottom);
}

.c-triangle[data-direction=left] {
  clip-path: var(--clip-triangle-left);
}

.c-triangle[data-direction=right] {
  clip-path: var(--clip-triangle-right);
}

.c-triangle[data-direction=lower-left] {
  clip-path: var(--clip-triangle-lower-left);
}

.c-triangle[data-direction=upper-left] {
  clip-path: var(--clip-triangle-upper-left);
}

.c-triangle[data-direction=lower-right] {
  clip-path: var(--clip-triangle-lower-right);
}

.c-triangle[data-direction=upper-right] {
  clip-path: var(--clip-triangle-upper-right);
}

.c-view-button {
  position: relative;
  display: inline-block;
  width: fit-content;
  padding-block: calc(10 * var(--to-rem));
  padding-inline: calc(20 * var(--to-rem));
  font-size: calc(14 * var(--to-rem));
  line-height: 1;
  letter-spacing: 0.05em;
}
.c-view-button::before {
  content: "";
  position: absolute;
  inset-block-end: 45%;
  inset-inline-end: 0;
  display: inline-block;
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(9 * var(--to-rem));
  block-size: calc(9 * var(--to-rem));
  background-color: currentcolor;
  transform: translateY(50%);
  transition: transform var(--duration) ease;
}
@media (any-hover: hover) {
  .c-view-button:hover::before {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
}

.c-view-button:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.p-aboutus-company {
  padding-block-end: calc(44 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-aboutus-company {
    padding-block-end: calc(100 * var(--to-rem));
  }
}

.p-aboutus-company__inner {
  position: relative;
}

.p-aboutus-company__table {
  margin-block-start: calc(14 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-aboutus-company__table {
    margin-block-start: calc(30 * var(--to-rem));
  }
}

.p-aboutus-company__row {
  display: grid;
  gap: calc(12 * var(--to-rem));
  padding-block: calc(20 * var(--to-rem)) calc(16 * var(--to-rem));
  border-block-end: 1px solid var(--color-badge-gray);
}
@media screen and (min-width: 768px) {
  .p-aboutus-company__row {
    grid-template-columns: minmax(0, min(160 * var(--to-rem), 80%)) minmax(0, 1fr);
    gap: calc(20 * var(--to-rem));
    padding-block: calc(14 * var(--to-rem)) calc(14 * var(--to-rem));
    padding-inline-start: calc(90 * var(--to-rem));
  }
}

.p-aboutus-company__row:last-child {
  border-block-end: none;
}

.p-aboutus-company__term {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .p-aboutus-company__term {
    padding-block-start: calc(8 * var(--to-rem));
  }
}

.p-aboutus-company__desc {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  letter-spacing: -0.05em;
}

.p-aboutus-company__desc em {
  font-style: normal;
  font-weight: var(--fw-bold);
}
@media screen and (min-width: 768px) {
  .p-aboutus-company__desc em {
    margin-inline-end: calc(4 * var(--to-rem));
  }
}

.p-aboutus-company__area {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-start;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-aboutus-company__area {
    display: inline;
    width: auto;
  }
}

@media screen and (min-width: 768px) {
  .p-aboutus-company__area + .p-aboutus-company__area {
    display: inline;
    width: auto;
    margin-top: 0;
  }
}

.p-aboutus-company__area-pref {
  flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .p-aboutus-company__area-pref {
    flex: unset;
    min-width: 0;
  }
}

.p-aboutus-company__area-txt {
  flex: 1 1 0%;
  min-width: 0;
}
@media screen and (min-width: 768px) {
  .p-aboutus-company__area-txt {
    flex: unset;
    min-width: 0;
  }
}

.p-aboutus__map {
  overflow: hidden;
  aspect-ratio: 1/1;
  margin-block-start: calc(20 * var(--to-rem));
  margin-inline: calc(50% - 50vi);
  border-radius: 6px;
}
@media screen and (min-width: 768px) {
  .p-aboutus__map {
    aspect-ratio: 1360/630;
    margin-block-start: calc(80 * var(--to-rem));
    padding-inline: calc(20 * var(--to-rem));
  }
}

.p-aboutus__map iframe {
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 6px;
  filter: grayscale(100%);
}

.p-aboutus-company__cta {
  margin-block-start: calc(42 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-aboutus-company__cta {
    max-inline-size: calc(800 * var(--to-rem));
    margin-block-start: calc(86 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-aboutus-company__line {
  text-decoration: underline;
  text-decoration-color: oklch(from var(--color-primary) l c h/30%);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
}

.p-aboutus-staff {
  overflow: hidden;
  padding-block-end: calc(92 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-aboutus-staff {
    padding-block-end: calc(192 * var(--to-rem));
  }
}

.p-aboutus-staff__track {
  overflow: hidden;
  margin-block-end: calc(10 * var(--to-rem));
}

@media screen and (min-width: 768px) {
  .p-aboutus-staff__track--sp {
    display: none;
  }
}

.p-aboutus-staff__track--pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-aboutus-staff__track--pc {
    display: block;
  }
}

.p-aboutus-staff__scroller {
  display: flex;
  inline-size: max-content;
  transform: translate3d(0, 0, 0);
  will-change: transform;
}

.p-aboutus-staff__scroller[data-direction=forward] {
  animation: marquee-forward 26s linear infinite;
}
@media screen and (min-width: 768px) {
  .p-aboutus-staff__scroller[data-direction=forward] {
    animation: marquee-forward 46s linear infinite;
  }
}

.p-aboutus-staff__scroller[data-direction=reverse] {
  animation: marquee-reverse 26s linear infinite;
}
@media screen and (min-width: 768px) {
  .p-aboutus-staff__scroller[data-direction=reverse] {
    animation: marquee-reverse 46s linear infinite;
  }
}

.p-aboutus-staff__list {
  display: flex;
  flex-shrink: 0;
  margin: 0;
  list-style: none;
}

.p-aboutus-staff__item {
  flex-shrink: 0;
  overflow: hidden;
  inline-size: calc(180 * var(--to-rem));
  margin-inline-start: calc(10 * var(--to-rem));
  border-radius: 6px;
}
@media screen and (min-width: 768px) {
  .p-aboutus-staff__item {
    inline-size: calc(240 * var(--to-rem));
  }
}

.p-aboutus-staff__item img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 180/120;
  object-fit: cover;
}

@keyframes marquee-forward {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-50%, 0, 0);
  }
}
@keyframes marquee-reverse {
  from {
    transform: translate3d(-50%, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .p-aboutus-staff__scroller {
    animation: none;
  }
}
.p-aboutus {
  padding-block-end: calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-aboutus {
    padding-block: calc(20 * var(--to-rem)) calc(128 * var(--to-rem));
  }
}

.p-aboutus__content {
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-aboutus__content {
    display: flex;
    gap: calc(6.25 * var(--base-size));
    align-items: center;
  }
}

.p-aboutus__image {
  overflow: hidden;
  margin-inline-start: calc(50% - 50vi);
  border-radius: 0 8px 8px 0;
}

.p-aboutus__image img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 335/300;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-aboutus__image img {
    aspect-ratio: 625/390;
  }
}

.p-aboutus__text {
  margin-block-start: calc(66 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-aboutus__text {
    flex: 0 0 48%;
    margin-block-start: calc(-15 * var(--to-rem));
  }
}

.js-parallax {
  overflow: hidden;
}

.js-parallax.js-parallax img {
  height: calc(100% + 60px);
  margin-block-start: calc(-30 * var(--to-rem));
}

.p-card-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(calc(320 * var(--to-rem)), 1fr));
  gap: calc(24 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-card-list {
    gap: calc(32 * var(--to-rem));
  }
}

.p-concept-detail {
  position: relative;
  padding-block: 0 calc(70 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-concept-detail {
    padding-block-end: calc(110 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-concept-detail__inner.l-inner {
    position: relative;
    max-inline-size: calc(1190 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-concept-detail__stage {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-concept-detail__stage {
    --min: 15;
    --max: 50;
    --min-vw: 800;
    --max-vw: 1400;
    position: absolute;
    inset-block: 0;
    inset-inline-end: 0;
    display: block;
    inline-size: calc(30.9375 * var(--base-size));
    margin-inline-end: clamp(var(--min) * 1px, var(--min) * 1px + (var(--max) - var(--min)) * (100vw - var(--min-vw) * 1px) / (var(--max-vw) - var(--min-vw)), var(--max) * 1px);
    pointer-events: none;
  }
}

@media screen and (min-width: 768px) {
  .p-concept-detail__stage-wrap {
    position: sticky;
    inset-block-start: calc(120 * var(--to-rem));
    overflow: hidden;
    inline-size: calc(30.9375 * var(--base-size));
    aspect-ratio: 495/330;
    border-radius: calc(8 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-concept-detail__stage-image {
    position: absolute;
    inset: 0;
    margin: 0;
    opacity: 0;
    will-change: opacity;
    transition: opacity 0.6s ease;
  }
}

@media screen and (min-width: 768px) {
  .p-concept-detail__stage-image.is-active {
    opacity: 1;
  }
}

@media screen and (min-width: 768px) {
  .p-concept-detail__stage-image img {
    display: block;
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}

.p-concept-detail__item {
  display: flex;
  flex-direction: column;
  gap: calc(38 * var(--to-rem));
  scroll-margin-block-start: calc(var(--header-height) + 20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-concept-detail__item {
    gap: 0;
  }
}

.p-concept-detail__item + .p-concept-detail__item {
  margin-block-start: calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-concept-detail__item + .p-concept-detail__item {
    margin-block-start: calc(122 * var(--to-rem));
  }
}

.p-concept-detail__image {
  overflow: hidden;
  border-radius: calc(8 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-concept-detail__image {
    display: none;
  }
}

.p-concept-detail__image img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 300/200;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-concept-detail__image img {
    aspect-ratio: 495/330;
  }
}

.p-concept-detail__body {
  display: flex;
  flex-direction: column;
  gap: calc(32 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-concept-detail__body {
    gap: 0;
    width: 46.0869565217%;
    padding-block-start: calc(18 * var(--to-rem));
  }
}

.p-concept-detail__title-wrap {
  position: relative;
  padding-inline-start: calc(30 * var(--to-rem));
}

.p-concept-detail__num {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 0;
  z-index: -1;
  display: block;
  inline-size: calc(3.75 * var(--base-size));
  block-size: calc(3.75 * var(--base-size));
  transform: translateY(-50%);
}

.p-concept-detail__num img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.p-concept-detail__title {
  position: relative;
  z-index: 5;
  width: max-content;
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.8;
}

.p-concept-detail__head {
  font-size: calc(1.875 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.6333333333;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 768px) {
  .p-concept-detail__head {
    margin-block-start: calc(82 * var(--to-rem));
    padding-inline-start: calc(30 * var(--to-rem));
  }
}

.p-concept-detail__content {
  display: flex;
  flex-direction: column;
  gap: 1.6em;
}
@media screen and (min-width: 768px) {
  .p-concept-detail__content {
    margin-block-start: calc(50 * var(--to-rem));
    padding-inline-start: calc(30 * var(--to-rem));
  }
}

.p-concept-detail__paragraph {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  text-align: justify;
}

.p-concept-detail__button-wrap {
  width: 100%;
  max-inline-size: calc(300 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-concept-detail__button-wrap {
    max-inline-size: calc(260 * var(--to-rem));
    margin-block-start: calc(54 * var(--to-rem));
    margin-inline: auto 0;
  }
}
.p-concept-detail__button-wrap .c-button {
  font-size: calc(0.875 * var(--base-size));
}

.p-concept {
  padding-block-end: calc(50 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-concept {
    padding-block-end: calc(105 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-concept__inner.l-inner {
    max-inline-size: calc(1330 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-concept__head {
  padding-block-start: calc(56 * var(--to-rem));
  border-block-start: 1px solid var(--color-border);
}
@media screen and (min-width: 768px) {
  .p-concept__head {
    width: 64.6153846154%;
    margin-inline: auto;
    padding-block-start: calc(86 * var(--to-rem));
    border-block-start: none;
  }
}

.p-concept__text {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  text-align: justify;
}

.p-concept__features {
  margin-block-start: calc(40 * var(--to-rem));
  margin-inline: calc(50% - 50vi);
  padding-block: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-concept__features {
    margin-block-start: calc(86 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-concept__splide {
  position: relative;
}

.p-concept__splide:not(.is-initialized),
.p-concept__splide:not(.is-initialized) .splide__track {
  visibility: visible;
}

.p-concept__splide:not(.is-initialized) .splide__track {
  overflow: visible;
}

@media screen and (min-width: 768px) {
  .p-concept__splide .p-concept__list,
  .p-concept__splide.splide.is-initialized:not(.is-active) .p-concept__list.splide__list {
    --min: 10;
    --max: 60;
    --min-vw: 850;
    --max-vw: 1400;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(3.75 * var(--base-size));
    gap: clamp(var(--min) * 1px, var(--min) * 1px + (var(--max) - var(--min)) * (100vw - var(--min-vw) * 1px) / (var(--max-vw) - var(--min-vw)), var(--max) * 1px);
    transform: none !important;
  }
}

@media screen and (min-width: 768px) {
  .p-concept__splide .p-concept__item {
    inline-size: auto !important;
    margin-inline-end: 0 !important;
  }
}

/* ── Splide arrows（SP のみ・ビューポート左右端固定） ── */
.p-concept__arrows {
  position: absolute;
  inset-inline: calc(50% - 50vi);
  inset-block-start: 0;
  aspect-ratio: 370/160;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-concept__arrows {
    display: none;
  }
}

.p-concept__arrow.splide__arrow {
  position: absolute;
  inset-block-start: 50%;
  inline-size: calc(72 * var(--to-rem));
  block-size: calc(72 * var(--to-rem));
  padding: 0;
  border: 0;
  border-radius: 50%;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(-50%);
  transition: filter var(--duration) ease;
}
@media (any-hover: hover) {
  .p-concept__arrow.splide__arrow:hover:not(:disabled) {
    opacity: 1;
    filter: brightness(1.1);
  }
}

.p-concept__arrow.splide__arrow--prev {
  inset-inline-start: calc(-36 * var(--to-rem));
}

.p-concept__arrow.splide__arrow--next {
  inset-inline-end: calc(-36 * var(--to-rem));
}

.p-concept__arrow.splide__arrow svg {
  display: none;
}

.p-concept__arrow img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.p-concept__arrow.splide__arrow:disabled {
  opacity: 0.4;
}

.p-concept__item a {
  display: flex;
  flex-direction: column;
  block-size: 100%;
}
@media (any-hover: hover) {
  .p-concept__item a:hover .p-concept__more::after {
    transform: translate(calc(4 * var(--to-rem)), calc(4 * var(--to-rem))) rotate(90deg);
  }
  .p-concept__item a:hover .p-concept__image img {
    transform: scale(1.06);
  }
}

.p-concept__image {
  overflow: hidden;
  border-radius: calc(6 * var(--to-rem));
}

.p-concept__image img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 240/160;
  object-fit: cover;
  transition: transform var(--duration) ease;
}

.p-concept__body {
  display: grid;
  grid-template-rows: auto 1fr auto;
  flex-grow: 1;
  margin-block-start: calc(44 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-concept__body {
    grid-template-columns: repeat(2, auto);
    grid-template-rows: repeat(2, auto);
    flex-grow: 0;
    margin-block-start: calc(40 * var(--to-rem));
  }
}

.p-concept__title-wrap {
  position: relative;
  grid-area: 1/1/2/2;
  padding-block-end: calc(26 * var(--to-rem));
  padding-inline-start: calc(1.875 * var(--base-size));
}
@media screen and (min-width: 768px) {
  .p-concept__title-wrap {
    grid-area: 1/1/2/2;
  }
}

.p-concept__num {
  position: absolute;
  inset-block-start: 30%;
  inset-inline-start: 0;
  z-index: -1;
  display: block;
  inline-size: calc(3.75 * var(--base-size));
  block-size: calc(3.75 * var(--base-size));
  transform: translateY(-50%);
}

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

.p-concept__title {
  position: relative;
  z-index: 5;
  width: max-content;
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.8;
}

.p-concept__lead {
  grid-area: 2/1/3/2;
  padding-block-start: calc(32 * var(--to-rem));
  border-block-start: 1px solid var(--color-border);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  .p-concept__lead {
    grid-area: 2/1/3/3;
  }
}

.p-concept__more {
  display: inline-flex;
  grid-area: 3/1/4/2;
  gap: calc(4 * var(--to-rem));
  justify-content: flex-end;
  align-items: center;
  margin-block-start: calc(20 * var(--to-rem));
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-medium);
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-concept__more {
    grid-area: 1/2/2/3;
    gap: calc(6 * var(--to-rem));
    margin-block-start: 0;
    padding-block-end: calc(23 * var(--to-rem));
    white-space: nowrap;
  }
}
.p-concept__more::after {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(10 * var(--to-rem));
  block-size: calc(10 * var(--to-rem));
  background-color: currentcolor;
  transform: rotate(90deg);
  transition: transform var(--duration) ease;
}

.p-contact {
  padding-block: calc(72 * var(--to-rem));
}

.p-contact__form {
  margin-block-start: calc(64 * var(--to-rem));
}

.p-contact__title {
  display: grid;
  place-items: center;
}

.p-dev-notice {
  padding-block: calc(24 * var(--to-rem));
  background-color: #fff3cd;
}
@media screen and (min-width: 768px) {
  .p-dev-notice {
    padding-block: calc(32 * var(--to-rem));
  }
}

.p-dev-notice__inner {
  max-width: calc(var(--inner) + var(--padding-inner) * 2);
}

.p-dev-notice__content {
  display: flex;
  flex-direction: column;
  gap: calc(16 * var(--to-rem));
  color: var(--color-text);
  font-size: calc(14 * var(--to-rem));
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  .p-dev-notice__content {
    gap: calc(20 * var(--to-rem));
    font-size: calc(16 * var(--to-rem));
  }
}

.p-dev-notice__title {
  color: var(--color-text);
  font-size: calc(18 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  .p-dev-notice__title {
    font-size: calc(20 * var(--to-rem));
  }
}

.p-dev-notice__text code {
  padding-block: calc(2 * var(--to-rem));
  padding-inline: calc(6 * var(--to-rem));
  border-radius: 4px;
  background-color: rgba(0, 0, 0, 0.05);
  color: var(--color-primary);
  font-family: "Courier New", Courier, monospace;
  font-size: calc(13 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-dev-notice__text code {
    font-size: calc(14 * var(--to-rem));
  }
}

.p-dev-notice__list {
  display: flex;
  flex-direction: column;
  gap: calc(12 * var(--to-rem));
  margin: 0;
  padding-inline-start: calc(24 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-dev-notice__list {
    gap: calc(16 * var(--to-rem));
    padding-inline-start: calc(32 * var(--to-rem));
  }
}

.p-dev-notice__item {
  display: flex;
  flex-direction: column;
  gap: calc(4 * var(--to-rem));
  line-height: 1.8;
}

.p-dev-notice__item strong {
  color: var(--color-primary);
  font-weight: var(--fw-bold);
}

.p-dev-notice__item code {
  padding-block: calc(2 * var(--to-rem));
  padding-inline: calc(6 * var(--to-rem));
  border-radius: 4px;
  background-color: rgba(0, 0, 0, 0.05);
  color: var(--color-primary);
  font-family: "Courier New", Courier, monospace;
  font-size: calc(13 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-dev-notice__item code {
    font-size: calc(14 * var(--to-rem));
  }
}

.p-dual-cta {
  position: relative;
}

.p-dual-cta__inner {
  max-width: calc(370 * var(--to-rem));
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .p-dual-cta__inner {
    max-inline-size: calc(880 * var(--to-rem));
  }
}

/* 全セクションの英語サイドラベル（右端固定 + フェード切替） */
.p-en-title-rail {
  position: fixed;
  inset-block: 0;
  inset-inline-end: calc(20 * var(--to-rem));
  z-index: var(--z-index-fixed);
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-en-title-rail {
    inset-inline-end: calc(58 * var(--to-rem));
  }
}

.p-en-title {
  position: fixed;
  top: calc(var(--header-height) + 16 * var(--to-rem));
  inset-inline-end: calc(20 * var(--to-rem));
  margin: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration) ease;
}
@media screen and (min-width: 768px) {
  .p-en-title {
    inset-inline-end: calc(36 * var(--to-rem));
  }
}

.p-en-title-rail .p-en-title {
  position: absolute;
  top: calc(var(--header-height) + 56 * var(--to-rem));
  inset-inline-end: 0;
}

.p-en-title.is-active {
  opacity: 1;
}

.p-error {
  padding-block: calc(120 * var(--to-rem)) calc(80 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-error {
    padding-block: calc(180 * var(--to-rem));
  }
}

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

.p-error__header + .p-error__content {
  margin-block-start: calc(24 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-error__header + .p-error__content {
    margin-block-start: calc(32 * var(--to-rem));
  }
}

.p-error__title {
  color: var(--color-text);
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  .p-error__title {
    font-size: calc(1.75 * var(--base-size));
  }
}

.p-error__content {
  max-width: calc(640 * var(--to-rem));
  margin-inline: auto;
  color: var(--color-text);
  font-size: calc(14 * var(--to-rem));
  line-height: 1.8;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-error__content {
    font-size: calc(16 * var(--to-rem));
  }
}

.p-error__content p {
  margin-block-start: calc(32 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-error__content p {
    margin-block-start: calc(42 * var(--to-rem));
  }
}

.p-error__button {
  max-inline-size: calc(300 * var(--to-rem));
  margin-block-start: calc(46 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-error__button {
    margin-block-start: calc(56 * var(--to-rem));
  }
}

.p-faq-cta {
  padding-block: 0 calc(60 * var(--to-rem));
}

.p-faq-cta__inner {
  max-inline-size: calc(370 * var(--to-rem));
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .p-faq-cta__inner {
    max-inline-size: calc(880 * var(--to-rem));
  }
}

.p-faq {
  --color-faq-border: #717f88;
  --color-faq-text: var(--color-border-gray);
  padding-block: calc(5 * var(--to-rem)) calc(63 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-faq {
    padding-block: calc(125 * var(--to-rem)) calc(122 * var(--to-rem));
  }
}

.p-faq__layout {
  display: flex;
  flex-direction: column;
  gap: calc(42 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-faq__layout {
    flex-direction: row;
    gap: calc(40 * var(--to-rem));
    align-items: flex-start;
  }
}

@media screen and (min-width: 768px) {
  .p-faq__cat-nav {
    position: sticky;
    top: calc(120 * var(--to-rem));
    flex: 0 0 calc(18.75 * var(--base-size));
  }
}

.p-faq__cat-list {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding-block: calc(6 * var(--to-rem));
  border-radius: 6px;
  list-style: none;
  background-color: var(--color-primary);
}

.p-faq__cat-item {
  padding-inline: calc(30 * var(--to-rem));
}

.p-faq__cat-link {
  display: inline-flex;
  gap: calc(8 * var(--to-rem));
  justify-content: space-between;
  align-items: center;
  inline-size: 100%;
  min-block-size: calc(54 * var(--to-rem));
  padding-block: calc(26 * var(--to-rem));
  padding-inline-end: calc(18 * var(--to-rem));
  border-block-end: 1px solid var(--color-faq-border);
  color: var(--color-faq-text);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.05em;
  transition: color 0.2s;
}
.p-faq__cat-link::after {
  content: "";
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(10 * var(--to-rem));
  block-size: calc(10 * var(--to-rem));
  background-color: currentcolor;
  rotate: 90deg;
  transition: rotate 0.2s;
}

.p-faq__cat-item:last-child .p-faq__cat-link {
  border-block-end: none;
}

.p-faq__cat-item.is-current .p-faq__cat-link {
  color: var(--color-white);
  cursor: default;
}

.p-faq__cat-item.is-current .p-faq__cat-link::after {
  rotate: 45deg;
}

@media (any-hover: hover) {
  .p-faq__cat-item:not(.is-current) .p-faq__cat-link:hover {
    color: var(--color-white);
  }
}
.p-faq__accordion {
  flex: 1;
  min-inline-size: 0;
}

.p-footer {
  position: relative;
  padding-block: calc(18 * var(--to-rem)) calc(62 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-footer {
    padding-block: calc(60 * var(--to-rem));
  }
}

.p-footer__logo {
  display: block;
  width: 100%;
  max-inline-size: calc(370 * var(--to-rem));
  margin-inline: auto;
  padding-inline: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-footer__logo {
    max-inline-size: calc(1340 * var(--to-rem));
  }
}

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

.p-footer__inner {
  margin-block-start: calc(44 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-footer__inner {
    margin-block-start: calc(78 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-footer__content {
    display: flex;
    gap: calc(12 * var(--to-rem));
    justify-content: space-between;
    max-inline-size: calc(930 * var(--to-rem));
    margin-inline: auto;
  }
}

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

.p-footer__name {
  display: inline-block;
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
  transition: opacity var(--duration) ease;
}
@media screen and (min-width: 768px) {
  .p-footer__name {
    margin-block: calc((1em - 1lh) / 2);
  }
}
@media (any-hover: hover) {
  .p-footer__name:hover {
    opacity: var(--opacity);
  }
}

.p-footer__address {
  margin-block-start: calc(18 * var(--to-rem));
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.5;
}

.p-footer__tel {
  display: block;
  margin-block-start: calc(6 * var(--to-rem));
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.5;
  transition: opacity var(--duration) ease;
}
@media (any-hover: hover) {
  .p-footer__tel:hover {
    opacity: var(--opacity);
  }
}

.p-footer__license {
  margin-block-start: calc(16 * var(--to-rem));
  font-size: calc(0.8125 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.7142857143;
}
@media screen and (min-width: 768px) {
  .p-footer__license {
    font-size: max(0.875 * var(--base-size), 10px);
  }
}

.p-footer__nav {
  margin-block-start: calc(48 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-footer__nav {
    width: 100%;
    min-inline-size: calc(440 * var(--to-rem));
    max-inline-size: calc(33.75 * var(--base-size));
    margin-block-start: 0;
  }
}

.p-footer__list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 calc(2.5 * var(--base-size));
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-footer__list {
    grid-template-columns: 120fr 140fr 200fr;
  }
}

.p-footer__item:last-of-type {
  grid-column: 1/3;
}
@media screen and (min-width: 768px) {
  .p-footer__item:last-of-type {
    grid-column: auto;
  }
}

.p-footer__item a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: calc(60 * var(--to-rem));
  border-bottom: 1px solid var(--color-border);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.75;
  transition: opacity var(--duration) ease;
}
@media screen and (min-width: 768px) {
  .p-footer__item a {
    justify-content: flex-start;
    padding-inline-start: calc(1.25 * var(--base-size));
  }
}
@media (any-hover: hover) {
  .p-footer__item a:hover {
    opacity: var(--opacity);
  }
}

.p-footer__item:nth-of-type(1) a,
.p-footer__item:nth-of-type(2) a {
  border-top: 1px solid var(--color-border);
}

@media screen and (min-width: 768px) {
  .p-footer__item:nth-of-type(3) a {
    border-top: 1px solid var(--color-border);
  }
}

.p-footer__item a:focus-visible {
  outline: 2px solid #2f4555;
  outline-offset: 2px;
}

.p-footer__copyright {
  display: block;
  margin-block-start: calc(34 * var(--to-rem));
  margin-inline: calc(-30 * var(--to-rem));
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-light);
  line-height: 1.7142857143;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-footer__copyright {
    width: fit-content;
    margin-block-start: calc(40 * var(--to-rem));
    margin-inline-start: auto;
    margin-inline-end: unset;
    padding-inline-end: calc(50 * var(--to-rem));
    font-size: max(0.875 * var(--base-size), 12px);
  }
}

.p-form {
  --_contact-border: var(--color-border);
  --_contact-bg: #f5f6f6;
  --_contact-focus: oklch(from var(--color-primary) l c h / 10%);
  --_contact-badge-required-bg: var(--color-primary);
  --_contact-badge-required-text: var(--color-white);
  --_contact-badge-optional-bg: #9ca5ac;
  --_contact-placeholder-text: #859199;
  --_contact-error: #dc3232;
  --_contact-error-bg: #fff4f4;
}
@media screen and (min-width: 768px) {
  .p-form {
    padding-inline: calc(20 * var(--to-rem));
  }
}

.p-form__bg {
  padding-block: calc(68 * var(--to-rem));
  border-radius: 12px;
  background-color: var(--_contact-bg);
}
@media screen and (min-width: 768px) {
  .p-form__bg {
    padding-block: calc(115 * var(--to-rem)) calc(156 * var(--to-rem));
  }
}

.p-form__content {
  max-width: calc(500 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-form__content {
    display: contents;
  }
}

.p-form__title {
  font-size: calc(20 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: 1.4;
  text-align: center;
}

.p-form__text {
  margin-block-start: calc(30 * var(--to-rem));
  color: var(--color-text);
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-form__text {
    width: 100%;
    max-width: calc(800 * var(--to-rem));
    margin-block-start: calc(50 * var(--to-rem));
    margin-inline: auto;
    letter-spacing: 0.02em;
  }
}

.p-form__body {
  display: grid;
  gap: calc(30 * var(--to-rem));
  width: 100%;
  max-width: calc(800 * var(--to-rem));
  margin-block-start: calc(30 * var(--to-rem));
  margin-inline: auto;
  border-block-start: 1px solid var(--_contact-border);
}
@media screen and (min-width: 768px) {
  .p-form__body {
    gap: calc(50 * var(--to-rem));
    margin-block-start: calc(76 * var(--to-rem));
  }
}

.p-form__fields {
  display: grid;
  gap: calc(35 * var(--to-rem));
  padding-block-start: calc(38 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-form__fields {
    gap: calc(58 * var(--to-rem));
    padding-block-start: calc(56 * var(--to-rem));
  }
}

.p-form__field {
  display: grid;
  gap: calc(12 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-form__field {
    grid-template-columns: calc(180 * var(--to-rem)) minmax(0, 1fr);
    gap: calc(20 * var(--to-rem));
    align-items: start;
  }
}

.p-form__label {
  display: flex;
  flex-wrap: wrap;
  gap: calc(8 * var(--to-rem));
  align-items: center;
  color: var(--color-text);
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.4;
}
@media screen and (min-width: 768px) {
  .p-form__label {
    padding-block-start: calc(8 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-form__label-br {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .p-form__label[data-layout=row] {
    row-gap: 0;
    padding-block-start: calc(10 * var(--to-rem));
  }
}

.p-form__label span {
  font-family: var(--gothic-new);
  font-size: calc(14 * var(--to-rem));
  font-weight: var(--fw-regular);
}
@media screen and (min-width: 768px) {
  .p-form__label span {
    width: 100%;
    padding-inline-start: calc(40 * var(--to-rem));
  }
}

.p-form__label[data-required=required]::before,
.p-form__label[data-required=optional]::before {
  position: relative;
  top: 0.1em;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-inline-size: calc(40 * var(--to-rem));
  min-block-size: calc(16 * var(--to-rem));
  padding: calc(2 * var(--to-rem)) calc(4 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: 1;
}

.p-form__label[data-required=required]::before {
  content: "必須";
  background-color: var(--_contact-badge-required-bg);
  color: var(--_contact-badge-required-text);
}

.p-form__label[data-required=optional]::before {
  content: "任意";
  background-color: var(--_contact-badge-optional-bg);
  color: var(--_contact-badge-required-text);
}

.p-form__control-wrap {
  display: grid;
  gap: calc(12 * var(--to-rem));
  min-width: 0;
}

.p-form__choices {
  display: grid;
  gap: calc(17 * var(--to-rem));
  padding-block-start: calc(6 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-form__choices {
    grid-template-columns: repeat(2, auto);
    gap: calc(15 * var(--to-rem)) calc(27 * var(--to-rem));
    justify-content: start;
    padding-block-start: 0;
  }
}

.p-form__choice {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: calc(6 * var(--to-rem));
  align-items: center;
  cursor: pointer;
}

.p-form__choice input[type=radio] {
  display: grid;
  place-content: center;
  width: calc(16 * var(--to-rem));
  height: calc(16 * var(--to-rem));
  margin: 0;
  border: 2px solid var(--_contact-border);
  border-radius: 50%;
  background-color: var(--color-white);
  appearance: none;
}

.p-form__choice input[type=radio]:checked {
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Ccircle cx='10' cy='10' r='6' fill='%2300396d'/%3E%3C/svg%3E");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  background-color: var(--color-white);
}

.p-form__choice span {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.5;
}

.p-form__input:focus,
.p-form__textarea:focus {
  box-shadow: 0 0 0 3px var(--_contact-focus);
  outline-color: var(--_contact-focus);
}

.p-form__input::placeholder,
.p-form__textarea::placeholder {
  color: var(--_contact-placeholder-text);
  font-family: var(--gothic-new);
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-regular);
}

.p-form__privacy-wrap {
  display: grid;
  gap: calc(22 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-form__privacy-wrap {
    gap: calc(24 * var(--to-rem));
  }
}

.p-form__privacy {
  display: grid;
  gap: calc(4 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-form__privacy {
    gap: calc(2 * var(--to-rem));
  }
}

.p-form__privacy-text {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: justify;
}

@media screen and (min-width: 768px) {
  .p-form__privacy-title + .p-form__privacy-text {
    margin-block-start: calc(6 * var(--to-rem));
  }
}

.p-form__agree {
  display: flex;
  gap: calc(6 * var(--to-rem));
  justify-content: center;
  align-items: center;
  cursor: pointer;
}

.p-form__agree-input {
  position: relative;
  top: 0.1em;
  display: grid;
  place-content: center;
  width: calc(16 * var(--to-rem));
  height: calc(16 * var(--to-rem));
  margin: 0;
  border: 2px solid var(--_contact-border);
  background-color: var(--color-white);
  appearance: none;
}

.p-form__agree-input:checked {
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpolyline points='1,5 4.5,8.5 11,1' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-position: center;
  background-size: calc(12 * var(--to-rem)) calc(10 * var(--to-rem));
  background-repeat: no-repeat;
  background-color: var(--color-primary);
}

.p-form__agree-input:focus {
  box-shadow: 0 0 0 3px var(--_contact-focus);
  outline: none;
}

.p-form__agree-text {
  color: var(--color-text);
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.5;
  letter-spacing: 0.05em;
}

.p-form__link {
  color: var(--color-primary);
  font-family: var(--gothic-new);
  font-weight: var(--fw-bold);
  text-decoration: underline;
  text-underline-offset: 0.2em;
  transition: opacity var(--duration) ease;
}
@media (any-hover: hover) {
  .p-form__link:hover {
    opacity: var(--opacity);
    text-decoration: underline;
  }
}

.p-form__actions {
  width: min(100%, 300 * var(--to-rem));
  min-block-size: calc(72 * var(--to-rem));
  margin-inline: auto;
  text-align: center;
}

.p-form__submit {
  position: relative;
  display: inline-flex;
  gap: calc(10 * var(--to-rem));
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: calc(11 * var(--to-rem)) calc(32 * var(--to-rem));
  border: 1px solid var(--color-primary);
  border-radius: 999px;
  background-color: var(--color-primary);
  color: var(--color-white);
  font-family: var(--gothic-new);
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: 1.2;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease;
}
.p-form__submit::after {
  content: "";
  position: absolute;
  inset-block-end: 46%;
  inset-inline-end: calc(34 * var(--to-rem));
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transition: transform var(--duration);
}
@media (any-hover: hover) {
  .p-form__submit:hover {
    background-color: var(--color-white);
    color: var(--color-black);
  }
  .p-form__submit:hover::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
}

.p-form__submit:focus {
  box-shadow: 0 0 0 3px var(--_contact-focus);
  outline: none;
}

.p-form__submit:disabled {
  border-color: var(--color-border);
  background-color: var(--color-border);
  cursor: not-allowed;
}

.p-form__complete {
  width: 100%;
  max-inline-size: calc(300 * var(--to-rem));
  margin-block-start: calc(10 * var(--to-rem));
  margin-inline: auto;
  padding: calc(12 * var(--to-rem)) calc(32 * var(--to-rem));
  border: 1px solid var(--color-primary);
  border-radius: 999px;
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  text-align: center;
}

.p-form__complete[hidden] {
  display: none;
}

/* 送信成功時は .p-form__complete に任せて CF7 標準メッセージは隠す（エラー時は表示）
   :has() でガードし、独自完了メッセージ要素が無い環境では CF7 標準を残す */
.p-form__body:has(.js-contact-complete)[data-status=sent] .wpcf7-response-output {
  display: none;
}

.p-form .p-form__body .wpcf7-response-output {
  margin: 0;
  padding: calc(10 * var(--to-rem)) calc(16 * var(--to-rem));
  border: 1px solid currentcolor;
  font-family: var(--gothic-new);
  font-size: calc(13 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: 1.6;
}

.p-form .p-form__body.invalid .wpcf7-response-output,
.p-form .p-form__body.unaccepted .wpcf7-response-output,
.p-form .p-form__body.failed .wpcf7-response-output,
.p-form .p-form__body.spam .wpcf7-response-output {
  border-color: var(--_contact-error);
  background-color: var(--_contact-error-bg);
  color: var(--_contact-error);
}

/* CF7 のラッパー span はバリデーション機構が依存するため残し、視覚的に無効化する */
.p-form .wpcf7-form-control-wrap {
  display: contents;
}

/* 個別フィールドエラー表示（[必須項目] が空欄のまま送信を試みたときなど） */
.wpcf7-not-valid-tip {
  display: block;
  margin-block-start: calc(6 * var(--to-rem));
  color: var(--_contact-error);
  font-family: var(--gothic-new);
  font-size: calc(13 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: 1.4;
}

/* エラー時の入力欄ハイライト */
.p-form__input.wpcf7-not-valid,
.p-form__textarea.wpcf7-not-valid,
.p-form__agree-input.wpcf7-not-valid {
  outline: 2px solid var(--_contact-error);
}

.p-form__input[data-width=short] {
  max-width: calc(160 * var(--to-rem));
}

.p-form__input,
.p-form__textarea {
  display: block;
  width: 100%;
  min-width: 0;
  min-block-size: calc(40 * var(--to-rem));
  padding: calc(6 * var(--to-rem)) calc(20 * var(--to-rem));
  border: none;
  background-color: var(--color-white);
  color: var(--color-text);
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  outline: 1px solid transparent;
  transition: outline-color var(--duration) ease;
}
@media (any-hover: hover) {
  .p-form__input:hover,
  .p-form__textarea:hover {
    outline-color: oklch(from var(--_contact-focus) l c h/20%);
  }
}

.p-form__textarea {
  min-block-size: calc(160 * var(--to-rem));
  resize: vertical;
}

.p-header {
  height: var(--header-height);
  background-color: var(--color-white);
}

.p-header__inner {
  display: flex;
  justify-content: space-between;
  height: inherit;
  padding-inline-start: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-header__inner {
    padding-inline-start: calc(60 * var(--to-rem));
  }
}

.p-header__logo {
  flex-shrink: 0;
  width: 100%;
  height: inherit;
  max-inline-size: calc(183 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-header__logo {
    position: relative;
    align-content: center;
    height: auto;
    max-inline-size: calc(244 * var(--to-rem));
  }
}

.p-header__logo a {
  display: flex;
  align-items: center;
  height: inherit;
  transition: opacity var(--duration);
}
@media screen and (min-width: 768px) {
  .p-header__logo a {
    height: auto;
    padding-block: calc(5 * var(--to-rem));
  }
}
@media (any-hover: hover) {
  .p-header__logo a:hover {
    opacity: var(--opacity);
  }
}

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

.p-header__hamburger {
  position: relative;
  z-index: 20;
  width: calc(64 * var(--to-rem));
  height: inherit;
  margin: 0;
  padding: 0;
  border: none;
  background-color: var(--color-white);
  outline: none;
  cursor: pointer;
  transition: background-color var(--duration);
}
@media screen and (min-width: 768px) {
  .p-header__hamburger {
    width: calc(60 * var(--to-rem));
    height: calc(60 * var(--to-rem));
  }
}

.p-header__hamburger span {
  position: relative;
  left: 50%;
  display: block;
  width: calc(30 * var(--to-rem));
  height: 1px;
  background-color: var(--color-text);
  translate: -50% 0;
  transition: top calc(var(--duration) * 1.67), opacity calc(var(--duration) * 1.67);
}
@media screen and (min-width: 768px) {
  .p-header__hamburger span {
    width: calc(30 * var(--to-rem));
  }
}
.p-header__hamburger span:nth-of-type(1) {
  top: -8px;
}
.p-header__hamburger span:nth-of-type(2) {
  top: 0;
}
.p-header__hamburger span:nth-of-type(3) {
  top: 8px;
}

.p-header__hamburger.is-open {
  background-color: var(--color-white);
}

.p-header__hamburger.is-open span {
  background-color: var(--color-primary);
}
.p-header__hamburger.is-open span:nth-of-type(1) {
  top: 0;
  rotate: 45deg;
}
.p-header__hamburger.is-open span:nth-of-type(2) {
  opacity: 0;
}
.p-header__hamburger.is-open span:nth-of-type(3) {
  top: -2px;
  rotate: -45deg;
}

.p-header__drawer {
  position: absolute;
  inset-inline: 0;
  inset-block-start: 0;
  z-index: 1;
  display: none;
  overflow-y: scroll;
  width: 100%;
  height: 100svh;
  padding-block-start: var(--header-height);
  background-color: var(--color-white);
  scrollbar-width: none;
}
.p-header__drawer::-webkit-scrollbar {
  display: none;
}

.p-header__drawer-nav {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: calc(100svh - var(--header-height));
  padding-block: calc(40 * var(--to-rem));
  padding-inline: calc(32 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-header__drawer-nav {
    max-inline-size: calc(1200 * var(--to-rem));
    margin-inline: auto;
    padding-inline: calc(80 * var(--to-rem));
  }
}

.p-header__drawer-list {
  counter-reset: nav-counter;
}

.p-header__drawer-item {
  border-block-end: 1px solid oklch(from var(--color-text) l c h/20%);
  counter-increment: nav-counter;
}
.p-header__drawer-item:first-child {
  border-block-start: 1px solid oklch(from var(--color-text) l c h/20%);
}

.p-header__drawer-item > a {
  position: relative;
  display: flex;
  gap: calc(20 * var(--to-rem));
  align-items: center;
  padding-block: calc(22 * var(--to-rem));
  padding-inline: calc(4 * var(--to-rem));
  color: var(--color-text);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  letter-spacing: 0.05em;
  text-decoration: none;
  transition: color var(--duration);
}
@media screen and (min-width: 768px) {
  .p-header__drawer-item > a {
    padding-block: calc(28 * var(--to-rem));
  }
}
.p-header__drawer-item > a::before {
  content: counter(nav-counter, decimal-leading-zero);
  flex-shrink: 0;
  color: var(--color-navy);
  opacity: 0.9;
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  letter-spacing: 0.05em;
}
.p-header__drawer-item > a::after {
  content: "";
  position: absolute;
  inset-block-end: 45%;
  inset-inline-end: calc(4 * var(--to-rem));
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transform: translateY(50%);
  transition: transform var(--duration) ease;
}

@media (any-hover: hover) {
  .p-header__drawer-item > a:hover::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
}
.p-land-cta {
  padding-block: 0 calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-cta {
    padding-block: 0 calc(74 * var(--to-rem));
  }
}

.p-land-cta__inner {
  max-inline-size: calc(370 * var(--to-rem));
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .p-land-cta__inner {
    max-inline-size: calc(880 * var(--to-rem));
  }
}

.p-land-detail-nav {
  padding-block: 0 calc(50 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-detail-nav {
    padding-block: 0 calc(100 * var(--to-rem));
  }
}

.p-land-detail {
  padding-block: 0 calc(48 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-detail {
    padding-block: calc(67 * var(--to-rem)) calc(80 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-land-detail__inner.l-inner {
    max-inline-size: calc(760 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-land-detail__body {
  display: flex;
  flex-direction: column;
  gap: calc(32 * var(--to-rem));
  margin-block-start: calc(32 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-detail__body {
    gap: calc(4.8125 * var(--base-size));
    align-items: flex-start;
  }
}

.p-land-detail__image {
  overflow: hidden;
  border-radius: 4px;
}
@media screen and (min-width: 768px) {
  .p-land-detail__image {
    flex: 1;
    min-inline-size: 0;
  }
}

.p-land-detail__image img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 3/2;
  object-fit: cover;
}

@media screen and (min-width: 768px) {
  .p-land-detail__content {
    width: 100%;
    min-inline-size: 0;
  }
}

.p-land-detail__title-wrap {
  display: flex;
  flex-direction: column;
  gap: calc(10 * var(--to-rem));
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-land-detail__title-wrap {
    width: min(100%, 560 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-land-detail__title {
  font-family: var(--gothic-new);
  font-size: calc(1.375 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-land-detail__price-wrap {
  display: flex;
  gap: calc(14 * var(--to-rem));
  justify-content: flex-end;
  align-items: center;
  margin-block-start: calc(8 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-detail__price-wrap {
    justify-content: center;
    margin-block-start: 0;
  }
}

.p-land-detail__surface {
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
}

.p-land-detail__price {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
}

.p-land-detail__price em {
  font-size: calc(1.625 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1;
}

.p-land-detail__desc {
  margin-block-start: calc(28 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: justify;
}

.p-land-detail__list {
  display: flex;
  flex-direction: column;
  margin-block-start: calc(30 * var(--to-rem));
  padding-block: calc(25 * var(--to-rem));
  padding-inline: calc(27 * var(--to-rem)) calc(10 * var(--to-rem));
  border-radius: 8px;
  background-color: var(--color-bg-light-gray2);
}
@media screen and (min-width: 768px) {
  .p-land-detail__list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, auto));
    gap: calc(2 * var(--to-rem)) calc(2.125 * var(--base-size));
    padding-block: calc(2.9375 * var(--base-size));
    padding-inline: calc(2.875 * var(--base-size)) calc(0.375 * var(--base-size));
  }
}

.p-land-detail__item {
  --gap: calc(30 * var(--to-rem));
  display: flex;
  gap: var(--gap);
  align-items: center;
}

.p-land-detail__item[data-align=top] {
  align-items: flex-start;
}

.p-land-detail__label {
  position: relative;
  flex-shrink: 0;
  min-inline-size: calc(72 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}
.p-land-detail__label::after {
  content: "";
  position: absolute;
  inset-block-start: 50%;
  inset-inline-end: calc(var(--gap) / -2);
  inline-size: 1px;
  block-size: 50%;
  background-color: var(--color-border);
  transform: translateY(-50%);
}

.p-land-detail__value {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-land-info {
  position: relative;
  padding-block: calc(67 * var(--to-rem)) calc(40 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-info {
    padding-block: calc(75 * var(--to-rem)) calc(120 * var(--to-rem));
  }
}

.p-land-info__outer {
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-land-info__outer {
    max-inline-size: calc(1330 * var(--to-rem));
    margin-inline: auto;
  }
}

@media screen and (min-width: 768px) {
  .p-land-info__inner.l-inner {
    max-inline-size: calc(760 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-land-info__title {
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.01em;
  text-align: center;
}

.p-land-info__table {
  margin-block-start: calc(48 * var(--to-rem));
  border-block: 1px solid var(--color-border);
}
@media screen and (min-width: 768px) {
  .p-land-info__table {
    --padding-block: calc(10.6 * var(--to-rem));
    margin-block-start: calc(57 * var(--to-rem));
    border-block: none;
  }
}

.p-land-info__row {
  display: flex;
  flex-direction: column;
  padding-block: calc(17 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-info__row {
    flex-direction: row;
    align-items: flex-start;
    padding-block: 0;
    border-inline-end: 1px solid var(--color-border);
  }
}

.p-land-info__table .p-land-info__row:nth-child(even) {
  border-radius: 6px;
  background-color: var(--color-bg-light-gray2);
}
@media screen and (min-width: 768px) {
  .p-land-info__table .p-land-info__row:nth-child(even) {
    border-radius: 0;
  }
}

.p-land-info__term {
  padding-inline-start: calc(30 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-land-info__term {
    width: 22%;
    padding-block: var(--padding-block);
    padding-inline-start: calc(38 * var(--to-rem));
    border-inline-start: 1px solid var(--color-border);
  }
}

.p-land-info__detail {
  padding-inline: calc(30 * var(--to-rem)) calc(16 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  .p-land-info__detail {
    padding-block: var(--padding-block);
    border-inline-start: 1px solid var(--color-border);
  }
}

.p-land-location {
  padding-block: calc(25 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-location {
    padding-block: calc(70 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-land-location__inner.l-inner {
    max-inline-size: calc(1360 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-land-location__title {
  margin: 0;
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.01em;
  text-align: center;
}

.p-land-location__map {
  overflow: hidden;
  max-inline-size: calc(240 * var(--to-rem));
  margin-inline: auto;
  border-radius: 6px;
}
@media screen and (min-width: 768px) {
  .p-land-location__map {
    max-inline-size: none;
  }
}

.p-land-location__map img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 24/16;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-land-location__map img {
    aspect-ratio: 3/2;
  }
}

.p-land-location__list {
  display: grid;
  gap: calc(54 * var(--to-rem));
  margin-block-start: calc(45 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-location__list {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: calc(1.875 * var(--base-size)) calc(2.3125 * var(--base-size));
    margin-block-start: calc(55 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-land-location__item {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 4;
  }
}

.p-land-location__name {
  margin-block-start: calc(34 * var(--to-rem));
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.01em;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-land-location__name {
    margin-block-start: 0;
  }
}

.p-land-location__time-wrap {
  margin-block-start: calc(24 * var(--to-rem));
  padding-block: calc(4 * var(--to-rem));
  padding-inline: calc(16 * var(--to-rem));
  border-radius: 6px;
  background-color: var(--color-bg-gray2);
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-land-location__time-wrap {
    margin-block-start: 0;
  }
}

.p-land-location__time {
  font-family: var(--gothic-new);
  font-size: calc(12 * var(--to-rem));
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.p-land-location__time span {
  margin-inline-start: 0.3em;
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-land-location__desc {
  margin-block-start: calc(24 * var(--to-rem));
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  .p-land-location__desc {
    margin-block-start: 0;
  }
}

.p-land-location__map-wrap {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 1/1;
  margin-block-start: calc(63 * var(--to-rem));
  border-radius: 6px;
}
@media screen and (min-width: 768px) {
  .p-land-location__map-wrap {
    aspect-ratio: 1360/630;
    padding-inline: calc(20 * var(--to-rem));
  }
}

.p-land-location__map-wrap iframe {
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 6px;
  filter: grayscale(100%);
}

.p-land-lot {
  padding-block: calc(40 * var(--to-rem)) calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-lot {
    padding-block: calc(47 * var(--to-rem)) calc(60 * var(--to-rem));
  }
}

.p-land-lot__outer {
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-land-lot__outer {
    max-inline-size: calc(1340 * var(--to-rem));
    margin-inline: auto;
  }
}

@media screen and (min-width: 768px) {
  .p-land-lot__inner.l-inner {
    max-inline-size: calc(760 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-land-lot__title-rail.p-en-title-rail {
  inset-inline-end: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-lot__title-rail.p-en-title-rail {
    inset-inline-end: calc(58 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-land-lot__side-label.c-en-title span {
    display: inline-block;
    padding-inline-start: 0.6em;
  }
}

.p-land-lot__title {
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.01em;
  text-align: center;
}

.p-land-lot__body {
  display: flex;
  flex-direction: column;
  gap: calc(42 * var(--to-rem));
  margin-block-start: calc(45 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-lot__body {
    gap: calc(79 * var(--to-rem));
    align-items: flex-start;
    margin-block-start: calc(58 * var(--to-rem));
  }
}

.p-land-lot__image {
  overflow: hidden;
  margin-inline: calc(50% - 50vi);
}
@media screen and (min-width: 768px) {
  .p-land-lot__image {
    flex: 1;
    min-inline-size: 0;
    margin-inline: auto;
    border-radius: 6px;
  }
}

.p-land-lot__image img {
  inline-size: 100%;
  block-size: auto;
  aspect-ratio: 370/236;
  object-fit: cover;
}

.p-land-lot__table-wrap {
  overflow-x: auto;
  margin-inline-end: calc(50% - 48vi);
}
@media screen and (min-width: 768px) {
  .p-land-lot__table-wrap {
    width: 100%;
    min-inline-size: 0;
  }
}

.p-land-lot__table {
  inline-size: 100%;
  border-collapse: collapse;
}

.p-land-lot__table th {
  padding: calc(12 * var(--to-rem)) calc(6 * var(--to-rem));
  border-inline-start: 1px solid var(--color-border);
  background-color: var(--color-white);
  text-align: center;
}

.p-land-lot__table td {
  padding: calc(12 * var(--to-rem)) calc(12 * var(--to-rem));
  border-inline-start: 1px solid var(--color-border);
}
@media screen and (min-width: 768px) {
  .p-land-lot__table td {
    padding-block: calc(10 * var(--to-rem));
    padding-inline-start: calc(39 * var(--to-rem));
  }
}

.p-land-lot__table th:last-child,
.p-land-lot__table td:last-child {
  border-inline-end: 1px solid var(--color-border);
}

th.p-land-lot__table-head {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  th.p-land-lot__table-head {
    padding-inline-start: calc(24 * var(--to-rem));
  }
}

.p-land-lot__table .p-land-lot__table-label {
  padding: calc(10 * var(--to-rem)) calc(16 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: start;
}
@media screen and (min-width: 768px) {
  .p-land-lot__table .p-land-lot__table-label {
    padding-inline-start: calc(40 * var(--to-rem));
  }
}

.p-land-lot__table .p-land-lot__position {
  padding: calc(10 * var(--to-rem)) calc(16 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: start;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .p-land-lot__table .p-land-lot__position {
    width: 22.1%;
    padding-inline-start: calc(39 * var(--to-rem));
  }
}

.p-land-lot__area,
.p-land-lot__price {
  padding: calc(10 * var(--to-rem)) calc(16 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  letter-spacing: 0.05em;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .p-land-lot__area,
  .p-land-lot__price {
    width: 39%;
  }
}

.p-land-lot__table tbody tr:nth-child(odd) {
  background-color: var(--color-bg-light-gray2);
}

.p-land-lot__note {
  margin-block-start: calc(14 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-land-lot__note {
    margin-block-start: calc(37 * var(--to-rem));
  }
}

.p-land-related {
  padding-block: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-related {
    padding-inline: calc(20 * var(--to-rem));
  }
}

.p-land-related__bg {
  padding-block: calc(72 * var(--to-rem));
  border-radius: 12px;
  background-color: var(--color-primary);
}
@media screen and (min-width: 768px) {
  .p-land-related__bg {
    padding-block: calc(100 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-land-related__outer {
    max-inline-size: calc(1360 * var(--to-rem));
    margin-inline: auto;
  }
}

@media screen and (min-width: 768px) {
  .p-land-related__inner.l-inner {
    max-inline-size: calc(1060 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-land-related__title {
  color: var(--color-white);
  font-family: var(--old-mincho);
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.1em;
}

.p-land-related__slider {
  position: relative;
  inline-size: calc(100% + 50vi - 50%);
  margin-block-start: calc(32 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land-related__slider {
    inline-size: auto;
    margin-block-start: calc(28 * var(--to-rem));
  }
}

.p-land-related__slider:not(.is-initialized),
.p-land-related__slider:not(.is-initialized) .splide__track {
  visibility: visible;
}

.p-land-related__slider:not(.is-initialized) .splide__track {
  overflow: visible;
}

.p-land-related__list {
  display: grid;
  gap: calc(24 * var(--to-rem));
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-land-related__list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.p-land-related__slider.is-initialized .p-land-related__list {
  display: flex;
  gap: 0;
}

@media screen and (min-width: 768px) {
  .p-land-related__slider .p-land-related__list.splide__list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(3.625 * var(--base-size));
    transform: none;
  }
}

@media screen and (min-width: 768px) {
  .p-land-related__slider .p-land-related__item.splide__slide {
    inline-size: auto;
    margin-inline-end: 0;
  }
}

.p-land-related__arrows {
  position: absolute;
  inset-block-start: 0;
  inset-inline-end: 0;
  width: 100vw;
  aspect-ratio: 370/175;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-land-related__arrows {
    display: none;
  }
}

.p-land-related__arrow.splide__arrow {
  inline-size: calc(72 * var(--to-rem));
  block-size: calc(72 * var(--to-rem));
  padding: 0;
  border: 0;
  background: transparent;
  opacity: 1;
  pointer-events: auto;
  transition: filter var(--duration) ease;
}
@media (any-hover: hover) {
  .p-land-related__arrow.splide__arrow:hover:not(:disabled) {
    opacity: 1;
    filter: brightness(1.1);
  }
}

.p-land-related__arrow.splide__arrow svg {
  display: none;
}

.p-land-related__arrow img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.p-land-related__arrow.splide__arrow--prev {
  inset-inline-start: calc(-36 * var(--to-rem));
}

.p-land-related__arrow.splide__arrow--next {
  inset-inline-end: calc(-36 * var(--to-rem));
}

.p-land {
  --color-badge: #aeb6bb;
  padding-block: calc(10 * var(--to-rem)) calc(63 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land {
    padding-block: 0 calc(82 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-land__inner.l-inner {
    max-inline-size: calc(1300 * var(--to-rem));
  }
}

.p-land__filter-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land__filter-list {
    gap: calc(10 * var(--to-rem));
    justify-content: center;
  }
}

.p-land__filter-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-inline-size: calc(5 * var(--base-size));
  min-block-size: calc(32 * var(--to-rem));
  padding-inline: calc(10 * var(--to-rem));
  border-radius: 2px;
  background-color: var(--color-badge);
  color: var(--color-white);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  cursor: pointer;
  transition: background-color var(--duration) ease, color var(--duration) ease;
}

.p-land__filter-item.is-current .p-land__filter-btn {
  background-color: var(--color-primary);
  color: var(--color-white);
}

@media (any-hover: hover) {
  .p-land__filter-item:not(.is-current) .p-land__filter-btn:hover {
    background-color: var(--color-primary);
  }
}
.p-land__list {
  display: grid;
  gap: calc(3.5 * var(--base-size));
  margin-block-start: calc(3.75 * var(--base-size));
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-land__list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(5 * var(--base-size)) calc(3.9375 * var(--base-size));
  }
}

.p-land__pagination {
  margin-block-start: calc(68 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-land__pagination {
    margin-block-start: calc(6.0625 * var(--base-size));
  }
}

.p-land__empty {
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.8;
  text-align: center;
}

.p-mv {
  position: relative;
  z-index: 1;
  width: 100%;
  height: max(100svh, 450 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-mv {
    height: max(500 * var(--to-rem), 100%);
  }
}

.p-mv__inner {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: inherit;
}

.p-mv__title-wrap {
  position: absolute;
  inset: 0;
  z-index: 2;
  container-type: inline-size;
  display: flex;
  flex-direction: column;
  gap: calc(24 * var(--to-rem));
  justify-content: center;
  align-items: center;
  width: 100%;
  margin: auto;
  padding-inline: var(--padding-inner);
  color: var(--color-white);
  text-align: center;
}

.p-mv__main-title {
  font-size: calc(32 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.2;
  letter-spacing: 0.05em;
  text-shadow: 0 2px 4px oklch(from var(--color-black) l c h/30%);
}
@media screen and (min-width: 768px) {
  .p-mv__main-title {
    font-size: clamp(32 * var(--to-rem), 5cqi, 64 * var(--to-rem));
  }
}

.p-mv__sub-title {
  font-size: calc(18 * var(--to-rem));
  line-height: 1.6;
  text-shadow: 0 1px 2px oklch(from var(--color-black) l c h/30%);
}
@media screen and (min-width: 768px) {
  .p-mv__sub-title {
    font-size: clamp(18 * var(--to-rem), 3cqi, 24 * var(--to-rem));
  }
}

.p-mv__splide {
  width: 100%;
  height: 100%;
}

.p-mv__splide .splide__track {
  height: 100%;
}

.p-mv__splide .splide__list {
  height: 100%;
}

.p-mv__splide .splide__slide {
  height: 100%;
}

.p-mv__splide .splide__slide-image {
  width: 100%;
  height: 100%;
}

.p-mv__splide .splide__slide-image picture,
.p-mv__splide .splide__slide-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-performance-cta {
  padding-block: calc(40 * var(--to-rem)) calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-performance-cta {
    padding-block: calc(105 * var(--to-rem)) calc(15 * var(--to-rem));
  }
}

.p-performance-cta__inner {
  max-inline-size: calc(var(--inner-sp) + var(--padding-inner-sp) * 2);
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .p-performance-cta__inner {
    max-inline-size: calc(880 * var(--to-rem));
  }
}

.p-performance-detail {
  position: relative;
  padding-block: calc(60 * var(--to-rem));
  border-radius: 12px;
  background-color: var(--color-bg-light-gray2);
}
@media screen and (min-width: 768px) {
  .p-performance-detail {
    margin-inline: calc(1.25 * var(--base-size));
    padding-block: calc(107 * var(--to-rem));
  }
}

.p-performance-detail__inner.l-inner {
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-performance-detail__inner.l-inner {
    max-inline-size: calc(1130 * var(--to-rem));
  }
}

.p-performance-detail__stage {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-performance-detail__stage {
    --min: 10;
    --max: 20;
    --min-vw: 800;
    --max-vw: 1400;
    position: absolute;
    inset-block: 0;
    inset-inline-end: 0;
    display: block;
    inline-size: calc(30.9375 * var(--base-size));
    margin-inline-end: clamp(var(--min) * 1px, var(--min) * 1px + (var(--max) - var(--min)) * (100vw - var(--min-vw) * 1px) / (var(--max-vw) - var(--min-vw)), var(--max) * 1px);
    pointer-events: none;
  }
}

@media screen and (min-width: 768px) {
  .p-performance-detail__stage-inner {
    position: sticky;
    inset-block-start: calc(120 * var(--to-rem));
    overflow: hidden;
    inline-size: calc(30.9375 * var(--base-size));
    aspect-ratio: 3/2;
    border-radius: calc(8 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-performance-detail__stage-image {
    position: absolute;
    inset: 0;
    margin: 0;
    opacity: 0;
    will-change: opacity;
    transition: opacity 0.6s ease;
  }
}

@media screen and (min-width: 768px) {
  .p-performance-detail__stage-image.is-active {
    opacity: 1;
  }
}

@media screen and (min-width: 768px) {
  .p-performance-detail__stage-image img {
    display: block;
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}

.p-performance-detail__item {
  scroll-margin-block-start: calc(var(--header-height) + 20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-performance-detail__item {
    display: grid;
    align-content: center;
    min-block-size: calc(20.625 * var(--base-size));
  }
}

.p-performance-detail__item + .p-performance-detail__item {
  margin-block-start: calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-performance-detail__item + .p-performance-detail__item {
    margin-block-start: calc(80 * var(--to-rem));
  }
}

.p-performance-detail__body {
  display: flex;
  flex-direction: column;
  gap: calc(32 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-performance-detail__body {
    display: grid;
    grid-template-columns: 45.871559633% 45.4128440367%;
    gap: 0;
  }
}

.p-performance-detail__title {
  font-size: calc(1.375 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.01em;
}

.p-performance-detail__content {
  margin-block-start: calc(20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-performance-detail__content {
    margin-block-start: calc(1.875 * var(--base-size));
  }
}

.p-performance-detail__paragraph {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  text-align: justify;
}

.p-performance-detail__image {
  overflow: hidden;
  border-radius: 6px;
}
@media screen and (min-width: 768px) {
  .p-performance-detail__image {
    display: none;
  }
}

.p-performance-detail__image img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 300/200;
  object-fit: cover;
}

.p-performance {
  padding-block: calc(20 * var(--to-rem)) calc(40 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-performance {
    padding-block: calc(88 * var(--to-rem)) calc(117 * var(--to-rem));
  }
}

.p-performance__text-wrap {
  display: grid;
  gap: calc(42 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-performance__text-wrap {
    gap: calc(50 * var(--to-rem));
    max-inline-size: calc(880 * var(--to-rem));
    margin-inline: auto;
    padding-inline: var(--padding-inner);
  }
}

.p-performance__subtitle {
  font-size: calc(1.875 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.01em;
  text-align: center;
}

.p-performance__text {
  font-size: calc(1.25 * var(--base-size));
  line-height: 1.8;
  text-align: center;
}

.p-performance__stats-list {
  display: grid;
  margin-block-start: calc(45 * var(--to-rem));
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-performance__stats-list {
    --min: 15;
    --max: 60;
    --min-vw: 800;
    --max-vw: 1400;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: clamp(var(--min) * 1px, var(--min) * 1px + (var(--max) - var(--min)) * (100vw - var(--min-vw) * 1px) / (var(--max-vw) - var(--min-vw)), var(--max) * 1px);
    max-inline-size: calc(1020 * var(--to-rem));
    margin-block-start: calc(100 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-performance__stats-item {
  border-block-end: 1px solid var(--color-border);
}

.p-performance__stats-link {
  display: flex;
  flex-direction: row;
  gap: calc(3 * var(--to-rem));
  justify-content: space-between;
  align-items: center;
  padding-block: calc(19 * var(--to-rem));
  color: inherit;
  text-align: start;
  text-decoration: none;
  transition: transform var(--duration) ease;
}
@media screen and (min-width: 768px) {
  .p-performance__stats-link {
    padding-block: calc(24 * var(--to-rem));
  }
}
.p-performance__stats-link::after {
  content: "";
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transform: rotate(90deg);
  transition: transform var(--duration) ease;
}
@media (any-hover: hover) {
  .p-performance__stats-link:hover::after {
    transform: rotate(90deg) translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
}

.p-performance__stats-text {
  min-inline-size: 0;
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.8;
}

.p-privacy {
  padding-block: 0 calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-privacy {
    padding-block: 0 calc(80 * var(--to-rem));
  }
}

.p-privacy__body {
  padding-block-start: calc(50 * var(--to-rem));
  border-block-start: 1px solid var(--color-border-gray);
  border-block-end: 1px solid var(--color-border-gray);
}
@media screen and (min-width: 768px) {
  .p-privacy__body {
    max-inline-size: calc(1100 * var(--to-rem));
    margin-inline: auto;
    padding-block: calc(70 * var(--to-rem)) calc(20 * var(--to-rem));
  }
}

.p-privacy__section {
  display: grid;
  gap: calc(26 * var(--to-rem));
  padding-block-end: calc(45 * var(--to-rem));
  border-block-end: 1px solid var(--color-border-gray);
}
@media screen and (min-width: 768px) {
  .p-privacy__section {
    max-inline-size: calc(1010 * var(--to-rem));
    margin-inline: auto;
    padding-inline: calc(76 * var(--to-rem));
  }
}

.p-privacy__section + .p-privacy__section {
  margin-block-start: calc(40 * var(--to-rem));
}

.p-privacy__section:last-child {
  border-block-end: none;
}

.p-privacy__list {
  margin-block-start: calc(-12 * var(--to-rem));
  padding-inline-start: 0;
}

.p-privacy__item {
  position: relative;
  padding-inline-start: 1em;
  list-style: none;
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: justify;
}

.p-privacy__item::before {
  content: "";
  position: absolute;
  inset-block-start: 0.65em;
  inset-inline-start: 0;
  inline-size: calc(10 * var(--to-rem));
  block-size: calc(10 * var(--to-rem));
  border-radius: 50%;
  background-color: var(--color-border-gray);
}

.p-privacy__title {
  font-family: var(--gothic-new);
  font-size: calc(1.125 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-privacy__text {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: justify;
}

.p-privacy__text a {
  color: var(--color-primary);
  font-weight: var(--fw-bold);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: opacity var(--duration);
}
@media (any-hover: hover) {
  .p-privacy__text a:hover {
    opacity: var(--opacity);
  }
}

.p-renovation-cta {
  padding-block: 0 calc(5 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-renovation-cta {
    padding-block: 0 calc(40 * var(--to-rem));
  }
}

.p-renovation-cta__inner {
  max-inline-size: calc(370 * var(--to-rem));
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .p-renovation-cta__inner {
    max-inline-size: calc(880 * var(--to-rem));
  }
}

.p-renovation-lineup {
  padding-block: calc(95 * var(--to-rem)) calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-renovation-lineup {
    padding-block: calc(212 * var(--to-rem)) calc(77 * var(--to-rem));
  }
}

.p-renovation-lineup__head {
  display: grid;
  gap: calc(27 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-renovation-lineup__head {
    gap: calc(45 * var(--to-rem));
  }
}

.p-renovation-lineup__heading {
  font-size: calc(1.875 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.01em;
  text-align: center;
}

.p-renovation-lineup__sub {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  .p-renovation-lineup__sub {
    text-align: center;
  }
}

.p-renovation-lineup__slider {
  margin-block-start: calc(54 * var(--to-rem));
}

.p-renovation-lineup__slider:not(.is-initialized),
.p-renovation-lineup__slider:not(.is-initialized) .splide__track {
  visibility: visible;
}

.p-renovation-lineup__slider:not(.is-initialized) .splide__track {
  overflow: visible;
}

.p-renovation-lineup__slider:not(.is-initialized) .p-renovation-lineup__list.splide__list {
  display: grid;
  gap: calc(54 * var(--to-rem));
}

.p-renovation-lineup__slider:not(.is-initialized) .p-renovation-lineup__item.splide__slide {
  width: auto;
}

@media screen and (min-width: 768px) {
  .p-renovation-lineup__slider.splide.is-initialized {
    margin-inline: calc(50% - 50vi);
  }
}

@media screen and (min-width: 768px) {
  .p-renovation-lineup__slider.splide.is-initialized .splide__track {
    overflow: visible;
    transform: translateX(calc(-190px - 1.7855vi));
  }
}

.p-renovation-lineup__item a {
  display: block;
}
@media (any-hover: hover) {
  .p-renovation-lineup__item a:hover .p-renovation-lineup__more::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
  .p-renovation-lineup__item a:hover .p-renovation-lineup__image img {
    transform: scale(1.06);
  }
}

.p-renovation-lineup__image {
  overflow: hidden;
  aspect-ratio: 304/200;
  border-radius: 6px;
}

.p-renovation-lineup__image img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  transition: transform var(--duration) ease;
}

.p-renovation-lineup__body {
  display: flex;
  gap: calc(6 * var(--to-rem));
  justify-content: space-between;
  align-items: center;
  margin-block-start: calc(36 * var(--to-rem));
}

.p-renovation-lineup__body[data-layout=row] {
  flex-direction: column;
  gap: 0;
  align-items: initial;
}
@media screen and (min-width: 768px) {
  .p-renovation-lineup__body[data-layout=row] {
    flex-direction: row;
    gap: calc(6 * var(--to-rem));
    justify-content: space-between;
    align-items: center;
  }
}

.p-renovation-lineup__body[data-layout=row] .p-renovation-lineup__more {
  margin-inline-start: auto;
}
@media screen and (min-width: 768px) {
  .p-renovation-lineup__body[data-layout=row] .p-renovation-lineup__more {
    margin-inline-start: unset;
  }
}

.p-renovation-lineup__title {
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  .p-renovation-lineup__title {
    font-size: calc(20 * var(--to-rem));
  }
}

.p-renovation-lineup__more {
  display: inline-flex;
  gap: calc(4 * var(--to-rem));
  align-items: center;
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-medium);
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-renovation-lineup__more {
    font-size: calc(14 * var(--to-rem));
  }
}

.p-renovation-lineup__more::after {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(10 * var(--to-rem));
  block-size: calc(10 * var(--to-rem));
  background-color: currentcolor;
  transition: transform var(--duration) ease;
}

.p-renovation-lineup__text {
  margin-block-start: calc(25 * var(--to-rem));
  padding-block-start: calc(32 * var(--to-rem));
  border-block-start: 1px solid var(--color-border);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  .p-renovation-lineup__text {
    font-size: calc(16 * var(--to-rem));
  }
}

.p-renovation-lineup__arrows {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-renovation-lineup__arrows {
    position: absolute;
    inset: 0;
    display: block;
    block-size: calc(250 * var(--to-rem));
    pointer-events: none;
  }
}

.p-renovation-lineup__arrow.splide__arrow {
  inline-size: calc(72 * var(--to-rem));
  block-size: calc(72 * var(--to-rem));
  padding: 0;
  border: 0;
  background: transparent;
  opacity: 1;
  pointer-events: auto;
  transition: filter var(--duration) ease;
}
@media (any-hover: hover) {
  .p-renovation-lineup__arrow.splide__arrow:hover:not(:disabled) {
    opacity: 1;
    filter: brightness(1.18);
  }
}

.p-renovation-lineup__arrow.splide__arrow svg {
  display: none;
}

.p-renovation-lineup__arrow img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.p-renovation-lineup__arrow.splide__arrow--prev {
  inset-inline-start: calc(-36 * var(--to-rem));
}

.p-renovation-lineup__arrow.splide__arrow--next {
  inset-inline-end: calc(-36 * var(--to-rem));
}

.p-renovation-lineup__arrow.splide__arrow:disabled {
  opacity: 0.4;
}

.p-renovation {
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-renovation {
    padding-block-start: calc(20 * var(--to-rem));
  }
}

.p-renovation__bg {
  overflow: hidden;
  padding-block-start: calc(203 * var(--to-rem));
  border-radius: 8px;
  background-image: url("../images/renovation_img01.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
  .p-renovation__bg {
    margin-inline: calc(20 * var(--to-rem));
    padding-block: 0 calc(176 * var(--to-rem));
  }
}

.p-renovation__inner {
  max-width: calc(550 * var(--to-rem));
  margin-inline: auto;
  padding-inline: calc(25 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-renovation__inner {
    max-width: calc(1250 * var(--to-rem));
    padding-inline: var(--padding-inner);
  }
}

.p-renovation__text-frame {
  --r: calc(8 * var(--to-rem));
  position: relative;
  clip-path: inset(0 0 100% 0);
  max-inline-size: calc(326 * var(--to-rem));
  margin-inline: auto;
  padding-inline: var(--r);
  transition: clip-path 0.9s cubic-bezier(0.65, 0, 0.35, 1);
}
@media screen and (min-width: 768px) {
  .p-renovation__text-frame {
    max-inline-size: calc(436 * var(--to-rem));
    margin-inline: calc(-1 * var(--r)) 0;
  }
}

.p-renovation__text-frame.is-revealed {
  clip-path: inset(0 0 0 0);
}

@media (prefers-reduced-motion: reduce) {
  .p-renovation__text-frame {
    clip-path: none;
    transition: none;
  }
}
.p-renovation__text-wrap {
  position: relative;
  padding-block: calc(33 * var(--to-rem)) calc(38 * var(--to-rem));
  padding-inline: calc(30 * var(--to-rem));
  border-radius: 8px 8px 0 0;
  background-color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .p-renovation__text-wrap {
    padding-block: calc(56 * var(--to-rem)) calc(36 * var(--to-rem));
    padding-inline: calc(60 * var(--to-rem));
    border-radius: 0 0 8px 8px;
  }
}

.p-renovation__text-wrap::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: calc(-8 * var(--to-rem));
  mask-image: radial-gradient(circle at 0 100%, transparent var(--r), #000 calc(var(--r) + 1px));
  width: var(--r);
  height: var(--r);
  background-color: var(--color-white);
  transform: rotate(90deg);
}
@media screen and (min-width: 768px) {
  .p-renovation__text-wrap::before {
    top: 0;
    bottom: auto;
    transform: rotate(0deg);
  }
}

.p-renovation__text-wrap::after {
  content: "";
  position: absolute;
  right: calc(-8 * var(--to-rem));
  bottom: 0;
  mask-image: radial-gradient(circle at 0 100%, transparent var(--r), #000 calc(var(--r) + 1px));
  width: var(--r);
  height: var(--r);
  background-color: var(--color-white);
  transform: rotate(180deg);
}
@media screen and (min-width: 768px) {
  .p-renovation__text-wrap::after {
    top: 0;
    bottom: auto;
    transform: rotate(270deg);
  }
}

.p-renovation__text {
  font-size: calc(1 * var(--base-size));
  line-height: 1.8;
  text-align: justify;
}

.p-renovation__button-wrap {
  max-inline-size: calc(240 * var(--to-rem));
  margin-block-start: calc(33 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-renovation__button-wrap {
    max-inline-size: calc(300 * var(--to-rem));
  }
}

.p-top-about {
  padding-block: calc(27 * var(--to-rem)) calc(60 * var(--to-rem));
  background-color: var(--color-bg-light-gray);
}
@media screen and (min-width: 768px) {
  .p-top-about {
    padding-block: calc(27 * var(--to-rem)) calc(40 * var(--to-rem));
  }
}

.p-top-about__content {
  position: relative;
  display: grid;
  gap: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-about__content {
    grid-template-columns: minmax(0, min(435 * var(--to-rem), 40%)) minmax(0, 1fr);
    gap: calc(46 * var(--to-rem));
    align-items: center;
  }
}

.p-top-about__button {
  width: 100%;
  max-inline-size: calc(300 * var(--to-rem));
}

.p-top-about__head {
  display: grid;
  gap: calc(30 * var(--to-rem));
  place-content: center;
}
@media screen and (min-width: 768px) {
  .p-top-about__head {
    place-content: start;
    padding-block-start: calc(40 * var(--to-rem));
  }
}

.p-top-about__image {
  order: -1;
}
@media screen and (min-width: 768px) {
  .p-top-about__image {
    order: 0;
    margin-inline-end: calc(-58 * var(--to-rem));
  }
}

.p-top-about__image img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.p-top-faq {
  padding-block: calc(69 * var(--to-rem)) calc(54 * var(--to-rem));
  background-color: var(--color-bg-light-gray);
}
@media screen and (min-width: 768px) {
  .p-top-faq {
    padding-block: calc(119 * var(--to-rem)) calc(123 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-top-faq__body {
    display: grid;
    grid-template-columns: minmax(0, min(265 * var(--to-rem), 30%)) minmax(0, 1fr);
    gap: calc(3.75 * var(--base-size));
    align-items: start;
  }
}

@media screen and (min-width: 768px) {
  .p-top-faq__title {
    padding-block-start: calc(86 * var(--to-rem));
  }
}

.p-top-faq__accordion {
  margin-block-start: calc(43 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-faq__accordion {
    margin-block-start: 0;
  }
}

.p-top-faq__button {
  width: 100%;
  max-inline-size: calc(300 * var(--to-rem));
  margin-block-start: calc(40 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-top-faq__button {
    margin-block-start: calc(60 * var(--to-rem));
    margin-inline: initial;
    margin-inline-start: calc(74 * var(--to-rem));
  }
}

.p-top-land {
  padding-block: 0 calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-land {
    padding-block: calc(20 * var(--to-rem)) calc(120 * var(--to-rem));
  }
}

.p-top-land__inner {
  position: relative;
}

@media screen and (min-width: 768px) {
  .p-top-land__section-title {
    text-align: center;
  }
  .p-top-land__section-title .c-section-title__sub {
    text-align: center;
  }
}

.p-top-land__splide {
  margin-block-start: calc(24 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-land__splide {
    position: relative;
    margin-block-start: calc(56 * var(--to-rem));
    margin-inline: calc(50% - 50vi);
  }
}

/* SP: Splide 未マウント時のワンカラム表示 */
.p-top-land__splide:not(.is-initialized),
.p-top-land__splide:not(.is-initialized) .splide__track {
  visibility: visible;
}

.p-top-land__splide:not(.is-initialized) .splide__track {
  overflow: visible;
}

.p-top-land__splide .splide__list {
  display: grid;
  gap: calc(21 * var(--to-rem));
  padding: 0;
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-top-land__splide .splide__list {
    display: flex;
    gap: 0;
  }
}

.p-top-land__item {
  padding-block-end: calc(16 * var(--to-rem));
}

/* ── Splide arrows カスタマイズ ──────────────────── */
.p-top-land__arrows {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-top-land__arrows {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    aspect-ratio: 1400/260;
    pointer-events: none;
  }
}

.p-top-land__arrow.splide__arrow {
  inline-size: calc(72 * var(--to-rem));
  block-size: calc(72 * var(--to-rem));
  padding: 0;
  border: 0;
  background: transparent;
  opacity: 1;
  pointer-events: auto;
  transition: filter var(--duration) ease;
}
@media (any-hover: hover) {
  .p-top-land__arrow.splide__arrow:hover:not(:disabled) {
    opacity: 1;
    filter: brightness(1.5);
  }
}

.p-top-land__arrow.splide__arrow svg {
  display: none;
}

.p-top-land__arrow img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.p-top-land__arrow.splide__arrow--prev {
  inset-inline-start: calc(-34 * var(--to-rem));
}

.p-top-land__arrow.splide__arrow--next {
  inset-inline-end: calc(-34 * var(--to-rem));
}

.p-top-land__arrow.splide__arrow:disabled {
  opacity: 0.4;
}

.p-top-land__button {
  max-inline-size: calc(300 * var(--to-rem));
  margin-block-start: calc(40 * var(--to-rem));
  margin-inline: auto;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-top-land__button {
    margin-block-start: calc(65 * var(--to-rem));
  }
}

.p-top-model-house {
  padding-block: calc(72 * var(--to-rem)) calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-model-house {
    padding-block: calc(210 * var(--to-rem)) calc(120 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-top-model-house__head {
    display: flex;
    gap: calc(20 * var(--to-rem));
    justify-content: space-between;
    align-items: flex-end;
  }
}

.p-top-model-house__button {
  width: 100%;
  max-inline-size: calc(300 * var(--to-rem));
  margin-block-start: calc(30 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-top-model-house__button {
    margin-block-start: calc(18 * var(--to-rem));
  }
}

.p-top-model-house__image {
  overflow: hidden;
  aspect-ratio: 300/200;
  margin-block-start: calc(58 * var(--to-rem));
  border-radius: 8px;
}
@media screen and (min-width: 768px) {
  .p-top-model-house__image {
    aspect-ratio: 1090/650;
    margin-block-start: calc(73 * var(--to-rem));
    border-radius: 8px;
  }
}

.p-top-model-house__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-top-model-house__summary {
  margin-block-start: calc(36 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-model-house__summary {
    margin-block-start: calc(44 * var(--to-rem));
  }
}

.p-top-model-house__title-wrap {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block-end: calc(20 * var(--to-rem));
  border-block-end: 1px solid var(--color-border);
}
@media screen and (min-width: 768px) {
  .p-top-model-house__title-wrap {
    justify-content: center;
  }
}

@media screen and (min-width: 768px) {
  .p-top-model-house__view-more {
    position: absolute;
    inset-block-end: 70%;
    inset-inline-end: 0;
    transform: translateY(50%);
  }
}

.p-top-model-house__title {
  font-size: calc(1.375 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.8;
}

.p-top-model-house__text {
  margin-block-start: calc(34 * var(--to-rem));
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  .p-top-model-house__text {
    text-align: center;
  }
}

.p-top-mv {
  position: relative;
  padding-block: calc(20 * var(--to-rem)) calc(54 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-mv {
    padding-block: 0 calc(60 * var(--to-rem));
  }
}

.p-top-mv__inner {
  max-width: calc(var(--inner-sp) + var(--padding-inner-sp) * 2);
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .p-top-mv__inner {
    position: relative;
    z-index: 10;
    max-width: calc(1300 * var(--to-rem) + var(--padding-inner) * 2);
    padding-inline: var(--padding-inner);
  }
}

.p-top-mv__wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  inline-size: min(100%, 400 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-top-mv__wrap {
    position: unset;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    inline-size: 100%;
    max-inline-size: calc(1280 * var(--to-rem));
    padding-inline: calc(4.375 * var(--base-size));
  }
}

.p-top-mv__content {
  position: relative;
  order: 2;
  margin-block-start: calc(18 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-mv__content {
    grid-area: 1/1/2/3;
    margin-block-start: 0;
    padding-block-start: calc(10.5 * var(--base-size));
    padding-inline-start: calc(1.5 * var(--base-size));
  }
}

.p-top-mv__title {
  position: relative;
  z-index: 10;
  font-family: var(--old-mincho);
  font-size: calc(2 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.5;
  letter-spacing: 0.06em;
}
@media screen and (min-width: 768px) {
  .p-top-mv__title {
    display: grid;
    gap: calc(10 * var(--to-rem));
    font-size: calc(4.375 * var(--base-size));
  }
}

.p-top-mv__title span {
  display: block;
  white-space: nowrap;
}

.p-top-mv__title span[data-animation=mask] {
  clip-path: inset(0 100% 0 0);
  will-change: clip-path;
  animation: top-mv-text-reveal 0.85s ease-in-out forwards;
}

.p-top-mv__title span[data-animation=mask]:nth-child(1) {
  animation-delay: 0.45s;
}

.p-top-mv__title span[data-animation=mask]:nth-child(2) {
  animation-delay: 0.55s;
}

.p-top-mv__sub[data-animation=mask] {
  clip-path: inset(0 100% 0 0);
  will-change: clip-path;
  animation: top-mv-text-reveal 0.85s ease-in-out forwards;
  animation-delay: 0.55s;
}

.p-top-mv__sub {
  max-inline-size: calc(177 * var(--to-rem));
  margin-block-start: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-mv__sub {
    max-inline-size: calc(377 * var(--to-rem));
    margin-block-start: calc(2.75 * var(--base-size));
    padding-inline-start: calc(16 * var(--to-rem));
  }
}
.p-top-mv__sub img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.p-top-mv__image {
  position: relative;
  width: min(100%, 400 * var(--to-rem));
  padding-inline-end: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-mv__image {
    grid-area: 1/2/2/4;
    inline-size: min(635 * var(--to-rem), 88%);
    margin-inline-start: auto;
    padding-inline-end: 0;
  }
}

.p-top-mv__image[data-animation=mask]::after {
  content: "";
  position: absolute;
  inset-block: calc(-40 * var(--to-rem)) 0;
  inset-inline: 0;
  z-index: 8;
  background-color: var(--color-white);
  pointer-events: none;
  transform: scaleY(0);
  transform-origin: bottom;
  will-change: transform;
  animation: top-mv-image-reveal 1.2s ease-in-out backwards;
}
@media screen and (min-width: 768px) {
  .p-top-mv__image[data-animation=mask]::after {
    inset-block-start: calc(-120 * var(--to-rem));
  }
}

.p-top-mv__image img {
  width: 100%;
  height: 100%;
  aspect-ratio: 290/370;
  border-radius: 6px;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-top-mv__image img {
    aspect-ratio: 635/830;
    border-radius: 12px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .p-top-mv__title span[data-animation=mask],
  .p-top-mv__sub[data-animation=mask] {
    clip-path: inset(0);
    animation: none;
  }
  .p-top-mv__image[data-animation=mask]::after {
    transform: scaleY(0);
    animation: none;
  }
}
@keyframes top-mv-image-reveal {
  from {
    transform: scaleY(1);
  }
  to {
    transform: scaleY(0);
  }
}
@keyframes top-mv-text-reveal {
  from {
    clip-path: inset(0 100% 0 0);
  }
  to {
    clip-path: inset(0);
  }
}
.p-top-mv__caption {
  position: absolute;
  inset-block-start: calc(-30 * var(--to-rem));
  inset-inline-start: calc(5 * var(--to-rem));
  z-index: 6;
  padding-block-start: calc(8 * var(--to-rem));
  opacity: 0;
  writing-mode: vertical-rl;
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.4;
  letter-spacing: 0.01em;
  transform: translateX(calc(8 * var(--to-rem)));
  animation: top-mv-caption-reveal 0.8s ease-in-out 0.25s forwards;
}
@media screen and (min-width: 768px) {
  .p-top-mv__caption {
    inset-block-start: calc(-6.25 * var(--base-size));
    inset-inline-start: calc(27 * var(--to-rem));
    font-size: calc(1.125 * var(--base-size));
  }
}

@media (prefers-reduced-motion: reduce) {
  .p-top-mv__caption {
    opacity: 1;
    transform: none;
    animation: none;
  }
}
@keyframes top-mv-caption-reveal {
  from {
    opacity: 0;
    transform: translateX(calc(6 * var(--to-rem)));
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
.p-top-mv-meta__list {
  position: absolute;
  display: none;
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-top-mv-meta__list {
    inset-inline-start: calc(38 * var(--to-rem));
    inset-block-end: calc(50% - max(19.625 * var(--base-size), 265px));
    display: flex;
    gap: calc(26 * var(--to-rem));
    min-height: calc(10.3125 * var(--base-size));
  }
}

@media screen and (min-width: 768px) {
  .p-top-mv-meta__item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    writing-mode: vertical-rl;
    font-family: var(--gothic-antique);
    font-size: calc(0.875 * var(--base-size));
    line-height: 1;
    letter-spacing: 0.08em;
  }
}

.p-top-mv-meta__item::before {
  content: "";
  position: relative;
  right: 1px;
  display: inline-block;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: var(--color-badge-gray);
}

.p-top-mv__mask {
  position: absolute;
  inset-inline-start: 50%;
  inset-block-end: 0;
  inline-size: min(100%, 21.875 * var(--base-size));
  transform: translate(-50%, 0%);
}
@media screen and (min-width: 768px) {
  .p-top-mv__mask {
    inline-size: min(100%, 1320 * var(--to-rem));
    margin-block-start: calc(-40 * var(--to-rem));
  }
}

.p-top-mv__mask img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.p-top-news {
  padding-block: calc(80 * var(--to-rem)) calc(62 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-news {
    padding-block: calc(80 * var(--to-rem)) calc(120 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-top-news__body {
    display: grid;
    grid-template-columns: minmax(0, min(280 * var(--to-rem), 30%)) minmax(0, 1fr);
    gap: calc(2.5 * var(--base-size));
    align-items: start;
  }
}

@media screen and (min-width: 768px) {
  .p-top-news__title {
    padding-block-start: calc(84 * var(--to-rem));
  }
}

.p-top-news__list {
  display: grid;
  overflow: hidden;
  margin-block-start: calc(34 * var(--to-rem));
  border-block-start: 1px solid var(--color-border);
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-top-news__list {
    margin-block-start: 0;
  }
}

.p-top-news__item {
  border-block-end: 1px solid var(--color-border);
}

.p-top-news__item-link {
  position: relative;
  display: grid;
  gap: calc(32 * var(--to-rem));
  overflow: hidden;
  padding-block: calc(36 * var(--to-rem)) calc(32 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-news__item-link {
    padding-block: calc(56 * var(--to-rem)) calc(51 * var(--to-rem));
    padding-inline: calc(60 * var(--to-rem));
  }
}
.p-top-news__item-link::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--color-bg-light-gray);
  pointer-events: none;
  transform: translateX(-101%);
  transition: transform 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}
@media (any-hover: hover) {
  .p-top-news__item-link:hover::before {
    transform: translateX(0);
  }
  .p-top-news__item-link:hover .p-top-news__item-more::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
}

.p-top-news__item-meta,
.p-top-news__item-title {
  position: relative;
  z-index: 1;
}

.p-top-news__item-meta {
  display: flex;
  gap: calc(16 * var(--to-rem));
  justify-content: space-between;
  align-items: center;
}

.p-top-news__item-date {
  color: var(--color-gray-text);
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-bold);
}

.p-top-news__item-more {
  display: inline-flex;
  gap: calc(8 * var(--to-rem));
  align-items: center;
  padding-inline-end: calc(4 * var(--to-rem));
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-medium);
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-top-news__item-more {
    padding-inline-end: initial;
  }
}
.p-top-news__item-more::after {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transition: transform 0.3s ease;
}

.p-top-news__item-title {
  display: -webkit-box;
  overflow: hidden;
  font-size: calc(1.125 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  text-align: justify;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
}

.p-top-news__button {
  width: 100%;
  max-inline-size: calc(300 * var(--to-rem));
  margin-block-start: calc(38 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-top-news__button {
    margin-block-start: calc(58 * var(--to-rem));
    margin-inline: initial;
    margin-inline-start: calc(4.625 * var(--base-size));
  }
}

.p-top-philosophy {
  padding-block: calc(50 * var(--to-rem)) calc(40 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-philosophy {
    padding-block: calc(54 * var(--to-rem)) calc(54 * var(--to-rem));
  }
}

.p-top-philosophy__inner {
  position: relative;
}

@media screen and (min-width: 768px) {
  .p-top-philosophy__body {
    display: flex;
    gap: calc(5.625 * var(--base-size));
  }
}

.p-top-philosophy__image {
  overflow: hidden;
  aspect-ratio: 335/332;
  margin-inline-start: calc(50% - 50vi);
  border-radius: 0 8px 8px 0;
}
@media screen and (min-width: 768px) {
  .p-top-philosophy__image {
    aspect-ratio: 625/650;
  }
}

.p-top-philosophy__image img {
  width: 100%;
  height: 100%;
  border-radius: 0 8px 8px 0;
  object-fit: cover;
}

.p-top-philosophy__garage {
  position: relative;
  z-index: 1;
  margin-block-start: calc(30 * var(--to-rem));
  margin-inline-end: calc(50% - 50vi);
}
@media screen and (min-width: 768px) {
  .p-top-philosophy__garage {
    inline-size: 77vw;
    margin-block-start: calc(-60 * var(--to-rem));
    margin-inline-start: auto;
  }
}

.p-top-philosophy__block {
  margin-block-start: calc(75 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-philosophy__block {
    flex-shrink: 0;
    width: 48.6363636364%;
    margin-block-start: 0;
    padding-block: calc(4.25 * var(--base-size)) calc(90 * var(--to-rem));
  }
}

.p-top-philosophy__button {
  margin-block-start: calc(23 * var(--to-rem));
  text-align: right;
}

.p-top-team {
  padding-block-start: calc(86 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-team {
    padding-block: calc(92 * var(--to-rem)) calc(74 * var(--to-rem));
  }
}

.p-top-team__content {
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-team__content {
    display: grid;
    grid-template-columns: minmax(0, min(332 * var(--to-rem), 40%)) minmax(0, 1fr);
    gap: calc(40 * var(--to-rem));
    align-items: start;
  }
}

.p-top-team__head {
  display: grid;
  gap: calc(30 * var(--to-rem));
  place-content: center;
}
@media screen and (min-width: 768px) {
  .p-top-team__head {
    padding-block-start: calc(68 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-top-team__button {
    max-inline-size: calc(300 * var(--to-rem));
  }
}

.p-top-team__image-list {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-rows: auto auto auto;
  gap: calc(10 * var(--to-rem));
  margin-block-start: calc(43 * var(--to-rem));
  margin-inline: calc(-25 * var(--to-rem));
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-top-team__image-list {
    margin-block-start: calc(24 * var(--to-rem));
    margin-inline: initial;
  }
}

.p-top-team__image {
  position: relative;
  grid-column: span 6;
  overflow: hidden;
  border-radius: calc(4 * var(--to-rem));
}

.p-top-team__image:nth-child(1) {
  grid-column: 1/5;
  grid-row: 1;
  aspect-ratio: 233/160;
}

.p-top-team__image:nth-child(2) {
  grid-column: 5/13;
  grid-row: 1/span 2;
  aspect-ratio: 476/330;
}

.p-top-team__image:nth-child(3) {
  grid-column: 1/5;
  grid-row: 2/span 4;
  aspect-ratio: 233/330;
}

.p-top-team__image:nth-child(4) {
  grid-column: 5/9;
  grid-row: 3;
  aspect-ratio: 233/160;
}

.p-top-team__image:nth-child(5) {
  grid-column: 9/13;
  grid-row: 3;
  aspect-ratio: 233/160;
}

.p-top-team__image img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.p-top-works {
  padding-block: calc(40 * var(--to-rem)) calc(90 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-works {
    padding-block: calc(68 * var(--to-rem)) calc(11.875 * var(--base-size));
  }
}

.p-top-works__inner {
  max-width: calc(var(--inner-sp) + 10 * var(--to-rem) * 2);
  margin-inline: auto;
  padding-inline: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-works__inner {
    max-width: calc(1140 * var(--to-rem));
    margin-inline: auto;
    padding-inline: var(--padding-inner);
  }
}

.p-top-works__content {
  position: relative;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .p-top-works__content {
    display: grid;
    grid-template-columns: minmax(0, 260px) minmax(0, 1fr);
    gap: calc(3.5 * var(--base-size));
    align-items: start;
  }
}

.p-top-works__title {
  padding-inline: calc(25 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-works__title {
    padding-inline: initial;
  }
}

.p-top-works__lead {
  display: contents;
}
@media screen and (min-width: 768px) {
  .p-top-works__lead {
    display: block;
    padding-block-start: calc(5.3125 * var(--base-size));
  }
}

.p-top-works__gallery {
  margin-block-start: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-top-works__gallery {
    margin-block-start: 0;
  }
}

.p-top-works__main-image {
  overflow: hidden;
  aspect-ratio: 350/225;
  border-radius: 6px;
}
@media screen and (min-width: 768px) {
  .p-top-works__main-image {
    aspect-ratio: 780/500;
  }
}

.p-top-works__main-image img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.p-top-works__sub-list {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: calc(12 * var(--to-rem));
  margin-block-start: calc(12 * var(--to-rem));
  padding: 0;
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-top-works__sub-list {
    gap: calc(16 * var(--to-rem));
    margin-block-start: calc(16 * var(--to-rem));
  }
}

.p-top-works__sub-item {
  grid-column: span 6;
  overflow: hidden;
  border-radius: 6px;
}

.p-top-works__sub-item:nth-child(1) {
  aspect-ratio: 170/112;
}
@media screen and (min-width: 768px) {
  .p-top-works__sub-item:nth-child(1) {
    aspect-ratio: 380/250;
  }
}

.p-top-works__sub-item:nth-child(2) {
  aspect-ratio: 170/112;
}
@media screen and (min-width: 768px) {
  .p-top-works__sub-item:nth-child(2) {
    aspect-ratio: 380/250;
  }
}

.p-top-works__sub-item:nth-child(3) {
  grid-column: span 8;
  aspect-ratio: 228/152;
}
@media screen and (min-width: 768px) {
  .p-top-works__sub-item:nth-child(3) {
    aspect-ratio: 510/340;
  }
}

.p-top-works__sub-item:nth-child(4) {
  grid-column: span 4;
  aspect-ratio: 112/152;
}
@media screen and (min-width: 768px) {
  .p-top-works__sub-item:nth-child(4) {
    aspect-ratio: 250/340;
  }
}

.p-top-works__sub-item:nth-child(5),
.p-top-works__sub-item:nth-child(6) {
  aspect-ratio: 170/112;
}
@media screen and (min-width: 768px) {
  .p-top-works__sub-item:nth-child(5),
  .p-top-works__sub-item:nth-child(6) {
    aspect-ratio: 380/250;
  }
}

.p-top-works__sub-item img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

/* ── カード個別マスクアニメーション ── */
.p-top-works__main-image,
.p-top-works__sub-item {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.p-top-works__main-image.is-revealed,
.p-top-works__sub-item.is-revealed {
  clip-path: inset(0 0 0% 0);
}

.p-top-works__button {
  order: 1;
  width: 100%;
  max-inline-size: calc(300 * var(--to-rem));
  margin-block-start: calc(2.5 * var(--base-size));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-top-works__button {
    order: initial;
    max-inline-size: calc(240 * var(--to-rem));
    margin-block-start: calc(55 * var(--to-rem));
    margin-inline: initial;
  }
}

.p-topics-cta {
  padding-block: 0 calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-cta {
    padding-block: 0 calc(78 * var(--to-rem));
  }
}

.p-topics-cta__inner {
  max-inline-size: calc(var(--inner-sp) + var(--padding-inner-sp) * 2);
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .p-topics-cta__inner {
    max-inline-size: calc(880 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-topics-detail-related {
    padding-block-end: calc(20 * var(--to-rem));
    padding-inline: calc(20 * var(--to-rem));
  }
}

.p-topics-detail-related__bg {
  padding-block: calc(70 * var(--to-rem)) calc(60 * var(--to-rem));
  border-radius: 12px;
  background-color: var(--color-primary);
}
@media screen and (min-width: 768px) {
  .p-topics-detail-related__bg {
    padding-block: calc(100 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-topics-detail-related__inner.l-inner {
    max-inline-size: calc(1060 * var(--to-rem));
  }
}

.p-topics-detail-related__slider {
  position: relative;
  inline-size: calc(100% + 50vi - 50%);
  margin-block-start: calc(32 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail-related__slider {
    inline-size: auto;
    margin-block-start: calc(28 * var(--to-rem));
  }
}

.p-topics-detail-related__slider:not(.is-initialized),
.p-topics-detail-related__slider:not(.is-initialized) .splide__track {
  visibility: visible;
}

.p-topics-detail-related__slider:not(.is-initialized) .splide__track {
  overflow: visible;
}

.p-topics-detail-related__meta-wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.p-topics-detail-related__meta {
  display: flex;
  gap: calc(10 * var(--to-rem));
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-topics-detail-related__meta {
    gap: calc(22 * var(--to-rem));
  }
}

.p-topics-detail-related__date {
  color: var(--color-white);
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.8;
}

.p-topics-detail-related__cat {
  display: inline-flex;
  align-items: center;
  min-block-size: calc(20 * var(--to-rem));
  padding-inline: calc(10 * var(--to-rem));
  border-radius: 999px;
  background-color: var(--color-category);
  color: var(--color-white);
  font-size: calc(0.75 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.6333333333;
  white-space: nowrap;
}

.p-topics-detail-related__heading {
  color: var(--color-white);
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.5;
  letter-spacing: 0.01em;
}

.p-topics-detail-related__list {
  display: grid;
  gap: calc(24 * var(--to-rem));
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-topics-detail-related__list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(3.75 * var(--base-size));
  }
}

.p-topics-detail-related__slider.is-initialized .p-topics-detail-related__list {
  display: flex;
  gap: 0;
}

@media screen and (min-width: 768px) {
  .p-topics-detail-related__slider .p-topics-detail-related__list.splide__list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(3.75 * var(--base-size));
    transform: none !important;
  }
}

@media screen and (min-width: 768px) {
  .p-topics-detail-related__slider .p-topics-detail-related__item.splide__slide {
    inline-size: auto !important;
    margin-inline-end: 0 !important;
  }
}

.p-topics-detail-related__arrows {
  position: absolute;
  inset-block-start: 0;
  inset-inline-end: 0;
  width: 100vw;
  aspect-ratio: 370/170;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-topics-detail-related__arrows {
    display: none;
  }
}

.p-topics-detail-related__arrow.splide__arrow {
  inline-size: calc(72 * var(--to-rem));
  block-size: calc(72 * var(--to-rem));
  padding: 0;
  border: 0;
  background: transparent;
  opacity: 1;
  pointer-events: auto;
  transition: filter var(--duration) ease;
}
@media (any-hover: hover) {
  .p-topics-detail-related__arrow.splide__arrow:hover:not(:disabled) {
    opacity: 1;
    filter: brightness(1.1);
  }
}

.p-topics-detail-related__arrow.splide__arrow svg {
  display: none;
}

.p-topics-detail-related__arrow img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.p-topics-detail-related__arrow.splide__arrow--prev {
  inset-inline-start: calc(-36 * var(--to-rem));
}

.p-topics-detail-related__arrow.splide__arrow--next {
  inset-inline-end: calc(-36 * var(--to-rem));
}

.p-topics-detail-related__arrow.splide__arrow:disabled {
  opacity: 0.4;
}

.p-topics-detail-related__wrap {
  display: flex;
  flex-direction: column;
  gap: calc(28 * var(--to-rem));
  color: inherit;
}
@media screen and (min-width: 768px) {
  .p-topics-detail-related__wrap {
    gap: calc(35 * var(--to-rem));
  }
}
@media (any-hover: hover) {
  .p-topics-detail-related__wrap:hover .p-topics-detail-related__more::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
  .p-topics-detail-related__wrap:hover .p-topics-detail-related__image img {
    transform: scale(1.05);
  }
}

.p-topics-detail-related__image {
  overflow: hidden;
  border-radius: 6px;
}

.p-topics-detail-related__image img {
  inline-size: 100%;
  block-size: auto;
  aspect-ratio: 3/2;
  object-fit: cover;
  transition: transform var(--duration);
}

.p-topics-detail-related__body {
  display: flex;
  flex-direction: column;
  gap: calc(28 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail-related__body {
    gap: calc(28 * var(--to-rem));
  }
}

.p-topics-detail-related__title {
  display: -webkit-box;
  overflow: hidden;
  margin: 0;
  color: var(--color-white);
  font-size: calc(1.125 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
}

.p-topics-detail-related__more {
  display: inline-flex;
  gap: calc(6 * var(--to-rem));
  align-items: center;
  color: var(--color-white);
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.05em;
}
.p-topics-detail-related__more::after {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transition: transform var(--duration);
}

.p-topics-detail {
  padding-block-end: calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail {
    padding-block-end: calc(120 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-topics-detail__inner.l-inner {
    max-inline-size: calc(760 * var(--to-rem));
  }
}

.p-topics-detail__image {
  overflow: hidden;
  border-radius: calc(6 * var(--to-rem));
}

.p-topics-detail__head {
  display: grid;
  gap: calc(14 * var(--to-rem));
  margin-block-start: calc(28 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail__head {
    gap: calc(50 * var(--to-rem));
    margin-block-start: calc(73 * var(--to-rem));
  }
}

.p-topics-detail__image img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.p-topics-detail__meta {
  display: flex;
  gap: calc(10 * var(--to-rem));
  justify-content: space-between;
  align-items: center;
}

.p-topics-detail__date {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-topics-detail__cat {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-block-size: calc(32 * var(--to-rem));
  padding-inline: calc(18 * var(--to-rem));
  border-radius: 999px;
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  white-space: nowrap;
}

.p-topics-detail__title {
  font-family: var(--gothic-new);
  font-size: calc(1.375 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-topics-detail__body {
  margin-block-start: calc(28 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body {
    margin-block-start: calc(67 * var(--to-rem));
  }
}

/* ── タイポグラフィ（要素のベース定義） ────────────── */
.p-topics-detail__body p {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-topics-detail__body h2 {
  position: relative;
  padding-block-end: calc(12 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.6;
  text-transform: uppercase;
}

.p-topics-detail__body h3 {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.625;
}

.p-topics-detail__body ul,
.p-topics-detail__body ol {
  padding-inline-start: calc(20 * var(--to-rem));
  font-family: var(--gothic-new);
}

.p-topics-detail__body blockquote {
  padding-inline: calc(16 * var(--to-rem));
  border-inline-start: calc(3 * var(--to-rem)) solid oklch(from var(--color-secondary) l c h/45%);
  color: oklch(from var(--color-black) l c h/80%);
  font-family: var(--gothic-new);
  font-size: calc(0.875 * var(--base-size));
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body blockquote {
    padding-inline: calc(20 * var(--to-rem));
    font-size: max(0.875 * var(--base-size), 12px);
  }
}

.p-topics-detail__body a {
  color: var(--color-primary);
  font-family: var(--gothic-new);
  text-decoration: underline;
  text-underline-offset: calc(3 * var(--to-rem));
  transition: opacity var(--duration);
}
@media (any-hover: hover) {
  .p-topics-detail__body a:hover {
    opacity: var(--opacity);
  }
}

.p-topics-detail__body code {
  padding-block: calc(2 * var(--to-rem));
  padding-inline: calc(4 * var(--to-rem));
  border-radius: calc(4 * var(--to-rem));
  background-color: oklch(from var(--color-black) l c h/6%);
  font-size: 0.92em;
}

.p-topics-detail__body figcaption {
  font-family: var(--gothic-new);
  font-feature-settings: "palt";
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body figcaption {
    font-size: max(0.875 * var(--base-size), 12px);
  }
}

/* ── 要素間マージン ────────────────────────────────── */
.p-topics-detail__body * + p {
  margin-block-start: calc(24 * var(--to-rem));
}

.p-topics-detail__body h2:not(:first-child) {
  margin-block-start: calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body h2:not(:first-child) {
    margin-block-start: calc(80 * var(--to-rem));
  }
}

.p-topics-detail__body > figure:not(:first-child) {
  margin-block-start: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body > figure:not(:first-child) {
    margin-block-start: calc(60 * var(--to-rem));
  }
}

.p-topics-detail__body > figure + * {
  margin-block-start: calc(35 * var(--to-rem));
}

.p-topics-detail__body :not(blockquote) + blockquote,
.p-topics-detail__body blockquote + :not(blockquote) {
  margin-block-start: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body :not(blockquote) + blockquote,
  .p-topics-detail__body blockquote + :not(blockquote) {
    margin-block-start: calc(60 * var(--to-rem));
  }
}

.p-topics-detail__body li + li {
  margin-block-start: calc(8 * var(--to-rem));
}

.p-topics-detail__body blockquote p {
  margin: 0;
}

/* ── ブロック単位のレイアウト ──────────────────────── */
.p-topics-detail__body .wp-block-group.is-layout-flex {
  display: flex;
  flex-direction: column;
  gap: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body .wp-block-group.is-layout-flex {
    flex-direction: row;
    gap: calc(62 * var(--to-rem));
    align-items: flex-start;
  }
}

.p-topics-detail__body .wp-block-group.is-layout-flex > .wp-block-image {
  order: -1;
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body .wp-block-group.is-layout-flex > .wp-block-image {
    order: 0;
    flex: 2;
    margin-block-start: 0;
  }
}

.p-topics-detail__body .wp-block-group.is-layout-flex > p {
  margin-block-start: 0;
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body .wp-block-group.is-layout-flex > p {
    flex: 1;
  }
}

.p-topics-detail__body .wp-block-group.is-layout-flex > .wp-block-image img {
  inline-size: 100%;
  block-size: auto;
  max-block-size: calc(700 * var(--to-rem));
  object-fit: contain;
}

.p-topics-detail__body .wp-block-group.is-layout-flex:not(:first-child) {
  margin-block-start: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics-detail__body .wp-block-group.is-layout-flex:not(:first-child) {
    margin-block-start: calc(60 * var(--to-rem));
  }
}

.p-topics-detail__back {
  margin-block-start: calc(66 * var(--to-rem));
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-topics-detail__back {
    margin-block-start: calc(115 * var(--to-rem));
  }
}

.p-topics {
  --color-border: var(--color-border-gray);
  padding-block: calc(10 * var(--to-rem)) calc(64 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics {
    padding-block: calc(20 * var(--to-rem)) calc(82 * var(--to-rem));
  }
}

.p-topics__list {
  border-block-start: 1px solid var(--color-border);
  list-style: none;
}

.p-topics__item {
  border-block-end: 1px solid var(--color-border);
}

.p-topics__article {
  position: relative;
  display: grid;
  gap: calc(35 * var(--to-rem));
  overflow: hidden;
  padding-block: calc(59 * var(--to-rem)) calc(54 * var(--to-rem));
  color: inherit;
}
@media screen and (min-width: 768px) {
  .p-topics__article {
    grid-template-columns: 20.2247191011% 1fr;
    gap: calc(3.75 * var(--base-size));
    align-items: center;
    padding-block: calc(64 * var(--to-rem)) calc(55 * var(--to-rem));
    padding-inline: calc(6.25 * var(--base-size));
  }
}
.p-topics__article::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--color-bg-light-gray);
  pointer-events: none;
  transform: translateX(-101%);
  transition: transform 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}
@media (any-hover: hover) {
  .p-topics__article:hover::before {
    transform: translateX(0);
  }
  .p-topics__article:hover .p-topics__more::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
}

.p-topics__thumb {
  position: relative;
  z-index: 1;
  overflow: hidden;
  inline-size: min(100%, 180 * var(--to-rem));
  aspect-ratio: 180/120;
  margin-inline: auto;
  border-radius: calc(4 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics__thumb {
    margin-inline: initial;
  }
}

.p-topics__thumb img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.p-topics__content {
  position: relative;
  z-index: 1;
  display: grid;
  gap: calc(30 * var(--to-rem));
}

.p-topics__body {
  min-inline-size: 0;
}

.p-topics__meta {
  display: flex;
  gap: calc(10 * var(--to-rem));
  justify-content: space-between;
  align-items: center;
}

.p-topics__box {
  display: flex;
  gap: calc(1.375 * var(--base-size));
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-topics__box {
    gap: calc(2 * var(--base-size));
  }
}

.p-topics__date {
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-bold);
}

.p-topics__cat {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-block-size: calc(22 * var(--to-rem));
  padding-inline: calc(10 * var(--to-rem));
  border-radius: 999px;
  background-color: var(--color-category);
  color: var(--color-white);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-medium);
  white-space: nowrap;
}

.p-topics__title {
  display: -webkit-box;
  overflow: hidden;
  margin: 0;
  font-size: calc(1.125 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.p-topics__more {
  display: inline-flex;
  gap: calc(6 * var(--to-rem));
  align-items: center;
  padding-inline-end: calc(3 * var(--to-rem));
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-medium);
  letter-spacing: 0.05em;
  white-space: nowrap;
}
.p-topics__more::after {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transition: transform 0.3s ease;
}

.p-topics__pagination {
  margin-block-start: calc(40 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-topics__pagination {
    margin-block-start: calc(80 * var(--to-rem));
  }
}

@media (prefers-reduced-motion: reduce) {
  .p-topics__article::before,
  .p-topics__more::after {
    transition: none;
  }
}
.p-works-cta {
  padding-block: 0 calc(55 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-cta {
    padding-block: 0 calc(80 * var(--to-rem));
  }
}

.p-works-cta__inner {
  max-inline-size: calc(370 * var(--to-rem));
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .p-works-cta__inner {
    max-inline-size: calc(880 * var(--to-rem));
  }
}

.p-works-detail-gallery {
  padding-block: 0 calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery {
    padding-block: calc(55 * var(--to-rem)) calc(30 * var(--to-rem));
  }
}

.p-works-detail-gallery__inner {
  max-inline-size: calc(640 * var(--to-rem));
  margin-inline: auto;
  padding-inline: var(--padding-inner-sp);
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__inner {
    max-inline-size: calc(1400 * var(--to-rem));
    padding-inline: calc(20 * var(--to-rem));
  }
}

.p-works-detail-gallery__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(12, 1fr);
  gap: calc(8 * var(--to-rem));
  aspect-ratio: 300/1324;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__list {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(6, 1fr);
    gap: calc(12 * var(--to-rem));
    aspect-ratio: 1360/1480;
  }
}

.p-works-detail-gallery__item {
  overflow: hidden;
  border-radius: calc(4 * var(--to-rem));
}

.p-works-detail-gallery__item img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.p-works-detail-gallery__item:nth-child(1) {
  grid-area: 1/1/3/2;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(1) {
    grid-area: 1/1/3/2;
  }
}

.p-works-detail-gallery__item:nth-child(2) {
  grid-area: 1/2/2/3;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(2) {
    grid-area: 1/2/2/3;
  }
}

.p-works-detail-gallery__item:nth-child(3) {
  grid-area: 3/1/4/2;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(3) {
    grid-area: 1/3/3/5;
  }
}

.p-works-detail-gallery__item:nth-child(4) {
  grid-area: 4/1/6/3;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(4) {
    grid-area: 3/1/4/2;
  }
}

.p-works-detail-gallery__item:nth-child(5) {
  grid-area: 2/2/4/3;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(5) {
    grid-area: 2/2/4/3;
  }
}

.p-works-detail-gallery__item:nth-child(6) {
  grid-area: 6/1/7/2;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(6) {
    grid-area: 3/3/4/4;
  }
}

.p-works-detail-gallery__item:nth-child(7) {
  grid-area: 6/2/7/3;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(7) {
    grid-area: 3/4/4/5;
  }
}

.p-works-detail-gallery__item:nth-child(8) {
  grid-area: 7/2/8/3;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(8) {
    grid-area: 4/1/6/3;
  }
}

.p-works-detail-gallery__item:nth-child(9) {
  grid-area: 7/1/9/2;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(9) {
    grid-area: 4/3/6/4;
  }
}

.p-works-detail-gallery__item:nth-child(10) {
  grid-area: 9/1/10/2;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(10) {
    grid-area: 4/4/5/5;
  }
}

.p-works-detail-gallery__item:nth-child(11) {
  grid-area: 10/1/12/3;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(11) {
    grid-area: 6/1/7/2;
  }
}

.p-works-detail-gallery__item:nth-child(12) {
  grid-area: 12/1/13/2;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(12) {
    grid-area: 6/2/7/3;
  }
}

.p-works-detail-gallery__item:nth-child(13) {
  grid-area: 12/2/13/3;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(13) {
    grid-area: 6/3/7/4;
  }
}

.p-works-detail-gallery__item:nth-child(14) {
  grid-area: 8/2/10/3;
}
@media screen and (min-width: 768px) {
  .p-works-detail-gallery__item:nth-child(14) {
    grid-area: 5/4/7/5;
  }
}

.p-works-detail-nav {
  padding-block: 0 calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-detail-nav {
    padding-block: 0 calc(120 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail-related {
    padding-block-end: calc(20 * var(--to-rem));
    padding-inline: calc(20 * var(--to-rem));
  }
}

.p-works-detail-related__bg {
  padding-block: calc(70 * var(--to-rem)) calc(60 * var(--to-rem));
  border-radius: 12px;
  background-color: var(--color-primary);
}
@media screen and (min-width: 768px) {
  .p-works-detail-related__bg {
    padding-block: calc(100 * var(--to-rem)) calc(120 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail-related__container {
    max-inline-size: calc(1400 * var(--to-rem));
    margin-inline: auto;
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail-related__inner.l-inner {
    max-inline-size: calc(1060 * var(--to-rem));
  }
}

.p-works-detail-related__slider {
  position: relative;
  inline-size: calc(100% + 50vi - 50%);
  margin-block-start: calc(32 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-detail-related__slider {
    inline-size: auto;
    margin-block-start: calc(28 * var(--to-rem));
  }
}

.p-works-detail-related__slider:not(.is-initialized),
.p-works-detail-related__slider:not(.is-initialized) .splide__track {
  visibility: visible;
}

.p-works-detail-related__slider:not(.is-initialized) .splide__track {
  overflow: visible;
}

.p-works-detail-related__heading {
  color: var(--color-white);
  font-size: calc(1.25 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.5;
  letter-spacing: 0.01em;
}

.p-works-detail-related__list {
  display: grid;
  gap: calc(24 * var(--to-rem));
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-works-detail-related__list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(3.75 * var(--base-size));
  }
}

.p-works-detail-related__slider.is-initialized .p-works-detail-related__list {
  display: flex;
  gap: 0;
}

@media screen and (min-width: 768px) {
  .p-works-detail-related__slider .p-works-detail-related__list.splide__list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(3.75 * var(--base-size));
    transform: none;
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail-related__slider .p-works-detail-related__item.splide__slide {
    inline-size: auto;
    margin-inline-end: 0;
  }
}

.p-works-detail-related__arrows {
  position: absolute;
  inset-block-start: 0;
  inset-inline-end: 0;
  width: 100vw;
  aspect-ratio: 370/170;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-works-detail-related__arrows {
    display: none;
  }
}

.p-works-detail-related__arrow.splide__arrow {
  inline-size: calc(72 * var(--to-rem));
  block-size: calc(72 * var(--to-rem));
  padding: 0;
  border: 0;
  background: transparent;
  opacity: 1;
  pointer-events: auto;
  transition: filter var(--duration) ease;
}
@media (any-hover: hover) {
  .p-works-detail-related__arrow.splide__arrow:hover:not(:disabled) {
    opacity: 1;
    filter: brightness(1.1);
  }
}

.p-works-detail-related__arrow.splide__arrow svg {
  display: none;
}

.p-works-detail-related__arrow img {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  object-fit: contain;
}

.p-works-detail-related__arrow.splide__arrow--prev {
  inset-inline-start: calc(-36 * var(--to-rem));
}

.p-works-detail-related__arrow.splide__arrow--next {
  inset-inline-end: calc(-36 * var(--to-rem));
}

.p-works-detail-related__wrap {
  display: flex;
  flex-direction: column;
  gap: calc(24 * var(--to-rem));
}
@media (any-hover: hover) {
  .p-works-detail-related__wrap:hover .p-works-detail-related__more::after {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
  .p-works-detail-related__wrap:hover .p-works-detail-related__image img {
    transform: scale(1.05);
  }
}

.p-works-detail-related__image {
  overflow: hidden;
  border-radius: 6px;
}

.p-works-detail-related__image img {
  inline-size: 100%;
  block-size: auto;
  aspect-ratio: 3/2;
  object-fit: cover;
  transition: transform var(--duration);
}

.p-works-detail-related__body {
  display: flex;
  flex-direction: column;
  gap: calc(6 * var(--to-rem));
}

.p-works-detail-related__title {
  display: -webkit-box;
  overflow: hidden;
  color: var(--color-white);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.8;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
}

.p-works-detail-related__more {
  display: inline-flex;
  gap: calc(6 * var(--to-rem));
  align-items: center;
  margin-inline-start: auto;
  color: var(--color-white);
  font-size: calc(0.875 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.65;
  letter-spacing: 0.05em;
}
.p-works-detail-related__more::after {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(8 * var(--to-rem));
  block-size: calc(8 * var(--to-rem));
  background-color: currentcolor;
  transition: transform var(--duration);
}

.p-works-detail-voice {
  position: relative;
  padding-block: calc(34 * var(--to-rem)) calc(40 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-detail-voice {
    padding-block: calc(90 * var(--to-rem)) calc(100 * var(--to-rem));
  }
}

.p-works-detail-voice__wrap {
  position: relative;
  max-inline-size: calc(1400 * var(--to-rem));
  margin-inline: auto;
}

.p-works-detail-voice__body {
  padding-block-end: calc(34 * var(--to-rem));
  border-bottom: 1px solid var(--color-border);
}
@media screen and (min-width: 768px) {
  .p-works-detail-voice__body {
    width: 90%;
    max-inline-size: calc(970 * var(--to-rem));
    margin-inline: auto;
    padding-block: calc(50 * var(--to-rem));
    padding-inline: calc(5.625 * var(--base-size));
    border-top: 1px solid var(--color-border);
  }
}

.p-works-detail-voice__text {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: justify;
}

.p-works-detail {
  padding-block: 0 calc(60 * var(--to-rem));
}

.p-works-detail__eyecatch {
  overflow: hidden;
  border-radius: calc(6 * var(--to-rem));
}

.p-works-detail__eyecatch img {
  inline-size: 100%;
  block-size: 100%;
  aspect-ratio: 300/200;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-works-detail__eyecatch img {
    aspect-ratio: 1090/580;
  }
}

.p-works-detail__title {
  font-family: var(--gothic-new);
  font-size: calc(1.75 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: center;
}

.p-works-detail__head {
  display: grid;
  gap: calc(22 * var(--to-rem));
  margin-block-start: calc(26 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-detail__head {
    gap: calc(42 * var(--to-rem));
    max-inline-size: calc(720 * var(--to-rem));
    margin-block-start: calc(70 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-works-detail__desc {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-works-detail__spec {
  margin-block-start: calc(35 * var(--to-rem));
  border-radius: 12px;
  background-color: var(--color-bg-light-gray2);
}
@media screen and (min-width: 768px) {
  .p-works-detail__spec {
    margin-block-start: calc(77 * var(--to-rem));
  }
}

.p-works-detail__list {
  display: flex;
  flex-direction: column;
  padding-block: calc(26 * var(--to-rem));
  padding-inline-start: calc(34 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-detail__list {
    display: grid;
    grid-template-columns: auto auto auto;
    gap: calc(1.25 * var(--base-size));
    align-items: center;
    max-inline-size: calc(850 * var(--to-rem));
    margin-inline: auto;
    padding-block: calc(66 * var(--to-rem));
    padding-inline: calc(16 * var(--to-rem));
  }
}

.p-works-detail__item {
  display: grid;
  grid-template-columns: minmax(0, 100px) minmax(0, 1fr);
}
@media screen and (min-width: 768px) {
  .p-works-detail__item {
    grid-template-columns: minmax(0, min(6.25 * var(--base-size), 80%)) minmax(0, 1fr);
    justify-content: center;
    align-items: center;
  }
}

.p-works-detail__label,
.p-works-detail__value {
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-works-detail__label {
  position: relative;
}

.p-works-detail__label::after {
  content: "";
  position: absolute;
  inset-block-start: calc(0.9375 * var(--base-size));
  inset-inline-end: calc(0.9375 * var(--base-size));
  inline-size: 1px;
  block-size: calc(0.9375 * var(--base-size));
  background-color: var(--color-border);
  transform: translateY(-50%);
}

.p-works-detail__layout {
  display: flex;
  flex-direction: column-reverse;
  gap: calc(32 * var(--to-rem));
  margin-block-start: calc(60 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-detail__layout {
    display: grid;
    grid-template-columns: minmax(0, 420px) minmax(0, 585px);
    justify-content: space-between;
    align-items: stretch;
    margin-block-start: calc(100 * var(--to-rem));
  }
}

.p-works-detail__content {
  display: flex;
  flex-direction: column;
  gap: calc(48 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-detail__content {
    gap: calc(170 * var(--to-rem));
    width: 100%;
    max-inline-size: calc(420 * var(--to-rem));
    padding-block-start: calc(70 * var(--to-rem));
  }
}

.p-works-detail__section-image {
  overflow: hidden;
  margin-block-end: calc(40 * var(--to-rem));
  border-radius: calc(6 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works-detail__section-image {
    display: none;
  }
}

.p-works-detail__section-image img {
  display: block;
  inline-size: 100%;
  block-size: auto;
  aspect-ratio: 3/2;
  object-fit: cover;
}

.p-works-detail__section-title {
  font-family: var(--gothic-new);
  font-size: calc(1.375 * var(--base-size));
  font-weight: var(--fw-medium);
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.p-works-detail__section-text {
  margin-block-start: calc(16 * var(--to-rem));
  font-family: var(--gothic-new);
  font-size: calc(1 * var(--base-size));
  line-height: 1.8;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  .p-works-detail__section-text {
    margin-block-start: calc(26 * var(--to-rem));
  }
}

.p-works-detail__content-images {
  margin-block-start: calc(40 * var(--to-rem));
  margin-inline: calc(50% - 50vi);
}
@media screen and (min-width: 768px) {
  .p-works-detail__content-images {
    margin-block-start: calc(67 * var(--to-rem));
    margin-inline: unset;
  }
}

/* Splide のデフォルトを上書き */
.p-works-detail__content-images.splide {
  visibility: visible;
}

.p-works-detail__content-image {
  overflow: hidden;
  border-radius: calc(4 * var(--to-rem));
}

.p-works-detail__content-image img {
  display: block;
  inline-size: 100%;
  block-size: auto;
  aspect-ratio: 3/2;
  object-fit: cover;
}

/* PC: Splide を destroy した状態で縦並びに上書き */
@media screen and (min-width: 768px) {
  .p-works-detail__content-images.splide .splide__track {
    overflow: visible;
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail__content-images.splide .splide__list {
    display: flex;
    flex-direction: column;
    gap: calc(10 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail__content-images.splide .splide__slide {
    inline-size: 100%;
  }
}

.p-works-detail__content-arrows {
  position: absolute;
  inset-block-start: 0;
  inset-inline-end: 0;
  width: 100vw;
  aspect-ratio: 300/132;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-works-detail__content-arrows {
    display: none;
  }
}

/* Splide のデフォルト矢印スタイルを上書き */
.p-works-detail__content-arrows .p-works-detail__content-arrow {
  inline-size: calc(72 * var(--to-rem));
  block-size: calc(72 * var(--to-rem));
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  opacity: 1;
  cursor: pointer;
  pointer-events: auto;
  transition: filter var(--duration) ease;
}
@media (any-hover: hover) {
  .p-works-detail__content-arrows .p-works-detail__content-arrow:hover:not(:disabled) {
    opacity: 1;
    filter: brightness(1.1);
  }
}

.p-works-detail__content-arrow.splide__arrow--prev {
  inset-inline-start: calc(-36 * var(--to-rem));
}

.p-works-detail__content-arrow.splide__arrow--next {
  inset-inline-end: calc(-36 * var(--to-rem));
}

.p-works-detail__content-arrows .p-works-detail__content-arrow img {
  display: block;
  inline-size: 100%;
  block-size: auto;
}

.p-works-detail__content-arrows .p-works-detail__content-arrow svg {
  display: none;
}

.p-works-detail__content-arrows .p-works-detail__content-arrow:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.p-works-detail__stage {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-works-detail__stage {
    display: block;
    min-inline-size: 0;
    pointer-events: none;
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail__stage-inner {
    position: sticky;
    inset-block-start: calc(120 * var(--to-rem));
    display: grid;
    overflow: hidden;
    inline-size: 100%;
    aspect-ratio: 3/2;
    border-radius: calc(6 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail__stage-image {
    grid-area: 1/1;
    margin: 0;
    opacity: 0;
    transition: opacity 0.6s ease;
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail__stage-image.is-active {
    opacity: 1;
  }
}

@media screen and (min-width: 768px) {
  .p-works-detail__stage-image img {
    display: block;
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
  }
}

.p-works {
  --color-badge: #aeb6bb;
  padding-block: calc(10 * var(--to-rem)) calc(63 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works {
    padding-block: 0 calc(84 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .p-works__inner.l-inner {
    max-inline-size: calc(1300 * var(--to-rem));
  }
}

.p-works__filter-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(10 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works__filter-list {
    gap: calc(10 * var(--to-rem));
    justify-content: center;
  }
}

.p-works__filter-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-inline-size: calc(5 * var(--base-size));
  min-block-size: calc(32 * var(--to-rem));
  padding-inline: calc(10 * var(--to-rem));
  border-radius: 2px;
  background-color: var(--color-badge);
  color: var(--color-white);
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-medium);
  cursor: pointer;
  transition: background-color var(--duration) ease, color var(--duration) ease;
}

.p-works__filter-item.is-current .p-works__filter-btn {
  background-color: var(--color-primary);
  color: var(--color-white);
}

@media (any-hover: hover) {
  .p-works__filter-item:not(.is-current) .p-works__filter-btn:hover {
    background-color: var(--color-primary);
  }
}
.p-works__list {
  display: grid;
  gap: calc(3.9375 * var(--base-size));
  margin-block-start: calc(3.75 * var(--base-size));
  list-style: none;
}
@media screen and (min-width: 768px) {
  .p-works__list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(5 * var(--base-size)) calc(3.9375 * var(--base-size));
  }
}

.p-works__card {
  display: flex;
  flex-direction: column;
  gap: calc(26 * var(--to-rem));
  color: inherit;
}
@media (any-hover: hover) {
  .p-works__card:hover .p-works__card-more::before {
    transform: translate(calc(3 * var(--to-rem)), calc(-3 * var(--to-rem)));
  }
  .p-works__card:hover .p-works__card-image img {
    transform: scale(1.05);
  }
}

.p-works__card-image {
  position: relative;
  overflow: hidden;
  border-radius: calc(6 * var(--to-rem));
}

.p-works__card-image img {
  display: block;
  inline-size: 100%;
  block-size: auto;
  aspect-ratio: 380/250;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.p-works__card-body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: calc(9 * var(--to-rem));
}

.p-works__card-title {
  font-size: calc(1 * var(--base-size));
  font-weight: var(--fw-bold);
  line-height: 1.8;
}

.p-works__card-more {
  position: relative;
  display: inline-block;
  width: fit-content;
  margin-inline-start: auto;
  padding-inline-end: calc(15 * var(--to-rem));
  font-size: calc(0.875 * var(--base-size));
  line-height: 1;
  letter-spacing: 0.05em;
}
.p-works__card-more::before {
  content: "";
  position: absolute;
  inset-block-end: 45%;
  inset-inline-end: 0;
  display: inline-block;
  flex-shrink: 0;
  mask-image: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='_レイヤー_2'%20data-name='レイヤー%202'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%208.85%208.85'%3e%3cdefs%3e%3cstyle%3e%20.cls-1%20{%20fill:%20none;%20stroke:%20%23344855;%20stroke-miterlimit:%2010;%20}%20%3c/style%3e%3c/defs%3e%3cg%20id='_レイヤー_1-2'%20data-name='レイヤー%201'%3e%3cg%3e%3cpolyline%20class='cls-1'%20points='.35%20.5%208.35%20.5%208.35%208.5'/%3e%3cline%20class='cls-1'%20x1='.35'%20y1='8.5'%20x2='8.35'%20y2='.5'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  inline-size: calc(9 * var(--to-rem));
  block-size: calc(9 * var(--to-rem));
  background-color: currentcolor;
  transform: translateY(50%);
  transition: transform var(--duration) ease;
}

.p-works__pagination {
  margin-block-start: calc(74 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-works__pagination {
    margin-block-start: calc(6.75 * var(--base-size));
  }
}

.p-works__empty {
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.8;
  text-align: center;
}

:root {
  --clip-triangle-top: polygon(50% 0, 100% 100%, 0 100%);
  --clip-triangle-bottom: polygon(0 0, 100% 0, 50% 100%);
  --clip-triangle-right: polygon(0 0, 100% 50%, 0 100%);
  --clip-triangle-left: polygon(0 50%, 100% 0, 100% 100%);
  --clip-triangle-lower-left: polygon(0 0, 100% 100%, 0 100%);
  --clip-triangle-upper-left: polygon(0 0, 100% 0, 0 100%);
  --clip-triangle-lower-right: polygon(100% 0, 100% 100%, 0 100%);
  --clip-triangle-upper-right: polygon(0 0, 100% 0, 100% 100%);
}

@media (width <= 767px) {
  [data-only-device=md] {
    display: none;
  }
}

@media (width >= 768px) {
  [data-only-device=sm] {
    display: none;
  }
}

.u-sr-only {
  position: absolute;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  white-space: nowrap;
}

.u-text__marker {
  background: linear-gradient(transparent 75%, var(--color-orange) 75%);
}

.u-text__inline-block {
  display: inline-block;
}

.u-text__indent {
  padding-inline-start: 1em;
  text-indent: -1em;
}/*! kiso.css v1.2.4 | MIT License | https://github.com/tak-dcxi/kiso.css */

/* ======================================================
//  MARK: Universal
// ====================================================== */
*,
::before,
::after {
  /*
  * Includes `padding` and `border` in the element's specified dimensions.
  * It is highly recommended to set `box-sizing: border-box;` by default, as it makes styling much easier, especially when specifying `width: 100%;`.
  */
  box-sizing: border-box;
}

/* ======================================================
//  MARK: Document and Body Elements
// ====================================================== */
:where(:root) {
  /* In Safari, if `font-family` is not specified, a serif font is applied by default, so `sans-serif` is set as the default here. */
  font-family: sans-serif;

  /*
  * For accessibility, it is recommended to set the `line-height` to at least 1.5 times the text size within paragraphs.
  * @see https://waic.jp/translations/WCAG21/#visual-presentation
  */
  line-height: 1.5;

  /* Remove space when punctuation marks are adjacent, and also remove leading spaces in a line. */
  text-spacing-trim: trim-start;

  /* Improves readability by inserting a small space between Japanese and alphanumeric characters. */
  text-autospace: normal;

  /* Prevents misreading by applying strict line-breaking rules. */
  line-break: strict;

  /* Wraps English words mid-word. Specifying `anywhere` also prevents content from overflowing in layouts like `flex` or `grid`. */
  overflow-wrap: anywhere;

  /*
  * Mobile browsers have an algorithm that automatically adjusts font sizes to prevent text from becoming too small.
  * This controls the auto-adjustment feature to prevent unwanted resizing.
  */
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;

  /*
  * Prevents layout shift caused by the appearance or disappearance of the scrollbar.
  * Starting with Chrome 145, specifying `scrollbar-gutter: stable` will cause vw to be calculated without considering the scrollbar, which will also prevent horizontal scrolling.
  */
  scrollbar-gutter: stable;

  /* Suppresses the tap highlight on iOS. */
  -webkit-tap-highlight-color: transparent;
}

:where(body) {
  /*
  * When creating a sticky footer, a minimum height is often required.
  * Setting the `min-block-size` to the dynamic viewport height ensures enough space for the footer.
  */
  min-block-size: 100dvb;

  /* The `margin` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset here. */
  margin: unset;
}

/* ======================================================
// MARK: Sections
// ------------------------------------------------------ */
:where(:is(h1, h2, h3, h4, h5, h6):lang(en)) {
  /* Prevents the last line of text from ending with a single word, which can look awkward (known as an orphan). */
  text-wrap: pretty;
}

:where(h1) {
  /*
  * Adjusts user agent (UA) styles for `h1` elements within sectioning content.
  * This addresses DevTools warnings that appear when `h1` elements nested within sectioning content lack `font-size` and `margin` properties.
  * @see https://html.spec.whatwg.org/#sections-and-headings
  */
  margin-block: 0.67em;
  font-size: 2em;
}

:where(h2, h3, h4, h5, h6) {
  /* The `margin-block` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-block: unset;
}

:where(search) {
  /*
  * The `<search>` element is supported from Safari 17.
  * This prevents it from being displayed as an inline element in unsupported environments.
  */
  display: block flow;
}

/* ======================================================
//  MARK: Grouping content
// ====================================================== */
:where(p, blockquote, figure, pre, address, ul, ol, dl, menu) {
  /* The `margin-block` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-block: unset;
}

:where(blockquote, figure) {
  /* The `margin-inline` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-inline: unset;
}

:where(p:lang(en)) {
  /*
  * In English, a single word on the last line is called a "widow" or "orphan" and is considered something to avoid as it makes the text harder to read.
  * Therefore, when lang="en", this prevents the last line from ending with a single word.
  */
  text-wrap: pretty;
}

:where(address:lang(ja)) {
  /* Italic style is not common in Japanese, so the `font-style` is reset. */
  font-style: unset;
}

:where(ul, ol, menu) {
  /* The `padding-inline-start` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  padding-inline-start: unset;

  /*
  * In Safari, using `list-style: none` prevents screen readers from announcing lists.
  * `list-style-type: ""` is used to hide markers without affecting accessibility.
  * @see https://matuzo.at/blog/2023/removing-list-styles-without-affecting-semantics
  */
  list-style-type: "";
}

:where(dt) {
  /* It is common to display `<dt>` elements in bold, so `font-weight: bolder;` is set by default. */
  font-weight: bolder;
}

:where(dd) {
  /* The `margin-inline-start` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-inline-start: unset;
}

:where(pre) {
  /*
  * Since `text-spacing-trim` can affect spacing in `<pre>` elements even with its initial value, the final rendering may depend on the user's font settings.
  * To ensure consistent alignment, `space-all` is explicitly specified and inheritance is prevented.
  */
  text-spacing-trim: space-all;

  /* Set to `no-autospace` as it can cause misalignment with monospaced fonts. */
  text-autospace: no-autospace;
}

@media print {
  :where(pre) {
    /* Prevent text wrapping in print media. */
    text-wrap-mode: unset;
  }
}

/* ======================================================
//  MARK: Text-level semantics
// ====================================================== */
:where(em:lang(ja)) {
  /* In Japanese, emphasis is commonly represented by bold text, so `font-weight: bolder;` is set by default. */
  font-weight: bolder;
}

:where(:is(i, cite, em, dfn):lang(ja)) {
  /* Italic style is not common in Japanese, so the `font-style` is reset. */
  font-style: unset;
}

:where(u, s, del, ins) {
  /* Set the underline inset to `auto` and separate only the horizontal lines when underlines are consecutive. */
  text-decoration-inset: auto;
}

:where(code, kbd, samp) {
  /*
  * Set a monospace font family referencing Tailwind.
  * @see https://tailwindcss.com/docs/font-family
  */
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas,
    "Liberation Mono", "Courier New", monospace;

  /* Font feature settings can have adverse effects on monospaced fonts, so their values are explicitly set to `initial` to prevent inheritance. */
  font-feature-settings: initial;
  font-variation-settings: initial;

  /* Resets the `font-size` specified in the UA stylesheet to allow inheritance. */
  font-size: unset;

  /*
  * Disables font ligatures for programming fonts (like Fira Code)
  * to prevent character combinations like `=>` from being rendered as a single symbol (e.g., `⇒`).
  */
  font-variant-ligatures: none;
}

:where(abbr[title]) {
  /*
  * The `<abbr>` element with the `title` attribute isn't helpful regarding accessibility because support is inconsistent, and it's only accessible to some users.
  * This rule shows a dotted underline on abbreviations in all browsers (there's a bug in Safari) and changes the cursor.
  * @see https://adrianroselli.com/2024/01/using-abbr-element-with-title-attribute.html
  */
  text-decoration-line: underline;
  text-decoration-style: dotted;
  text-decoration-inset: auto;
  cursor: help;
}

:where(time) {
  /* Set to `no-autospace` because date notations in typography do not include spaces. */
  text-autospace: no-autospace;
}

@media (forced-colors: active) {
  :where(mark) {
    /*
    * In forced-colors mode, the color of the mark element may not change, which can be problematic. Use system colors in forced-colors mode.
    * @see https://adrianroselli.com/2017/12/tweaking-text-level-styles.html#MarkWHCM
    */
    background-color: Highlight;
    color: HighlightText;
  }
}

@media print {
  :where(mark) {
    /*
    * Not all printers support color, and users might print in grayscale.
    * It's worth adding a non-disruptive style that scales with the text, as an alternative to relying only on background color.
    * @see https://adrianroselli.com/2017/12/tweaking-text-level-styles.html#MarkPrint
    */
    border-width: 1px;
    border-style: dotted;
  }
}

/* ======================================================
//  MARK: Links
// ====================================================== */
:where(a) {
  /*
  * The default `color` from the UA stylesheet is rarely used as is, so it's reset to allow inheritance.
  * In Firefox on iOS, the user agent stylesheet’s text color is applied even when the text is not a link.
  * @see https://github.com/darkreader/darkreader/issues/9836
  */
  color: unset;
}

:where(a:any-link) {
  /*
  * While link underlines can be useful, they are often obstructive.
  * They are disabled by default.
  * If needed, restore them using `text-decoration-line: revert;`.
  */
  text-decoration-line: unset;

  /* Set the underline thickness to the font's default thickness. */
  text-decoration-thickness: from-font;

  /* Set the underline inset to `auto` and separate only the horizontal lines when underlines are consecutive. */
  text-decoration-inset: auto;
}

/* ======================================================
//  MARK: Embedded content
// ====================================================== */
:where(img, svg, picture, video, audio, canvas, model, iframe, embed, object) {
  /* Prevents overflow by setting the maximum width to `100%`. */
  max-inline-size: 100%;

  /* Prevents extra space from appearing at the bottom of the element. */
  vertical-align: bottom;
}

:where(img, svg, picture, video, canvas, model, iframe, embed, object) {
  /*
  * Automatically adjust block size based on content.
  * Exclude the <audio> element as it disappears when block-size is auto.
  * @see https://github.com/tak-dcxi/kiso.css/issues/5
  */
  block-size: auto;
}

:where(iframe) {
  /* The `border` specified in the UA stylesheet is often unnecessary, so it is reset. */
  border: unset;
}

/* ======================================================
//  MARK: Tabular data
// ====================================================== */
:where(table) {
  /* Collapse borders for a more refined table design. */
  border-collapse: collapse;
}

:where(caption, th) {
  /* The `text-align` specified in the UA stylesheet is often unnecessary, so it is reset. */
  text-align: unset;
}

:where(caption:lang(en)) {
  /* Prevents the last line of text from ending with a single word, which can look awkward (known as an orphan). */
  text-wrap: pretty;
}

/* ======================================================
//  MARK: Forms
// ====================================================== */
:where(button, input, select, textarea),
::file-selector-button {
  /*
  * These elements are often styled with a border, so a `1px` border is applied by default for consistency.
  * This ensures readability even for unstyled elements.
  * When resetting, it's recommended to use `border-color: transparent` instead of `border: none` to account for forced color modes.
  */
  border-width: 1px;
  border-style: solid;

  /* These styles specified in the UA stylesheet are often unnecessary, so they are reset to allow for inheritance. */
  border-color: unset;
  border-radius: unset;
  color: unset;
  font: unset;
  letter-spacing: unset;
  text-align: unset;
}

:where(input:is([type="radio" i], [type="checkbox" i])) {
  /* The `margin` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset here. */
  margin: unset;
}

:where(input[type="file" i]) {
  /* The `border` is often unnecessary, so it is reset here. */
  border: unset;
}

:where(input[type="search" i]) {
  /* Remove the rounded corners of search inputs on macOS and normalize the background color. */
  -webkit-appearance: textfield;
}

@supports (-webkit-touch-callout: none) {
  :where(input[type="search" i]) {
    /* normalize the background color on iOS. */
    background-color: Canvas;
  }
}

:where(
    input:is(
        [type="tel" i],
        [type="url" i],
        [type="email" i],
        [type="number" i]
      ):not(:placeholder-shown)
  ) {
  /*
  * Certain input types need to maintain left alignment even in right-to-left (RTL) languages.
  * However, this only applies when the value is not empty, as the placeholder should be right-aligned.
  * @see https://rtlstyling.com/posts/rtl-styling#form-inputs
  */
  direction: ltr;
}

:where(textarea) {
  /* The `margin-block` specified in Firefox's UA stylesheet is often unnecessary, so it is reset. */
  margin-block: unset;

  /* Allows vertical resizing for `<textarea>` elements. */
  resize: block;
}

:where(
    input:not([type="button" i], [type="submit" i], [type="reset" i]),
    textarea,
    [contenteditable]
  ) {
  /* Set to `no-autospace` because `text-autospace` can insert spaces during input, potentially causing erratic behavior. */
  text-autospace: no-autospace;
}

:where(
    button,
    input:is([type="button" i], [type="submit" i], [type="reset" i])
  ),
::file-selector-button {
  /* The `background-color` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset here. */
  background-color: unset;
}

:where(
    button,
    input:is([type="button" i], [type="submit" i], [type="reset" i]),
    [role="tab" i],
    [role="button" i],
    [role="option" i]
  ),
::file-selector-button {
  /*
  * On iOS, double-tapping a button can cause zooming, which harms usability.
  * `touch-action: manipulation` is specified to disable zooming on double-tap.
  * Third-party plugins such as Swiper sometimes use div elements with these roles as buttons, since double-tapping a div can still trigger zooming, it's advisable to specify this property.
  */
  touch-action: manipulation;
}

:where(
    button:enabled,
    label[for],
    select:enabled,
    input:is(
        [type="button" i],
        [type="submit" i],
        [type="reset" i],
        [type="radio" i],
        [type="checkbox" i]
      ):enabled,
    [role="tab" i],
    [role="button" i],
    [role="option" i]
  ),
:where(:enabled)::file-selector-button {
  /* Indicate clickable elements with a pointer cursor. */
  cursor: pointer;
}

:where(fieldset) {
  /*
  * Prevent fieldset from causing overflow.
  * Reset the default `min-inline-size: min-content` to prevent children from stretching fieldset.
  * @see https://github.com/twbs/bootstrap/issues/12359
  */
  min-inline-size: 0;

  /* The following default styles are often unnecessary, so they are reset. */
  margin-inline: unset;
  padding: unset;
  border: unset;
}

:where(legend) {
  /* The default `padding-inline` is often unnecessary, so it is reset. */
  padding-inline: unset;
}

:where(progress) {
  /* Resets the vertical alignment of the `<progress>` element to its initial value. */
  vertical-align: unset;
}

::placeholder {
  /* Standardize the opacity of placeholder text (it may be set lower by default in Firefox). */
  opacity: unset;
}

/* ======================================================
//  MARK: Interactive elements
// ====================================================== */
:where(summary) {
  /* The default triangle marker is often unnecessary, so it is disabled. */
  list-style-type: "";

  /* Changing the cursor to a pointer clarifies the clickability of the element. */
  cursor: pointer;
}

:where(summary)::-webkit-details-marker {
  /* In Safari versions earlier than 18.4 (released in April 2025), a triangle icon is displayed using the -webkit-details-marker CSS pseudo-element, so it should be removed. */
  display: none;
}

:where(dialog, [popover]) {
  /*
  * When these fixed-position elements are scrolled, preventing scroll chaining on the underlying page and bounce effects on mobile improves usability.
  * Disabling block-direction scroll chaining is recommended.
  */
  overscroll-behavior-block: contain;

  /* The following default styles are often unnecessary, so they are reset. */
  padding: unset;
  border: unset;
}

:where(dialog:not([open], [popover]), [popover]:not(:popover-open)) {
  /*
  * These elements can be easily displayed by explicitly setting their `display` property.
  * To prevent them from appearing when not in an open state, they are forcibly hidden.
  */
  display: none !important;
}

:where(dialog) {
  /*
  * The max width and height of a `<dialog>` element are typically determined by the design.
  * These UA stylesheet properties are reset as they can be obstructive, especially when trying to make the dialog full-screen.
  */
  max-inline-size: unset;
  max-block-size: unset;
}

:where(dialog)::backdrop {
  /* Normalize the background color of the `::backdrop` element. */
  background-color: oklch(0% 0 0deg / 30%);
}

:where([popover]) {
  /*
  * While the UA stylesheet's `margin` for `<dialog>` elements is useful for centering with `inset: 0`,
  * but `margin` for `popover` elements is often obstructive as they frequently use Anchor Positioning.
  */
  margin: unset;
}

/* ======================================================
//  MARK: Focus Styles
// ====================================================== */
:where(:focus-visible) {
  /* Add space between the content and the focus outline. */
  outline-offset: 3px;
}

[tabindex="-1"]:focus {
  /* Prevent programmatically focused elements from displaying an outline unless they are naturally focusable. */
  outline: none !important;
}

/* ======================================================
//  MARK: Misc
// ====================================================== */
:where(:disabled, [aria-disabled="true" i]) {
  /* Display the default cursor on disabled elements to reflect their non-interactive state. */
  cursor: default;
}

[hidden]:not([hidden="until-found" i]) {
  /* Ensure that elements intended to be hidden are not displayed, improving clarity and layout control. */
  display: none !important;
}
.splide__container{box-sizing:border-box;position:relative}.splide__list{backface-visibility:hidden;display:-ms-flexbox;display:flex;height:100%;margin:0!important;padding:0!important}.splide.is-initialized:not(.is-active) .splide__list{display:block}.splide__pagination{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:center;justify-content:center;margin:0;pointer-events:none}.splide__pagination li{display:inline-block;line-height:1;list-style-type:none;margin:0;pointer-events:auto}.splide:not(.is-overflow) .splide__pagination{display:none}.splide__progress__bar{width:0}.splide{position:relative;visibility:hidden}.splide.is-initialized,.splide.is-rendered{visibility:visible}.splide__slide{backface-visibility:hidden;box-sizing:border-box;-ms-flex-negative:0;flex-shrink:0;list-style-type:none!important;margin:0;position:relative}.splide__slide img{vertical-align:bottom}.splide__spinner{animation:splide-loading 1s linear infinite;border:2px solid #999;border-left-color:transparent;border-radius:50%;bottom:0;contain:strict;display:inline-block;height:20px;left:0;margin:auto;position:absolute;right:0;top:0;width:20px}.splide__sr{clip:rect(0 0 0 0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.splide__toggle.is-active .splide__toggle__play,.splide__toggle__pause{display:none}.splide__toggle.is-active .splide__toggle__pause{display:inline}.splide__track{overflow:hidden;position:relative;z-index:0}@keyframes splide-loading{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.splide__track--draggable{-webkit-touch-callout:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.splide__track--fade>.splide__list>.splide__slide{margin:0!important;opacity:0;z-index:0}.splide__track--fade>.splide__list>.splide__slide.is-active{opacity:1;z-index:1}.splide--rtl{direction:rtl}.splide__track--ttb>.splide__list{display:block}.splide__arrow{-ms-flex-align:center;align-items:center;background:#ccc;border:0;border-radius:50%;cursor:pointer;display:-ms-flexbox;display:flex;height:2em;-ms-flex-pack:center;justify-content:center;opacity:.7;padding:0;position:absolute;top:50%;transform:translateY(-50%);width:2em;z-index:1}.splide__arrow svg{fill:#000;height:1.2em;width:1.2em}.splide__arrow:hover:not(:disabled){opacity:.9}.splide__arrow:disabled{opacity:.3}.splide__arrow:focus-visible{outline:3px solid #0bf;outline-offset:3px}.splide__arrow--prev{left:1em}.splide__arrow--prev svg{transform:scaleX(-1)}.splide__arrow--next{right:1em}.splide.is-focus-in .splide__arrow:focus{outline:3px solid #0bf;outline-offset:3px}.splide__pagination{bottom:.5em;left:0;padding:0 1em;position:absolute;right:0;z-index:1}.splide__pagination__page{background:#ccc;border:0;border-radius:50%;display:inline-block;height:8px;margin:3px;opacity:.7;padding:0;position:relative;transition:transform .2s linear;width:8px}.splide__pagination__page.is-active{background:#fff;transform:scale(1.4);z-index:1}.splide__pagination__page:hover{cursor:pointer;opacity:.9}.splide__pagination__page:focus-visible{outline:3px solid #0bf;outline-offset:3px}.splide.is-focus-in .splide__pagination__page:focus{outline:3px solid #0bf;outline-offset:3px}.splide__progress__bar{background:#ccc;height:3px}.splide__slide{-webkit-tap-highlight-color:rgba(0,0,0,0)}.splide__slide:focus{outline:0}@supports(outline-offset:-3px){.splide__slide:focus-visible{outline:3px solid #0bf;outline-offset:-3px}}@media screen and (-ms-high-contrast:none){.splide__slide:focus-visible{border:3px solid #0bf}}@supports(outline-offset:-3px){.splide.is-focus-in .splide__slide:focus{outline:3px solid #0bf;outline-offset:-3px}}@media screen and (-ms-high-contrast:none){.splide.is-focus-in .splide__slide:focus{border:3px solid #0bf}.splide.is-focus-in .splide__track>.splide__list>.splide__slide:focus{border-color:#0bf}}.splide__toggle{cursor:pointer}.splide__toggle:focus-visible{outline:3px solid #0bf;outline-offset:3px}.splide.is-focus-in .splide__toggle:focus{outline:3px solid #0bf;outline-offset:3px}.splide__track--nav>.splide__list>.splide__slide{border:3px solid transparent;cursor:pointer}.splide__track--nav>.splide__list>.splide__slide.is-active{border:3px solid #000}.splide__arrows--rtl .splide__arrow--prev{left:auto;right:1em}.splide__arrows--rtl .splide__arrow--prev svg{transform:scaleX(1)}.splide__arrows--rtl .splide__arrow--next{left:1em;right:auto}.splide__arrows--rtl .splide__arrow--next svg{transform:scaleX(-1)}.splide__arrows--ttb .splide__arrow{left:50%;transform:translate(-50%)}.splide__arrows--ttb .splide__arrow--prev{top:1em}.splide__arrows--ttb .splide__arrow--prev svg{transform:rotate(-90deg)}.splide__arrows--ttb .splide__arrow--next{bottom:1em;top:auto}.splide__arrows--ttb .splide__arrow--next svg{transform:rotate(90deg)}.splide__pagination--ttb{bottom:0;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;left:auto;padding:1em 0;right:.5em;top:0}