/* 女風EX Mockup v0.3 / tokens layer
   Aesthetic: Midnight crimson × women's AV intimacy × video-as-vessel
   v0.2 までは light-base / nocturne accent だったが、クライアントFB
   「おしゃれすぎる / 女性用 AV みたい寄せ」を受けて DARK base にフリップ。
   レッドライン 21 項 + AG-1 追加 11 語は不変。
*/

:root {
  /* ---- DARK base palette (default scope = dark) ---- */
  --bg            : #090504;  /* deep midnight, near-black with a bordeaux undertone */
  --bg-warm       : #130b0a;  /* warmer midnight for sub-sections */
  --bg-card       : #1a0f0e;  /* card surface, slightly raised */
  --bg-elev       : #241514;  /* hover / focused surface */
  --ink           : #f6e6d4;  /* warm cream text */
  --ink-soft      : #d1bda7;
  --ink-mute      : #927f72;

  /* ---- Crimson / bordeaux accent (punched up) ---- */
  --bordeaux      : #b52a3e;
  --bordeaux-deep : #5a101b;
  --crimson       : #df435d;  /* hover / active flush */
  --crimson-soft  : #842432;

  --rose          : #c88988;
  --rose-soft     : #ecc1b9;
  --rose-deep     : #6c4852;
  --gold          : #d0aa70;
  --gold-soft     : #9a7a42;
  --cold-rim      : #8ca1aa;
  --cold-rim-soft : #40515a;
  --lacquer       : #2a1117;

  --hairline      : #30211d;
  --hairline-warm : #433127;
  --hairline-hot  : #57212a; /* crimson-tinged hairline for dark sections */
  --hairline-cold : #314047;

  /* ---- Light pocket palette (限定使用: 18+ モーダル / 拒否バナー / 法務エリア) ---- */
  --bg-light            : #faf7f3;
  --bg-light-warm       : #f0e5d5;
  --ink-on-light        : #1a1410;
  --ink-on-light-mute   : #5a4f47;
  --hairline-light      : #d4c5b3;

  /* ---- Typography (Mincho を主軸に italic Fraunces で艶) ---- */
  --f-display     : "Shippori Mincho", "Hiragino Mincho ProN", "YuMincho", serif;
  --f-title       : "Shippori Mincho B1", "Shippori Mincho", "Hiragino Mincho ProN", "YuMincho", serif;
  --f-display-en  : "Fraunces", "Cormorant Garamond", serif;
  --f-body        : "Zen Kaku Gothic New", "Hiragino Sans", "YuGothic", sans-serif;
  --f-accent-en   : "Cormorant Garamond", "Fraunces", serif;
  --f-cinema-en   : "Italiana", "Cormorant Garamond", "Fraunces", serif;

  /* ---- Layout (少し狭めて密度を上げる) ---- */
  --max           : 1180px;
  --max-wide      : 1320px;

  /* ---- Space scale (やや圧縮) ---- */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 22px;
  --s-6: 30px;
  --s-7: 44px;
  --s-8: 64px;
  --s-9: 88px;
  --s-10: 112px;

  /* ---- Atmosphere / FX ---- */
  --grain-opacity     : 0.075;
  --vignette          : 0 0 150px 12px rgba(0,0,0,0.78) inset;
  --vignette-soft     : 0 0 78px 6px rgba(0,0,0,0.52) inset;
  --glow-crimson      : 0 0 38px rgba(223, 67, 93, 0.46);
  --glow-crimson-soft : 0 0 20px rgba(223, 67, 93, 0.25);
  --glow-gold         : 0 0 26px rgba(208, 170, 112, 0.34);
  --glow-cold         : 0 0 26px rgba(140, 161, 170, 0.22);
  --shadow-card       : 0 22px 46px -22px rgba(0,0,0,0.86), 0 1px 0 rgba(255,255,255,0.035) inset;
  --shadow-card-hover : 0 34px 70px -24px rgba(0,0,0,0.92), 0 0 0 1px rgba(223,67,93,0.28), 0 0 34px rgba(90,16,27,0.36);
  --shadow-thumb      : 0 18px 44px -22px rgba(0,0,0,0.96), 0 0 0 1px rgba(140,161,170,0.12);
  --shadow-thumb-hot  : 0 28px 64px -22px rgba(0,0,0,0.96), 0 0 36px rgba(223,67,93,0.22), 0 0 0 1px rgba(208,170,112,0.12);
  --sheen-thumb       : linear-gradient(135deg, rgba(140,161,170,0.24) 0%, transparent 24%, transparent 64%, rgba(208,170,112,0.16) 100%);
  --sheen-lacquer     : linear-gradient(135deg, rgba(255,236,211,0.10), rgba(223,67,93,0.06) 36%, rgba(0,0,0,0.16) 100%);

  /* ---- DEFAULT scope = DARK (v0.2 から逆転) ---- */
  --bg-current        : var(--bg);
  --bg-warm-current   : var(--bg-warm);
  --bg-card-current   : var(--bg-card);
  --ink-current       : var(--ink);
  --ink-soft-current  : var(--ink-soft);
  --ink-mute-current  : var(--ink-mute);
  --hairline-current  : var(--hairline);
}

[data-bg-mode="dark"] {
  --bg-current       : var(--bg);
  --bg-warm-current  : var(--bg-warm);
  --bg-card-current  : var(--bg-card);
  --ink-current      : var(--ink);
  --ink-soft-current : var(--ink-soft);
  --ink-mute-current : var(--ink-mute);
  --hairline-current : var(--hairline);
}

[data-bg-mode="light"] {
  --bg-current       : var(--bg);
  --bg-warm-current  : var(--bg-warm);
  --bg-card-current  : var(--bg-card);
  --ink-current      : var(--ink);
  --ink-soft-current : var(--ink-soft);
  --ink-mute-current : var(--ink-mute);
  --hairline-current : var(--hairline);
}

/* ---- v0.2 旧変数名の後方互換 alias (style.css 内のハードコード参照を生かす) ---- */
:root {
  --bg-dark            : var(--bg);
  --bg-dark-warm       : var(--bg-warm);
  --ink-on-dark        : var(--ink);
  --ink-on-dark-mute   : var(--ink-soft);
  --hairline-dark      : var(--hairline);
}
/* 女風EX Mockup v0.3 / Aesthetic: Midnight crimson × women's AV intimacy × video-as-vessel
   v0.2 (Boutique-hotel nocturne) からクライアント FB「おしゃれすぎる / 女性用 AV 寄せ」を受けて pivot。
   レッドライン 21 項 + AG-1 追加 11 語は厳守。 */
@import url('./tokens.css');

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

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  /* off-canvas ドロワー (.nav at translateX(100%)) が iOS Safari で水平
     スクロールを誘発するのを抑止。`clip` は sticky を壊さず、未対応
     ブラウザは `hidden` にフォールバックする (Safari < 16 対策)。 */
  overflow-x: hidden;
  overflow-x: clip;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.8;
  letter-spacing: 0.02em;
  font-feature-settings: "palt" 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background-image:
    radial-gradient(rgba(223, 67, 93, 0.045) 1px, transparent 1px),
    radial-gradient(rgba(208, 170, 112, 0.028) 1px, transparent 1px),
    radial-gradient(ellipse at 50% 0%, rgba(132, 36, 50, 0.26) 0%, transparent 58%),
    linear-gradient(110deg, rgba(140,161,170,0.035), transparent 32%, rgba(90,16,27,0.12) 72%, transparent);
  background-size: 3px 3px, 7px 7px, 100% 900px, 100% 100%;
  background-position: 0 0, 1px 2px, 0 0, 0 0;
  background-repeat: repeat, repeat, no-repeat, no-repeat;
  position: relative;
}

/* film grain overlay (very subtle, for atmosphere) */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: var(--grain-opacity);
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.85'/></svg>");
}

img, svg { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
ul, ol { list-style: none; margin: 0; padding: 0; }
h1, h2, h3, h4, h5, h6, p, figure { margin: 0; }

/* ==========================================================================
   typography presets
   ========================================================================== */
.h-display {
  font-family: var(--f-title);
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: 0.04em;
}
.h-display-en {
  font-family: var(--f-display-en);
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0.01em;
}
.label-en {
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
}
.num-en {
  font-family: var(--f-accent-en);
  font-style: italic;
  letter-spacing: 0.04em;
}

/* ==========================================================================
   layout primitives
   ========================================================================== */
.container {
  width: 100%;
  max-width: var(--max);
  margin-inline: auto;
  padding-inline: var(--s-5);
}
.container--wide { max-width: var(--max-wide); }
.container--narrow { max-width: 760px; }

.bg-fill {
  background: var(--bg-current);
  color: var(--ink-current);
}

[data-bg-mode="dark"] {
  background: var(--bg-dark);
  color: var(--ink-on-dark);
}
[data-bg-mode="dark"] a { color: var(--ink-on-dark); }

[data-bg-mode="light"] {
  background: var(--bg);
  color: var(--ink);
}

/* ==========================================================================
   site header
   ========================================================================== */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(8, 6, 5, 0.86);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid var(--hairline-hot);
  box-shadow: 0 8px 24px -16px rgba(0,0,0,0.7);
}
.site-header__inner {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: var(--s-6);
  height: 72px;
  max-width: var(--max-wide);
  margin-inline: auto;
  padding-inline: var(--s-5);
}
/* PC では nav 内の LINE ボタンを隠す。`.nav a` (specificity 0,1,1) に
   負けないよう `.nav a.nav__line` (0,2,1) で書く。Header 側の
   `.header__line` ボタンと二重表示にならないようにする。 */
.nav a.nav__line { display: none; }
.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid rgba(208, 170, 112, 0.18);
  border-radius: 2px;
  cursor: pointer;
  padding: 0;
  position: relative;
  transition: border-color 200ms ease, background 200ms ease;
}
.nav-toggle:hover { border-color: rgba(208, 170, 112, 0.42); background: rgba(90, 16, 27, 0.18); }
.nav-toggle__bar {
  position: absolute;
  left: 12px;
  right: 12px;
  height: 1.5px;
  background: var(--ink);
  border-radius: 1px;
  transition: transform 240ms ease, opacity 200ms ease, top 240ms ease;
}
.nav-toggle__bar:nth-child(1) { top: 14px; }
.nav-toggle__bar:nth-child(2) { top: 21px; }
.nav-toggle__bar:nth-child(3) { top: 28px; }
[data-nav-open="true"] .nav-toggle__bar:nth-child(1) { top: 21px; transform: rotate(45deg); }
[data-nav-open="true"] .nav-toggle__bar:nth-child(2) { opacity: 0; }
[data-nav-open="true"] .nav-toggle__bar:nth-child(3) { top: 21px; transform: rotate(-45deg); }
.nav-scrim {
  position: fixed;
  inset: 0;
  z-index: 49;
  background: rgba(8, 5, 4, 0.72);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 240ms ease;
}
[data-nav-open="true"] .nav-scrim { opacity: 1; pointer-events: auto; }
[data-nav-open="true"] { overflow: hidden; }
.brand {
  font-family: var(--f-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--ink);
  display: inline-flex;
  align-items: baseline;
  gap: var(--s-3);
  text-shadow: 0 0 18px rgba(214, 60, 84, 0.35);
}
.brand__mark {
  font-family: var(--f-display-en);
  font-style: italic;
  font-size: 12px;
  letter-spacing: 0.22em;
  color: var(--crimson);
  text-transform: uppercase;
}
/* PC: .nav-wrap は layout に影響しない passthrough。
   SP では fixed の containing block に変える (2363 行〜)。 */
