/* ============================================================
   ゼンリュウ — 那覇空港駐車サービス
   PREMIUM · Black + Gold · Omotenashi luxury
   ============================================================ */

:root {
  --bg: #0a0907;
  --bg-soft: #11100d;
  --bg-card: #16140f;
  --bg-card-2: #1b1812;
  --ink: #efe7d5;
  --ink-soft: #c4b9a4;
  --ink-mute: #8a8170;
  --line: #2a241b;
  --line-soft: #1d1812;
  --gold: #c9a449;
  --gold-bright: #e6c574;
  --gold-deep: #9a7d2f;
  --champagne: #d8c79a;
  --green: #7fa67a;

  --serif: "Noto Serif JP", "Hiragino Mincho ProN", serif;
  --sans: "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: "JetBrains Mono", "SFMono-Regular", ui-monospace, monospace;

  --r-sm: 2px;
  --r-md: 4px;
  --r-lg: 8px;

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 12px 32px -12px rgba(0, 0, 0, 0.6);
  --shadow-lg: 0 32px 80px -24px rgba(0, 0, 0, 0.7);
  --shadow-gold: 0 0 0 1px rgba(201, 164, 73, 0.2), 0 16px 48px -16px rgba(201, 164, 73, 0.25);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "palt";
  line-height: 1.75;
  font-weight: 300;
}

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
::selection { background: var(--gold); color: var(--bg); }

/* ---------- Top utility bar ---------- */
.util-bar {
  background: #000;
  color: var(--ink-soft);
  font-size: 11px;
  letter-spacing: 0.16em;
  border-bottom: 1px solid var(--line);
}
.util-bar__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 9px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}
.util-bar__left { display: flex; gap: 24px; white-space: nowrap; overflow: hidden; }
.util-bar__left span { white-space: nowrap; }
.util-bar__right { display: flex; gap: 18px; align-items: center; white-space: nowrap; flex-shrink: 0; }
.util-bar__phone {
  font-family: var(--mono);
  letter-spacing: 0.1em;
  color: var(--gold);
}
.util-bar__dot {
  display: inline-block;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--gold);
  margin-right: 8px;
  vertical-align: middle;
}

/* ---------- Header / Nav ---------- */
.nav {
  position: sticky;
  top: 0;
  z-index: 70;
  background: rgba(10, 9, 7, 0.85);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 18px 32px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 28px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 14px;
}
.brand__mark {
  width: 44px; height: 44px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--serif);
  font-weight: 500;
  font-size: 20px;
  color: var(--gold);
  letter-spacing: 0;
  position: relative;
}
.brand__mark::after {
  content: "";
  position: absolute;
  inset: 3px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  opacity: 0.3;
}
.brand__name {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 17px;
  letter-spacing: 0.08em;
  line-height: 1.2;
  color: var(--ink);
  white-space: nowrap;
}
.brand__sub {
  font-size: 9px;
  letter-spacing: 0.28em;
  color: var(--gold);
  text-transform: uppercase;
  margin-top: 3px;
  white-space: nowrap;
}
.nav__links {
  display: flex;
  gap: 24px;
  font-size: 12px;
  letter-spacing: 0.12em;
  justify-self: center;
  color: var(--ink-soft);
  white-space: nowrap;
}
.nav__links a {
  position: relative;
  padding: 6px 0;
  transition: color 0.25s;
  cursor: pointer;
}
.nav__links a:hover { color: var(--gold); }
.nav__links a.is-current { color: var(--gold); }
.nav__links a.is-current::after {
  content: "";
  position: absolute;
  bottom: -2px; left: 0; right: 0;
  height: 1px;
  background: var(--gold);
}
.nav__cta {
  justify-self: end;
  display: flex;
  gap: 12px;
  align-items: center;
}

/* ---------- Mobile menu ---------- */
.nav__menu-btn {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--ink);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  cursor: pointer;
  transition: border-color 0.25s;
}
.nav__menu-btn:hover { border-color: var(--gold); }
.nav__menu-btn__line {
  display: block;
  width: 18px;
  height: 1px;
  background: var(--ink);
  transition: transform 0.3s, opacity 0.3s;
}
.nav__menu-btn.is-open .nav__menu-btn__line:nth-child(1) { transform: translateY(3px) rotate(45deg); }
.nav__menu-btn.is-open .nav__menu-btn__line:nth-child(2) { opacity: 0; }
.nav__menu-btn.is-open .nav__menu-btn__line:nth-child(3) { transform: translateY(-3px) rotate(-45deg); }

.nav__drawer {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: var(--bg);
  padding: 100px 32px 40px;
  flex-direction: column;
  gap: 4px;
  z-index: 60;
  overflow-y: auto;
}
.nav__drawer.is-open { display: flex; }
.nav__drawer .nav__drawer__brand {
  position: absolute;
  top: 22px; left: 32px;
  display: flex;
  align-items: center;
  gap: 12px;
  z-index: 1;
}
.nav__drawer__overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 55;
  opacity: 0;
  transition: opacity 0.3s;
}
.nav__drawer__overlay.is-open { opacity: 1; }
.nav__drawer a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  border-bottom: 1px solid var(--line);
  font-family: var(--serif);
  font-size: 17px;
  letter-spacing: 0.08em;
  color: var(--ink);
  transition: color 0.2s;
}
.nav__drawer a:hover { color: var(--gold); }
.nav__drawer a::after {
  content: "→";
  font-family: var(--sans);
  color: var(--gold);
  font-size: 14px;
}
.nav__drawer__cta {
  margin-top: 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.nav__drawer__contact {
  font-family: var(--serif);
  font-size: 22px;
  color: var(--gold);
  margin-top: 24px;
  letter-spacing: 0.04em;
}
.nav__drawer__contact small {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--ink-mute);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
body.nav-open { overflow: hidden; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  font-size: 12px;
  letter-spacing: 0.2em;
  border-radius: 0;
  transition: all 0.3s ease;
  white-space: nowrap;
  font-weight: 400;
  cursor: pointer;
  position: relative;
}
.btn--gold {
  background: var(--gold);
  color: #0a0907;
  font-weight: 500;
}
.btn--gold:hover {
  background: var(--gold-bright);
  transform: translateY(-1px);
  box-shadow: var(--shadow-gold);
}
.btn--ghost {
  border: 1px solid var(--gold);
  color: var(--gold);
}
.btn--ghost:hover {
  background: var(--gold);
  color: var(--bg);
}
.btn--outline {
  border: 1px solid var(--ink-mute);
  color: var(--ink);
}
.btn--outline:hover {
  border-color: var(--gold);
  color: var(--gold);
}
.btn--lg { padding: 18px 32px; font-size: 13px; }
.btn--sm { padding: 10px 18px; font-size: 11px; letter-spacing: 0.16em; }
.btn__arrow {
  display: inline-block;
  transition: transform 0.25s;
}
.btn:hover .btn__arrow { transform: translateX(4px); }

/* ---------- Section base ---------- */
.section {
  padding: 140px 40px;
  max-width: 1280px;
  margin: 0 auto;
}
.section--narrow { max-width: 980px; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 24px;
  font-weight: 500;
  white-space: nowrap;
}
.eyebrow::before {
  content: "";
  width: 32px; height: 1px;
  background: var(--gold);
}
.section-title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(34px, 4.2vw, 56px);
  line-height: 1.3;
  letter-spacing: 0.04em;
  margin: 0 0 28px;
  text-wrap: balance;
  color: var(--ink);
}
.section-title em {
  font-style: normal;
  color: var(--gold);
}
.section-lede {
  font-size: 15px;
  color: var(--ink-soft);
  max-width: 640px;
  margin: 0 0 64px;
  text-wrap: pretty;
  line-height: 1.95;
}
.divider-mark {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin: 0 auto 28px;
}
.divider-mark::before, .divider-mark::after {
  content: "";
  width: 40px; height: 1px;
  background: var(--gold);
  opacity: 0.5;
}
.divider-mark span {
  font-family: var(--serif);
  color: var(--gold);
  font-size: 14px;
}