.nav-wrap { display: contents; }

.nav {
  display: flex;
  gap: var(--s-5);
  align-items: center;
  justify-content: center;
}
.nav a {
  font-family: var(--f-display);
  font-size: 13px;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  display: inline-flex;
  align-items: baseline;
  gap: var(--s-2);
  padding-block: var(--s-2);
  border-bottom: 1px solid transparent;
  transition: color 200ms ease, border-color 200ms ease;
}
.nav a:hover { color: var(--ink); border-bottom-color: var(--crimson); }
.nav a.is-current { border-bottom-color: var(--crimson); color: var(--ink); }
.nav__sub {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 10.5px;
  color: var(--crimson);
  letter-spacing: 0.14em;
}
.btn-line {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 10px 20px;
  font-size: 12.5px;
  letter-spacing: 0.14em;
  border-radius: 2px;
  background: var(--bordeaux);
  color: var(--ink) !important;
  border: 1px solid var(--crimson-soft);
  transition: background 200ms ease, box-shadow 200ms ease;
}
.btn-line:hover {
  background: var(--crimson);
  box-shadow: var(--glow-crimson-soft);
}
.btn__icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* ==========================================================================
   buttons
   ========================================================================== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: 15px 30px;
  font-family: var(--f-display);
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: 0.18em;
  border-radius: 2px;
  transition: background 220ms ease, color 220ms ease, border-color 220ms ease, box-shadow 220ms ease, transform 220ms ease;
  cursor: pointer;
  white-space: nowrap;
  position: relative;
}
.btn--primary {
  background: var(--bordeaux);
  color: var(--ink);
  border: 1px solid var(--crimson);
  box-shadow: var(--glow-crimson-soft);
}
.btn--primary:hover {
  background: var(--crimson);
  box-shadow: var(--glow-crimson);
  transform: translateY(-1px);
}
.btn--outline {
  background: transparent;
  color: var(--crimson);
  border: 1px solid var(--crimson-soft);
}
.btn--outline:hover {
  background: var(--bordeaux);
  color: var(--ink);
  border-color: var(--crimson);
  box-shadow: var(--glow-crimson-soft);
}
.btn--ghost {
  background: transparent;
  color: var(--ink-current);
  border: 1px solid var(--hairline-current);
}
.btn--ghost:hover {
  border-color: var(--crimson);
  color: var(--ink);
  background: rgba(214, 60, 84, 0.08);
}
.btn--line {
  background: #047a34;
  color: #f8fff8;
  border: 1px solid #06c755;
}
.btn--line:hover { background: #035f29; box-shadow: 0 0 18px rgba(6, 199, 85, 0.35); }
.btn--lg { padding: 18px 36px; font-size: 14.5px; letter-spacing: 0.22em; }

/* ==========================================================================
   crumbs
   ========================================================================== */
.crumbs {
  font-size: 12.5px;
  color: var(--ink-mute);
  letter-spacing: 0.08em;
  padding: var(--s-5) 0 var(--s-3);
}
.crumbs a { border-bottom: 1px solid transparent; }
.crumbs a:hover { border-bottom-color: var(--gold); }
.sep { margin-inline: var(--s-3); color: var(--gold); }

/* ==========================================================================
   HERO (index, 暗背景フルブリード動画)
   brief §4
   ========================================================================== */
.hero {
  position: relative;
  min-height: 88vh;
  background: var(--bg);
  color: var(--ink);
  overflow: hidden;
  isolation: isolate;
  border-bottom: 1px solid rgba(208, 170, 112, 0.10);
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse at 22% 64%, rgba(181, 42, 62, 0.32) 0%, transparent 56%),
    radial-gradient(ellipse at 82% 18%, rgba(140, 161, 170, 0.14) 0%, transparent 42%),
    linear-gradient(180deg, rgba(8, 5, 4, 0.2) 0%, rgba(8, 5, 4, 0.62) 70%, rgba(8, 5, 4, 0.92) 100%);
  box-shadow: var(--vignette);
  pointer-events: none;
}
.hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: var(--s-8);
  padding-block: var(--s-9) var(--s-8);
  min-height: 88vh;
  align-items: center;
}
.hero__copy {
  position: relative;
  z-index: 2;
  max-width: 38em;
}
.hero__media {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: var(--s-4);
}
.hero__media .v-card--main {
  grid-column: 1 / -1;
}
.hero__media .v-card--main .v-card__thumb {
  aspect-ratio: 16 / 9;
}
.hero__video,
.hero__poster {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.62;
  filter: saturate(128%) contrast(116%) brightness(0.84);
}
.hero__overlay {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--s-8);
  max-width: var(--max-wide);
  margin-inline: auto;
  padding: var(--s-9) var(--s-5) var(--s-8);
  min-height: 88vh;
  align-items: center;
}
.hero__eyebrow {
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 12px;
  letter-spacing: 0.38em;
  color: var(--crimson);
  text-transform: uppercase;
  margin-bottom: var(--s-5);
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
}
.hero__eyebrow::before,
.hero__eyebrow::after {
  content: '';
  width: 34px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--crimson), var(--gold));
  box-shadow: var(--glow-crimson-soft);
}
.hero__title {
  font-family: var(--f-title);
  font-weight: 600;
  font-size: clamp(36px, 4.8vw, 60px);
  line-height: 1.34;
  letter-spacing: 0.055em;
  color: var(--ink);
  margin-bottom: var(--s-6);
  text-shadow:
    0 2px 28px rgba(0,0,0,0.72),
    0 0 44px rgba(181, 42, 62, 0.28),
    0 0 1px rgba(246, 230, 212, 0.28);
}
.hero__title em {
  font-style: italic;
  color: var(--rose-soft);
  font-family: var(--f-display-en);
  font-weight: 400;
  margin-inline: 0.08em;
  text-shadow:
    0 0 22px rgba(223, 67, 93, 0.48),
    0 0 1px rgba(246, 230, 212, 0.36);
}
.hero__title-line {
  display: block;
  position: relative;
  white-space: nowrap;
}
.hero__title-line:nth-child(2) {
  padding-left: clamp(14px, 2.5vw, 34px);
}
.hero__lead {
  font-size: 16px;
  line-height: 2.1;
  color: var(--ink);
  max-width: 36em;
  margin-bottom: var(--s-7);
  text-shadow: 0 1px 18px rgba(0, 0, 0, 0.72);
}
.hero__cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s-3) var(--s-4);
}
.hero__cta-note {
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 12.5px;
  letter-spacing: 0.24em;
  color: var(--gold);
  text-transform: uppercase;
}
.hero__cta .btn--ghost {
  color: var(--ink-on-dark);
  border-color: var(--ink-on-dark-mute);
}
.hero__cta .btn--ghost:hover { color: var(--gold); border-color: var(--gold); }
.hero__meta {
  position: relative;
  border-left: 1px solid rgba(208, 170, 112, 0.25);
  padding: var(--s-5) 0 var(--s-5) var(--s-6);
  background:
    linear-gradient(90deg, rgba(90, 16, 27, 0.22), transparent 64%),
    linear-gradient(180deg, transparent, rgba(0,0,0,0.16));
  box-shadow:
    -18px 0 38px -28px rgba(223, 67, 93, 0.58),
    inset 1px 0 0 rgba(140, 161, 170, 0.18);
}
.hero__meta::before {
  content: '';
  position: absolute;
  left: -5px;
  top: var(--s-5);
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--crimson);
  box-shadow: 0 0 16px rgba(223, 67, 93, 0.8);
}
.hero__meta::after {
  content: 'PLAYING';
  position: absolute;
  right: 0;
  top: -18px;
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0.28em;
  color: rgba(208, 170, 112, 0.54);
}
.hero__meta-label {
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0.28em;
  color: var(--gold);
  text-transform: uppercase;
  display: block;
  margin-bottom: var(--s-3);
}
.hero__meta-title {
  font-family: var(--f-title);
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 600;
  line-height: 1.55;
  letter-spacing: 0.075em;
  margin-bottom: var(--s-3);
  color: var(--ink);
  text-shadow: 0 0 24px rgba(181, 42, 62, 0.24);
}
.hero__meta-sub {
  font-size: 13px;
  color: var(--ink-on-dark-mute);
  letter-spacing: 0.05em;
}
.hero__meta-duration {
  font-family: var(--f-cinema-en);
  font-style: italic;
  color: var(--gold);
  margin-left: var(--s-2);
  padding: 2px 9px;
  border: 1px solid rgba(208, 170, 112, 0.24);
  background: rgba(9, 5, 4, 0.42);
}

/* ==========================================================================
   video-row (暗背景、HERO の続き)
   brief §4-2 / §5-1
   ========================================================================== */
.video-row {
  background: var(--bg-dark-warm);
  color: var(--ink-on-dark);
  padding-block: var(--s-9);
  position: relative;
  overflow: hidden;
  background-image:
    radial-gradient(ellipse at 18% 0%, rgba(223, 67, 93, 0.18) 0%, transparent 48%),
    radial-gradient(ellipse at 90% 20%, rgba(140, 161, 170, 0.08) 0%, transparent 42%),
    linear-gradient(180deg, rgba(0,0,0,0.16), transparent 24%, rgba(0,0,0,0.20));
}
.video-row::before {
  content: 'JOFU EX  FILMS';
  position: absolute;
  right: var(--s-5);
  top: var(--s-7);
  writing-mode: vertical-rl;
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0.34em;
  color: rgba(208, 170, 112, 0.24);
  pointer-events: none;
}
.video-row .container { max-width: var(--max-wide); }
.row__heading {
  font-family: var(--f-title);
  font-size: clamp(26px, 2.6vw, 34px);
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.32;
  margin-bottom: var(--s-2);
  color: var(--ink);
  text-shadow: 0 0 24px rgba(181, 42, 62, 0.18);
}
.row__heading-en {
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 12.5px;
  color: var(--gold);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  display: block;
  margin-bottom: var(--s-3);
}
.row__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: var(--s-6);
  border-bottom: 1px solid rgba(208, 170, 112, 0.16);
  padding-bottom: var(--s-4);
  position: relative;
}
.row__head::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  width: min(180px, 34vw);
  height: 1px;
  background: linear-gradient(90deg, var(--crimson), rgba(208,170,112,0.72), transparent);
  box-shadow: var(--glow-crimson-soft);
}
.row__more {
  font-size: 13px;
  letter-spacing: 0.14em;
  color: var(--gold);
  border-bottom: 1px solid transparent;
  transition: color 200ms ease, border-color 200ms ease, text-shadow 200ms ease;
}
.row__more:hover { border-bottom-color: var(--gold); color: var(--ink); text-shadow: var(--glow-gold); }
.row__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-6);
}
.row__grid--3 { grid-template-columns: repeat(3, 1fr); }
.row__grid--6 { grid-template-columns: repeat(6, 1fr); gap: var(--s-5); }
.row__grid--column { grid-template-columns: repeat(3, 1fr); gap: var(--s-7); }

/* ==========================================================================
   v-card (体験動画カード、暗明両対応)
   ========================================================================== */
.v-card {
  display: block;
  background: transparent;
  transition: transform 320ms ease;
  position: relative;
}
.v-card:hover { transform: translateY(-4px); }
.v-card__thumb {
  position: relative;
  aspect-ratio: 5 / 3;
  overflow: hidden;
  background:
    linear-gradient(135deg, #050303, #19090d 48%, #070606),
    #06040a;
  border: 1px solid rgba(208, 170, 112, 0.16);
  box-shadow: var(--shadow-thumb);
  transition: box-shadow 320ms ease, border-color 320ms ease, filter 320ms ease;
  isolation: isolate;
}
.v-card__thumb::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(circle at 50% 50%, rgba(246,230,212,0.92) 0 6px, rgba(246,230,212,0.34) 7px 17px, transparent 18px),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='42' height='42' viewBox='0 0 42 42'%3E%3Cpath d='M17 12v18l14-9z' fill='%23f6e6d4'/%3E%3C/svg%3E") center / 42px 42px no-repeat,
    linear-gradient(180deg, transparent 28%, rgba(8, 5, 4, 0.72) 100%),
    radial-gradient(ellipse at 50% 28%, transparent 22%, rgba(0,0,0,0.48) 100%),
    var(--sheen-thumb);
  opacity: 0.72;
  pointer-events: none;
  transition: opacity 320ms ease, background-size 320ms ease;
}
.v-card__thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 3;
  border: 1px solid rgba(140, 161, 170, 0.22);
  box-shadow:
    inset 0 1px 0 rgba(246, 230, 212, 0.10),
    inset 0 -34px 54px rgba(90, 16, 27, 0.28),
    inset 0 0 0 1px rgba(0,0,0,0.34);
  pointer-events: none;
  transition: border-color 320ms ease, box-shadow 320ms ease;
}
.v-card__thumb:has(.v-card__play)::before {
  background:
    linear-gradient(180deg, transparent 28%, rgba(8, 5, 4, 0.72) 100%),
    radial-gradient(ellipse at 50% 28%, transparent 22%, rgba(0,0,0,0.48) 100%),
    var(--sheen-thumb);
}
.v-card:hover .v-card__thumb {
  border-color: rgba(223, 67, 93, 0.52);
  box-shadow: var(--shadow-thumb-hot);
}
.v-card:hover .v-card__thumb::before { opacity: 0.94; }
.v-card:hover .v-card__thumb::after {
  border-color: rgba(208, 170, 112, 0.26);
  box-shadow:
    inset 0 1px 0 rgba(246, 230, 212, 0.14),
    inset 0 -42px 64px rgba(181, 42, 62, 0.34),
    inset 0 0 0 1px rgba(223, 67, 93, 0.16),
    var(--glow-cold);
}
.v-card__thumb img,
.v-card__thumb svg,
.v-card__thumb video {
  /* 2026-05-25 perf: <img> と lazy 生成 <video> を同 box に重ねるため絶対配置。
     4 辺は inset shorthand で明示 (jofuex_cascade_traps 予防) */
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(112%) contrast(108%) brightness(0.86);
  transition: transform 720ms ease, filter 420ms ease;
}
.v-card__thumb video.v-card__media {
  z-index: 1;
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease, transform 720ms ease, filter 420ms ease;
}
.v-card[data-jofuex-video-state="playing"] .v-card__thumb video.v-card__media { opacity: 1; }
.v-card:hover .v-card__thumb img,
.v-card:hover .v-card__thumb svg,
.v-card:hover .v-card__thumb video {
  transform: scale(1.055);
  filter: saturate(132%) contrast(112%) brightness(1.02);
}
.v-card__play {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: transparent;
  color: var(--ink);
  opacity: 0.86;
  transition: opacity 280ms ease, transform 320ms ease;
  z-index: 4;
}
.v-card:hover .v-card__play { opacity: 1; transform: scale(1.04); }
.v-card__play svg {
  width: 62px;
  height: 62px;
  padding: 16px;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(246, 230, 212, 0.16), rgba(90, 16, 27, 0.58) 68%, rgba(0,0,0,0.18)),
    var(--sheen-lacquer);
  border: 1px solid rgba(246, 230, 212, 0.22);
  box-shadow:
    0 0 22px rgba(223, 67, 93, 0.62),
    inset 0 0 18px rgba(0,0,0,0.48);
  filter: drop-shadow(0 0 12px rgba(223, 67, 93, 0.66));
}
.v-card__duration {
  position: absolute;
  right: var(--s-3);
  bottom: var(--s-3);
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 12.5px;
  letter-spacing: 0.14em;
  color: var(--ink);
  background:
    linear-gradient(135deg, rgba(246,230,212,0.11), rgba(90,16,27,0.62)),
    rgba(8, 5, 4, 0.84);
  border: 1px solid rgba(208, 170, 112, 0.32);
  padding: 4px 11px;
  border-radius: 2px;
  z-index: 5;
  box-shadow:
    0 8px 18px rgba(0,0,0,0.46),
    inset 0 1px 0 rgba(246, 230, 212, 0.12);
}
.v-card__body { padding-top: var(--s-4); }
.v-card__title {
  font-family: var(--f-title);
  font-size: 16.5px;
  font-weight: 600;
  line-height: 1.58;
  letter-spacing: 0.065em;
  color: var(--ink-current);
  margin-bottom: var(--s-2);
  text-shadow: 0 0 18px rgba(181, 42, 62, 0.14);
  transition: color 240ms ease, text-shadow 240ms ease;
}
.v-card:hover .v-card__title {
  color: var(--rose-soft);
  text-shadow: 0 0 24px rgba(223, 67, 93, 0.32);
}
.v-card__meta {
  font-size: 12.5px;
  color: var(--ink-mute-current);
  letter-spacing: 0.075em;
}
.v-card__meta strong {
  color: var(--ink-current);
  font-weight: 500;
  font-family: var(--f-title);
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: var(--s-3);
}
.tag {
  display: inline-flex;
  align-items: center;
  padding: 4px 11px;
  font-size: 11.5px;
  letter-spacing: 0.08em;
  background:
    linear-gradient(135deg, rgba(246,230,212,0.055), rgba(90,16,27,0.20)),
    var(--bg-warm-current);
  color: var(--ink-soft-current);
  border-radius: 2px;
  border: 1px solid rgba(140, 161, 170, 0.16);
  box-shadow: inset 0 1px 0 rgba(246, 230, 212, 0.055);
}
.tag--ghost {
  background: rgba(9, 5, 4, 0.20);
  color: var(--ink-mute-current);
  border-color: rgba(208, 170, 112, 0.20);
}
.tag--gold {
  background:
    linear-gradient(135deg, rgba(246,230,212,0.28), rgba(208,170,112,0.62) 42%, rgba(90,16,27,0.18)),
    var(--gold);
  color: var(--bg);
  border-color: rgba(246, 230, 212, 0.22);
  box-shadow:
    0 0 16px rgba(208, 170, 112, 0.22),
    inset 0 1px 0 rgba(246, 230, 212, 0.32);
}

/* ==========================================================================
   section common (明背景)
   ========================================================================== */
.section {
  padding-block: var(--s-9);
  background: var(--bg);
  color: var(--ink);
  position: relative;
}
.section--alt {
  background: var(--bg-warm);
  background-image:
    radial-gradient(ellipse at 20% 0%, rgba(178, 38, 56, 0.10) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 100%, rgba(122, 31, 44, 0.08) 0%, transparent 50%);
}
.section--narrow { padding-block: var(--s-8); }

.sec-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-4);
  align-items: end;
  margin-bottom: var(--s-7);
  padding-bottom: var(--s-4);
  border-bottom: 1px solid rgba(208, 170, 112, 0.16);
  position: relative;
}
.sec-head::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  width: min(150px, 32vw);
  height: 1px;
  background: linear-gradient(90deg, var(--crimson), rgba(208,170,112,0.62), transparent);
  box-shadow: 0 0 16px rgba(223, 67, 93, 0.56);
}
.sec-head__num {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 11.5px;
  letter-spacing: 0.34em;
  color: var(--crimson);
  text-transform: uppercase;
  margin-bottom: var(--s-3);
}
.sec-head__num::before {
  content: '◆';
  font-size: 8px;
  color: var(--crimson);
  font-style: normal;
}
.sec-head__title {
  font-family: var(--f-title);
  font-size: clamp(26px, 2.8vw, 36px);
  font-weight: 600;
  letter-spacing: 0.11em;
  color: var(--ink);
  line-height: 1.36;
  text-shadow: 0 0 24px rgba(181, 42, 62, 0.18);
}
.sec-head__action {
  font-family: var(--f-title);
  font-size: 12.5px;
  letter-spacing: 0.18em;
  color: var(--ink-soft);
  border-bottom: 1px solid var(--crimson-soft);
  padding-bottom: 2px;
  transition: color 200ms ease, border-color 200ms ease;
}
.sec-head__action:hover { color: var(--crimson); border-color: var(--crimson); }

/* ==========================================================================
   t-card (セラピストカード、明背景前提)
   ========================================================================== */
.t-card {
  display: block;
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  transition: border-color 240ms ease, transform 240ms ease;
}
.t-card:hover { border-color: var(--gold); transform: translateY(-3px); }
.t-card__portrait {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--bg-warm);
}
.t-card__portrait img,
.t-card__portrait svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.t-card__body {
  padding: var(--s-5);
}
.t-card__name {
  font-family: var(--f-title);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--rose-soft);
  margin-bottom: var(--s-2);
  text-shadow: 0 0 16px rgba(223, 67, 93, 0.18);
}
.t-card__name .age {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 14px;
  color: var(--gold);
  margin-left: var(--s-2);
}
.t-card__meta {
  font-size: 12.5px;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
  margin-bottom: var(--s-3);
}
.t-card__quote {
  font-family: var(--f-display);
  font-size: 13.5px;
  line-height: 1.9;
  color: var(--ink-soft);
  border-top: 1px solid var(--hairline);
  padding-top: var(--s-3);
}
.t-card__sns-placeholder {
  margin-top: var(--s-3);
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 11.5px;
  color: var(--ink-mute);
  letter-spacing: 0.08em;
  padding-top: var(--s-3);
  border-top: 1px dashed var(--hairline);
}
.t-card__sns-placeholder span {
  color: var(--gold);
}