/* ---------- HERO ---------- */
.hero {
  position: relative;
  min-height: 760px;
  padding: 100px 40px 120px;
  overflow: hidden;
  background:
    radial-gradient(ellipse at top right, rgba(201, 164, 73, 0.06) 0%, transparent 50%),
    var(--bg);
}
.hero__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
  z-index: 2;
}
.hero__copy { position: relative; }
.hero__kicker {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 8px 18px;
  background: transparent;
  border: 1px solid var(--gold);
  border-radius: 0;
  font-size: 10px;
  font-family: var(--mono);
  letter-spacing: 0.28em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 36px;
}
.hero__kicker__dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(1.4); }
}
.hero__title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(42px, 5.6vw, 78px);
  line-height: 1.2;
  letter-spacing: 0.04em;
  margin: 0 0 32px;
  text-wrap: balance;
}
.hero__title em {
  font-style: normal;
  color: var(--gold);
  font-weight: 500;
}
.hero__title .accent {
  display: inline-block;
  position: relative;
  padding-right: 6px;
}
.hero__title .accent::after {
  content: "";
  position: absolute;
  bottom: -2px; left: 0; right: 0;
  height: 1px;
  background: var(--gold);
  opacity: 0.4;
}
.hero__lede {
  font-size: 16px;
  line-height: 2;
  color: var(--ink-soft);
  max-width: 500px;
  margin: 0 0 44px;
  font-weight: 300;
}
.hero__actions {
  display: flex;
  gap: 16px;
  align-items: center;
  margin-bottom: 60px;
}
.hero__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  padding-top: 32px;
  max-width: 560px;
}
.hero__stat {
  border-right: 1px solid var(--line-soft);
  padding-right: 20px;
}
.hero__stat:last-child { border-right: none; padding-right: 0; }
.hero__stat__num {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  line-height: 1.15;
  margin-bottom: 8px;
  color: var(--gold);
  letter-spacing: 0.04em;
}
.hero__stat__label {
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--ink-mute);
  text-transform: uppercase;
  white-space: nowrap;
}

/* Hero visual */
.hero__visual {
  position: relative;
  height: 640px;
}
.hero__photo {
  position: absolute;
  inset: 0;
  border-radius: 0;
  overflow: hidden;
  border: 1px solid var(--line);
}
.hero__photo__placeholder {
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(135deg, rgba(201, 164, 73, 0.04) 0 2px, transparent 2px 16px),
    linear-gradient(180deg, #1a1610 0%, #0a0907 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 36px;
  color: var(--ink-mute);
}
.hero__photo__placeholder::before {
  content: "";
  position: absolute;
  inset: 16px;
  border: 1px solid rgba(201, 164, 73, 0.15);
  pointer-events: none;
}
.hero__photo__label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  margin-bottom: 8px;
  color: var(--gold);
}
.hero__photo__desc {
  font-size: 12px;
  color: var(--ink-mute);
  max-width: 280px;
  line-height: 1.6;
}
.hero__card {
  position: absolute;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 0;
  padding: 22px 26px;
  box-shadow: var(--shadow-lg);
  z-index: 3;
  backdrop-filter: blur(12px);
}
.hero__card--booking {
  bottom: 40px;
  left: -28px;
  width: 320px;
  border-color: var(--gold);
}
.hero__card--trust {
  top: 36px;
  right: -20px;
  width: 280px;
}
.hero__card__title {
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 14px;
  font-family: var(--mono);
}
.hero__card__row {
  display: flex;
  justify-content: space-between;
  padding: 7px 0;
  font-size: 12px;
  color: var(--ink-soft);
  border-bottom: 1px dashed var(--line);
}
.hero__card__row:last-child { border-bottom: none; }
.hero__card__row strong {
  font-family: var(--serif);
  font-weight: 500;
  color: var(--ink);
}
.hero__card__big {
  font-family: var(--serif);
  font-size: 40px;
  font-weight: 400;
  line-height: 1;
  margin: 6px 0 8px;
  color: var(--gold);
}
.hero__card__small {
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}

.hero__bg-mark {
  position: absolute;
  font-family: var(--serif);
  font-size: 480px;
  font-weight: 300;
  color: rgba(201, 164, 73, 0.025);
  z-index: 0;
  top: 20px;
  right: -80px;
  pointer-events: none;
  letter-spacing: -0.05em;
}

/* ---------- Plan card — Total-price edition ---------- */
.plan-card__price__total {
  font-family: var(--serif);
  font-size: 48px;
  font-weight: 400;
  line-height: 1;
  color: var(--ink);
}
.plan-card--featured .plan-card__price__total,
.plan-card--premium .plan-card__price__total { color: var(--gold); }
.plan-card__price__suffix {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--ink-mute);
  margin-left: 6px;
  letter-spacing: 0.04em;
}
.plan-card__duration {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-top: 6px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 22px;
}

/* ---------- Concept band — flagship value-prop section ---------- */
.concept {
  background: #000;
  padding: 140px 40px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.concept__inner {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.concept__title {
  font-family: var(--serif);
  font-size: clamp(38px, 5vw, 64px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.04em;
  margin: 0 0 60px;
  text-wrap: balance;
  max-width: 1000px;
}
.concept__title em {
  font-style: normal;
  color: var(--gold);
  font-weight: 500;
  position: relative;
}
.concept__title em::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 1px;
  background: var(--gold);
  opacity: 0.6;
}
.concept__flow {
  display: grid;
  grid-template-columns: 1fr 60px 1fr 60px 1fr;
  align-items: center;
  gap: 0;
  border: 1px solid var(--line);
  background: var(--bg-card);
}
.concept__flow__node {
  padding: 36px 32px;
  text-align: center;
}
.concept__flow__char {
  font-family: var(--serif);
  font-size: 64px;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 14px;
  opacity: 0.7;
}
.concept__flow__label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.concept__flow__text {
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  letter-spacing: 0.04em;
}
.concept__flow__arrow {
  text-align: center;
  font-size: 24px;
  color: var(--gold);
  font-family: var(--serif);
}

/* ---------- Triad service grid (3 businesses on homepage) ---------- */
.triad {
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.triad__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.triad-tile {
  position: relative;
  padding: 64px 44px 56px;
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  background: var(--bg);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: background 0.4s;
  min-height: 480px;
}
.triad-tile:last-child { border-right: none; }
.triad-tile:hover { background: var(--bg-soft); }
.triad-tile:hover .triad-tile__char { color: var(--gold-bright); transform: scale(1.05) rotate(-2deg); }
.triad-tile:hover .triad-tile__arrow { transform: translateX(6px); }
.triad-tile__char {
  font-family: var(--serif);
  font-size: 140px;
  line-height: 1;
  color: rgba(201, 164, 73, 0.05);
  position: absolute;
  bottom: -20px;
  right: 0;
  transition: color 0.5s, transform 0.5s;
  pointer-events: none;
}
.triad-tile__num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.28em;
  color: var(--gold);
  margin-bottom: 24px;
  text-transform: uppercase;
}
.triad-tile__name {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.04em;
  margin: 0 0 14px;
}
.triad-tile__en {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--ink-mute);
  margin-bottom: 24px;
  text-transform: uppercase;
}
.triad-tile__desc {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.95;
  max-width: 340px;
  margin-bottom: 28px;
  flex: 1;
}
.triad-tile__price {
  display: inline-block;
  font-family: var(--serif);
  font-size: 20px;
  color: var(--gold);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--gold);
  margin-bottom: 28px;
  letter-spacing: 0.04em;
  position: relative;
  z-index: 1;
  background: linear-gradient(to right, var(--bg) 0%, var(--bg) 100%);
}
.triad-tile__price small {
  font-family: var(--sans);
  font-size: 11px;
  color: var(--ink-mute);
  margin-left: 4px;
  letter-spacing: 0.06em;
}
.triad-tile__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  align-self: flex-start;
}
.triad-tile__arrow { transition: transform 0.3s; }