/* ==========================================================================
   s-card (店舗カード)
   ========================================================================== */
.s-card {
  display: block;
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  padding: var(--s-5);
  transition: border-color 240ms ease;
}
.s-card:hover { border-color: var(--gold); }
.s-card__logo {
  aspect-ratio: 4 / 3;
  background: var(--bg-warm);
  margin-bottom: var(--s-4);
  display: grid;
  place-items: center;
  overflow: hidden;
}
.s-card__logo img,
.s-card__logo svg {
  max-height: 80%;
  width: auto;
}
.s-card__name {
  font-family: var(--f-title);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--rose-soft);
  margin-bottom: var(--s-2);
}
.s-card__meta {
  font-size: 12.5px;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}
.s-card--featured-shop {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--s-6);
  align-items: center;
  padding: var(--s-5);
}
.s-card--featured-shop .s-card__logo {
  aspect-ratio: 1 / 1;
  margin-bottom: 0;
}

/* ==========================================================================
   c-card (一人称コラムカード) — 署名 3 種視覚区別
   brief §7-2 / §7-4
   ========================================================================== */
.c-card {
  display: block;
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  transition: border-color 240ms ease, transform 240ms ease;
}
.c-card:hover { border-color: var(--gold); transform: translateY(-3px); }
.c-card__thumb {
  aspect-ratio: 5 / 3;
  overflow: hidden;
  background: var(--bg-warm);
}
.c-card__thumb img,
.c-card__thumb svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.c-card__inner {
  padding: var(--s-5);
}
.c-card__badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--f-display);
  font-size: 12px;
  letter-spacing: 0.16em;
  padding: 4px 12px;
  border-radius: 2px;
  margin-bottom: var(--s-4);
}
.c-card--therapist .c-card__badge {
  background: var(--bordeaux);
  color: var(--bg);
}
.c-card--therapist {
  border-left: 3px solid var(--bordeaux);
}
.c-card--guest .c-card__badge {
  background: var(--rose-soft);
  color: var(--bordeaux-deep);
  border: 1px solid var(--rose);
}
.c-card--guest {
  border-left: 3px solid var(--rose);
}
.c-card--editor .c-card__badge {
  background: var(--gold-soft);
  color: var(--bordeaux-deep);
  border: 1px solid var(--gold);
}
.c-card--editor {
  border-left: 3px solid var(--gold);
}
.c-card__title {
  font-family: var(--f-display);
  font-size: 17px;
  font-weight: 500;
  line-height: 1.85;
  letter-spacing: 0.05em;
  color: var(--ink);
  margin-bottom: var(--s-3);
}
.c-card__excerpt {
  font-size: 13.5px;
  line-height: 2.1;
  color: var(--ink-soft);
}
.c-card__sign {
  display: block;
  font-family: var(--f-display);
  font-size: 12.5px;
  color: var(--ink-mute);
  letter-spacing: 0.1em;
  text-align: right;
  margin-top: var(--s-4);
  padding-top: var(--s-3);
  border-top: 1px solid var(--hairline);
}

/* ==========================================================================
   pledge (運営の宣誓、明背景セクション、§9-6 サンプル準拠)
   ========================================================================== */
.pledge {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--s-8);
  max-width: 980px;
  margin-inline: auto;
}
.pledge__title {
  font-family: var(--f-display);
  font-size: 28px;
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.08em;
  color: var(--bordeaux);
}
.pledge__list {
  display: grid;
  gap: var(--s-7);
}
.pledge__item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--s-4);
  align-items: start;
}
.pledge__num {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 24px;
  color: var(--gold);
  letter-spacing: 0.06em;
}
.pledge__heading {
  font-family: var(--f-display);
  font-size: 17px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: var(--s-3);
}
.pledge__text {
  font-size: 14px;
  line-height: 2.1;
  color: var(--ink-soft);
}
.pledge__privacy-bridge {
  font-size: 12.5px;
  color: var(--ink-mute);
  margin-top: var(--s-3);
  padding-top: var(--s-3);
  border-top: 1px dashed var(--hairline);
  letter-spacing: 0.05em;
}

/* ==========================================================================
   experience archive (動画一覧)
   ========================================================================== */
.page-head {
  padding-block: var(--s-8) var(--s-7);
  background: var(--bg);
  border-bottom: 1px solid rgba(208, 170, 112, 0.14);
  background-image:
    radial-gradient(ellipse at 16% 0%, rgba(223, 67, 93, 0.16) 0%, transparent 48%),
    linear-gradient(180deg, rgba(0,0,0,0.10), transparent);
}
.page-head--dark {
  background: var(--bg-dark);
  background-image:
    radial-gradient(ellipse at 16% 0%, rgba(223, 67, 93, 0.16) 0%, transparent 48%),
    radial-gradient(ellipse at 82% 14%, rgba(140, 161, 170, 0.08) 0%, transparent 38%),
    linear-gradient(180deg, rgba(0,0,0,0.10), transparent);
  color: var(--ink-on-dark);
  border-bottom-color: var(--hairline-dark);
}
.page-head__eyebrow {
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 12px;
  letter-spacing: 0.30em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: var(--s-3);
}
.page-head__title {
  font-family: var(--f-title);
  font-size: clamp(34px, 4.4vw, 56px);
  font-weight: 600;
  letter-spacing: 0.09em;
  line-height: 1.32;
  color: var(--ink);
  margin-bottom: var(--s-4);
  text-shadow: 0 0 34px rgba(181, 42, 62, 0.24);
}
.page-head--dark .page-head__title { color: var(--ink-on-dark); }
.page-head__lead {
  font-size: 14.5px;
  line-height: 2.1;
  color: var(--ink-soft);
  max-width: 38em;
}
.page-head--dark .page-head__lead { color: var(--ink-on-dark-mute); }

.filters {
  padding-block: var(--s-5);
  border-bottom: 1px solid var(--hairline-current);
  background: var(--bg-current);
  color: var(--ink-current);
}
.filters__inner {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  align-items: center;
}
.filter {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  padding: 10px 18px;
  border: 1px solid var(--hairline-current);
  background: transparent;
  color: var(--ink-current);
  font-size: 12.5px;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: border-color 200ms ease;
}
.filter:hover { border-color: var(--gold); }
.filter__label {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.filter__value { color: var(--ink-current); }
.filters__sort {
  margin-left: auto;
  font-size: 12px;
  letter-spacing: 0.1em;
  color: var(--ink-mute-current);
}
.filters__sort strong {
  color: var(--ink-current);
  font-weight: 500;
  margin-left: var(--s-2);
}

.grid-videos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-7) var(--s-6);
  padding-block: var(--s-7);
}

.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--s-3);
  padding-block: var(--s-6) var(--s-9);
  font-family: var(--f-accent-en);
  font-style: italic;
  letter-spacing: 0.1em;
  font-size: 13.5px;
}
.pagination a, .pagination span {
  padding: 6px 10px;
  border-bottom: 1px solid transparent;
  color: var(--ink-mute);
}
.pagination a:hover { border-bottom-color: var(--gold); color: var(--ink); }
.pagination a.is-current { color: var(--bordeaux); border-bottom-color: var(--bordeaux); }

/* ==========================================================================
   experience-single (動画詳細、暗明ハイブリッド)
   brief §6
   ========================================================================== */
.exp-single__hero {
  background: var(--bg-dark);
  color: var(--ink-on-dark);
  padding-block: var(--s-7);
  border-bottom: 1px solid rgba(208, 170, 112, 0.16);
  background-image:
    radial-gradient(ellipse at 50% 0%, rgba(223, 67, 93, 0.16) 0%, transparent 54%),
    radial-gradient(ellipse at 82% 22%, rgba(140, 161, 170, 0.09) 0%, transparent 42%);
}
.exp-single__hero .container { max-width: var(--max-wide); }
.exp-single__player {
  position: relative;
  background: #000;
  aspect-ratio: 16 / 9;
  margin-bottom: var(--s-5);
  border: 1px solid rgba(208, 170, 112, 0.18);
  overflow: hidden;
  box-shadow:
    0 34px 74px -30px rgba(0,0,0,0.96),
    0 0 0 1px rgba(140,161,170,0.10),
    0 0 46px rgba(90,16,27,0.24);
  isolation: isolate;
}
.exp-single__player::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(circle at 50% 50%, rgba(246,230,212,0.88) 0 8px, rgba(246,230,212,0.22) 9px 26px, transparent 27px),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='58' height='58' viewBox='0 0 58 58'%3E%3Cpath d='M23 17v24l19-12z' fill='%23f6e6d4'/%3E%3C/svg%3E") center / 58px 58px no-repeat,
    linear-gradient(180deg, rgba(0,0,0,0.08), rgba(8,5,4,0.42) 72%, rgba(8,5,4,0.72)),
    var(--sheen-thumb);
  pointer-events: none;
}
.exp-single__player::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 3;
  border: 1px solid rgba(140, 161, 170, 0.20);
  box-shadow:
    inset 0 1px 0 rgba(246,230,212,0.12),
    inset 0 -60px 86px rgba(90,16,27,0.28),
    var(--vignette-soft);
  pointer-events: none;
}
.exp-single__player video,
.exp-single__player img,
.exp-single__player svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.exp-single__meta-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--s-6);
  align-items: end;
}
.exp-single__h1 {
  font-family: var(--f-title);
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 600;
  line-height: 1.45;
  letter-spacing: 0.075em;
  color: var(--ink-on-dark);
  margin-bottom: var(--s-3);
  text-shadow: 0 0 28px rgba(181, 42, 62, 0.24);
}
.exp-single__meta-sub {
  font-size: 13px;
  color: var(--ink-on-dark-mute);
  letter-spacing: 0.06em;
}
.exp-single__date {
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 12px;
  letter-spacing: 0.24em;
  color: var(--gold);
  text-align: right;
}
.exp-single__layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--s-7);
  padding-block: var(--s-8);
  max-width: var(--max-wide);
  margin-inline: auto;
}
.exp-single__main {
  background: var(--bg);
}
.exp-single__main .interview {
  margin-bottom: var(--s-7);
}
.interview__heading {
  font-family: var(--f-title);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.09em;
  color: var(--ink);
  margin-bottom: var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid rgba(208, 170, 112, 0.16);
  text-shadow: 0 0 18px rgba(181, 42, 62, 0.18);
}
.interview__heading-en {
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 11.5px;
  color: var(--gold);
  letter-spacing: 0.24em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 4px;
}
.interview__body p {
  font-size: 14.5px;
  line-height: 2.15;
  color: var(--ink-soft);
  margin-bottom: var(--s-4);
}
.interview__body em {
  font-style: normal;
  color: var(--rose-soft);
  border-bottom: 1px solid rgba(208, 170, 112, 0.58);
  padding-bottom: 1px;
  text-shadow: 0 0 18px rgba(223, 67, 93, 0.22);
}
.interview__sign {
  font-family: var(--f-display);
  font-size: 13.5px;
  color: var(--ink-mute);
  letter-spacing: 0.1em;
  text-align: right;
  margin-top: var(--s-4);
}

.exp-single__aside {
  display: grid;
  gap: var(--s-6);
  align-self: start;
  position: sticky;
  top: 96px;
}
.aside-block {
  background:
    linear-gradient(145deg, rgba(246,230,212,0.035), rgba(90,16,27,0.12) 42%, transparent),
    var(--bg-card);
  border: 1px solid rgba(208, 170, 112, 0.14);
  padding: var(--s-5);
  box-shadow: var(--shadow-card);
}
.aside-block__label {
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.26em;
  text-transform: uppercase;
  display: block;
  margin-bottom: var(--s-3);
  padding-bottom: var(--s-2);
  border-bottom: 1px solid var(--hairline);
}
.aside-block__heading {
  font-family: var(--f-title);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: var(--s-3);
}
.aside-block .v-card { margin-bottom: var(--s-4); }
.aside-block .v-card:last-child { margin-bottom: 0; }
.aside-block .v-card__title { font-size: 14px; line-height: 1.7; }
.aside-block__column-row {
  display: grid;
  gap: var(--s-4);
}
.mini-column {
  border-top: 1px solid var(--hairline);
  padding-top: var(--s-4);
}
.mini-column:first-child { border-top: 0; padding-top: 0; }
.mini-column__badge {
  font-family: var(--f-display);
  font-size: 11px;
  letter-spacing: 0.16em;
  padding: 3px 10px;
  border-radius: 2px;
  display: inline-block;
  margin-bottom: var(--s-3);
}
.mini-column--therapist .mini-column__badge { background: var(--bordeaux); color: var(--bg); }
.mini-column--guest .mini-column__badge { background: var(--rose-soft); color: var(--bordeaux-deep); }
.mini-column--editor .mini-column__badge { background: var(--gold-soft); color: var(--bordeaux-deep); }
.mini-column__title {
  font-family: var(--f-display);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.7;
  color: var(--ink);
  margin-bottom: var(--s-2);
}
.mini-column__sign {
  font-size: 11.5px;
  color: var(--ink-mute);
  letter-spacing: 0.08em;
  text-align: right;
}

/* ==========================================================================
   therapist hero (明背景)
   ========================================================================== */
.t-hero {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: var(--s-7);
  padding-block: var(--s-8);
  align-items: center;
}
.t-hero__portrait {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--bg-warm);
  border: 1px solid var(--hairline);
}
.t-hero__portrait img,
.t-hero__portrait svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.t-hero__eyebrow {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: var(--s-3);
}
.t-hero__name {
  font-family: var(--f-display);
  font-size: 44px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--bordeaux);
  margin-bottom: var(--s-5);
}
.t-hero__name .age {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 22px;
  color: var(--gold);
  margin-left: var(--s-3);
}
.t-hero__facts {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-4);
  padding: var(--s-5);
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  margin-bottom: var(--s-5);
}
.t-hero__fact-label {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: var(--s-2);
}
.t-hero__fact-value {
  font-family: var(--f-display);
  font-size: 15px;
  color: var(--ink);
}
.t-hero__fact-value a { border-bottom: 1px solid var(--gold); }
.t-hero__ctas {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
}
.t-hero__sns-placeholder {
  margin-top: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--bg-warm);
  border: 1px dashed var(--hairline-warm);
  font-size: 12.5px;
  color: var(--ink-mute);
  letter-spacing: 0.05em;
}
.t-hero__sns-placeholder strong {
  display: block;
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 11px;
  color: var(--gold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: var(--s-2);
}
.t-hero__sns-placeholder code {
  font-family: var(--f-accent-en);
  font-style: italic;
  color: var(--bordeaux);
}

/* ==========================================================================
   shop hero (明背景)
   ========================================================================== */
.shop-hero {
  aspect-ratio: 16 / 6;
  background: var(--bg-warm);
  overflow: hidden;
}
.shop-hero img,
.shop-hero svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.shop-head {
  padding-block: var(--s-7) var(--s-5);
  border-bottom: 1px solid var(--hairline);
}
.shop-head__name {
  font-family: var(--f-display);
  font-size: clamp(34px, 4vw, 44px);
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--bordeaux);
  margin-bottom: var(--s-4);
}
.shop-head__name-en {
  font-family: var(--f-display-en);
  font-style: italic;
  font-size: 0.45em;
  color: var(--gold);
  margin-left: var(--s-4);
  vertical-align: middle;
}
.shop-head__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s-3);
  font-size: 13px;
  color: var(--ink-soft);
  letter-spacing: 0.06em;
  margin-bottom: var(--s-5);
}
.shop-head__ctas {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
}

.price-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
  margin-bottom: var(--s-3);
}
.price-table th,
.price-table td {
  text-align: left;
  padding: 14px 12px;
  border-bottom: 1px solid var(--hairline);
}
.price-table th {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 400;
}
.price-table .num {
  text-align: right;
  font-family: var(--f-accent-en);
  font-style: italic;
  color: var(--gold);
}

.shop-body {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--s-7);
}
.shop-info-table dl {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--s-3);
  padding: var(--s-3) 0;
  border-bottom: 1px dashed var(--hairline);
  font-size: 13px;
}
.shop-info-table dt {
  font-family: var(--f-accent-en);
  font-style: italic;
  color: var(--gold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 11.5px;
}
.shop-info-table dd { color: var(--ink-soft); }

/* ==========================================================================
   rel-section (関連セクション、明背景の汎用)
   ========================================================================== */
.rel-section {
  padding-block: var(--s-7);
  border-top: 1px solid var(--hairline);
}

/* ==========================================================================
   areas (エリアから探す)
   ========================================================================== */
.areas {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-6) var(--s-7);
}
.areas--single { grid-template-columns: 1fr; }
.areas__group { background: var(--bg-card); border: 1px solid var(--hairline); padding: var(--s-5); }
.areas__label {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--hairline);
}
.areas__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3) var(--s-5);
}
.areas__list a {
  display: inline-flex;
  align-items: baseline;
  gap: var(--s-2);
  padding: 6px 0;
  border-bottom: 1px solid transparent;
  transition: border-color 200ms ease;
}
.areas__list a:hover { border-bottom-color: var(--gold); }
.area-jp { font-size: 14px; }
.area-en {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 11.5px;
  color: var(--gold);
  letter-spacing: 0.12em;
}
.areas__note {
  margin-top: var(--s-4);
  font-size: 12px;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}

/* ==========================================================================
   community section (#community anchor 先、招待制ベータ運用)
   brief §4-4-S1 反映 (SR-C-1)
   ========================================================================== */
.community {
  padding-block: var(--s-8);
  background: var(--bg-warm);
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.community__inner {
  max-width: 720px;
  margin-inline: auto;
  text-align: center;
}
.community__eyebrow {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 12.5px;
  color: var(--gold);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: var(--s-3);
}
.community__title {
  font-family: var(--f-display);
  font-size: 26px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--bordeaux);
  margin-bottom: var(--s-4);
}
.community__lead {
  font-size: 14.5px;
  line-height: 2.1;
  color: var(--ink-soft);
  margin-bottom: var(--s-5);
}
.community__cta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  justify-content: center;
}
.community__note {
  margin-top: var(--s-5);
  font-size: 12.5px;
  color: var(--ink-mute);
  letter-spacing: 0.05em;
}

/* ==========================================================================
   site footer
   ========================================================================== */
.site-footer {
  background: var(--bg-dark);
  color: var(--ink-on-dark);
  padding-block: var(--s-8) var(--s-6);
}
.site-footer__brand {
  font-family: var(--f-display);
  font-size: 26px;
  letter-spacing: 0.1em;
  color: var(--ink-on-dark);
  margin-bottom: var(--s-3);
}
.site-footer__tagline {
  font-size: 13px;
  color: var(--ink-on-dark-mute);
  letter-spacing: 0.06em;
  margin-bottom: var(--s-7);
  line-height: 2;
}
.site-footer__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-6);
  padding-bottom: var(--s-6);
  border-bottom: 1px solid var(--hairline-dark);
  margin-bottom: var(--s-5);
}
.site-footer__col h4 {
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold);
  letter-spacing: 0.2em;
  margin-bottom: var(--s-3);
  text-transform: uppercase;
  font-weight: 400;
}
.site-footer__col ul { display: grid; gap: var(--s-2); }
.site-footer__col a {
  font-size: 13px;
  color: var(--ink-on-dark-mute);
  letter-spacing: 0.06em;
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
}
.site-footer__col a:hover { color: var(--gold); border-bottom-color: var(--gold); }
.site-footer__bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11.5px;
  color: var(--ink-on-dark-mute);
  letter-spacing: 0.16em;
}
.copyright { font-family: var(--f-accent-en); font-style: italic; }

/* ==========================================================================
   age-cookie-modal (18+ 同意 + Cookie 同意 統合モーダル / SUB-D-1 / #95)
   旧 .age-gate ブロックは age-cookie-modal に統合済み (v0.5 §12-3-B)。
   ========================================================================== */

/* ==========================================================================
   exit-bar (履歴離脱導線、brief §8-B)
   ========================================================================== */
.exit-bar {
  background: var(--bg-warm);
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  padding-block: var(--s-5);
}
.exit-bar__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--s-5);
  max-width: var(--max);
  margin-inline: auto;
  padding-inline: var(--s-5);
}
.exit-bar__lead {
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.9;
}
.exit-bar__lead kbd {
  font-family: var(--f-accent-en);
  font-style: italic;
  background: var(--bg-card);
  border: 1px solid var(--hairline);
  padding: 2px 8px;
  font-size: 12px;
  border-radius: 2px;
}
.exit-bar__button {
  padding: 12px 22px;
  background: var(--bordeaux);
  color: var(--bg);
  font-size: 13px;
  letter-spacing: 0.1em;
  border-radius: 4px;
  cursor: pointer;
}
.exit-bar__button:hover { background: var(--bordeaux-deep); }
.exit-bar__caveat {
  margin-top: var(--s-3);
  font-size: 11.5px;
  color: var(--ink-mute);
  letter-spacing: 0.05em;
}

/* ==========================================================================
   age-cookie-modal (年齢 + Cookie 同意 統合モーダル / SUB-D-1 / #95)
   v0.5 §12-3-B / AC-COOKIE-001/002/010/020/030/040/041/050
   ========================================================================== */