/* ---------- Sub-business teaser (rental + used cars) ---------- */
.subbiz {
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
}
.subbiz__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.subbiz__card {
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 56px 48px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  transition: border-color 0.3s;
  position: relative;
  overflow: hidden;
}
.subbiz__card:hover { border-color: var(--gold); }
.subbiz__card__bg-char {
  position: absolute;
  font-family: var(--serif);
  font-size: 220px;
  color: rgba(201, 164, 73, 0.04);
  bottom: -40px;
  right: -20px;
  line-height: 1;
  pointer-events: none;
}
.subbiz__card__head {
  position: relative;
}
.subbiz__card__num {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--gold);
  margin-bottom: 14px;
  text-transform: uppercase;
}
.subbiz__card__title {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 500;
  margin: 0 0 8px;
  letter-spacing: 0.04em;
}
.subbiz__card__en {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.24em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.subbiz__card__price {
  font-family: var(--serif);
  font-size: 36px;
  color: var(--gold);
  letter-spacing: 0.04em;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
  position: relative;
}
.subbiz__card__price small {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--ink-mute);
  margin-left: 6px;
}
.subbiz__card__points {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 18px;
  position: relative;
}
.subbiz__card__points li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 14px;
  font-size: 13px;
  line-height: 1.7;
  color: var(--ink-soft);
}
.subbiz__card__points strong {
  font-family: var(--serif);
  font-weight: 500;
  color: var(--ink);
  font-size: 15px;
  letter-spacing: 0.04em;
}
.subbiz__card__points em {
  font-style: normal;
  font-family: var(--mono);
  color: var(--gold);
  font-weight: 500;
  font-size: 12px;
}

/* ---------- Rental car lineup ---------- */
.rental-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.rental-car {
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 28px 28px 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px 24px;
  transition: border-color 0.3s;
}
.rental-car:hover { border-color: var(--gold); }
.rental-car__head { grid-column: 1 / -1; }
.rental-car__cat {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 8px;
  display: flex;
  gap: 10px;
  align-items: center;
}
.rental-car__cat__chip {
  padding: 2px 8px;
  border: 1px solid var(--line);
  color: var(--ink-soft);
  font-size: 9px;
  text-transform: none;
  letter-spacing: 0.08em;
}
.rental-car__name {
  font-family: var(--serif);
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin: 0;
}
.rental-car__spec {
  font-size: 12px;
  color: var(--ink-soft);
  line-height: 1.85;
  border-top: 1px dashed var(--line);
  padding-top: 14px;
  grid-column: 1 / -1;
}
.rental-car__spec dt {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.16em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-right: 8px;
  display: inline;
}
.rental-car__spec dd {
  display: inline;
  margin: 0;
  color: var(--ink);
}
.rental-car__spec dd::after {
  content: " · ";
  color: var(--line);
}
.rental-car__spec dd:last-child::after { content: ""; }
.rental-car__prices {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 16px;
  border-top: 1px dashed var(--line);
  padding-top: 14px;
  font-size: 12px;
}
.rental-car__prices__label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.rental-car__prices__val {
  font-family: var(--serif);
  font-size: 18px;
  color: var(--gold);
}
.rental-car__prices__val small {
  font-family: var(--sans);
  font-size: 11px;
  color: var(--ink-mute);
  margin-left: 4px;
}
.rental-list__note {
  margin-top: 24px;
  font-size: 11px;
  color: var(--ink-mute);
  font-family: var(--mono);
  letter-spacing: 0.08em;
  line-height: 1.8;
}
.rental-cta {
  margin-top: 36px;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

/* ---------- Trust strip ---------- */
.trust-strip {
  background: #000;
  color: var(--ink);
  padding: 36px 40px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.trust-strip__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  align-items: center;
}
.trust-strip__item {
  display: flex;
  gap: 16px;
  align-items: center;
  font-size: 12px;
  border-right: 1px solid var(--line);
  padding-right: 24px;
}
.trust-strip__item:last-child { border-right: none; padding-right: 0; }
.trust-strip__icon {
  width: 44px;
  height: 44px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--serif);
  color: var(--gold);
  font-size: 18px;
  flex-shrink: 0;
}
.trust-strip__title {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 3px;
  letter-spacing: 0.04em;
}
.trust-strip__label {
  color: var(--ink-soft);
  letter-spacing: 0.04em;
  line-height: 1.5;
  font-size: 11px;
}

/* ---------- Services intro ---------- */
.services {
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.services__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 24px;
}
.service-tile {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  padding: 48px 44px;
  position: relative;
  transition: border-color 0.3s, transform 0.3s;
  overflow: hidden;
}
.service-tile:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
}
.service-tile__num {
  position: absolute;
  top: 24px; right: 28px;
  font-family: var(--serif);
  font-size: 90px;
  color: rgba(201, 164, 73, 0.08);
  line-height: 1;
}
.service-tile__icon {
  font-family: var(--serif);
  font-size: 32px;
  color: var(--gold);
  margin-bottom: 28px;
}
.service-tile__title {
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 500;
  margin: 0 0 14px;
  letter-spacing: 0.04em;
}
.service-tile__desc {
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.95;
  margin-bottom: 28px;
  max-width: 420px;
}
.service-tile__list {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  border-top: 1px solid var(--line);
  padding-top: 20px;
}
.service-tile__list li {
  font-size: 12px;
  padding: 7px 0;
  color: var(--ink-soft);
  display: flex;
  align-items: center;
  gap: 12px;
}
.service-tile__list li::before {
  content: "—";
  color: var(--gold);
}