.age-cookie-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  background:
    linear-gradient(180deg, rgba(8, 4, 4, 0.94), rgba(22, 8, 10, 0.94) 48%, rgba(5, 3, 3, 0.96)),
    var(--bg-dark);
  padding: var(--s-5);
  overflow-y: auto;
}
.age-cookie-modal::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.26;
  background:
    linear-gradient(90deg, rgba(208, 170, 112, 0.12) 0 1px, transparent 1px 100%),
    linear-gradient(180deg, rgba(246, 230, 212, 0.08) 0 1px, transparent 1px 100%);
  background-size: 74px 74px;
  mask-image: linear-gradient(180deg, transparent, #000 16%, #000 76%, transparent);
}
.age-cookie-modal[aria-hidden="true"] { display: none; }

/* AC-COOKIE-002: 背面スクロール禁止 */
body[data-modal-open="cookie"] { overflow: hidden; }

.age-cookie-modal__panel {
  position: relative;
  width: 100%;
  max-width: 620px;
  background:
    linear-gradient(180deg, rgba(36, 21, 20, 0.96), rgba(12, 7, 6, 0.98) 58%, rgba(19, 11, 10, 0.98)),
    var(--bg-dark);
  color: var(--ink-on-dark);
  border: 1px solid rgba(208, 170, 112, 0.34);
  border-radius: 8px;
  box-shadow: 0 34px 110px -34px rgba(0, 0, 0, 0.96), 0 0 0 1px rgba(181, 42, 62, 0.22) inset;
  padding: 42px 44px 36px;
  margin-block: auto;
  overflow: hidden;
}
.age-cookie-modal__panel::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(246, 230, 212, 0.08);
  border-radius: 5px;
  pointer-events: none;
}
.age-cookie-modal__mark {
  display: grid;
  place-items: center;
  width: 104px;
  height: 104px;
  margin: 0 auto var(--s-5);
  border: 1px solid rgba(208, 170, 112, 0.62);
  border-radius: 50%;
  background: rgba(9, 5, 4, 0.72);
  box-shadow: var(--glow-gold);
}
.age-cookie-modal__mark-main {
  display: block;
  font-family: var(--f-display-en);
  font-size: 34px;
  line-height: 1;
  color: var(--ink);
  letter-spacing: 0.02em;
}
.age-cookie-modal__mark-sub {
  display: block;
  margin-top: -14px;
  font-family: var(--f-accent-en);
  font-size: 10px;
  line-height: 1;
  color: var(--gold);
  letter-spacing: 0.28em;
}
.age-cookie-modal__brand {
  font-family: var(--f-display);
  font-size: 24px;
  letter-spacing: 0.16em;
  color: var(--ink);
  text-align: center;
  margin-bottom: 4px;
}
.age-cookie-modal__brand-en {
  font-family: var(--f-display-en);
  font-style: italic;
  font-size: 12px;
  color: var(--gold);
  letter-spacing: 0.28em;
  text-align: center;
  margin-bottom: var(--s-5);
}
.age-cookie-modal__heading {
  font-family: var(--f-display);
  font-size: clamp(24px, 4vw, 34px);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: var(--s-4);
}
.age-cookie-modal__body {
  max-width: 430px;
  margin-inline: auto;
  font-size: 14px;
  line-height: 2;
  color: var(--ink-on-dark-mute);
  text-align: center;
  margin-bottom: var(--s-5);
}
.age-cookie-modal__body--lead {
  margin-bottom: var(--s-6);
  color: var(--ink-on-dark);
}
.age-cookie-modal__actions {
  display: grid;
  gap: var(--s-3);
  margin: 0 auto var(--s-3);
  max-width: 430px;
}
.age-cookie-modal__actions button,
.age-cookie-modal__exit button {
  appearance: none;
  border: 0;
  background: transparent;
  font: inherit;
  cursor: pointer;
}
.age-cookie-modal__actions button:focus-visible,
.age-cookie-modal__exit button:focus-visible {
  outline: 2px solid rgba(208, 170, 112, 0.78);
  outline-offset: 3px;
}

/* ボタン size hierarchy (AC-COOKIE-001: 最大 / 中 / 最小) */
.age-cookie-modal__btn-primary {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  justify-content: center;
  gap: 4px;
  padding: 18px 28px 17px;
  font-size: 14px;
  letter-spacing: 0.12em;
  font-weight: 500;
  color: var(--ink);
  background: linear-gradient(180deg, rgba(181, 42, 62, 0.96), rgba(90, 16, 27, 0.98));
  border: 1px solid rgba(208, 170, 112, 0.72);
  border-radius: 6px;
  box-shadow: 0 18px 42px -20px rgba(223, 67, 93, 0.9), 0 0 0 1px rgba(246, 230, 212, 0.08) inset;
  transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}
.age-cookie-modal__btn-primary:hover,
.age-cookie-modal__btn-primary:focus-visible {
  transform: translateY(-1px);
  filter: brightness(1.06);
  box-shadow: 0 24px 52px -20px rgba(223, 67, 93, 1), 0 0 0 1px rgba(208, 170, 112, 0.3) inset;
}
.age-cookie-modal__btn-en {
  font-family: var(--f-display-en);
  font-size: 22px;
  line-height: 1;
  letter-spacing: 0.2em;
  color: var(--gold);
}
.age-cookie-modal__btn-ja {
  font-size: 13px;
  line-height: 1.45;
  letter-spacing: 0.08em;
}
.age-cookie-modal__btn-sub {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  line-height: 1.5;
  color: var(--ink-on-dark-mute);
  letter-spacing: 0.04em;
}
.age-cookie-modal__btn-secondary {
  display: block;
  width: 100%;
  text-align: center;
  padding: 13px 16px;
  font-size: 13px;
  letter-spacing: 0.08em;
  color: var(--ink-on-dark);
  border: 1px solid rgba(246, 230, 212, 0.18);
  border-radius: 6px;
  background: rgba(246, 230, 212, 0.035);
  transition: color 200ms ease, border-color 200ms ease, background 200ms ease;
}
.age-cookie-modal__btn-secondary:hover,
.age-cookie-modal__btn-secondary:focus-visible {
  color: var(--gold);
  border-color: rgba(208, 170, 112, 0.46);
  background: rgba(208, 170, 112, 0.07);
}
.age-cookie-modal__btn-tertiary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-align: center;
  margin-top: var(--s-3);
  font-family: var(--f-cinema-en, var(--f-display-en));
  font-size: 11.5px;
  letter-spacing: 0.18em;
  color: var(--ink-on-dark-mute);
  border-bottom: 1px solid transparent;
  width: max-content;
  margin-inline: auto;
  padding-bottom: 2px;
  transition: color 200ms ease, border-color 200ms ease;
}
.age-cookie-modal__btn-tertiary span {
  color: var(--gold);
  letter-spacing: 0.22em;
}
.age-cookie-modal__btn-tertiary:hover {
  color: var(--gold);
  border-bottom-color: var(--gold);
}

.age-cookie-modal__exit {
  display: block;
  text-align: center;
  margin-top: var(--s-4);
}

/* 詳細セクション (AC-COOKIE-041: 送信先 / 項目 / 目的 / プライバシーポリシーリンク) */
.age-cookie-modal__details {
  max-width: 430px;
  margin: var(--s-5) auto 0;
  padding-top: var(--s-4);
  border-top: 1px solid var(--hairline-dark);
  font-size: 12.5px;
  color: var(--ink-on-dark-mute);
}
.age-cookie-modal__details-summary {
  cursor: pointer;
  text-align: center;
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--ink-on-dark);
  padding: 6px 0;
  list-style: none;
}
.age-cookie-modal__details-summary::-webkit-details-marker { display: none; }
.age-cookie-modal__details-summary::after {
  content: " ＋";
  color: var(--gold);
}
.age-cookie-modal__details[open] .age-cookie-modal__details-summary::after {
  content: " −";
}
.age-cookie-modal__details-body {
  margin-top: var(--s-3);
  text-align: left;
  line-height: 1.85;
}
.age-cookie-modal__dl {
  margin: 0;
  display: grid;
  gap: var(--s-2);
}
.age-cookie-modal__dl dt {
  font-weight: 500;
  color: var(--ink-on-dark);
  letter-spacing: 0.04em;
  margin-top: var(--s-2);
}
.age-cookie-modal__dl dt:first-child { margin-top: 0; }
.age-cookie-modal__dl dd {
  margin: 0 0 var(--s-2);
  color: var(--ink-on-dark-mute);
}
.age-cookie-modal__details-link {
  margin-top: var(--s-3);
  text-align: center;
}
.age-cookie-modal__details-link a {
  color: var(--gold);
  border-bottom: 1px solid transparent;
  transition: border-color 200ms ease;
}
.age-cookie-modal__details-link a:hover {
  border-bottom-color: var(--gold);
}

.age-cookie-modal__note {
  margin-top: var(--s-5);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--ink-on-dark-mute);
  text-align: center;
}

/* ==========================================================================
   cookie-degraded-banner (8-C、Cookie 拒否時の縮退バナー、brief §8-C)
   ========================================================================== */
.cookie-degraded-banner {
  position: sticky;
  top: 0;
  z-index: 80;
  background: var(--bordeaux-deep);
  color: var(--bg);
  padding: 10px var(--s-5);
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
  font-size: 12.5px;
  letter-spacing: 0.05em;
}
body[data-cookie-consent="denied"] .cookie-degraded-banner,
body[data-cookie-consent="0"] .cookie-degraded-banner { display: flex; }
body[data-cookie-consent="denied"][data-cookie-degraded-dismissed="1"] .cookie-degraded-banner,
body[data-cookie-consent="0"][data-cookie-degraded-dismissed="1"] .cookie-degraded-banner { display: none; }
.cookie-degraded-banner__text {
  line-height: 1.7;
}
.cookie-degraded-banner__dismiss {
  background: transparent;
  border: 1px solid var(--gold-soft);
  color: var(--bg);
  padding: 6px 14px;
  font-size: 11.5px;
  letter-spacing: 0.08em;
  cursor: pointer;
  border-radius: 2px;
}
.cookie-degraded-banner__dismiss:hover { background: rgba(255, 255, 255, 0.1); }

/* ==========================================================================
   proto-nav (mockup-only)
   ========================================================================== */
.proto-nav {
  position: fixed;
  right: var(--s-4);
  bottom: var(--s-4);
  z-index: 90;
  background: rgba(31, 24, 20, 0.94);
  color: var(--ink-on-dark);
  padding: var(--s-3) var(--s-4);
  font-family: var(--f-accent-en);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0.16em;
  display: grid;
  gap: 4px;
  border: 1px solid var(--hairline-dark);
}
.proto-nav__head {
  color: var(--gold);
  border-bottom: 1px solid var(--hairline-dark);
  padding-bottom: 4px;
  margin-bottom: 4px;
}
.proto-nav a {
  color: var(--ink-on-dark-mute);
  padding: 2px 4px;
  border-bottom: 1px solid transparent;
}
.proto-nav a.is-current { color: var(--gold); border-bottom-color: var(--gold); }

/* ==========================================================================
   sticky-cta (detail page mobile fallback)
   ========================================================================== */
.sticky-cta {
  display: none;
}

/* ==========================================================================
   responsive
   ========================================================================== */
@media (max-width: 1024px) {
  .hero__overlay { grid-template-columns: 1fr; gap: var(--s-6); }
  .hero__inner { grid-template-columns: 1fr; gap: var(--s-7); padding-block: var(--s-8) var(--s-7); }
  .hero__media { grid-template-columns: 1fr 1fr; }
  .hero__meta {
    border-left: 0;
    border-top: 1px solid rgba(208, 170, 112, 0.20);
    padding-left: 0;
    padding-top: var(--s-5);
    padding-bottom: 0;
  }
  .hero__meta::before { left: 0; top: -5px; }
  .hero__meta::after { right: auto; left: 0; top: -28px; }
  .row__grid { grid-template-columns: repeat(2, 1fr); }
  .row__grid--6 { grid-template-columns: repeat(3, 1fr); }
  .row__grid--column { grid-template-columns: 1fr; }
  .grid-videos { grid-template-columns: repeat(2, 1fr); }
  .exp-single__layout {
    grid-template-columns: 1fr;
    padding-inline: var(--s-5);
  }
  .exp-single__aside { position: static; }
  .t-hero { grid-template-columns: 1fr; }
  .pledge { grid-template-columns: 1fr; }
  .shop-body { grid-template-columns: 1fr; }
  .areas__list { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 720px) {
  .site-header__inner {
    grid-template-columns: auto 1fr auto auto;
    gap: var(--s-3);
  }
  .nav-toggle { display: inline-flex; }
  .header__line { display: none; }
  /* nav-wrap: viewport を覆う fixed コンテナ。drawer の containing block
     となり、`overflow: hidden` で translateX(100%) ではみ出した分を
     確実にクリップ。これが iOS Safari で水平スクロールを発生させない
     唯一確実な方法 (fixed 子要素は html/body の overflow ではクリップ
     されないため、fixed 親 + overflow:hidden が必要)。 */
  .nav-wrap {
    display: block;
    position: fixed;
    inset: 0;
    overflow: hidden;
    /* 常時 pointer-events: none。drawer 本体 (.nav) のみ auto にして
       クリックを拾う。空白部はそのまま下層の .nav-scrim に届き、
       タップで drawer を閉じる動線が壊れない。 */
    pointer-events: none;
    z-index: 60;
  }
  .nav {
    /* fixed → absolute に変更 (containing block = .nav-wrap) */
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
    height: 100%;
    width: min(88vw, 380px);
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    padding: calc(72px + var(--s-5)) 0 calc(var(--s-5) + env(safe-area-inset-bottom));
    background:
      linear-gradient(180deg, rgba(20, 8, 10, 0.97), rgba(8, 5, 4, 0.99)),
      radial-gradient(ellipse at 88% 6%, rgba(181, 42, 62, 0.30), transparent 58%);
    border-left: 1px solid var(--hairline-hot);
    box-shadow: -32px 0 64px -20px rgba(0, 0, 0, 0.82);
    transform: translateX(100%);
    transition: transform 320ms cubic-bezier(0.22, 0.61, 0.36, 1);
    overflow-y: auto;
    overscroll-behavior: contain;
    pointer-events: auto;
  }
  [data-nav-open="true"] .nav { transform: translateX(0); }
  .nav a {
    display: grid;
    grid-template-columns: 2.4rem 1fr;
    align-items: baseline;
    gap: var(--s-4);
    min-height: 60px;
    padding: var(--s-4) var(--s-5);
    margin: 0;
    border: 0;
    border-bottom: 1px solid rgba(208, 170, 112, 0.10);
    font-family: var(--f-title);
    font-size: 20px;
    font-weight: 500;
    line-height: 1.25;
    letter-spacing: 0.06em;
    color: var(--ink);
  }
  .nav a:first-of-type { border-top: 1px solid rgba(208, 170, 112, 0.10); }
  .nav a:hover, .nav a.is-current { color: var(--ink); border-bottom-color: rgba(223, 67, 93, 0.42); }
  .nav a .nav__sub {
    font-family: var(--f-cinema-en);
    font-style: italic;
    font-size: 13px;
    letter-spacing: 0.24em;
    color: var(--gold);
    opacity: 0.82;
    font-variant-numeric: tabular-nums;
    margin: 0;
  }
  /* SP では nav (ドロワー) 内の LINE ボタンを再表示。`.nav a` (0,1,1)
     に勝つよう `.nav a.nav__line` (0,2,1) で書く。 */
  .nav a.nav__line {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--s-2);
    margin: auto var(--s-5) 0;
    padding: 17px 22px;
    font-size: 13px;
    letter-spacing: 0.2em;
    min-height: 56px;
    border: 1px solid var(--crimson-soft);
    border-bottom: 1px solid var(--crimson-soft) !important;
  }
  .nav a.nav__line .btn__icon { width: 18px; height: 18px; }
  .hero__overlay { padding-block: var(--s-7); }
  .hero__media { grid-template-columns: 1fr; }
  .hero__media .v-card--main .v-card__thumb { aspect-ratio: 5 / 3; }
  .row__grid { grid-template-columns: 1fr; }
  .row__grid--6 { grid-template-columns: repeat(2, 1fr); }
  .grid-videos { grid-template-columns: 1fr; }
  .areas__list { grid-template-columns: repeat(2, 1fr); }
  .site-footer__grid { grid-template-columns: repeat(2, 1fr); }
  .exit-bar__inner { grid-template-columns: 1fr; }
  .t-hero__facts { grid-template-columns: 1fr; }
}

/* ==========================================================================
   v0.3 動画前面化 — 追加コンポーネント (新着 dense / ランキング / シリーズチップ)
   ========================================================================== */

/* ----- denser row variant (新着) ----- */
.video-row--dense { padding-block: var(--s-7); }
.video-row--dense .row__grid { gap: var(--s-4); }

/* ----- compact v-card (sm) ----- */
.v-card--sm .v-card__title { font-size: 13.5px; line-height: 1.55; letter-spacing: 0.04em; }
.v-card--sm .v-card__meta { font-size: 11.5px; }
.v-card--sm .v-card__body { padding-top: var(--s-3); }

/* ----- NEW badge ----- */
.v-card__badge-new {
  position: absolute;
  top: var(--s-3);
  left: var(--s-3);
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 10.5px;
  letter-spacing: 0.22em;
  color: var(--ink);
  background:
    linear-gradient(135deg, rgba(246,230,212,0.18), rgba(223,67,93,0.84) 48%, rgba(90,16,27,0.88)),
    var(--crimson);
  padding: 3px 9px;
  border-radius: 1px;
  border: 1px solid rgba(246,230,212,0.16);
  box-shadow: var(--glow-crimson-soft), inset 0 1px 0 rgba(246,230,212,0.18);
  z-index: 5;
  text-transform: uppercase;
}

/* ----- ranked v-card ----- */
.v-card--ranked { position: relative; }
.v-card__rank {
  position: absolute;
  top: -14px;
  left: -10px;
  z-index: 4;
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(58px, 6.4vw, 92px);
  line-height: 1;
  color: rgba(246, 230, 212, 0.88);
  text-shadow:
    0 0 34px rgba(223, 67, 93, 0.62),
    0 0 1px rgba(208, 170, 112, 0.60),
    -2px -2px 0 rgba(9,5,4,0.96),
    2px 2px 0 rgba(90,16,27,0.78);
  pointer-events: none;
  letter-spacing: 0;
}

/* ----- series chip grid ----- */
.series-grid-sec {
  padding-block: var(--s-8);
  background: var(--bg-warm);
  background-image:
    radial-gradient(ellipse at 30% 0%, rgba(223, 67, 93, 0.18) 0%, transparent 55%),
    radial-gradient(ellipse at 70% 100%, rgba(90, 16, 27, 0.16) 0%, transparent 50%),
    linear-gradient(180deg, rgba(0,0,0,0.10), transparent 30%, rgba(0,0,0,0.12));
}
.series-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--s-3);
}
.series-chip {
  display: block;
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--bg-card);
  border: 1px solid rgba(208, 170, 112, 0.14);
  transition: border-color 280ms ease, transform 280ms ease, box-shadow 280ms ease;
  box-shadow: var(--shadow-thumb);
}
.series-chip:hover {
  border-color: rgba(223, 67, 93, 0.52);
  transform: translateY(-3px);
  box-shadow: var(--shadow-thumb-hot);
}
.series-chip__thumb { position: absolute; inset: 0; z-index: 0; }
.series-chip__thumb img,
.series-chip__thumb svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(110%) brightness(0.55);
  transition: filter 280ms ease, transform 600ms ease;
}
.series-chip:hover .series-chip__thumb img,
.series-chip:hover .series-chip__thumb svg {
  filter: saturate(130%) brightness(0.78);
  transform: scale(1.08);
}
.series-chip::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 48%, rgba(246,230,212,0.68) 0 4px, rgba(246,230,212,0.22) 5px 14px, transparent 15px),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='34' viewBox='0 0 34 34'%3E%3Cpath d='M14 9v16l12-8z' fill='%23f6e6d4'/%3E%3C/svg%3E") center / 34px 34px no-repeat,
    linear-gradient(180deg, transparent 28%, rgba(8, 5, 4, 0.94) 100%),
    var(--sheen-thumb);
  opacity: 0.86;
  z-index: 1;
  pointer-events: none;
}
.series-chip__label {
  position: absolute;
  z-index: 2;
  left: var(--s-4);
  bottom: var(--s-4);
  font-family: var(--f-title);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--ink);
  text-shadow: 0 1px 14px rgba(0,0,0,0.75);
}
.series-chip__count {
  position: absolute;
  z-index: 2;
  right: var(--s-3);
  top: var(--s-3);
  font-family: var(--f-cinema-en);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--ink);
  background: rgba(8, 5, 4, 0.72);
  padding: 2px 8px;
  border: 1px solid rgba(208, 170, 112, 0.24);
}