/* ---------- How it works ---------- */
.how {
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.how__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
}
.how__step {
  padding: 40px 32px;
  border-right: 1px solid var(--line);
  position: relative;
}
.how__step:last-child { border-right: none; }
.how__step__num {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--gold);
  margin-bottom: 28px;
  text-transform: uppercase;
}
.how__step__icon {
  width: 56px; height: 56px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin-bottom: 24px;
  font-family: var(--serif);
  font-size: 22px;
  color: var(--gold);
}
.how__step__title {
  font-family: var(--serif);
  font-size: 20px;
  margin: 0 0 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.how__step__desc {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.85;
}

/* ---------- Plan section ---------- */
.plans {
  background: var(--bg);
}
.plans__header {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: end;
  margin-bottom: 64px;
}
.plans__toggle {
  display: inline-flex;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 0;
  padding: 4px;
  font-size: 11px;
}
.plans__toggle button {
  padding: 11px 22px;
  border-radius: 0;
  letter-spacing: 0.16em;
  color: var(--ink-mute);
  transition: all 0.25s;
  text-transform: uppercase;
}
.plans__toggle button.is-active {
  background: var(--gold);
  color: var(--bg);
  font-weight: 500;
}

.plans__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: stretch;
}
.plan-card {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 0;
  padding: 44px 36px 36px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
  cursor: pointer;
}
.plan-card:hover {
  transform: translateY(-6px);
  border-color: var(--gold);
}
.plan-card.is-selected {
  border-color: var(--gold);
}
.plan-card.is-selected::before {
  content: "";
  position: absolute;
  inset: -1px;
  border: 1px solid var(--gold);
  pointer-events: none;
}
.plan-card--featured {
  background: linear-gradient(180deg, #1a1610 0%, #0e0c08 100%);
  border-color: var(--gold);
  box-shadow: var(--shadow-gold);
}
.plan-card--premium {
  background:
    radial-gradient(ellipse at top, rgba(201, 164, 73, 0.1) 0%, transparent 60%),
    linear-gradient(180deg, #1c180f 0%, #0a0907 100%);
  border-color: var(--gold);
}
.plan-card--premium::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(201, 164, 73, 0.25);
  pointer-events: none;
}

.plan-card__ribbon {
  position: absolute;
  top: -12px;
  right: 28px;
  background: var(--gold);
  color: var(--bg);
  padding: 5px 14px;
  font-size: 10px;
  letter-spacing: 0.22em;
  border-radius: 0;
  font-weight: 600;
  text-transform: uppercase;
}
.plan-card__ribbon--premium {
  background: linear-gradient(135deg, var(--gold-bright) 0%, var(--gold) 100%);
  color: #0a0907;
}
.plan-card__char {
  font-family: var(--serif);
  font-size: 96px;
  font-weight: 400;
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: 0;
  color: var(--gold);
}
.plan-card__romaji {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.plan-card__name {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 500;
  margin: 0 0 16px;
  letter-spacing: 0.05em;
}
.plan-card__tagline {
  font-size: 13px;
  color: var(--ink-soft);
  margin-bottom: 32px;
  line-height: 1.85;
  min-height: 48px;
}

.plan-card__min {
  display: inline-block;
  padding: 4px 10px;
  background: rgba(201, 164, 73, 0.12);
  border: 1px solid var(--gold-deep);
  color: var(--gold);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  margin-bottom: 16px;
  text-transform: uppercase;
}
.plan-card__price {
  display: flex;
  align-items: baseline;
  gap: 4px;
  border-top: 1px solid var(--line);
  padding-top: 24px;
  margin-bottom: 24px;
}
.plan-card__price__yen {
  font-family: var(--serif);
  font-size: 20px;
  color: var(--ink-soft);
}
.plan-card__price__num {
  font-family: var(--serif);
  font-size: 48px;
  font-weight: 400;
  line-height: 1;
  color: var(--ink);
}
.plan-card--featured .plan-card__price__num,
.plan-card--premium .plan-card__price__num { color: var(--gold); }
.plan-card__price__unit {
  font-size: 12px;
  color: var(--ink-mute);
  margin-left: 6px;
  letter-spacing: 0.08em;
}

.plan-card__features {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  flex: 1;
}
.plan-card__features li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  font-size: 13px;
  border-bottom: 1px dashed var(--line);
  line-height: 1.6;
  color: var(--ink-soft);
}
.plan-card__features li:last-child { border-bottom: none; }
.plan-card__features li.is-off { opacity: 0.3; }
.plan-card__check {
  flex-shrink: 0;
  width: 18px; height: 18px;
  display: grid;
  place-items: center;
  font-size: 12px;
  color: var(--gold);
  margin-top: 1px;
  font-weight: 700;
}
.plan-card__cross {
  flex-shrink: 0;
  width: 18px; height: 18px;
  display: grid;
  place-items: center;
  font-size: 11px;
  color: var(--ink-mute);
  margin-top: 1px;
}
.plan-card__cta {
  width: 100%;
  justify-content: center;
}

.plans__note {
  margin-top: 32px;
  font-size: 11px;
  color: var(--ink-mute);
  text-align: center;
  font-family: var(--mono);
  letter-spacing: 0.12em;
}

/* ---------- Detailing showcase ---------- */
.detail {
  background: #000;
  color: var(--ink);
  padding: 140px 40px;
  border-top: 1px solid var(--line);
}
.detail__inner {
  max-width: 1280px;
  margin: 0 auto;
}
.detail__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  margin-bottom: 64px;
  align-items: end;
}
.detail__lede {
  font-size: 15px;
  color: var(--ink-soft);
  line-height: 2;
}
.detail__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 300px 300px;
  gap: 16px;
}
.detail__tile {
  border-radius: 0;
  overflow: hidden;
  position: relative;
  background: var(--bg-card);
  padding: 28px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  border: 1px solid var(--line);
  transition: border-color 0.3s, transform 0.3s;
}
.detail__tile:hover {
  transform: translateY(-3px);
  border-color: var(--gold);
}
.detail__tile--lg { grid-row: span 2; }
.detail__tile__placeholder {
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(45deg, rgba(201, 164, 73, 0.03) 0 2px, transparent 2px 14px);
  z-index: 0;
}
.detail__tile__hint {
  position: absolute;
  top: 22px; left: 22px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--gold);
  z-index: 1;
}
.detail__tile__content { position: relative; z-index: 2; }
.detail__tile__num {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--gold);
  margin-bottom: 10px;
}
.detail__tile__title {
  font-family: var(--serif);
  font-size: 22px;
  margin: 0 0 8px;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.detail__tile__desc {
  font-size: 12px;
  color: var(--ink-soft);
  line-height: 1.75;
}
.detail__tile--lg .detail__tile__title { font-size: 30px; }
.detail__tile--lg .detail__tile__desc { font-size: 13px; max-width: 360px; }

/* ---------- Testimonials ---------- */
.voice {
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.voice__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.voice-card {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  position: relative;
}
.voice-card__quote {
  font-family: var(--serif);
  font-size: 60px;
  line-height: 1;
  color: var(--gold);
  opacity: 0.35;
  margin-bottom: -10px;
}
.voice-card__stars {
  color: var(--gold);
  letter-spacing: 0.2em;
  margin-bottom: 16px;
  font-size: 13px;
}
.voice-card__title {
  font-family: var(--serif);
  font-size: 17px;
  margin: 0 0 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.5;
}
.voice-card__body {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.9;
  margin-bottom: 24px;
  flex: 1;
}
.voice-card__meta {
  border-top: 1px solid var(--line);
  padding-top: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
}
.voice-card__name {
  color: var(--ink);
  font-weight: 500;
}
.voice-card__attr {
  color: var(--ink-mute);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
}

/* ---------- Booking flow ---------- */
.booking {
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
}
.booking__shell {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: 340px 1fr;
  box-shadow: var(--shadow-lg);
  min-height: 600px;
}
.booking__sidebar {
  background: #000;
  color: var(--ink);
  padding: 40px 32px;
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--line);
}
.booking__sidebar__title {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 500;
  margin: 0 0 6px;
  letter-spacing: 0.06em;
}
.booking__sidebar__sub {
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.2em;
  font-family: var(--mono);
  margin-bottom: 40px;
  text-transform: uppercase;
}
.booking__steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
.booking__step {
  display: flex;
  gap: 16px;
  align-items: center;
  padding: 12px 0;
  font-size: 13px;
  color: var(--ink-mute);
  transition: color 0.25s;
  position: relative;
  letter-spacing: 0.06em;
}
.booking__step__num {
  width: 30px; height: 30px;
  border-radius: 50%;
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  font-family: var(--mono);
  font-size: 11px;
  flex-shrink: 0;
  transition: all 0.25s;
  color: var(--ink-mute);
}
.booking__step.is-active { color: var(--gold); }
.booking__step.is-active .booking__step__num {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--bg);
  font-weight: 600;
}
.booking__step.is-done { color: var(--ink-soft); }
.booking__step.is-done .booking__step__num {
  border-color: var(--gold);
  color: var(--gold);
}
.booking__summary {
  border-top: 1px solid var(--line);
  padding-top: 24px;
  font-size: 12px;
}
.booking__summary__row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  color: var(--ink-mute);
}
.booking__summary__row strong { color: var(--ink); font-weight: 500; }
.booking__summary__total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.booking__summary__total__num {
  font-family: var(--serif);
  font-size: 28px;
  color: var(--gold);
}

.booking__main {
  padding: 48px 56px;
  display: flex;
  flex-direction: column;
  background: var(--bg);
}
.booking__main__header {
  margin-bottom: 36px;
}
.booking__main__step-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--gold);
  margin-bottom: 10px;
  text-transform: uppercase;
}
.booking__main__title {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 500;
  margin: 0 0 8px;
  letter-spacing: 0.04em;
}
.booking__main__desc {
  font-size: 13px;
  color: var(--ink-soft);
}