@media (max-width: 1024px) {
  .row__grid--6 { grid-template-columns: repeat(3, 1fr); }
  .series-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .row__grid--6 { grid-template-columns: repeat(2, 1fr); }
  .series-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ==========================================================================
   v0.3 レスポンシブ強化パス (mobile-first 想定でスマホ表示を整える)
   primary device = phone (375〜480px), iPad / tablet も補完
   ========================================================================== */

@media (max-width: 720px) {
  /* container を 16px に */
  .container { padding-inline: var(--s-4); }

  /* section 間隔を圧縮 */
  .section { padding-block: var(--s-7); }
  .video-row { padding-block: var(--s-7); }
  .video-row--dense { padding-block: var(--s-6); }
  .series-grid-sec { padding-block: var(--s-7); }
  .community { padding-block: var(--s-7); }
  .site-footer { padding-block: var(--s-7) var(--s-5); }

  /* HERO 圧縮 */
  .hero { min-height: 76vh; }
  .hero__overlay { padding: var(--s-7) var(--s-4) var(--s-6); min-height: 76vh; gap: var(--s-5); }
  .hero__title {
    font-size: clamp(27px, 7vw, 38px);
    letter-spacing: 0.045em;
    line-height: 1.42;
    margin-bottom: var(--s-5);
  }
  .hero__title-line:nth-child(2) { padding-left: 0; }
  .hero__lead { font-size: 14px; line-height: 2; margin-bottom: var(--s-6); }
  .hero__eyebrow { font-size: 11px; letter-spacing: 0.24em; margin-bottom: var(--s-4); }
  .hero__eyebrow::before,
  .hero__eyebrow::after { display: none; }
  .hero__cta { width: 100%; gap: var(--s-2); }
  .hero__cta .btn { flex: 1 1 100%; padding: 14px 18px; font-size: 13px; letter-spacing: 0.14em; }
  .hero__cta .btn--lg { padding: 16px 20px; font-size: 13.5px; }
  .hero__meta { padding-top: var(--s-5); background: transparent; box-shadow: none; }
  .hero__meta-title { font-size: 16px; line-height: 1.6; }
  .hero__meta::after { display: none; }

  /* sec-head 縦積み */
  .sec-head { grid-template-columns: 1fr; gap: var(--s-3); align-items: start; }
  .sec-head__title { font-size: 22px; letter-spacing: 0.08em; line-height: 1.45; }
  .sec-head__num { font-size: 10.5px; letter-spacing: 0.28em; }
  .sec-head__action { justify-self: start; font-size: 12px; }

  /* row__head 縦積み */
  .row__head { flex-direction: column; align-items: flex-start; gap: var(--s-3); }
  .row__heading { font-size: 24px; }
  .row__heading-en { font-size: 11px; letter-spacing: 0.2em; }
  .video-row::before { display: none; }

  /* v-card mobile */
  .v-card__title { font-size: 15px; line-height: 1.58; }
  .v-card--sm .v-card__title { font-size: 13.5px; }
  .v-card__rank { font-size: 54px; top: -10px; left: -6px; }
  .v-card__play svg { width: 48px; height: 48px; padding: 13px; }
  .v-card__thumb::before {
    background:
      radial-gradient(circle at 50% 50%, rgba(246,230,212,0.92) 0 5px, rgba(246,230,212,0.28) 6px 15px, transparent 16px),
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36'%3E%3Cpath d='M15 10v16l13-8z' fill='%23f6e6d4'/%3E%3C/svg%3E") center / 36px 36px no-repeat,
      linear-gradient(180deg, transparent 28%, rgba(8, 5, 4, 0.72) 100%),
      radial-gradient(ellipse at 50% 28%, transparent 22%, rgba(0,0,0,0.48) 100%),
      var(--sheen-thumb);
  }
  .v-card__thumb:has(.v-card__play)::before {
    background:
      linear-gradient(180deg, transparent 28%, rgba(8, 5, 4, 0.72) 100%),
      radial-gradient(ellipse at 50% 28%, transparent 22%, rgba(0,0,0,0.48) 100%),
      var(--sheen-thumb);
  }
  .exp-single__player::before {
    background:
      radial-gradient(circle at 50% 50%, rgba(246,230,212,0.88) 0 6px, rgba(246,230,212,0.22) 7px 20px, transparent 21px),
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='46' height='46' viewBox='0 0 46 46'%3E%3Cpath d='M19 13v20l16-10z' fill='%23f6e6d4'/%3E%3C/svg%3E") center / 46px 46px no-repeat,
      linear-gradient(180deg, rgba(0,0,0,0.08), rgba(8,5,4,0.42) 72%, rgba(8,5,4,0.72)),
      var(--sheen-thumb);
  }

  /* series chip */
  .series-chip__label { font-size: 14px; letter-spacing: 0.05em; left: var(--s-3); bottom: var(--s-3); }
  .series-chip__count { font-size: 10px; padding: 2px 6px; letter-spacing: 0.1em; }

  /* pledge stacked */
  .pledge__title { font-size: 24px; }

  /* community */
  .community__inner { padding-inline: var(--s-3); }
  .community__title { font-size: 22px; }
  .community__lead { font-size: 13.5px; line-height: 2; }
  .community__cta .btn { width: 100%; }

  /* footer */
  .site-footer__brand { font-size: 22px; }
  .site-footer__tagline { font-size: 12.5px; margin-bottom: var(--s-6); }
  .site-footer__bar { flex-direction: column; gap: var(--s-2); text-align: center; letter-spacing: 0.12em; }

  /* cookie-degraded banner stacking */
  .cookie-degraded-banner { flex-direction: column; align-items: stretch; gap: var(--s-2); }
  .cookie-degraded-banner__dismiss { align-self: flex-end; }

  /* age-cookie-modal mobile (≤720px) */
  .age-cookie-modal { padding: var(--s-3); align-items: start; }
  .age-cookie-modal__panel { padding: var(--s-5) var(--s-4); max-width: 100%; margin-top: var(--s-3); }
  .age-cookie-modal__panel::before { inset: 8px; }
  .age-cookie-modal__mark { width: 78px; height: 78px; margin-bottom: var(--s-4); }
  .age-cookie-modal__mark-main { font-size: 27px; }
  .age-cookie-modal__mark-sub { margin-top: -10px; font-size: 8px; letter-spacing: 0.22em; }
  .age-cookie-modal__brand { font-size: 19px; letter-spacing: 0.1em; margin-bottom: 3px; }
  .age-cookie-modal__brand-en { font-size: 10px; letter-spacing: 0.16em; margin-bottom: var(--s-4); }
  .age-cookie-modal__heading { font-size: 20px; letter-spacing: 0.05em; margin-bottom: var(--s-3); }
  .age-cookie-modal__body { font-size: 12.5px; line-height: 1.85; margin-bottom: var(--s-4); }
  .age-cookie-modal__body--lead { margin-bottom: var(--s-4); }
  .age-cookie-modal__actions { gap: var(--s-2); }
  .age-cookie-modal__btn-primary {
    padding: 14px 12px;
    line-height: 1.55;
    word-break: keep-all;
    overflow-wrap: break-word;
  }
  .age-cookie-modal__btn-en { font-size: 19px; letter-spacing: 0.18em; }
  .age-cookie-modal__btn-ja { font-size: 12.5px; }
  .age-cookie-modal__btn-sub { font-size: 10.5px; }
  .age-cookie-modal__btn-secondary { padding: 10px 10px; letter-spacing: 0.04em; }
  .age-cookie-modal__btn-tertiary { font-size: 10.5px; letter-spacing: 0.12em; }
  .age-cookie-modal__details { font-size: 12px; margin-top: var(--s-4); padding-top: var(--s-3); }
  .age-cookie-modal__details-summary { font-size: 11.5px; }
  .age-cookie-modal__note { font-size: 10.5px; letter-spacing: 0.12em; margin-top: var(--s-4); }

  /* exit-bar */
  .exit-bar__button { width: 100%; padding: 14px 20px; }

  /* proto-nav を縮小 (モックアップ補助なので mobile は最小に) */
  .proto-nav { right: var(--s-3); bottom: var(--s-3); font-size: 10px; padding: var(--s-2) var(--s-3); gap: 2px; }
  .proto-nav__head { padding-bottom: 3px; margin-bottom: 3px; }

  /* btn-line ヘッダ内 */
  .btn-line { padding: 8px 14px; font-size: 11.5px; letter-spacing: 0.1em; }

  /* tag-row gap */
  .tag-row { gap: 4px; }
  .tag { font-size: 11px; padding: 2px 8px; }

  /* experience-single 詳細ページ: meta-row 縦積み */
  .exp-single__meta-row { grid-template-columns: 1fr; gap: var(--s-3); align-items: start; }
  .exp-single__date { text-align: left; }
  .exp-single__h1 { font-size: clamp(20px, 6vw, 26px); line-height: 1.55; }
  .exp-single__layout { padding-inline: var(--s-4); }

  /* areas: 2 列 → 1 列 (--single 以外も保険) */
  .areas { grid-template-columns: 1fr; gap: var(--s-5); }

  /* shop info table のラベル幅縮小 */
  .shop-info-table dl { grid-template-columns: 92px 1fr; gap: var(--s-2); font-size: 12.5px; }

  .s-card--featured-shop {
    grid-template-columns: 1fr;
    gap: var(--s-4);
  }
  .s-card--featured-shop .s-card__logo {
    width: min(100%, 220px);
  }
}

/* small phone (iPhone SE 〜 標準スマホ縦、≤ 480px) */
@media (max-width: 480px) {
  .row__grid--6 { grid-template-columns: 1fr; }
  .series-grid { grid-template-columns: repeat(2, 1fr); gap: var(--s-2); }
  .site-footer__grid { grid-template-columns: 1fr; gap: var(--s-5); }
  .areas__list { grid-template-columns: 1fr; }

  .hero__title {
    font-size: clamp(23px, 7.4vw, 30px);
    letter-spacing: 0.035em;
  }
  .hero__overlay { padding-block: var(--s-6) var(--s-5); }
  .hero { min-height: 70vh; }

  .v-card__rank { font-size: 46px; }

  .brand__mark { display: none; }

  /* proto-nav はモック表示なので最小スクリーンでは hide */
  .proto-nav { display: none; }

  /* age-cookie-modal ≤480px (iPhone SE 〜 標準スマホ縦) */
  .age-cookie-modal { padding: var(--s-2); }
  .age-cookie-modal__panel { padding: var(--s-4) var(--s-3); }
  .age-cookie-modal__mark { width: 70px; height: 70px; }
  .age-cookie-modal__mark-main { font-size: 24px; }
  .age-cookie-modal__brand { font-size: 17px; letter-spacing: 0.08em; }
  .age-cookie-modal__brand-en { font-size: 9.5px; letter-spacing: 0.14em; margin-bottom: var(--s-3); }
  .age-cookie-modal__heading { font-size: 18px; }
  .age-cookie-modal__body { font-size: 12px; line-height: 1.8; }
  .age-cookie-modal__btn-primary { padding: 12px 10px; }
  .age-cookie-modal__btn-en { font-size: 18px; }
  .age-cookie-modal__btn-ja { font-size: 12px; }
  .age-cookie-modal__btn-sub { font-size: 10px; }
  .age-cookie-modal__btn-tertiary { font-size: 10px; letter-spacing: 0.12em; }
  .age-cookie-modal__details { font-size: 11.5px; }
  .age-cookie-modal__note { font-size: 10px; }

  /* sec-head__title さらに小さく */
  .sec-head__title { font-size: 21px; }
  .row__heading { font-size: 22px; }
}

/* ultra narrow (≤ 360px、古い Android / 折りたたみ) */
@media (max-width: 360px) {
  .container { padding-inline: var(--s-3); }
  .site-header__inner { padding-inline: var(--s-3); height: 64px; }
  .brand { font-size: 18px; }
  .brand__mark { display: none; }
  .btn-line { padding: 7px 10px; font-size: 11px; }
}