.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}
.field {
  display: flex;
  flex-direction: column;
}
.field--full { grid-column: 1 / -1; }
.field__label {
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--ink-mute);
  margin-bottom: 10px;
  font-family: var(--mono);
  text-transform: uppercase;
}
.field__input {
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 0;
  background: var(--bg-soft);
  font-size: 14px;
  font-family: inherit;
  color: var(--ink);
  transition: border-color 0.25s, background 0.25s;
}
.field__input:focus {
  outline: none;
  border-color: var(--gold);
}
.field__input::placeholder { color: var(--ink-mute); opacity: 0.6; }

.plan-pick {
  display: grid;
  gap: 12px;
}
.plan-pick__option {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  align-items: center;
  gap: 22px;
  padding: 20px 24px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 0;
  cursor: pointer;
  transition: all 0.25s;
  text-align: left;
}
.plan-pick__option:hover { border-color: var(--gold); }
.plan-pick__option.is-active {
  border-color: var(--gold);
  background: rgba(201, 164, 73, 0.05);
}
.plan-pick__char {
  font-family: var(--serif);
  font-size: 48px;
  font-weight: 400;
  text-align: center;
  line-height: 1;
  color: var(--gold);
}
.plan-pick__body strong {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 500;
  display: block;
  margin-bottom: 4px;
  letter-spacing: 0.04em;
}
.plan-pick__body span { font-size: 12px; color: var(--ink-mute); }
.plan-pick__price {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 500;
  color: var(--gold);
}
.plan-pick__price small { font-size: 11px; color: var(--ink-mute); margin-left: 2px; font-family: var(--sans); }

.addon-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.addon {
  display: flex;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 0;
  cursor: pointer;
  transition: all 0.25s;
}
.addon:hover { border-color: var(--gold); }
.addon.is-active { border-color: var(--gold); background: rgba(201, 164, 73, 0.05); }
.addon__check {
  width: 20px; height: 20px;
  border: 1px solid var(--ink-mute);
  border-radius: 0;
  display: grid;
  place-items: center;
  font-size: 11px;
  color: transparent;
  transition: all 0.25s;
  flex-shrink: 0;
}
.addon.is-active .addon__check {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--bg);
}
.addon__body { flex: 1; font-size: 13px; }
.addon__body strong { display: block; font-weight: 500; margin-bottom: 2px; }
.addon__body span { color: var(--ink-mute); font-size: 11px; }
.addon__price {
  font-family: var(--serif);
  font-size: 16px;
  color: var(--gold);
}

.booking__confirm {
  text-align: center;
  padding: 40px 20px;
}
.booking__confirm__icon {
  width: 72px; height: 72px;
  border-radius: 50%;
  border: 1px solid var(--gold);
  color: var(--gold);
  display: grid;
  place-items: center;
  font-size: 30px;
  margin: 0 auto 28px;
  font-family: var(--serif);
}
.booking__confirm__title {
  font-family: var(--serif);
  font-size: 30px;
  margin: 0 0 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.booking__confirm__desc {
  color: var(--ink-soft);
  margin-bottom: 32px;
  font-size: 14px;
  line-height: 1.9;
}
.booking__confirm__ref {
  display: inline-block;
  padding: 12px 24px;
  background: var(--bg-soft);
  border: 1px dashed var(--gold);
  border-radius: 0;
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.12em;
  color: var(--gold);
}

.booking__actions {
  margin-top: auto;
  padding-top: 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--line);
}

.day-counter {
  display: flex;
  gap: 12px;
  align-items: center;
}
.day-counter__btn {
  width: 36px; height: 36px;
  border: 1px solid var(--line);
  border-radius: 0;
  font-size: 16px;
  display: grid;
  place-items: center;
  color: var(--ink);
  transition: all 0.25s;
}
.day-counter__btn:hover { border-color: var(--gold); color: var(--gold); }
.day-counter__val {
  font-family: var(--serif);
  font-size: 32px;
  min-width: 100px;
  text-align: center;
  color: var(--gold);
}
.day-counter__val small {
  font-size: 12px;
  color: var(--ink-mute);
  margin-left: 6px;
  font-family: var(--sans);
}

/* ---------- Access / Map ---------- */
.access {
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
}
.access__grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 40px;
  align-items: stretch;
  min-height: 480px;
}
.access__info {
  background: #000;
  padding: 44px;
  border: 1px solid var(--line);
}
.access__info dl {
  margin: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px 24px;
}
.access__info dt {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--gold);
  text-transform: uppercase;
  padding-top: 4px;
}
.access__info dd {
  margin: 0;
  font-size: 14px;
  color: var(--ink);
  line-height: 1.7;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--line);
}
.access__info dd:last-of-type { border-bottom: none; }
.access__info dd strong {
  font-family: var(--serif);
  font-weight: 500;
  display: block;
  margin-bottom: 4px;
}
.access__map {
  background: var(--bg-card);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.access__map__placeholder {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(201, 164, 73, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201, 164, 73, 0.06) 1px, transparent 1px);
  background-size: 40px 40px;
}
.access__map__roads {
  position: absolute;
  inset: 0;
}
.access__map__road {
  position: absolute;
  background: rgba(201, 164, 73, 0.18);
}
.access__map__road--h { height: 2px; left: 0; right: 0; }
.access__map__road--v { width: 2px; top: 0; bottom: 0; }
.access__map__road--diag {
  height: 2px; left: -10%; right: -10%;
  top: 64%; transform: rotate(-12deg);
}
.access__map__pin {
  position: absolute;
  top: 50%; left: 38%;
  transform: translate(-50%, -100%);
  z-index: 3;
}
.access__map__pin__dot {
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--gold);
  border: 3px solid var(--bg);
  box-shadow: 0 0 0 1px var(--gold);
  margin: 0 auto;
  position: relative;
}
.access__map__pin__dot::before {
  content: "";
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  border: 1px solid var(--gold);
  animation: pulse-ring 2.5s ease-out infinite;
}
@keyframes pulse-ring {
  0% { transform: scale(0.7); opacity: 1; }
  100% { transform: scale(2.4); opacity: 0; }
}
.access__map__pin__label {
  margin-top: 10px;
  font-family: var(--serif);
  font-size: 14px;
  color: var(--gold);
  background: rgba(0,0,0,0.7);
  padding: 4px 10px;
  white-space: nowrap;
  border: 1px solid var(--gold);
}
.access__map__pin--airport {
  top: 75%; left: 72%;
}
.access__map__pin--airport .access__map__pin__dot {
  background: transparent;
  border-color: var(--ink-soft);
  box-shadow: 0 0 0 1px var(--ink-soft);
}
.access__map__pin--airport .access__map__pin__dot::before { display: none; }
.access__map__pin--airport .access__map__pin__label {
  color: var(--ink-soft);
  border-color: var(--ink-soft);
}
.access__map__route {
  position: absolute;
  top: 50%; left: 38%;
  width: 240px;
  height: 2px;
  background: repeating-linear-gradient(90deg, var(--gold) 0 6px, transparent 6px 12px);
  transform-origin: left center;
  transform: rotate(28deg);
  z-index: 2;
}
.access__map__label {
  position: absolute;
  bottom: 24px; left: 24px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--gold);
  text-transform: uppercase;
  z-index: 5;
  background: rgba(0,0,0,0.5);
  padding: 6px 10px;
}
.access__map__compass {
  position: absolute;
  top: 24px; right: 24px;
  width: 50px; height: 50px;
  border: 1px solid var(--line);
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--serif);
  color: var(--ink-soft);
  font-size: 14px;
  background: rgba(0,0,0,0.5);
  z-index: 5;
}

/* ---------- Company info ---------- */
.company {
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.company__layout {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: start;
}
.company__visual {
  position: sticky;
  top: 100px;
}
.company__seal {
  width: 220px; height: 220px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin-bottom: 32px;
  position: relative;
  background: var(--bg-soft);
}
.company__seal::after {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  opacity: 0.3;
}
.company__seal__char {
  font-family: var(--serif);
  font-size: 110px;
  color: var(--gold);
  font-weight: 400;
  line-height: 1;
}
.company__motto {
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.85;
  color: var(--ink);
  font-weight: 400;
  letter-spacing: 0.06em;
  border-left: 1px solid var(--gold);
  padding-left: 20px;
}
.company__table {
  width: 100%;
  border-collapse: collapse;
}
.company__table tr {
  border-bottom: 1px solid var(--line);
}
.company__table th {
  text-align: left;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--gold);
  text-transform: uppercase;
  font-weight: 500;
  padding: 20px 0;
  width: 180px;
  vertical-align: top;
}
.company__table td {
  padding: 20px 0;
  color: var(--ink-soft);
  font-size: 14px;
  line-height: 1.85;
}
.company__table strong {
  color: var(--ink);
  font-family: var(--serif);
  font-weight: 500;
}

/* ---------- FAQ ---------- */
.faq {
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
}
.faq__list {
  border-top: 1px solid var(--gold);
}
.faq__item {
  border-bottom: 1px solid var(--line);
}
.faq__q {
  width: 100%;
  text-align: left;
  padding: 26px 0;
  display: grid;
  grid-template-columns: 72px 1fr 28px;
  gap: 28px;
  align-items: center;
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 500;
  transition: color 0.25s;
  letter-spacing: 0.04em;
  color: var(--ink);
  cursor: pointer;
}
.faq__q:hover { color: var(--gold); }
.faq__num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--gold);
}
.faq__icon {
  font-size: 22px;
  font-family: var(--serif);
  color: var(--gold);
  transition: transform 0.4s ease;
}
.faq__item.is-open .faq__icon { transform: rotate(45deg); }
.faq__a {
  padding: 0 28px 28px 100px;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.95;
  max-width: 820px;
  display: none;
}
.faq__item.is-open .faq__a { display: block; }

/* ---------- Inquiry form ---------- */
.inquiry {
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
}
.inquiry__shell {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  border: 1px solid var(--line);
  background: var(--bg);
  box-shadow: var(--shadow-lg);
}
.inquiry__form {
  padding: 56px 56px;
  border-right: 1px solid var(--line);
}
.inquiry__form h3 {
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 500;
  margin: 0 0 8px;
  letter-spacing: 0.04em;
}
.inquiry__form__sub {
  font-size: 13px;
  color: var(--ink-soft);
  margin-bottom: 36px;
  line-height: 1.8;
}
.inquiry__radio-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 4px;
}
.inquiry__radio {
  padding: 12px 12px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  font-size: 12px;
  color: var(--ink-soft);
  text-align: center;
  cursor: pointer;
  transition: all 0.25s;
  letter-spacing: 0.04em;
}
.inquiry__radio:hover { border-color: var(--gold); color: var(--gold); }
.inquiry__radio.is-active {
  border-color: var(--gold);
  background: rgba(201, 164, 73, 0.08);
  color: var(--gold);
}
.inquiry__form__submit {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--line);
  padding-top: 28px;
  margin-top: 24px;
}
.inquiry__form__note {
  font-size: 11px;
  color: var(--ink-mute);
  font-family: var(--mono);
  letter-spacing: 0.1em;
  line-height: 1.6;
  max-width: 240px;
}
.inquiry__form textarea.field__input {
  font-family: inherit;
  resize: vertical;
  min-height: 110px;
  line-height: 1.7;
}
.inquiry__form select.field__input {
  appearance: none;
  -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--gold) 50%), linear-gradient(135deg, var(--gold) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 40px;
}

.inquiry__side {
  padding: 56px 48px;
  background: #000;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.inquiry__side h3 {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 500;
  margin: 0;
  letter-spacing: 0.04em;
}
.inquiry__channel {
  border: 1px solid var(--line);
  padding: 26px 24px;
  background: var(--bg-card);
  transition: border-color 0.25s;
}
.inquiry__channel:hover { border-color: var(--gold); }
.inquiry__channel__label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.inquiry__channel__value {
  font-family: var(--serif);
  font-size: 26px;
  color: var(--ink);
  margin-bottom: 8px;
  letter-spacing: 0.04em;
}
.inquiry__channel__value a { color: var(--gold); }
.inquiry__channel__hours {
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.1em;
  font-family: var(--mono);
}
.inquiry__channel__desc {
  font-size: 12px;
  color: var(--ink-soft);
  margin-top: 10px;
  line-height: 1.7;
}

.inquiry__form.is-submitted .inquiry__form__inner { display: none; }
.inquiry__success {
  display: none;
  text-align: center;
  padding: 60px 20px;
}
.inquiry__form.is-submitted .inquiry__success { display: block; }
.inquiry__success__icon {
  width: 64px; height: 64px;
  border: 1px solid var(--gold);
  color: var(--gold);
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin: 0 auto 24px;
  font-family: var(--serif);
  font-size: 26px;
}
.inquiry__success__title {
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 500;
  margin: 0 0 12px;
  letter-spacing: 0.04em;
}
.inquiry__success__desc {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.95;
  max-width: 420px;
  margin: 0 auto;
}

/* ---------- Contact ---------- */
.contact {
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.contact__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.contact-card {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  padding: 44px 36px;
  text-align: left;
  position: relative;
  transition: border-color 0.3s, transform 0.3s;
}
.contact-card:hover { border-color: var(--gold); transform: translateY(-3px); }
.contact-card__icon {
  font-family: var(--serif);
  font-size: 36px;
  color: var(--gold);
  margin-bottom: 24px;
  line-height: 1;
}
.contact-card__title {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 500;
  margin: 0 0 8px;
  letter-spacing: 0.06em;
}
.contact-card__desc {
  font-size: 12px;
  color: var(--ink-mute);
  margin-bottom: 24px;
  line-height: 1.7;
  min-height: 42px;
}
.contact-card__value {
  font-family: var(--serif);
  font-size: 24px;
  color: var(--gold);
  letter-spacing: 0.04em;
  margin-bottom: 14px;
  word-break: break-all;
}
.contact-card__hours {
  font-size: 11px;
  color: var(--ink-mute);
  font-family: var(--mono);
  letter-spacing: 0.14em;
}

/* ---------- CTA band ---------- */
.cta-band {
  background:
    radial-gradient(ellipse at top, rgba(201, 164, 73, 0.08) 0%, transparent 60%),
    #000;
  color: var(--ink);
  padding: 120px 40px;
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--line);
}
.cta-band__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 60px;
  align-items: center;
  position: relative;
  z-index: 2;
}
.cta-band__title {
  font-family: var(--serif);
  font-size: clamp(34px, 4.2vw, 52px);
  margin: 0 0 18px;
  font-weight: 400;
  line-height: 1.35;
  letter-spacing: 0.04em;
}
.cta-band__title em { color: var(--gold); font-style: normal; }
.cta-band__sub {
  color: var(--ink-soft);
  font-size: 15px;
  max-width: 580px;
  line-height: 1.9;
}
.cta-band__bg {
  position: absolute;
  font-family: var(--serif);
  font-size: 480px;
  color: rgba(201, 164, 73, 0.025);
  right: -60px;
  bottom: -180px;
  pointer-events: none;
  font-weight: 300;
}

/* ---------- Footer ---------- */
.footer {
  background: #000;
  color: var(--ink-soft);
  padding: 80px 40px 32px;
  font-size: 13px;
  border-top: 1px solid var(--line);
}
.footer__inner {
  max-width: 1280px;
  margin: 0 auto;
}
.footer__top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--line);
}
.footer__brand p {
  margin: 18px 0 0;
  line-height: 1.85;
  font-size: 12px;
  color: var(--ink-mute);
}
.footer__col h4 {
  color: var(--gold);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  margin: 0 0 20px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}
.footer__col ul { list-style: none; padding: 0; margin: 0; }
.footer__col li {
  padding: 7px 0;
  font-size: 13px;
  color: var(--ink-soft);
  cursor: pointer;
  transition: color 0.2s;
}
.footer__col li:hover { color: var(--gold); }
.footer__bot {
  padding-top: 28px;
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.12em;
}

/* ---------- Hub / service entry tiles (index page) ---------- */
.hub {
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.hub__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.hub-tile {
  position: relative;
  padding: 88px 64px;
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  background: var(--bg);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: background 0.4s;
  min-height: 560px;
}
.hub-tile:last-child { border-right: none; }
.hub-tile:hover { background: var(--bg-soft); }
.hub-tile:hover .hub-tile__char { color: var(--gold-bright); transform: scale(1.05); }
.hub-tile:hover .hub-tile__arrow { transform: translateX(6px); }
.hub-tile__char {
  font-family: var(--serif);
  font-size: 280px;
  line-height: 1;
  color: rgba(201, 164, 73, 0.08);
  position: absolute;
  bottom: -60px;
  right: -20px;
  transition: color 0.5s, transform 0.5s;
  pointer-events: none;
}
.hub-tile__num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.32em;
  color: var(--gold);
  margin-bottom: 32px;
  text-transform: uppercase;
}
.hub-tile__name {
  font-family: var(--serif);
  font-size: clamp(34px, 3.6vw, 48px);
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.04em;
  margin: 0 0 20px;
}
.hub-tile__en {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.28em;
  color: var(--ink-mute);
  margin-bottom: 32px;
  text-transform: uppercase;
}
.hub-tile__desc {
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 2;
  max-width: 380px;
  margin-bottom: 36px;
  flex: 1;
}
.hub-tile__keywords {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}
.hub-tile__kw {
  padding: 5px 12px;
  border: 1px solid var(--line);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--ink-soft);
}
.hub-tile__cta {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--serif);
  font-size: 16px;
  color: var(--gold);
  letter-spacing: 0.08em;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--gold);
  align-self: flex-start;
}
.hub-tile__arrow { transition: transform 0.3s; }

/* ---------- Page hero (slimmer hero for sub-pages) ---------- */
.page-hero {
  position: relative;
  padding: 100px 40px 80px;
  background:
    radial-gradient(ellipse at top right, rgba(201, 164, 73, 0.05) 0%, transparent 50%),
    var(--bg);
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.page-hero__inner {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.page-hero__breadcrumb {
  display: flex;
  gap: 10px;
  align-items: center;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--ink-mute);
  margin-bottom: 32px;
}
.page-hero__breadcrumb a { color: var(--ink-mute); transition: color 0.2s; }
.page-hero__breadcrumb a:hover { color: var(--gold); }
.page-hero__breadcrumb span.sep { color: var(--gold); }
.page-hero__breadcrumb span.current { color: var(--gold); }
.page-hero__layout {
  display: grid;
  grid-template-columns: 1fr 0.8fr;
  gap: 80px;
  align-items: end;
}
.page-hero__title {
  font-family: var(--serif);
  font-size: clamp(40px, 5vw, 68px);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.03em;
  margin: 0 0 24px;
}
.page-hero__title em { color: var(--gold); font-style: normal; font-weight: 500; }
.page-hero__lede {
  font-size: 15px;
  line-height: 2;
  color: var(--ink-soft);
  max-width: 540px;
  margin: 0;
}
.page-hero__meta {
  display: grid;
  gap: 14px;
  border-left: 1px solid var(--gold);
  padding-left: 24px;
}
.page-hero__meta__row {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 16px;
  font-size: 13px;
  align-items: baseline;
}
.page-hero__meta__row dt {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--gold);
  text-transform: uppercase;
}
.page-hero__meta__row dd {
  margin: 0;
  font-family: var(--serif);
  color: var(--ink);
}
.page-hero__bg-mark {
  position: absolute;
  font-family: var(--serif);
  font-size: 420px;
  color: rgba(201, 164, 73, 0.025);
  right: -60px;
  top: -40px;
  pointer-events: none;
  font-weight: 300;
  line-height: 1;
}

/* ---------- Detailing menu (3 tiers — different from 松竹梅) ---------- */
.dt-menu {
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.dt-menu__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.dt-menu__card {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  padding: 40px 36px 36px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform 0.3s, border-color 0.3s;
}
.dt-menu__card:hover {
  transform: translateY(-4px);
  border-color: var(--gold);
}
.dt-menu__card--featured { border-color: var(--gold); }
.dt-menu__card--premium {
  background:
    radial-gradient(ellipse at top, rgba(201, 164, 73, 0.1) 0%, transparent 60%),
    linear-gradient(180deg, #1c180f 0%, #0a0907 100%);
  border-color: var(--gold);
  position: relative;
}
.dt-menu__card--premium::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(201, 164, 73, 0.25);
  pointer-events: none;
}
.dt-menu__card__tier {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.32em;
  color: var(--gold);
  margin-bottom: 16px;
  text-transform: uppercase;
}
.dt-menu__card__name {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 500;
  margin: 0 0 12px;
  letter-spacing: 0.04em;
}
.dt-menu__card__tag {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.85;
  min-height: 50px;
  margin-bottom: 24px;
}
.dt-menu__card__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-top: 1px solid var(--line);
  padding-top: 22px;
  margin-bottom: 26px;
}
.dt-menu__card__duration {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--ink-mute);
}
.dt-menu__card__price {
  font-family: var(--serif);
  font-size: 32px;
  color: var(--ink);
}
.dt-menu__card--featured .dt-menu__card__price,
.dt-menu__card--premium .dt-menu__card__price { color: var(--gold); }
.dt-menu__card__price__yen {
  font-size: 16px;
  color: var(--ink-soft);
  margin-right: 2px;
}
.dt-menu__card__price__unit {
  font-size: 11px;
  color: var(--ink-mute);
  margin-left: 4px;
  font-family: var(--sans);
}
.dt-menu__card__list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  flex: 1;
}
.dt-menu__card__list li {
  font-size: 13px;
  padding: 7px 0;
  color: var(--ink-soft);
  border-bottom: 1px dashed var(--line);
  position: relative;
  padding-left: 18px;
  line-height: 1.6;
}
.dt-menu__card__list li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--gold);
}
.dt-menu__card__list li:last-child { border-bottom: none; }

/* ---------- Process timeline (detailing) ---------- */
.process {
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.process__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}
.process__step {
  background: var(--bg);
  padding: 36px 32px;
  position: relative;
}
.process__step__num {
  font-family: var(--serif);
  font-size: 64px;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 16px;
  opacity: 0.4;
}
.process__step__title {
  font-family: var(--serif);
  font-size: 20px;
  font-weight: 500;
  margin: 0 0 12px;
  letter-spacing: 0.04em;
}
.process__step__desc {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.85;
}

/* ---------- Before/After ---------- */
.beforeafter {
  background: #000;
  border-top: 1px solid var(--line);
}
.beforeafter__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}
.beforeafter__pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--line);
}
.beforeafter__half {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--bg-card);
  overflow: hidden;
  border-right: 1px solid var(--line);
}
.beforeafter__half:last-child { border-right: none; }
.beforeafter__half--before .beforeafter__half__bg {
  background:
    repeating-linear-gradient(45deg, rgba(255,255,255,0.02) 0 2px, transparent 2px 12px),
    linear-gradient(180deg, #14110d 0%, #0a0907 100%);
}
.beforeafter__half--after .beforeafter__half__bg {
  background:
    repeating-linear-gradient(45deg, rgba(201,164,73,0.04) 0 2px, transparent 2px 12px),
    linear-gradient(180deg, #1f1a10 0%, #0d0b08 100%);
}
.beforeafter__half__bg { position: absolute; inset: 0; }
.beforeafter__half__label {
  position: absolute;
  top: 14px; left: 14px;
  background: rgba(0,0,0,0.7);
  padding: 5px 12px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.24em;
  color: var(--gold);
  z-index: 2;
}
.beforeafter__half--before .beforeafter__half__label { color: var(--ink-soft); }
.beforeafter__half__hint {
  position: absolute;
  bottom: 14px; right: 14px;
  font-family: var(--mono);
  font-size: 9px;
  color: var(--ink-mute);
  letter-spacing: 0.16em;
  z-index: 2;
}
.beforeafter__caption {
  grid-column: 1 / -1;
  padding: 18px 24px;
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 13px;
}
.beforeafter__caption strong {
  font-family: var(--serif);
  font-weight: 500;
  color: var(--ink);
}
.beforeafter__caption span {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--gold);
}

/* ---------- Artisan ---------- */
.artisan {
  background: var(--bg);
  border-top: 1px solid var(--line);
}
.artisan__layout {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: center;
}
.artisan__photo {
  position: relative;
  aspect-ratio: 3 / 4;
  border: 1px solid var(--line);
  background:
    repeating-linear-gradient(135deg, rgba(201, 164, 73, 0.04) 0 2px, transparent 2px 14px),
    linear-gradient(180deg, #1a1610 0%, #0a0907 100%);
  overflow: hidden;
}
.artisan__photo::before {
  content: "";
  position: absolute;
  inset: 16px;
  border: 1px solid rgba(201, 164, 73, 0.2);
}
.artisan__photo__label {
  position: absolute;
  bottom: 32px; left: 32px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--gold);
}
.artisan__quote {
  font-family: var(--serif);
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 2;
  color: var(--ink);
  letter-spacing: 0.05em;
  margin: 0 0 36px;
  white-space: pre-line;
  text-wrap: pretty;
}
.artisan__quote::before {
  content: """;
  font-size: 80px;
  color: var(--gold);
  line-height: 0.5;
  display: block;
  margin-bottom: 10px;
  opacity: 0.4;
}
.artisan__meta {
  display: grid;
  grid-template-columns: auto auto;
  gap: 8px 32px;
  border-top: 1px solid var(--line);
  padding-top: 28px;
  font-size: 13px;
}
.artisan__meta dt {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--gold);
  text-transform: uppercase;
}
.artisan__meta dd {
  margin: 0;
  color: var(--ink);
}
.artisan__name {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 500;
  margin-bottom: 4px;
  letter-spacing: 0.06em;
}
.artisan__role {
  font-size: 12px;
  color: var(--gold);
  letter-spacing: 0.16em;
  font-family: var(--mono);
  text-transform: uppercase;
  margin-bottom: 28px;
}

/* ---------- Cross-link card (between parking & detailing pages) ---------- */
.crosslink {
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
}
.crosslink__card {
  display: grid;
  grid-template-columns: 100px 1fr auto;
  gap: 32px;
  align-items: center;
  padding: 44px 48px;
  border: 1px solid var(--gold);
  background:
    radial-gradient(ellipse at left, rgba(201, 164, 73, 0.08) 0%, transparent 60%),
    var(--bg);
  transition: background 0.3s;
}
.crosslink__card:hover { background: rgba(201, 164, 73, 0.05); }
.crosslink__char {
  font-family: var(--serif);
  font-size: 80px;
  color: var(--gold);
  line-height: 1;
  text-align: center;
}
.crosslink__title {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 500;
  margin: 0 0 6px;
  letter-spacing: 0.04em;
}
.crosslink__desc {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.7;
}

/* ---------- Responsive ---------- */
@media (max-width: 1100px) {
  .hero__inner, .plans__grid, .how__grid, .detail__grid, .booking__shell,
  .detail__head, .footer__top, .cta-band__inner, .plans__header,
  .voice__grid, .access__grid, .company__layout, .contact__grid,
  .services__grid, .hub__grid, .page-hero__layout, .dt-menu__grid,
  .process__list, .beforeafter__grid, .artisan__layout, .crosslink__card,
  .inquiry__shell, .inquiry__radio-row, .triad__grid, .subbiz__grid,
  .rental-list {
    grid-template-columns: 1fr;
  }
  .concept__flow {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto auto;
  }
  .concept__flow__arrow { transform: rotate(90deg); padding: 12px 0; }
  .nav__inner { grid-template-columns: 1fr auto; gap: 16px; padding: 16px 24px; }
  .nav__links { display: none; }
  .nav__cta { display: none; }
  .nav__menu-btn { display: flex; }
  .nav__drawer__overlay { display: block; pointer-events: none; }
  .nav__drawer__overlay.is-open { pointer-events: auto; }
  .hero__visual { display: none; }
  .hero__bg-mark { display: none; }
  .trust-strip__inner { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .trust-strip__item { padding-right: 16px; }
  .trust-strip__item:nth-child(2) { border-right: none; padding-right: 0; }
  .section { padding: 88px 24px; }
  .booking__main { padding: 32px 24px; }
  .hub-tile, .triad-tile { padding: 56px 32px; min-height: auto; border-right: none; border-bottom: 1px solid var(--line); }
  .hub-tile:last-child, .triad-tile:last-child { border-bottom: none; }
  .util-bar__left { gap: 16px; }
  .util-bar__left span:nth-child(2) { display: none; }
  .hero { min-height: auto; padding: 60px 24px 80px; }
  .hero__title { font-size: clamp(36px, 8vw, 52px); }
  .cta-band__inner { gap: 32px; }
  .cta-band__inner > div:last-child { width: 100%; }
  .plans__header { gap: 24px; }
  .plans__toggle { align-self: flex-start; }
  .booking__sidebar { padding: 32px 24px; }
  .hero__photo { position: relative; }
  .access__map { min-height: 360px; }
  .footer { padding: 60px 24px 28px; }
  .footer__top { gap: 32px; padding-bottom: 32px; }
  .footer__bot { flex-direction: column; gap: 10px; align-items: flex-start; }
  .page-hero { padding: 60px 24px 60px; }
  .page-hero__title { font-size: clamp(32px, 6.5vw, 48px); }
  .crosslink__card { gap: 20px; padding: 32px 24px; text-align: left; }
  .crosslink__char { font-size: 56px; }
  .concept { padding: 80px 24px; }
  .concept__title { font-size: clamp(28px, 5vw, 42px); margin-bottom: 36px; }
  .access__info { padding: 32px 28px; }
  .access__info dl { grid-template-columns: 1fr; gap: 8px 0; }
  .access__info dd { padding-bottom: 16px; }
  .company__visual { position: static; margin-bottom: 32px; }
  .company__seal { width: 140px; height: 140px; }
  .company__seal__char { font-size: 64px; }
  .company__motto { font-size: 16px; line-height: 1.85; }
  .company__table th { width: 110px; padding: 14px 0; font-size: 9px; }
  .company__table td { padding: 14px 0; font-size: 13px; }
  .faq__q { grid-template-columns: 60px 1fr 24px; gap: 16px; font-size: 16px; padding: 20px 0; }
  .faq__a { padding: 0 16px 22px 76px; font-size: 13px; }
  .inquiry__form { padding: 36px 28px; border-right: none; border-bottom: 1px solid var(--line); }
  .inquiry__side { padding: 36px 28px; gap: 20px; }
  .voice-card { padding: 28px 24px; }
  .plan-card { padding: 36px 28px 28px; }
  .plan-pick__option { grid-template-columns: 48px 1fr auto; gap: 14px; padding: 16px 18px; }
  .plan-pick__char { font-size: 36px; }
  .addon-grid { grid-template-columns: 1fr; }
}
