/* Generated from css/parts/*.css; edit those files, not this bundle (npm run css:concat). */
/* Direction A: Fraunces (display / headings) + DM Sans (body) + Zen Maru Gothic (JP accents — softer café feel) */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,100..900;1,9..144,100..900&family=DM+Sans:ital,wght@0,300;0,400;0,500&family=Zen+Maru+Gothic:wght@400;500;700&display=swap');

/* ── Variables ───────────────────────────────────────────── */
:root {
  /*
   * Sampled from flagship art (Direction A):
   * Onsen — yukata sage #8A9A84, sash teal #6B9BA0, sash mauve #C5879E, hair pink #D15D7D, amber eyes #F4A442,
   *         wood #B08D79, bath stone #4A4E5A, interior glow #FDF2A7.
   * Kyo × Vivi cover — neon / magenta pinks, crimson hair, charcoal blacks; UI pink biased to #E94D8E for pop.
   */
  --bg:        #131518;
  --bg2:       #1a1d22;
  --bg3:       #24282f;
  --surface:   #2c3139;
  --border:    rgba(253, 242, 167, 0.09);
  --pink:      #e94d8e;
  --pink-deep: #c5879e;
  --teal:      #6b9ba0;
  --purple:    #c5879e;
  /* Dusty blue-lavender (steam / sash, toned for UI text) */
  --accent-yuzu: #9eb8bc;
  --accent-yuzu-soft: rgba(158, 184, 188, 0.38);
  /* Onsen lamplight */
  --accent-warm: #e8cf8a;
  --accent-warm-soft: rgba(253, 242, 167, 0.26);
  /* Yukata / foliage accent (filters, chips, future pattern) */
  --accent-sage: #8a9a84;
  --cream:     #faf6f0;
  --muted:     #a898a8;
  --text:      #f5f1f3;
  --font-serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-sans:  'DM Sans', system-ui, sans-serif;
  --font-jp:    'Zen Maru Gothic', 'Hiragino Maru Gothic ProN', sans-serif;
  --ease-out:   cubic-bezier(0.16, 1, 0.3, 1);
  /* Hero wash (05-hero) — mauve / lamp / magenta rose */
  --hero-glow-orchid: rgba(197, 135, 158, 0.12);
  --hero-glow-lamp:   rgba(253, 242, 167, 0.065);
  --hero-glow-rose:   rgba(233, 77, 142, 0.09);
  /* Stamp book disc + toast/modal preview — “paper” under transparent ink art */
  --stamp-paper: #fdfaf6;
  /* Stamp book cover + slot name strip (same family as .stamp-book-cover) */
  --stamp-book-cover-grad: linear-gradient(165deg, #2c2628 0%, #1e1a1c 100%);
  /* Direction A — tea house rims & paper (see 21-tea-house-surfaces.css) */
  --ocha-rim: rgba(253, 242, 167, 0.07);
  --ocha-rim-soft: rgba(253, 242, 167, 0.045);
  --ocha-inset-shine: rgba(255, 255, 255, 0.05);
  --ocha-card-shadow: 0 14px 36px rgba(0, 0, 0, 0.32);
  /* Below fixed nav → section eyebrow / H1 on inner pages (gallery, stamps, …); was 10rem, tightened slightly */
  --ocha-inner-page-pad-top: clamp(7rem, 11vh + 4.25rem, 8.75rem);
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  max-width: 100%;
}

.skip-link {
  position: absolute;
  top: -100px;
  left: 1rem;
  z-index: 10001;
  padding: 0.75rem 1.25rem;
  background: var(--pink);
  color: var(--bg);
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 500;
  border-radius: 999px;
  transition: top 0.2s var(--ease-out);
}
.skip-link:focus {
  top: 1rem;
  outline: none;
}

:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 3px;
}
button:focus:not(:focus-visible),
a:focus:not(:focus-visible) {
  outline: none;
}

body {
  background-color: var(--bg);
  background-image:
    radial-gradient(ellipse 100% 65% at 50% -18%, rgba(233, 77, 142, 0.06) 0%, transparent 52%),
    radial-gradient(ellipse 55% 42% at 100% 32%, rgba(107, 155, 160, 0.055) 0%, transparent 48%),
    radial-gradient(ellipse 45% 38% at 0% 78%, rgba(197, 135, 158, 0.05) 0%, transparent 50%),
    radial-gradient(ellipse 70% 50% at 80% 100%, rgba(138, 154, 132, 0.03) 0%, transparent 45%);
  color: var(--text);
  font-family: var(--font-sans);
  font-weight: 300;
  line-height: 1.7;
  min-height: 100vh;
  overflow-x: hidden;
}
/* Film grain — softer frequency + lower opacity so it doesn’t fight the cup silhouettes */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.55' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  opacity: 0.01;
  pointer-events: none;
  z-index: 0;
}
/* Tea-room motif — sparse mug silhouettes only (no steam/leaf shapes that read wrong at low contrast) */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20520%20520%22%3E%3Cdefs%3E%3Cg%20id%3D%22m%22%3E%3Cellipse%20cx%3D%2240%22%20cy%3D%2258%22%20rx%3D%2219%22%20ry%3D%225.5%22%20fill%3D%22%23fef9f2%22%20opacity%3D%220.55%22%2F%3E%3Cpath%20fill%3D%22%23fef9f2%22%20opacity%3D%220.45%22%20d%3D%22M25%2026v19c0%204.5%203.8%208%208.5%208h13c4.7%200%208.5-3.5%208.5-8V26c0-3-2.3-5.2-5.2-5.2H30.2C27.3%2020.8%2025%2023%2025%2026z%22%2F%3E%3Cpath%20fill%3D%22none%22%20stroke%3D%22%23fef9f2%22%20stroke-width%3D%223%22%20stroke-linecap%3D%22round%22%20d%3D%22M52%2033c11%200%2016%205.5%2016%2013.5S63%2059%2052%2059%22%20opacity%3D%220.6%22%2F%3E%3C%2Fg%3E%3C%2Fdefs%3E%3Cg%20transform%3D%22translate(62%20102)%20rotate(-12%2040%2042)%22%3E%3Cuse%20href%3D%22%23m%22%2F%3E%3C%2Fg%3E%3Cg%20transform%3D%22translate(308%2046)%20rotate(10%2040%2042)%22%3E%3Cg%20transform%3D%22matrix(-1%200%200%201%2080%200)%22%3E%3Cuse%20href%3D%22%23m%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3Cg%20transform%3D%22translate(332%20252)%20rotate(-8%2040%2042)%20scale(0.86)%22%3E%3Cuse%20href%3D%22%23m%22%2F%3E%3C%2Fg%3E%3Cg%20transform%3D%22translate(88%20378)%20rotate(11%2040%2042)%22%3E%3Cg%20transform%3D%22matrix(-1%200%200%201%2080%200)%22%3E%3Cuse%20href%3D%22%23m%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  background-size: 600px 600px;
  background-position: 43px 107px;
  background-repeat: repeat;
}
/* Exclude nav: a plain `nav` rule loses specificity to `body > *`, so main was stacking above the bar and blocking the mobile drawer/toggle. */
/* Toast host must stay position:fixed + high z-index; see 20-stamp-toast.css (#ocha-stamp-toast-host beats this rule). */
body > *:not(nav):not(#ocha-lightbox):not(#ocha-stamp-toast-host):not(#stamp-hint-modal) {
  position: relative;
  z-index: 1;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ── Age Gate ────────────────────────────────────────────── */
/* html.age-verified is set by inline <head> script when localStorage is already OK, which avoids a flash before main.js */
html.age-verified #age-gate {
  display: none !important;
  visibility: hidden;
  pointer-events: none;
}
#age-gate {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: 100dvh;
  min-height: -webkit-fill-available;
  z-index: 9999;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  text-align: center;
  padding: max(1.25rem, env(safe-area-inset-top)) max(1.25rem, env(safe-area-inset-right))
    max(1.25rem, env(safe-area-inset-bottom)) max(1.25rem, env(safe-area-inset-left));
  box-sizing: border-box;
  overflow-y: auto;
  overscroll-behavior: none;
  touch-action: pan-y;
  transition: opacity 0.6s var(--ease-out), visibility 0.6s;
  isolation: isolate;
}
/* Corner steam / motif — kept in the margins, behind the card (not on body text) */
#age-gate::before,
#age-gate::after {
  content: '';
  position: fixed;
  pointer-events: none;
  z-index: 0;
  width: min(36vw, 14rem);
  height: min(36vw, 14rem);
  opacity: 0.11;
}
#age-gate::before {
  top: 0;
  left: 0;
  background: radial-gradient(circle at 0 0, var(--teal), transparent 68%);
}
#age-gate::after {
  bottom: 0;
  right: 0;
  background: radial-gradient(circle at 100% 100%, var(--pink), transparent 70%);
}
@media (prefers-reduced-motion: reduce) {
  #age-gate::before,
  #age-gate::after {
    opacity: 0.06;
  }
}
#age-gate.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
/* Set on <html> via main.js while the gate is shown, so background scroll is stopped */
html.age-gate-locked {
  overflow: hidden;
  height: 100%;
  overscroll-behavior: none;
  /* pan-y: allow #age-gate to scroll when copy is taller than the viewport (touch-action: none blocked this on mobile). */
  touch-action: pan-y;
}
/* Gate is z-index 9999 but the fixed nav bar can still peek through gradients or catch focus — hide it until verified. */
html.age-gate-locked:not(.age-verified) nav {
  visibility: hidden !important;
  pointer-events: none !important;
}
html.age-gate-locked body {
  overflow: hidden;
  height: 100%;
  overscroll-behavior: none;
  touch-action: pan-y;
  position: fixed;
  width: 100%;
  left: 0;
  right: 0;
  /* top set in JS to preserve scroll position */
}
.gate-inner {
  position: relative;
  z-index: 1;
  max-width: 480px;
  width: 100%;
  margin: auto;
  max-height: min(92dvh, 100%);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
  animation: fadeUp 0.8s var(--ease-out) both;
}
.gate-logo {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 6vw, 3.5rem);
  font-style: italic;
  color: var(--pink);
  margin-bottom: 0.25rem;
  letter-spacing: -0.02em;
}
.gate-jp {
  font-family: var(--font-jp);
  font-size: 0.9rem;
  color: var(--muted);
  letter-spacing: 0.15em;
  margin-bottom: 2.5rem;
}
.gate-icon {
  font-size: 3rem;
  margin-bottom: 1.5rem;
  display: block;
}
.gate-inner h2 {
  font-family: var(--font-serif);
  font-size: clamp(1.4rem, 4vw, 2rem);
  font-weight: 600;
  margin-bottom: 0.75rem;
  color: var(--cream);
}
.gate-inner p {
  color: var(--muted);
  font-size: 0.95rem;
  margin-bottom: 2.5rem;
  line-height: 1.8;
}
.gate-inner p strong { color: var(--text); font-weight: 500; }
.gate-buttons {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.btn-enter {
  background: var(--pink);
  color: var(--bg);
  border: none;
  padding: 0.85rem 2.5rem;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 500;
  border-radius: 999px;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
  letter-spacing: 0.04em;
}
.btn-enter:hover {
  background: var(--pink-deep);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(233,77,142,0.36);
}
.btn-leave {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--border);
  padding: 0.85rem 2rem;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  border-radius: 999px;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s;
}
.btn-leave:hover { color: var(--text); border-color: rgba(255,255,255,0.2); }
.gate-disclaimer {
  margin-top: 2rem;
  font-size: 0.75rem;
  color: var(--muted);
  opacity: 0.6;
}
.gate-copy--restricted h2 {
  color: var(--teal);
}
.gate-copy--restricted p {
  margin-bottom: 2rem;
}

/*
 * Narrow viewports: full-width panel, top-aligned — scroll on #age-gate (not a min-height:100dvh flex
 * box) so disclaimer / long copy stays reachable. Pair with touch-action: pan-y on html/body when locked.
 */
@media (max-width: 640px) {
  #age-gate {
    align-items: flex-start;
    justify-content: center;
    padding: max(0.75rem, env(safe-area-inset-top, 0px)) max(1rem, env(safe-area-inset-right, 0px))
      max(1rem, env(safe-area-inset-bottom, 0px)) max(1rem, env(safe-area-inset-left, 0px));
    -webkit-overflow-scrolling: touch;
  }

  .gate-inner {
    margin-top: 0;
    max-width: 100%;
    width: 100%;
    max-height: none;
    min-height: 0;
    border-radius: 0;
    border-left: none;
    border-right: none;
    box-shadow:
      0 1px 0 var(--ocha-inset-shine) inset,
      0 18px 48px rgba(0, 0, 0, 0.38);
    box-sizing: border-box;
  }
}

/* ── Navigation ──────────────────────────────────────────── */
nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 1.25rem 2.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(to bottom, rgba(14,11,20,0.95) 0%, transparent 100%);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.nav-logo {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  font-style: italic;
  color: var(--pink);
  letter-spacing: -0.02em;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.nav-logo .tea {
  font-size: 1.1rem;
  font-style: normal;
}
.nav-links {
  display: flex;
  align-items: center;
  gap: 2rem;
  list-style: none;
}
.nav-links a {
  font-size: 0.85rem;
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  transition: color 0.2s;
  position: relative;
}
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--pink);
  transition: width 0.3s var(--ease-out);
}
.nav-links a:hover { color: var(--text); }
.nav-links a:hover::after { width: 100%; }
.nav-links a.active { color: var(--pink); }
.nav-links a.active::after { width: 100%; }
.nav-commission {
  background: var(--pink);
  color: var(--bg) !important;
  padding: 0.5rem 1.25rem;
  border-radius: 999px;
  font-weight: 500 !important;
  transition: transform 0.2s, box-shadow 0.2s !important;
}
.nav-commission:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 20px rgba(233,77,142,0.32);
}
.nav-commission::after { display: none !important; }

.nav-menu-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  min-width: 2.75rem;
  height: 2.75rem;
  min-height: 2.75rem;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  background: rgba(36, 32, 48, 0.85);
  color: var(--cream);
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.nav-menu-toggle:hover {
  background: var(--surface);
  border-color: rgba(255, 255, 255, 0.12);
  color: var(--text);
}
.nav-menu-toggle:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}
.nav-menu-toggle-box {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.28rem;
  width: 1.15rem;
}
.nav-menu-toggle-bar {
  display: block;
  height: 2px;
  border-radius: 1px;
  background: currentColor;
  transition: transform 0.25s var(--ease-out), opacity 0.2s;
}
nav.nav-open .nav-menu-toggle-bar:nth-child(1) {
  transform: translateY(0.45rem) rotate(45deg);
}
nav.nav-open .nav-menu-toggle-bar:nth-child(2) {
  opacity: 0;
}
nav.nav-open .nav-menu-toggle-bar:nth-child(3) {
  transform: translateY(-0.45rem) rotate(-45deg);
}
.nav-menu-backdrop {
  display: none;
}
html.nav-drawer-open {
  overflow: hidden;
  overscroll-behavior: none;
}
html.nav-drawer-open body {
  overflow: hidden;
}

/* ── Hero ────────────────────────────────────────────────── */
/* Content biased toward top of fold; soft colour blooms sit at z-index 0 behind text + frame (z-index 1). */
.hero {
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  padding: max(5.75rem, 10svh) 5vw max(4.5rem, 6svh);
}
.hero-inner {
  width: 100%;
  max-width: min(92rem, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.12fr);
  align-items: start;
  gap: clamp(1.75rem, 3.5vw, 3.25rem);
  position: relative;
  z-index: 1;
  flex-shrink: 0;
}
@media (min-width: 901px) {
  .hero-inner {
    padding-top: clamp(0.25rem, 2vh, 1.5rem);
  }
}
/* Warm pink bloom — top-right behind portrait */
.hero::before {
  content: '';
  position: absolute;
  z-index: 0;
  pointer-events: none;
  top: -8%;
  right: -12%;
  width: 50vw;
  height: 50vw;
  max-width: 900px;
  max-height: 900px;
  background: radial-gradient(circle closest-side, rgba(240, 122, 170, 0.22) 0%, rgba(240, 122, 170, 0.07) 42%, transparent 72%);
  filter: blur(80px);
  transform: translateZ(0);
}
/* Purple bloom — bottom-left behind copy */
.hero::after {
  content: '';
  position: absolute;
  z-index: 0;
  pointer-events: none;
  bottom: -12%;
  left: -14%;
  width: 40vw;
  height: 48vw;
  max-width: 720px;
  max-height: 640px;
  background: radial-gradient(ellipse 80% 70% at 40% 60%, rgba(168, 127, 222, 0.12) 0%, rgba(168, 127, 222, 0.05) 45%, transparent 70%);
  filter: blur(100px);
  transform: translateZ(0);
}
.hero-scroll-hint {
  position: absolute;
  bottom: max(2.65rem, calc(0.65rem + env(safe-area-inset-bottom)));
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  color: #f07aaa;
  opacity: 0.44;
  text-decoration: none;
  transition: opacity 0.2s;
}
.hero-scroll-hint:hover {
  opacity: 0.62;
}
.hero-scroll-hint:focus-visible {
  outline: 2px solid rgba(240, 122, 170, 0.55);
  outline-offset: 4px;
  opacity: 0.56;
}
.hero-scroll-hint-icon {
  display: block;
  width: 0.62rem;
  height: 0.62rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  margin-top: -0.2rem;
}
@media (prefers-reduced-motion: no-preference) {
  @keyframes hero-scroll-bob {
    0%,
    100% {
      transform: translateX(-50%) translateY(0);
    }
    50% {
      transform: translateX(-50%) translateY(7px);
    }
  }
  .hero-scroll-hint {
    animation: hero-scroll-bob 2.4s ease-in-out infinite;
  }
}

/* Mobile: flow below hero copy + stamp CTA instead of overlapping the fold (desktop unchanged). */
@media (max-width: 900px) {
  .hero-scroll-hint {
    position: static;
    transform: none;
    margin: 1.85rem auto 0;
    align-self: center;
  }
}

@media (max-width: 900px) and (prefers-reduced-motion: no-preference) {
  @keyframes hero-scroll-bob-mobile {
    0%,
    100% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(7px);
    }
  }
  .hero-scroll-hint {
    animation: hero-scroll-bob-mobile 2.4s ease-in-out infinite;
  }
}
.hero-text {
  position: relative;
  z-index: 1;
}
@media (min-width: 901px) {
  .hero-text {
    transform: translateX(-2.5%);
    max-width: 36rem;
  }
}
.hero-eyebrow {
  font-family: var(--font-jp);
  font-size: 0.8rem;
  letter-spacing: 0.25em;
  color: var(--teal);
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.hero-eyebrow::before {
  content: '';
  width: 2rem;
  height: 2px;
  border-radius: 1px;
  background: linear-gradient(90deg, var(--teal), var(--accent-yuzu));
  display: block;
}
.hero-title {
  font-family: var(--font-serif);
  font-size: clamp(2.8rem, 6vw, 5rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
  margin-bottom: 1.5rem;
  color: var(--cream);
  font-optical-sizing: auto;
}
.hero-title em {
  font-style: italic;
  color: var(--pink);
  display: block;
}
.hero-desc {
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.8;
  margin-bottom: 2.5rem;
  max-width: 42ch;
}
.hero-desc strong { color: var(--text); font-weight: 500; }
.hero-actions {
  display: flex;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
}
/* Quiet home-hero nudge toward the stamp book (secondary to gallery / commissions). */
.hero-stamp-cta {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-top: 1.35rem;
  max-width: min(100%, 26rem);
  padding: 0.65rem 0.85rem 0.7rem 0.7rem;
  border-radius: 0.85rem;
  border: 1px solid var(--border);
  background: rgba(44, 49, 57, 0.42);
  backdrop-filter: blur(10px);
  text-decoration: none;
  color: var(--muted);
  transition:
    border-color 0.2s,
    background 0.2s,
    color 0.2s;
}
.hero-stamp-cta:hover {
  border-color: var(--accent-yuzu-soft);
  background: rgba(44, 49, 57, 0.58);
  color: var(--text);
}
.hero-stamp-cta:focus-visible {
  outline: 2px solid rgba(107, 155, 160, 0.55);
  outline-offset: 3px;
}
.hero-stamp-cta-icon {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  margin-top: 0.06rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-stamp-cta-svg {
  width: 100%;
  height: 100%;
  display: block;
}
/* Perforated “postage” silhouette + check — reads as collectible, not abstract UI chrome. */
.hero-stamp-cta-svg-stamp {
  fill: rgba(158, 184, 188, 0.1);
  stroke: var(--teal);
  stroke-width: 1.1;
  stroke-opacity: 0.5;
  stroke-linejoin: round;
  transition: stroke-opacity 0.2s, fill 0.2s;
}
.hero-stamp-cta-svg-check {
  stroke: var(--teal);
  stroke-width: 1.65;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-opacity: 0.62;
  transition: stroke-opacity 0.2s;
}
.hero-stamp-cta:hover .hero-stamp-cta-svg-stamp {
  stroke-opacity: 0.78;
  fill: rgba(158, 184, 188, 0.14);
}
.hero-stamp-cta:hover .hero-stamp-cta-svg-check {
  stroke-opacity: 0.88;
}
.hero-stamp-cta-copy {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}
.hero-stamp-cta-label {
  font-family: var(--font-jp);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--teal);
}
.hero-stamp-cta:hover .hero-stamp-cta-label {
  color: var(--accent-yuzu);
}
.hero-stamp-cta-line {
  font-size: 0.8rem;
  line-height: 1.5;
  letter-spacing: 0.02em;
}
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--pink);
  color: var(--bg);
  padding: 0.9rem 2rem;
  border-radius: 999px;
  font-weight: 500;
  font-size: 0.9rem;
  letter-spacing: 0.03em;
  transition: transform 0.2s, box-shadow 0.2s;
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 8px 28px rgba(233, 77, 142, 0.36),
    0 0 0 1px var(--accent-warm-soft);
}
.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--muted);
  font-size: 0.9rem;
  letter-spacing: 0.03em;
  transition: color 0.2s;
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
}
.btn-secondary:hover {
  color: var(--text);
  border-color: var(--text);
}
.hero-socials {
  margin-top: 3rem;
  display: flex;
  gap: 1.5rem;
  align-items: center;
}
.hero-socials span {
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}
.social-link {
  color: var(--muted);
  font-size: 0.85rem;
  letter-spacing: 0.06em;
  transition: color 0.2s;
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.social-link:hover { color: var(--pink); }

.hero-image {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
}
@media (min-width: 901px) {
  .hero-image {
    justify-content: flex-end;
    align-items: flex-start;
  }
}
.hero-frame {
  position: relative;
  width: 100%;
  max-width: 31.25rem;
  min-width: min(100%, 25rem);
  aspect-ratio: 4 / 5;
  border-radius: 2rem;
}
@media (min-width: 901px) {
  .hero-frame {
    transform: rotate(-1.25deg) translateX(2%);
    max-width: min(31.25rem, 100%);
    min-height: clamp(25rem, 52vh, 34rem);
  }
}
.hero-frame::before {
  content: '';
  position: absolute;
  inset: -2px;
  background: linear-gradient(135deg, var(--accent-yuzu), var(--pink) 40%, var(--purple) 78%, var(--teal));
  border-radius: 2rem;
  z-index: 0;
  opacity: 0.55;
  pointer-events: none;
}
.hero-frame-crop {
  position: absolute;
  inset: 0;
  border-radius: 2rem;
  overflow: hidden;
  z-index: 1;
}
.hero-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  filter: saturate(1.1);
}
.hero-badge {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  z-index: 2;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent-yuzu);
  border-radius: 1rem;
  padding: 0.85rem 1.25rem;
  font-size: 0.8rem;
  color: var(--muted);
  backdrop-filter: blur(12px);
}
@media (min-width: 901px) {
  .hero-badge {
    transform: rotate(0.5deg);
    bottom: 1.15rem;
    left: 1.15rem;
  }
}
.hero-badge strong {
  display: block;
  color: var(--text);
  font-size: 1.1rem;
  font-family: var(--font-serif);
  font-weight: 600;
}

/* ── Section shared ──────────────────────────────────────── */
section { padding: 6rem 5vw; }
.section-label {
  font-family: var(--font-jp);
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: var(--teal);
  text-transform: uppercase;
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.section-label::before {
  content: '';
  width: 1.5rem;
  height: 2px;
  border-radius: 1px;
  background: linear-gradient(90deg, var(--teal), var(--accent-yuzu));
}
.section-title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--cream);
  margin-bottom: 1rem;
  font-optical-sizing: auto;
}
.section-title em { font-style: italic; color: var(--pink); }
/* Japanese line under / beside English headlines — rewrite copy freely */
.section-title-jp,
.hero-title-jp {
  font-family: var(--font-jp);
  font-weight: 400;
  font-size: clamp(0.95rem, 2.2vw, 1.15rem);
  letter-spacing: 0.12em;
  color: var(--accent-yuzu);
  margin: 0 0 0.75rem;
  line-height: 1.5;
}
.hero-title-jp {
  margin-top: -0.35rem;
  margin-bottom: 1rem;
  opacity: 0.92;
}
.section-title + .section-title-jp {
  margin-top: -0.5rem;
}
.section-label--center {
  justify-content: center;
}

/* ── Featured Gallery ────────────────────────────────────── */
.gallery-section { background: var(--bg2); }
.gallery-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 3rem;
  gap: 2rem;
  flex-wrap: wrap;
  width: 100%;
  max-width: min(70rem, 100%);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}
@media (min-width: 901px) {
  .gallery-header > div:first-child {
    transform: translateX(-1.25rem) rotate(-0.35deg);
    transform-origin: left bottom;
  }
}
/* Homepage featured editorial with explicit areas so the left column is always 2× height of one cell */
/* Full gallery page uses .gallery-full (separate rules below) */
.featured-editorial {
  display: grid;
  gap: 1.1rem;
  width: 100%;
  max-width: min(70rem, 100%);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
  /* Wider hero column (~44% vs ~28% each for the right four) */
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr) minmax(0, 1fr);
  grid-template-rows: minmax(200px, 1fr) minmax(200px, 1fr);
  grid-template-areas:
    "hero c2 c3"
    "hero c4 c5";
  align-items: stretch;
  min-height: min(420px, 52vh);
}
.featured-editorial > :nth-child(1) { grid-area: hero; }
.featured-editorial > :nth-child(2) { grid-area: c2; }
.featured-editorial > :nth-child(3) { grid-area: c3; }
.featured-editorial > :nth-child(4) { grid-area: c4; }
.featured-editorial > :nth-child(5) { grid-area: c5; }
.featured-editorial .featured-tile {
  aspect-ratio: unset;
  min-height: 0;
  height: 100%;
  align-self: stretch;
}
.gallery-item {
  position: relative;
  border-radius: 1rem;
  overflow: hidden;
  aspect-ratio: 3/4;
  background: var(--surface);
}
.gallery-tile-trigger {
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  margin: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: left;
}
.gallery-tile-trigger:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}
.gallery-item::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(to top, rgba(14,11,20,0.8) 0%, transparent 50%);
  opacity: 0;
  transition: opacity 0.3s;
}
.gallery-item:hover::after { opacity: 1; }
.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--ease-out);
  -webkit-user-drag: none;
  user-select: none;
}
.gallery-item:hover img { transform: scale(1.05); }
.gallery-item-label {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  z-index: 1;
  pointer-events: none;
  font-size: 0.8rem;
  color: var(--cream);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.3s, transform 0.3s;
}
.gallery-item:hover .gallery-item-label,
.gallery-item:focus-within .gallery-item-label {
  opacity: 1;
  transform: translateY(0);
}
.view-all {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--accent-yuzu);
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--accent-yuzu-soft);
  padding-bottom: 2px;
  transition: color 0.2s, border-color 0.2s;
  white-space: nowrap;
}
.view-all:hover {
  color: var(--cream);
  border-color: rgba(232, 179, 57, 0.65);
}

/* ── About strip ─────────────────────────────────────────── */
/* Match homepage “wide inner” rhythm with gallery-style bands (~70rem + 5vw section padding) */
.about-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.5rem, 5vw, 4.5rem);
  align-items: center;
  width: 100%;
  max-width: min(70rem, 100%);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.home-about-band .about-eyebrow {
  margin-top: 1.2rem;
}

/* Eyebrow is first in DOM: desktop sits above copy in column 2; mobile stacks before art (see 18-responsive). */
@media (min-width: 901px) {
  .about-eyebrow {
    grid-column: 2;
    grid-row: 1;
    align-self: end;
    margin-bottom: 0;
    transform: translateX(2%);
  }
  .about-image {
    grid-column: 1;
    grid-row: 1 / span 2;
    transform: translateY(0.75rem) translateX(-2%);
    justify-self: end;
    margin-inline: 0;
  }
  .about-text {
    grid-column: 2;
    grid-row: 2;
    align-self: start;
    transform: translateX(2%);
  }
}
.about-image {
  position: relative;
  /* Between full column width and the previous tight cap — scales with viewport */
  width: 100%;
  max-width: min(100%, clamp(22rem, 46vw, 32rem));
  margin-inline: auto;
}
.about-image img {
  border-radius: 1.5rem;
  width: 100%;
}
.about-image::after {
  content: 'お茶';
  font-family: var(--font-jp);
  font-size: 8rem;
  color: rgba(232, 179, 57, 0.07);
  position: absolute;
  bottom: -2rem;
  right: -2rem;
  line-height: 1;
  pointer-events: none;
  user-select: none;
}
.about-text .section-title { margin-bottom: 1.5rem; }
.about-text p {
  color: var(--muted);
  margin-bottom: 1.25rem;
  font-size: 1rem;
  line-height: 1.85;
}
.about-text p strong { color: var(--text); font-weight: 500; }
.about-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 2rem;
}
.tag {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 0.35rem 1rem;
  font-size: 0.8rem;
  color: var(--muted);
  letter-spacing: 0.04em;
}
.tag.highlight {
  border-color: rgba(232, 179, 57, 0.45);
  color: var(--cream);
  box-shadow: inset 0 0 0 1px rgba(233, 77, 142, 0.16);
}

/* Homepage only: mobile band + eyebrow before art so “About” reads as a new section, not more gallery tiles. */
@media (max-width: 900px) {
  .home-about-band {
    padding-top: 2.5rem;
    padding-bottom: 6rem;
    padding-left: max(1rem, 5vw, env(safe-area-inset-left, 0px));
    padding-right: max(1rem, 5vw, env(safe-area-inset-right, 0px));
    border-top: 1px solid var(--ocha-rim-soft);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
    background: linear-gradient(180deg, rgba(22, 25, 30, 0.82) 0%, rgba(22, 25, 30, 0.28) 36%, transparent 58%);
  }

  .about-eyebrow {
    justify-content: center;
    width: 100%;
    margin-bottom: 1.15rem;
    transform: none;
  }

  .about-image {
    grid-column: 1;
    grid-row: auto;
    transform: none;
  }

  .about-text {
    grid-column: 1;
    grid-row: auto;
    transform: none;
  }
}

/* ── Commission CTA ──────────────────────────────────────── */
.commission-cta {
  background: var(--bg3);
  border-radius: 2rem;
  padding: 4rem;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 3rem;
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent-yuzu);
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
  width: min(70rem, calc(100% - 10vw));
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 6rem;
}
@media (min-width: 901px) {
  .commission-cta > div:first-child {
    transform: translateX(-2%) rotate(-0.25deg);
    transform-origin: left center;
  }
  .commission-actions {
    transform: translateX(4%);
  }
}
.commission-cta::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -10%;
  width: 40%;
  height: 200%;
  background: radial-gradient(ellipse, rgba(233,77,142,0.09) 0%, transparent 70%);
  pointer-events: none;
}
.commission-status {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(109,207,207,0.1);
  border: 1px solid rgba(109,207,207,0.2);
  border-radius: 999px;
  padding: 0.3rem 0.85rem;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  color: var(--teal);
  margin-bottom: 1rem;
}
.commission-status .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--teal);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}
.commission-cta h2 {
  font-family: var(--font-serif);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--cream);
  margin-bottom: 0.75rem;
}
.commission-cta p { color: var(--muted); max-width: 50ch; line-height: 1.8; }
.commission-actions { display: flex; flex-direction: column; gap: 0.75rem; align-items: flex-end; }

/* ── Newsletter ──────────────────────────────────────────── */
.newsletter-section {
  padding: 4rem 5vw;
  background: var(--bg2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.newsletter-inner {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
}
.newsletter-inner .section-title {
  margin-bottom: 0.5rem;
}
.newsletter-inner .section-title-jp {
  margin: -0.25rem auto 0.75rem;
}
.newsletter-inner > p {
  color: var(--muted);
  font-size: 0.95rem;
  margin-bottom: 1.75rem;
  line-height: 1.75;
}
.newsletter-form {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
  align-items: stretch;
}
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.newsletter-form input[type="email"] {
  flex: 1 1 220px;
  max-width: 320px;
  padding: 0.85rem 1.25rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 0.95rem;
}
.newsletter-form input[type="email"]::placeholder {
  color: var(--muted);
  opacity: 0.8;
}
.newsletter-form .hp-field {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
}
.newsletter-form-note {
  margin-top: 1rem;
  font-size: 0.8rem;
  color: var(--muted);
  line-height: 1.5;
}
.newsletter-form-note[hidden] {
  display: none !important;
}
.newsletter-form-note code {
  font-family: ui-monospace, monospace;
  font-size: 0.88em;
  background: var(--surface);
  padding: 0.15em 0.45em;
  border-radius: 4px;
  border: 1px solid var(--border);
}

/* ── Lightbox ──────────────────────────────────────────────── */
body.lightbox-open {
  overflow: hidden;
}
/* Added with lightbox-open on narrow viewports only (see gallery.js); avoids MQ/CSS mismatch on rotate. */
body.lightbox-open--scroll-lock {
  position: fixed;
  width: 100%;
  left: 0;
  right: 0;
  overscroll-behavior: none;
  touch-action: none;
}
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 10050;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: min(1.5rem, 3vw);
}
.lightbox[hidden] {
  display: none !important;
}
.lightbox-backdrop {
  position: absolute;
  inset: 0;
  cursor: pointer;
  background: rgba(14, 11, 20, 0.92);
  backdrop-filter: blur(6px);
}
.lightbox-panel {
  position: relative;
  z-index: 1;
  width: min(98vw, 1920px);
  max-height: 96vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}
.lightbox-stage {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  width: 100%;
  max-width: min(98vw, 1920px);
  box-sizing: border-box;
  touch-action: manipulation;
}
/* Clicks on letterboxing beside the image close the lightbox; only the bitmap catches events */
.lightbox-img-wrap {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: calc(100% - 4.75rem);
  pointer-events: none;
}
.lightbox-zoom-outer {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  max-height: min(88vh, 1600px);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  touch-action: none;
  pointer-events: auto;
}
.lightbox-zoom-inner {
  transform-origin: center center;
  will-change: transform;
}
.lightbox-zoom-inner.is-panning {
  cursor: grab;
}
.lightbox-zoom-inner.is-panning:active {
  cursor: grabbing;
}
.lightbox-nav {
  flex-shrink: 0;
  width: 2.5rem;
  height: 3.5rem;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 0.5rem;
  background: rgba(36, 32, 48, 0.95);
  color: var(--cream);
  font-size: 1.65rem;
  line-height: 1;
  font-weight: 300;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, color 0.2s, opacity 0.2s;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
}
.lightbox-nav:hover:not(:disabled) {
  background: rgba(255, 107, 157, 0.35);
  color: var(--cream);
}
.lightbox-nav:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}
.lightbox-nav:disabled {
  opacity: 0.38;
  cursor: not-allowed;
}
.lightbox-nav[hidden] {
  display: none !important;
}
.lightbox-img {
  display: block;
  max-width: 100%;
  max-height: min(88vh, 1600px);
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 0.75rem;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45);
  pointer-events: auto;
  touch-action: none;
  user-select: none;
  -webkit-user-drag: none;
}
@media (max-width: 520px) {
  .lightbox-nav {
    width: 2rem;
    height: 3rem;
    font-size: 1.35rem;
  }
}

@media (max-width: 700px) {
  body.lightbox-open {
    overscroll-behavior: none;
  }
  .lightbox {
    padding: 0;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    /* inset + % height avoids 100dvh extending past the visible viewport (top crop on iOS). */
    inset: 0;
    width: 100%;
    max-width: 100%;
    height: 100%;
    max-height: none;
    min-height: 0;
    box-sizing: border-box;
    padding-top: env(safe-area-inset-top, 0px);
    padding-bottom: env(safe-area-inset-bottom, 0px);
    padding-left: env(safe-area-inset-left, 0px);
    padding-right: env(safe-area-inset-right, 0px);
  }
  .lightbox-backdrop {
    background: rgba(14, 11, 20, 0.98);
  }
  .lightbox-panel {
    width: 100%;
    max-width: none;
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    height: 100%;
    gap: 0.35rem;
    /* Top row for close; safe-area is on .lightbox outer only. */
    padding: 2.65rem 0.35rem 0.5rem;
    border-radius: 0;
    box-sizing: border-box;
  }
  .lightbox-stage {
    flex: 1 1 auto;
    min-height: 0;
    max-width: 100%;
    gap: 0;
  }
  .lightbox-nav:not([hidden]) {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
    opacity: 0;
    pointer-events: none;
  }
  .lightbox-img-wrap {
    max-width: 100%;
    flex: 1 1 auto;
    min-height: 0;
  }
  .lightbox-zoom-outer {
    max-height: none;
    max-width: 100%;
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
  }
  .lightbox-img {
    max-height: 100%;
    max-width: 100%;
    width: auto;
    height: auto;
    border-radius: 0.35rem;
  }
  .lightbox-meta {
    max-width: none;
    flex-shrink: 0;
    padding: 0 0.35rem;
    max-height: 24vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .lightbox-title {
    font-size: 1rem;
    margin-bottom: 0.15rem;
    line-height: 1.25;
  }
  .lightbox-caption {
    font-size: 0.82rem;
    line-height: 1.45;
  }
  .lightbox-close {
    top: 0.35rem;
    right: 0.35rem;
  }
}
.lightbox-meta {
  text-align: center;
  max-width: 50ch;
}
.lightbox-title {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--cream);
  margin-bottom: 0.35rem;
}
.lightbox-caption {
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.6;
}
.lightbox-caption[hidden] {
  display: none !important;
}
.lightbox-link {
  display: inline-flex;
  margin-top: 0.75rem;
}
.lightbox-close {
  position: absolute;
  top: -0.25rem;
  right: -0.25rem;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, color 0.2s;
  z-index: 5;
}
.lightbox-close:hover {
  background: var(--pink);
  color: var(--bg);
  border-color: var(--pink);
}

/* ── Footer ──────────────────────────────────────────────── */
footer {
  border-top: 1px solid var(--border);
  padding: 3rem 5vw;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 2rem;
}
.footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
  justify-content: flex-end;
  align-items: center;
  margin-bottom: 0.75rem;
}
.footer-socials .social-link {
  font-size: 0.8rem;
}
.footer-logo {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--pink);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2rem;
}
.footer-logo-jp {
  font-family: var(--font-jp);
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.28em;
  color: var(--accent-yuzu);
  opacity: 0.88;
}
.footer-links {
  display: flex;
  gap: 2rem;
  list-style: none;
}
.footer-links a {
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  transition: color 0.2s;
}
.footer-links a:hover { color: var(--text); }
.footer-right {
  text-align: right;
  font-size: 0.75rem;
  color: var(--muted);
  line-height: 1.6;
}

/* ── Gallery Page ────────────────────────────────────────── */
.gallery-page-hero,
.comics-page-hero {
  padding: var(--ocha-inner-page-pad-top) 5vw 4rem;
  text-align: center;
}
.gallery-page-hero .section-title-jp {
  text-align: center;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
}
.comics-page-hero {
  max-width: min(100%, 1920px);
  margin: 0 auto;
  box-sizing: border-box;
}
.gallery-page-hero .section-label,
.comics-page-hero .section-label {
  justify-content: center;
}
.gallery-hero-intro {
  color: var(--muted);
  max-width: 58ch;
  margin: 0 auto;
  font-size: 1rem;
  line-height: 1.75;
}
.gallery-filters {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  flex-wrap: wrap;
  margin: 2.5rem 0;
}
.filter-btn {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 0.5rem 1.25rem;
  font-family: var(--font-sans);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  color: var(--muted);
  cursor: pointer;
  transition: all 0.2s;
}
.filter-btn:hover { color: var(--text); border-color: rgba(255,255,255,0.15); }
.filter-btn.active {
  background: var(--pink);
  border-color: var(--accent-yuzu);
  color: var(--bg);
  box-shadow: 0 0 0 1px var(--accent-yuzu-soft);
}

.gallery-filters--characters {
  flex-direction: column;
  align-items: center;
  gap: 0.65rem;
  margin-top: 0.25rem;
  margin-bottom: 2.25rem;
}

.gallery-filters-subhead {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 0.68rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
}

.gallery-filters-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}

/*
 * .gallery-filters sets display:flex — that beats the default [hidden] display:none in the cascade,
 * so JS toggling hidden was ineffective and OC chips stayed visible. Match .gallery-group[hidden].
 */
#gallery-character-filters[hidden] {
  display: none !important;
}

/* Full gallery page: outer band + grouped sub-grids (world buckets from gallery.js) */
.gallery-full {
  display: flex;
  flex-direction: column;
  gap: 2.25rem;
  padding: 0 5vw 6rem;
  margin-inline: auto;
  box-sizing: border-box;
  max-width: min(100%, 1920px);
}
.gallery-items-root {
  display: flex;
  flex-direction: column;
  gap: 2.25rem;
}
.gallery-group[hidden] {
  display: none !important;
}
.gallery-group-heading {
  font-family: var(--font-jp);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--teal);
  margin: 0 0 0.85rem;
  font-weight: 500;
}
.gallery-group-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.gallery-full .gallery-item,
.gallery-full .gallery-tile {
  min-width: 0;
  scroll-margin-block: 1.5rem;
}
@media (min-width: 700px) {
  .gallery-group-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (min-width: 960px) {
  .gallery-group-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (min-width: 1280px) {
  .gallery-group-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}
.gallery-full > .gallery-empty {
  width: 100%;
  align-self: stretch;
}
.gallery-empty {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--muted);
  font-size: 0.95rem;
}
.gallery-empty[hidden] {
  display: none !important;
}

/* ── Comics reader page ──────────────────────────────────── */
body.comics-reader-open {
  overflow: hidden;
}
/* main has z-index:1 from body > *; nav is z-index:100, so fixed #comics-reader was trapped below the nav gradient */
body.comics-reader-open > main {
  z-index: 150;
}
body.comics-reader-open > footer {
  display: none !important;
}
/* Hide site nav for the whole session — fixed bar (and mobile drawer z-index:10000) can stack above #comics-reader topbar otherwise. */
body.comics-reader-open nav {
  visibility: hidden !important;
  pointer-events: none !important;
}
/* Like gallery: hero supplies horizontal/top padding, so avoid stacking with section { padding: 6rem } */
.comics-landing-section {
  padding: 0;
}
.comics-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1.25rem;
  padding: 0 5vw 6rem;
  max-width: min(100%, 1920px);
  margin: 0 auto;
  box-sizing: border-box;
}
/* Shelf-like landing list (DESIGN-CONCEPTS §7) */
.comics-list--shelf {
  position: relative;
  gap: 1.5rem;
  padding-bottom: 6.5rem;
}
.comics-card--shelf {
  position: relative;
  transform: rotate(-0.35deg);
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s;
}
.comics-list--shelf .comics-card--shelf:nth-child(even) {
  transform: rotate(0.45deg);
}
@media (hover: hover) and (pointer: fine) {
  .comics-card--shelf:hover {
    transform: rotate(0deg) translateY(-3px);
    z-index: 1;
  }
}
@media (prefers-reduced-motion: reduce) {
  .comics-card--shelf,
  .comics-list--shelf .comics-card--shelf:nth-child(even) {
    transform: none;
    transition: none;
  }
  .comics-card--shelf:hover {
    transform: none;
  }
}
.comics-card--shelf::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 5px;
  border-radius: 0.35rem 0 0 0.35rem;
  background: linear-gradient(
    180deg,
    rgba(107, 155, 160, 0.35),
    rgba(233, 77, 142, 0.22) 55%,
    rgba(253, 242, 167, 0.12)
  );
  pointer-events: none;
  opacity: 0.9;
}
.comics-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 1rem;
  overflow: hidden;
  text-align: left;
}
.comics-card.comics-card--shelf {
  border-radius: 0.35rem 1rem 1rem 0.35rem;
}
.comics-card-trigger {
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  border: 0;
  background: var(--bg2);
  cursor: pointer;
  font: inherit;
}
.comics-card-trigger img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  display: block;
}
.comics-card-body {
  padding: 1.1rem 1.25rem 1.35rem;
}
.comics-card-title {
  font-family: var(--font-serif);
  font-size: 1.2rem;
  color: var(--cream);
  margin: 0 0 0.35rem;
}
.comics-card-desc {
  font-size: 0.88rem;
  color: var(--muted);
  line-height: 1.55;
  margin: 0 0 0.5rem;
}
.comics-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin: 0 0 0.65rem;
}
.comics-card-tags[hidden] {
  display: none !important;
}
.comics-card-tag {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 0.2rem 0.65rem;
  font-size: 0.72rem;
  color: var(--muted);
  letter-spacing: 0.04em;
}
.comics-card-meta {
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  opacity: 0.85;
}
.comics-page-hero .section-title-jp {
  text-align: center;
  max-width: 32rem;
  margin-left: auto;
  margin-right: auto;
}
.comics-page-lead {
  color: var(--muted);
  max-width: 52ch;
  margin: 0 auto 1rem;
  font-size: 1rem;
  line-height: 1.65;
  text-align: center;
}
.comics-page-tips {
  color: var(--muted);
  max-width: 58ch;
  margin: 0 auto 2.25rem;
  font-size: 0.88rem;
  line-height: 1.55;
  text-align: center;
  opacity: 0.92;
}
.comics-page-tips code {
  font-size: 0.85em;
}
.comics-lead-mobile,
.comics-page-tips--mobile {
  display: none;
}
.comics-card-continue {
  display: inline-block;
  margin-top: 0.5rem;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--pink);
}
.comics-chrome-extras {
  display: contents;
}
.comics-chrome-overflow-actions {
  display: none;
}
.comics-chrome-overflow-toggle {
  width: 100%;
  max-width: 12rem;
  margin: 0.35rem auto 0;
  padding: 0.5rem 1rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.8rem;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.comics-chrome-overflow-toggle:hover {
  color: var(--text);
  border-color: rgba(255, 255, 255, 0.15);
}
.comics-chrome-overflow-toggle:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}
.comics-reader-back--chrome {
  display: none;
  min-height: 2.75rem;
  min-width: 2.75rem;
  padding: 0.35rem 0.65rem;
  margin-right: auto;
  align-self: center;
}
.comics-reader--vertical .comics-reader-back--chrome {
  display: none !important;
}
.comics-reader {
  position: fixed;
  inset: 0;
  z-index: 10040;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  padding: 0;
}
/* --comics-topbar-h, --comics-chrome-h, --comics-vpage-h (px) set by comics.js for vertical padding + page band height. */
/* [hidden] alone is overridden by display:flex above, using the same pattern as .lightbox[hidden] */
.comics-reader[hidden] {
  display: none !important;
}
.comics-reader-topbar,
.comics-reader-chrome {
  transition: transform 0.35s ease, opacity 0.35s ease;
}
@media (prefers-reduced-motion: reduce) {
  .comics-reader-topbar,
  .comics-reader-chrome {
    transition-duration: 0.01ms;
  }
}
.comics-reader--vertical.comics-reader--chrome-hidden .comics-reader-topbar {
  transform: translateY(-120%);
  opacity: 0;
  pointer-events: none;
}
.comics-reader--vertical.comics-reader--chrome-hidden .comics-reader-chrome {
  transform: translateY(120%);
  opacity: 0;
  pointer-events: none;
}
@media (max-width: 700px) {
  .comics-reader:not(.comics-reader--vertical).comics-reader--chrome-hidden .comics-reader-chrome {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    transform: translateY(120%);
    opacity: 0;
    pointer-events: none;
  }
}
/* Horizontal reader: bars in normal flow so the stage only occupies space between them (no overlap). */
.comics-reader:not(.comics-reader--vertical) .comics-reader-topbar {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  flex-shrink: 0;
}
.comics-reader:not(.comics-reader--vertical) .comics-reader-chrome {
  position: relative;
  bottom: auto;
  left: auto;
  right: auto;
  flex-shrink: 0;
}
.comics-reader:not(.comics-reader--vertical) .comics-reader-stage:not(.comics-reader-stage--vertical) {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.comics-reader-topbar {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 4;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 0.75rem 1rem;
  padding: max(0.75rem, env(safe-area-inset-top)) max(1rem, 5vw) 0.75rem;
  padding-left: max(1rem, 5vw, env(safe-area-inset-left));
  padding-right: max(1rem, 5vw, env(safe-area-inset-right));
  border-bottom: 1px solid var(--border);
  background: rgba(14, 11, 20, 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.comics-reader-back {
  justify-self: start;
  background: transparent;
  border: 0;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.9rem;
  cursor: pointer;
  padding: 0.35rem 0.5rem;
  border-radius: 0.35rem;
}
.comics-reader-back:hover {
  color: var(--text);
}
.comics-reader-title {
  justify-self: center;
  max-width: min(70vw, 36rem);
  font-family: var(--font-serif);
  font-size: 1.05rem;
  color: var(--cream);
  margin: 0;
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.comics-reader-topbar-spacer {
  justify-self: end;
  min-width: 0;
}
.comics-reader-body {
  flex: 1 1 0;
  min-height: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 0;
  box-sizing: border-box;
}
.comics-reader-chrome {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 4;
  border-top: 1px solid var(--border);
  background: rgba(12, 10, 18, 0.94);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 0.55rem max(1rem, 5vw) max(0.65rem, env(safe-area-inset-bottom));
  padding-left: max(1rem, 5vw, env(safe-area-inset-left));
  padding-right: max(1rem, 5vw, env(safe-area-inset-right));
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.35rem;
}
.comics-reader-chrome-nav-group {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.35rem;
  width: 100%;
}
/* One row under the scrubber: view modes | divider | zoom */
.comics-reader-chrome-view-zoom {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5rem 0.85rem;
  width: 100%;
}
.comics-reader-chrome-view-zoom .comics-reader-chrome-row--modes {
  flex: 0 1 auto;
  margin: 0;
  padding: 0;
  border: 0;
}
.comics-reader-chrome-divider--view-zoom {
  display: none;
  width: 1px;
  flex-shrink: 0;
  align-self: stretch;
  min-height: 2.5rem;
  margin: 0;
  background: rgba(255, 255, 255, 0.12);
}
@media (min-width: 701px) {
  .comics-reader-chrome-divider--view-zoom {
    display: block;
  }
}
.comics-reader-chrome-view-zoom .comics-reader-chrome-row--zoom {
  flex: 0 1 auto;
  margin: 0;
  padding: 0;
  border: 0;
}
.comics-reader-chrome-view-zoom .comics-zoom-hint {
  flex: 1 1 100%;
  width: 100%;
  margin-top: 0.1rem;
  order: 4;
}
.comics-reader--vertical .comics-reader-chrome-divider--view-zoom {
  display: none !important;
}
.comics-reader-chrome-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.45rem 0.65rem;
}
.comics-reader-chrome-row--pager {
  padding-bottom: 0.5rem;
  margin-bottom: 0.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.comics-reader-chrome-nav-group .comics-reader-chrome-row--pager {
  margin-bottom: 0;
}
.comics-reader-chrome-row--modes {
  gap: 0.5rem;
}
.comics-reader-chrome-row--scrubber {
  width: 100%;
  max-width: min(36rem, 100%);
  min-width: 0;
  margin: 0 auto;
  padding-bottom: 0.45rem;
  margin-bottom: 0.35rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.comics-scrubber {
  width: 100%;
  height: 0.45rem;
  cursor: pointer;
  accent-color: var(--pink);
}
.comics-scrubber:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}
.comics-reader-chrome-row--zoom {
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
.comics-reader--vertical .comics-reader-chrome-row--zoom {
  display: none;
}
.comics-zoom-hint {
  font-size: 0.72rem;
  color: var(--muted);
  width: 100%;
  text-align: center;
  margin-top: 0.15rem;
}
@media (max-width: 600px) {
  .comics-zoom-hint {
    display: none;
  }
}
.comics-reader-zoom-outer {
  overflow: hidden;
  width: 100%;
  height: 100%;
  min-height: 0;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  touch-action: none;
}
.comics-reader-zoom-inner {
  transform-origin: center center;
  will-change: transform;
}
/* Bound horizontal page images to the stage (flex chain + % max-height). */
.comics-reader:not(.comics-reader--vertical) .comics-reader-zoom-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  min-width: 0;
  min-height: 0;
  box-sizing: border-box;
}
.comics-reader:not(.comics-reader--vertical) .comics-reader-spread {
  min-height: 0;
  min-width: 0;
}
.comics-reader-zoom-outer.is-pannable {
  cursor: grab;
}
.comics-reader-zoom-outer.is-pannable:active {
  cursor: grabbing;
}
.comics-page-indicator {
  font-size: 0.88rem;
  color: var(--muted);
  min-width: 10rem;
  text-align: center;
}
.comics-jump-group {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.comics-jump-input {
  width: 3.25rem;
  padding: 0.35rem 0.4rem;
  border-radius: 0.35rem;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 0.85rem;
  text-align: center;
  -moz-appearance: textfield;
}
.comics-jump-input::-webkit-outer-spin-button,
.comics-jump-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.comics-jump-go {
  padding: 0.35rem 0.75rem;
  font-size: 0.8rem;
}
/* Match gallery filter-btn / surface language */
.comics-reader-skip,
.comics-reader-nav {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.comics-reader-nav {
  font-size: 1.35rem;
  font-weight: 400;
}
.comics-reader-skip:hover:not(:disabled),
.comics-reader-nav:hover:not(:disabled) {
  color: var(--text);
  border-color: rgba(255, 255, 255, 0.15);
  background: var(--bg3);
}
.comics-reader-skip:focus-visible,
.comics-reader-nav:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}
.comics-reader-skip:disabled,
.comics-reader-nav:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.comics-reader-chrome button.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 2.5rem;
  padding: 0.45rem 1.1rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: none;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.comics-reader-chrome button.btn-secondary:hover:not(:disabled) {
  color: var(--text);
  border-color: rgba(255, 255, 255, 0.15);
}
.comics-reader-chrome button.btn-secondary[aria-pressed='true'] {
  background: var(--pink);
  border-color: var(--pink);
  color: var(--bg);
}
.comics-reader-chrome button.btn-secondary:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}
.comics-reader-stage {
  position: absolute;
  inset: 0;
  min-width: 0;
  min-height: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  touch-action: pan-y;
  box-sizing: border-box;
}
.comics-reader:not(.comics-reader--vertical) .comics-reader-stage {
  cursor: pointer;
}
@media (min-width: 701px) {
  .comics-reader-chrome-nav-group .comics-reader-chrome-row--pager,
  .comics-reader-chrome-nav-group .comics-reader-chrome-row--scrubber {
    width: 100%;
    max-width: 42rem;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
    margin-bottom: 0;
  }
  .comics-reader-chrome-nav-group .comics-reader-chrome-row--pager {
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    padding-bottom: 0.35rem;
    margin-bottom: 0;
  }
  .comics-reader-chrome-nav-group .comics-reader-chrome-row--scrubber {
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: 0;
  }
}
.comics-reader-spread {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  box-sizing: border-box;
}
/* Manga-style spread: right page first in reading order */
.comics-reader--rtl .comics-reader-spread {
  flex-direction: row-reverse;
}
.comics-reader-page-img {
  max-width: calc(50% - 0.35rem);
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 0.5rem;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.35);
}
.comics-reader-page-img--single {
  max-width: 100%;
  max-height: 100%;
}
.comics-reader:not(.comics-reader--vertical) .comics-reader-page-img {
  max-height: 100%;
}
.comics-reader:not(.comics-reader--vertical) .comics-reader-page-img--single {
  max-height: 100%;
}
.comics-reader-stage--dual .comics-reader-page-img {
  max-width: calc(50% - 0.35rem);
}
.comics-reader--vertical #comics-reader-layout {
  display: none !important;
}
.comics-reader--vertical .comics-reader-chrome-row--pager .comics-reader-nav {
  display: none !important;
}
.comics-reader-stage--vertical {
  position: absolute;
  inset: 0;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding-top: max(0.25rem, var(--comics-topbar-h, 4rem));
  padding-bottom: max(0.35rem, var(--comics-chrome-h, 11rem));
  padding-left: max(0.75rem, env(safe-area-inset-left));
  padding-right: max(0.75rem, env(safe-area-inset-right));
  gap: 0;
  max-width: 100%;
  margin: 0 auto;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  touch-action: pan-y;
}
.comics-reader-vertical-slot {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
}
.comics-reader-vertical-img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 0.5rem;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}
@media (min-width: 701px) {
  .comics-reader--vertical .comics-reader-vertical-slot {
    height: var(--comics-vpage-h, 80vh);
    min-height: var(--comics-vpage-h, 80vh);
    max-height: var(--comics-vpage-h, 80vh);
  }
  .comics-reader--vertical .comics-reader-vertical-slot .comics-reader-vertical-img {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
  }
}
@media (max-width: 700px) {
  /* Inset stage with safe areas so art clears the notch; body padding keeps flex layout honest. */
  .comics-reader:not(.comics-reader--vertical) .comics-reader-body {
    padding-top: env(safe-area-inset-top, 0px);
    padding-left: env(safe-area-inset-left, 0px);
    padding-right: env(safe-area-inset-right, 0px);
    box-sizing: border-box;
  }
  .comics-reader:not(.comics-reader--vertical) .comics-reader-stage:not(.comics-reader-stage--vertical) {
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
  }
  .comics-reader-chrome-nav-group {
    order: 1;
  }
  .comics-chrome-overflow-actions {
    order: 2;
  }
  .comics-chrome-extras.comics-reader-chrome-view-zoom {
    order: 3;
  }
  .comics-reader-chrome-divider--view-zoom {
    display: none !important;
  }
  /* Block flow avoids WebKit flex overlap where vertical pages stack unreadably */
  .comics-reader--vertical .comics-reader-stage--vertical {
    display: block;
  }
  .comics-reader--vertical .comics-reader-vertical-slot {
    display: block;
    height: auto;
    min-height: 0;
    max-height: none;
    width: 100%;
    margin: 0 0 0.5rem;
  }
  .comics-reader--vertical .comics-reader-vertical-slot:last-child {
    margin-bottom: 0;
  }
  .comics-reader--vertical .comics-reader-vertical-img {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    object-fit: contain;
  }
  .comics-lead-desktop {
    display: none;
  }
  .comics-lead-mobile {
    display: inline;
  }
  .comics-page-tips--desktop {
    display: none;
  }
  .comics-page-tips--mobile {
    display: block;
  }
  .comics-reader:not(.comics-reader--vertical) .comics-reader-topbar {
    position: relative;
    height: 0;
    margin: 0;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
    opacity: 0;
    pointer-events: none;
  }
  .comics-reader:not(.comics-reader--vertical) .comics-reader-back--chrome {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .comics-reader:not(.comics-reader--vertical) .comics-reader-chrome-row--pager .comics-reader-nav,
  .comics-reader:not(.comics-reader--vertical) .comics-reader-chrome-row--pager .comics-reader-skip {
    display: none !important;
  }
  #comics-reader-fullscreen,
  #comics-reader-layout {
    display: none !important;
  }
  .comics-chrome-extras {
    display: none;
    flex-direction: column;
    gap: 0.35rem;
    width: 100%;
  }
  .comics-chrome-extras.is-open {
    display: flex;
  }
  .comics-chrome-overflow-actions {
    display: flex;
    justify-content: center;
    width: 100%;
  }
  .comics-reader-chrome-row--pager {
    flex-wrap: wrap;
    justify-content: center;
  }
  .comics-reader-topbar {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .comics-reader-back:not(.comics-reader-back--chrome) {
    justify-self: center;
  }
  .comics-reader-title {
    max-width: 100%;
    order: -1;
  }
  .comics-reader-topbar-spacer {
    display: none;
  }
}

@media (min-width: 701px) {
  .comics-chrome-overflow-actions {
    display: none !important;
  }
}

.comics-page-img-error {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  min-height: 12rem;
  padding: 1.5rem;
  text-align: center;
  color: var(--muted);
  font-size: 0.9rem;
  background: var(--surface);
  border-radius: 0.5rem;
  border: 1px solid var(--border);
}
.comics-page-img-error button {
  padding: 0.45rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--bg3);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 0.85rem;
  cursor: pointer;
}
.comics-reader-page-img.is-loading {
  opacity: 0.35;
}
.comics-reader-loading-placeholder {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 2.5rem;
  height: 2.5rem;
  border: 3px solid rgba(255, 255, 255, 0.12);
  border-top-color: var(--pink);
  border-radius: 50%;
  animation: comics-spin 0.7s linear infinite;
  pointer-events: none;
}
@media (prefers-reduced-motion: reduce) {
  .comics-reader-loading-placeholder {
    animation: none;
    border-top-color: rgba(255, 255, 255, 0.2);
  }
}
@keyframes comics-spin {
  to {
    transform: rotate(360deg);
  }
}
.comics-reader-zoom-outer.is-loading-wrap {
  position: relative;
  min-height: 8rem;
}

/* Mobile-only (≤700px): explicit controls toggle — hidden on desktop */
.comics-reader-mobile-chrome-toggle {
  display: none;
}
@media (max-width: 700px) {
  #comics-reader:not([hidden]) .comics-reader-mobile-chrome-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    z-index: 6;
    min-height: 2.65rem;
    padding: 0.45rem 1.15rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: rgba(20, 16, 30, 0.96);
    color: var(--cream);
    font-family: var(--font-sans);
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    cursor: pointer;
    box-shadow: 0 4px 28px rgba(0, 0, 0, 0.5);
    -webkit-tap-highlight-color: transparent;
  }
  #comics-reader:not([hidden]) .comics-reader-mobile-chrome-toggle:focus-visible {
    outline: 2px solid var(--pink);
    outline-offset: 2px;
  }
  #comics-reader:not(.comics-reader--chrome-hidden) .comics-reader-mobile-chrome-toggle {
    bottom: calc(var(--comics-chrome-h, 7.5rem) + 0.4rem);
  }
  #comics-reader.comics-reader--chrome-hidden .comics-reader-mobile-chrome-toggle {
    bottom: max(0.65rem, env(safe-area-inset-bottom));
  }
}
@media (min-width: 701px) {
  .comics-reader-mobile-chrome-toggle {
    display: none !important;
  }
}

/* ── Commissions Page ────────────────────────────────────── */
.commissions-page {
  padding: 0 5vw 6rem;
  max-width: min(58rem, 100%);
  margin: 0 auto;
}
/* Light desk marginalia — no extra copy in the policies */
.commissions-page--marginalia {
  position: relative;
}
.commissions-page--marginalia::before {
  content: '';
  position: absolute;
  top: 5.5rem;
  right: max(0.25rem, calc(5vw - 0.5rem));
  width: 2.75rem;
  height: 2.75rem;
  border: 1px dashed rgba(158, 184, 188, 0.22);
  border-radius: 0.35rem;
  pointer-events: none;
  opacity: 0.65;
  transform: rotate(6deg);
}
.commissions-page--marginalia::after {
  content: 'お';
  position: absolute;
  bottom: 12%;
  left: max(0.15rem, 2vw);
  font-family: var(--font-jp);
  font-size: clamp(2.5rem, 8vw, 3.5rem);
  color: var(--accent-yuzu);
  opacity: 0.06;
  pointer-events: none;
  line-height: 1;
  user-select: none;
}
.commissions-page-hero {
  padding: var(--ocha-inner-page-pad-top) 0 2.5rem;
  text-align: center;
}
.commissions-page-hero .section-label {
  justify-content: center;
}
.commissions-page-hero .section-title-jp {
  text-align: center;
}
.commissions-page-lead {
  color: var(--muted);
  max-width: 55ch;
  margin: 1rem auto 0;
  line-height: 1.85;
  font-size: 1rem;
  text-align: center;
}
.commissions-page-lead a {
  color: var(--text);
  font-weight: 500;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.commissions-page-lead strong {
  color: var(--text);
  font-weight: 500;
}
.commissions-page-hero-cta {
  margin-top: 2rem;
}
.commissions-cta-panel {
  margin-top: 4rem;
  padding: 2.5rem;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 1.5rem;
}
.commissions-cta-title {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  color: var(--cream);
  margin-bottom: 0.75rem;
}
.commissions-cta-copy {
  color: var(--muted);
  margin-bottom: 1.5rem;
  font-size: 0.95rem;
}
.commissions-cta-button {
  display: inline-flex;
}
.price-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.25rem;
  margin: 3rem 0;
}
.price-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 1.5rem;
  padding: 2rem;
  transition: border-color 0.2s, transform 0.2s;
}
.price-card:hover {
  border-color: rgba(233,77,142,0.32);
  transform: translateY(-3px);
}
.price-card.featured { border-color: rgba(233,77,142,0.4); }
.price-card h3 {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  color: var(--cream);
  margin-bottom: 0.5rem;
}
.price-card .price {
  font-size: 2rem;
  font-weight: 600;
  color: var(--pink);
  font-family: var(--font-serif);
  margin-bottom: 1rem;
}
.price-card .price span { font-size: 1rem; font-weight: 300; color: var(--muted); }
.price-card p { color: var(--muted); font-size: 0.9rem; line-height: 1.7; }
.tos-section { margin-top: 4rem; }
.tos-section h3 {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  color: var(--cream);
  margin-bottom: 1.5rem;
}
.tos-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.tos-item {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 1rem;
  padding: 1.25rem;
}
.tos-item h4 {
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: var(--teal);
  margin-bottom: 0.5rem;
  text-transform: uppercase;
}
.tos-item p { font-size: 0.85rem; color: var(--muted); line-height: 1.7; }

/* ── About Page ──────────────────────────────────────────── */
.about-page {
  padding: var(--ocha-inner-page-pad-top) 5vw 6rem;
  max-width: min(58rem, 100%);
  margin: 0 auto;
}
.about-page p {
  color: var(--muted);
  line-height: 1.9;
  margin-bottom: 1.5rem;
  font-size: 1.05rem;
}
/* Headings: same system as section-shared; explicit here so they never fall back to body --text (too bright / “plain white”). */
.about-page .section-title {
  color: var(--cream);
  font-family: var(--font-serif);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.about-page h1.section-title {
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: 1rem;
}
.about-page h2.section-title {
  font-size: clamp(1.65rem, 3.2vw, 2.35rem);
  margin-top: 0.15rem;
  margin-bottom: 0.85rem;
}
.about-page .section-label {
  color: var(--teal);
}
.about-characters-block {
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid var(--border);
}
.about-characters-list {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.about-characters-list li {
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.85;
  padding: 1rem 1.15rem 1rem 1.35rem;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 0.85rem;
  border-left: 3px solid var(--teal);
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.12);
}
.about-characters-list li strong {
  color: var(--cream);
  font-weight: 600;
}
.about-characters-list li i {
  color: var(--pink);
  font-style: italic;
}
.about-page ul:not(.about-characters-list) {
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.85;
  margin: 0 0 1.5rem;
  padding-left: 1.35rem;
}
.about-page ul:not(.about-characters-list) li {
  margin-bottom: 0.65rem;
}
.about-page ul:not(.about-characters-list) li::marker {
  color: var(--teal);
}
.about-links-section {
  margin-top: 3rem;
}
.about-content-note {
  margin-top: 4rem;
  padding: 2.5rem;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 1.5rem;
}
.about-content-note h3 {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  color: var(--cream);
  margin-bottom: 0.5rem;
}
.about-content-note p {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.85;
  margin: 0;
}
.simple-page {
  padding-top: var(--ocha-inner-page-pad-top);
}
.simple-page-lead {
  color: var(--muted);
  max-width: 50ch;
  margin-top: 1rem;
  line-height: 1.85;
}
.simple-page-actions {
  margin-top: 2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.link-teal {
  color: var(--teal);
}
.footer-logo .tea {
  font-style: normal;
}
.footer-meta {
  opacity: 0.5;
}
.text-strong {
  color: var(--text);
  font-weight: 500;
}
.about-page p strong { color: var(--text); font-weight: 500; }
.links-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-top: 3rem;
}
.link-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 1rem;
  padding: 1.5rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: border-color 0.2s, transform 0.2s;
}
.link-card:hover {
  border-color: rgba(233,77,142,0.32);
  transform: translateY(-2px);
}
.link-card .link-icon { font-size: 1.5rem; }
.link-card h4 { font-size: 0.9rem; font-weight: 500; color: var(--cream); }
.link-card p { font-size: 0.75rem; color: var(--muted); }

/* ── Animations ──────────────────────────────────────────── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1;
    transform: none;
    transition: none;
    animation: none !important;
  }
  .reveal.visible {
    animation: none !important;
  }
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .hero {
    min-height: 0;
    justify-content: flex-start;
    padding: 7rem max(1rem, 5vw) 3rem;
    padding-left: max(1rem, 5vw, env(safe-area-inset-left, 0px));
    padding-right: max(1rem, 5vw, env(safe-area-inset-right, 0px));
  }
  .hero-inner {
    grid-template-columns: 1fr;
    max-width: min(70rem, 100%);
  }
  .hero-image { order: -1; }
  .hero-badge {
    left: 0.65rem;
    bottom: 0.85rem;
  }
  .about-section { grid-template-columns: 1fr; gap: 3rem; }
  .featured-editorial {
    min-height: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: minmax(200px, auto) minmax(200px, auto) minmax(200px, auto);
    grid-template-areas:
      "hero hero"
      "c2 c3"
      "c4 c5";
  }
  .commission-cta { grid-template-columns: 1fr; }
  .commission-actions { align-items: flex-start; }
  footer {
    grid-template-columns: minmax(0, 1fr);
    text-align: center;
    gap: 1.5rem;
    padding: 3rem max(1rem, 5vw) 3rem;
    padding-left: max(1rem, 5vw, env(safe-area-inset-left, 0px));
    padding-right: max(1rem, 5vw, env(safe-area-inset-right, 0px));
    min-width: 0;
  }
  .footer-logo {
    align-items: center;
    margin: 0 auto;
    max-width: 100%;
    min-width: 0;
  }
  .footer-right {
    text-align: center;
    max-width: 100%;
    min-width: 0;
    margin: 0 auto;
    overflow-wrap: break-word;
  }
  .footer-links {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    max-width: 100%;
    margin: 0 auto;
    padding: 0;
    min-width: 0;
  }
  .footer-links li {
    flex: 0 1 auto;
  }
  .footer-socials {
    justify-content: center;
    margin-bottom: 0.5rem;
    gap: 0.45rem 0.85rem;
    max-width: 100%;
    min-width: 0;
  }
  nav {
    padding: 1rem max(1rem, env(safe-area-inset-right)) 1rem max(1rem, env(safe-area-inset-left));
    padding-top: max(1rem, env(safe-area-inset-top));
    gap: 0.75rem;
  }
  nav.nav-open {
    z-index: 10000;
  }
  nav .nav-logo,
  nav .nav-menu-toggle {
    position: relative;
    z-index: 3;
  }
  .nav-menu-toggle {
    display: inline-flex;
    margin-left: auto;
  }
  .nav-menu-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 0;
    background: rgba(14, 11, 20, 0.72);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border: 0;
    padding: 0;
    margin: 0;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s var(--ease-out), visibility 0.3s;
  }
  .nav-menu-backdrop:not([hidden]) {
    opacity: 1;
    visibility: visible;
  }
  .nav-links {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    /* 100vw can exceed the layout width and cause horizontal page scroll on mobile. */
    width: 100%;
    max-width: none;
    min-width: min(20rem, 100%);
    margin: 0;
    min-height: 100dvh;
    min-height: -webkit-fill-available;
    max-height: 100dvh;
    max-height: -webkit-fill-available;
    padding: max(3.5rem, calc(2.75rem + env(safe-area-inset-top))) max(1.25rem, env(safe-area-inset-right))
      max(1.25rem, env(safe-area-inset-bottom)) max(1.25rem, env(safe-area-inset-left));
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0.2rem;
    background: rgba(20, 16, 30, 0.98);
    border-left: 1px solid var(--border);
    box-shadow: -12px 0 40px rgba(0, 0, 0, 0.45);
    list-style: none;
    z-index: 2;
    transform: translateX(100%);
    transition: transform 0.35s var(--ease-out), visibility 0.35s;
    visibility: hidden;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    box-sizing: border-box;
  }
  nav.nav-open .nav-links {
    transform: translateX(0);
    visibility: visible;
  }
  .nav-links li {
    width: 100%;
  }
  .nav-links a {
    display: flex;
    align-items: center;
    padding: 1.05rem 0.85rem;
    font-size: 1.08rem;
    min-height: 3.25rem;
    box-sizing: border-box;
  }
  .nav-links a.nav-commission {
    justify-content: center;
    margin-top: 0.5rem;
    padding: 0.65rem 1rem;
    text-align: center;
  }
  .tos-grid { grid-template-columns: 1fr; }
}

@media (max-width: 900px) and (prefers-reduced-motion: reduce) {
  .nav-links,
  .nav-menu-backdrop {
    transition-duration: 0.01ms !important;
  }
  .nav-menu-toggle-bar {
    transition-duration: 0.01ms !important;
  }
}

@media (max-width: 900px) {
  .footer-links a,
  .footer-socials a {
    min-height: 2.75rem;
    display: inline-flex;
    align-items: center;
  }
  .newsletter-form input[type='email'],
  .newsletter-form button[type='submit'] {
    min-height: 2.75rem;
  }
}

/* ── Stamp rally page — stamp book + hint modal ──────────── */
/* Full-width page: hero copy is not locked to the narrow book width. */
.stamps-page {
  padding: var(--ocha-inner-page-pad-top) 5vw 5rem;
  max-width: min(72rem, 100%);
  margin: 0 auto;
  box-sizing: border-box;
}

.stamps-page-hero {
  text-align: center;
  margin-bottom: 2rem;
  max-width: 48rem;
  margin-left: auto;
  margin-right: auto;
}

.stamps-page-hero .section-label {
  justify-content: center;
}

.stamps-page-lead {
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.75;
  max-width: none;
  margin: 1.25rem auto 0;
}

.stamps-progress {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.35rem;
  width: fit-content;
  max-width: 100%;
  margin: 1.35rem auto 0;
  padding: 0.65rem 1.25rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 1rem;
  font-size: 0.95rem;
  color: var(--text);
  box-sizing: border-box;
}

.stamps-progress strong {
  font-size: 1.35rem;
  font-family: var(--font-serif);
  font-weight: 600;
  color: var(--cream);
}

.stamps-progress span {
  color: var(--muted);
}

/* ── Stamp book (bingo / album spread) — narrow column, centred ── */
.stamp-book {
  position: relative;
  margin-top: 2.5rem;
  margin-left: auto;
  margin-right: auto;
  max-width: min(36rem, 100%);
  width: 100%;
  padding: 0 0.35rem 0.35rem;
  box-sizing: border-box;
}

/*
 * All stamps collected — warm rim + halo. Previous box-shadow on the wrapper was too faint on --bg;
 * this uses an inset-outset ::before so light sits just outside the booklet and reads clearly.
 */
.stamp-book.stamp-book--complete {
  z-index: 0;
}

/* Halo paint is deferred until .stamp-book--glow-on (after last stamp plonk ends — see stamps.js). */
.stamp-book.stamp-book--complete::before {
  content: '';
  position: absolute;
  inset: -12px;
  border-radius: 0.65rem;
  pointer-events: none;
  z-index: -1;
  /* Thin visible edge + outward bloom (tuned down a notch from first pass) */
  border: 1px solid rgba(232, 207, 138, 0.24);
  box-shadow:
    0 0 12px 1px rgba(232, 207, 138, 0.38),
    0 0 28px 3px rgba(253, 242, 167, 0.22),
    0 0 52px 9px rgba(212, 175, 88, 0.14),
    0 0 80px 16px rgba(232, 207, 138, 0.075);
  background: linear-gradient(
    180deg,
    rgba(232, 207, 138, 0.045) 0%,
    rgba(253, 242, 167, 0.022) 40%,
    transparent 72%
  );
  opacity: 0;
}

.stamp-book.stamp-book--complete.stamp-book--glow-on::before {
  animation: stamp-book-complete-glow-in 1s ease forwards;
}

@keyframes stamp-book-complete-glow-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* Full-bleed within .stamp-book — avoids side gaps that read as hairlines */
.stamp-book-ring {
  position: absolute;
  top: -0.35rem;
  left: 0;
  right: 0;
  width: auto;
  height: 0.65rem;
  background: linear-gradient(180deg, #6b6560, #3a3634);
  border-radius: 4px;
  /* Vertical-only depth — no horizontal spread past the bar */
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.38);
  z-index: 2;
}

.stamp-book-cover {
  text-align: center;
  padding: 0.5rem 0.75rem 0.65rem;
  background: var(--stamp-book-cover-grad);
  border: 1px solid rgba(253, 242, 167, 0.12);
  border-radius: 0.35rem 0.35rem 0 0;
  border-bottom: none;
}

.stamp-book-cover-title {
  font-family: var(--font-jp);
  font-size: 0.95rem;
  letter-spacing: 0.2em;
  color: var(--accent-warm);
  margin: 0;
}

.stamp-book-cover-sub {
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0.2rem 0 0;
}

.stamp-book-board {
  position: relative;
  /* Grid lives in the board’s own background stack — DOM stamps always paint above it (no ::after layer / compositor bugs) */
  /* Shorter than launch sizing, with more vertical room than the first tighten */
  min-height: clamp(24.75rem, 67vw, 33.5rem);
  /* Tight under cover so dashed grid sits close to “Ocha stamps” band */
  padding: clamp(0.25rem, 1.2vw, 0.5rem) clamp(1.5rem, 8%, 2.5rem) clamp(1.75rem, 6.5%, 2.65rem);
  box-sizing: border-box;
  border-radius: 0 0 0.5rem 0.5rem;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 200' preserveAspectRatio='none'%3E%3Cg fill='none' stroke='%232a211e' stroke-width='1.5' stroke-dasharray='3 2.5' stroke-linecap='round' stroke-linejoin='round' opacity='0.94'%3E%3Crect x='2.5' y='2.5' width='95' height='95' rx='2'/%3E%3Crect x='102.5' y='2.5' width='95' height='95' rx='2'/%3E%3Crect x='202.5' y='2.5' width='95' height='95' rx='2'/%3E%3Crect x='2.5' y='102.5' width='95' height='95' rx='2'/%3E%3Crect x='102.5' y='102.5' width='95' height='95' rx='2'/%3E%3Crect x='202.5' y='102.5' width='95' height='95' rx='2'/%3E%3C/g%3E%3C/svg%3E")
      center / 100% 100% no-repeat,
    linear-gradient(165deg, rgba(253, 242, 167, 0.07) 0%, transparent 42%),
    linear-gradient(180deg, #ede4d8 0%, #dcd2c4 45%, #cfc4b5 100%);
  box-shadow:
    inset 0 0 0 1px rgba(74, 62, 58, 0.12),
    inset 0 -18px 28px rgba(42, 33, 30, 0.06),
    0 12px 36px rgba(0, 0, 0, 0.35);
  overflow: hidden;
}

/* Paper grain — coarse fiber */
.stamp-book-board::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.055'/%3E%3C/svg%3E");
  pointer-events: none;
  mix-blend-mode: multiply;
  opacity: 0.85;
}

/* Finer speckle + slight tooth (second pass) */
.stamp-book-board::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.09' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)' opacity='0.12'/%3E%3C/svg%3E");
  pointer-events: none;
  mix-blend-mode: soft-light;
  opacity: 0.45;
}

.stamp-slot {
  position: absolute;
  left: var(--sx);
  /* 3D translate matches -50% centering but often composites sharper than translateX alone */
  transform: translate3d(-50%, 0, 0);
  /*
   * Pin cell with top + bottom (not height %) — percentage height was unreliable when the board
   * only had min-height, collapsing hit boxes so later siblings stole hovers/clicks.
   * Row1: top 2.5/200, bottom inset 100% − 97.5/200. Row2: top 102.5/200, bottom 100% − 197.5/200.
   */
  top: var(--slot-yt, 1.25%);
  bottom: var(--slot-yb-inset, 51.25%);
  width: calc(100% * 95 / 300);
  height: auto;
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  /* Only the circular .stamp-slot-visual receives hits — avoids whole-cell rectangles overlapping neighbors */
  pointer-events: none;
  cursor: default;
  color: inherit;
  font: inherit;
  text-align: center;
  /* Earlier slots win if anything still overlaps (paint + hit-test) */
  z-index: var(--slot-z, 1);
  /* Small idle offset so stamps feel hand-placed (plonk/wiggle bake these in) */
  --jx: 0;
  --jy: 0;
  /* Hover: in-plane tilt + scale (see --peel-rz / --peel-y on each slot in pages/stamps.html) */
  --peel-ox: 50%;
  --peel-oy: 50%;
  --peel-y: 0deg;
  --peel-rz: -2deg;
  /* Plonk animation (overridden per slot via nth-child) */
  --plonk-y0: -1rem;
  --plonk-s0: 1.14;
  --plonk-r0: 11deg;
  --plonk-y-mid: 5px;
  --plonk-r-mid: -3deg;
  --plonk-s-mid: 0.95;
}

.stamp-slot:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 4px;
  border-radius: 0.5rem;
}

/*
 * Land with a twist: --plonk-r0 / --plonk-r-mid are signed offsets from final --sr (CW +, CCW -).
 * Each slot sets its own pair so some stamps overshoot clockwise, others counter-clockwise, with varied strength.
 */
@keyframes stamp-stack-plonk {
  0% {
    opacity: 0;
    transform: translate3d(var(--jx, 0), calc(var(--jy, 0) + var(--plonk-y0)), 0.5px) scale(var(--plonk-s0));
  }
  58% {
    opacity: 1;
    transform: translate3d(var(--jx, 0), calc(var(--jy, 0) + var(--plonk-y-mid)), 0.5px) scale(var(--plonk-s-mid));
  }
  100% {
    opacity: 1;
    transform: translate3d(var(--jx, 0), var(--jy, 0), 0.5px) scale(1);
  }
}

/* Rotation + plonk overshoot live on .stamp-slot-rotate so the bitmap isn’t under translate+rotate+img counter-rotate. */
@keyframes stamp-rotate-plonk {
  0% {
    transform: rotate(calc(var(--sr) + var(--plonk-r0, 11deg)));
  }
  58% {
    transform: rotate(calc(var(--sr) + var(--plonk-r-mid, -3deg)));
  }
  100% {
    transform: rotate(var(--sr));
  }
}

/* Short burst (~2 wobbles); rotation only — stack stays translate-only */
@keyframes stamp-rotate-wiggle {
  0% {
    transform: rotate(var(--sr));
  }
  15% {
    transform: rotate(calc(var(--sr) + 2.6deg));
  }
  32% {
    transform: rotate(calc(var(--sr) - 2deg));
  }
  50% {
    transform: rotate(calc(var(--sr) + 1.5deg));
  }
  68% {
    transform: rotate(calc(var(--sr) - 1deg));
  }
  100% {
    transform: rotate(var(--sr));
  }
}

@keyframes stamp-rotate-wiggle-b {
  0% {
    transform: rotate(var(--sr));
  }
  18% {
    transform: rotate(calc(var(--sr) - 2.2deg));
  }
  35% {
    transform: rotate(calc(var(--sr) + 2.8deg));
  }
  52% {
    transform: rotate(calc(var(--sr) - 1.4deg));
  }
  72% {
    transform: rotate(calc(var(--sr) + 0.9deg));
  }
  100% {
    transform: rotate(var(--sr));
  }
}

@keyframes stamp-rotate-wiggle-c {
  0% {
    transform: rotate(var(--sr));
  }
  12% {
    transform: rotate(calc(var(--sr) + 3.1deg));
  }
  28% {
    transform: rotate(calc(var(--sr) - 1.6deg));
  }
  48% {
    transform: rotate(calc(var(--sr) + 2deg));
  }
  65% {
    transform: rotate(calc(var(--sr) - 1.1deg));
  }
  100% {
    transform: rotate(var(--sr));
  }
}

/* Frame fills positioned slot = one dashed cell (width/height set on .stamp-slot) */
.stamp-slot-frame {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  width: 100%;
  height: 100%;
  min-height: 0;
  box-sizing: border-box;
  pointer-events: none;
}

/*
 * Desktop: row + centered stack. Disc size uses cqw/cqh vs .stamp-slot-upper (see @supports
 * below)—plain % on .stamp-slot-visual was cyclic with shrink-wrapped .stamp-slot-stack, so
 * desktop never picked up min(90%, …) changes. Narrow viewports add column + full-width stack.
 */
.stamp-slot-upper {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
  pointer-events: none;
}

@supports (width: 1cqw) {
  .stamp-slot-upper {
    container-type: size;
    container-name: stamp-upper;
  }
}

/*
 * Stack = translate + plonk scale only. Rotation + wiggle live on .stamp-slot-rotate so <img> isn’t
 * composited through stack rotate + counter-rotated img (fixes persistent soft halftone on many GPUs).
 */
.stamp-slot-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transform: translate3d(var(--jx, 0), var(--jy, 0), 0.5px);
  transform-origin: 50% 50%;
  pointer-events: none;
}

.stamp-slot-rotate {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transform: rotate(var(--sr));
  transform-origin: 50% 50%;
  pointer-events: none;
}

.stamp-book-board.stamp-book-settled .stamp-slot--collected .stamp-slot-rotate {
  will-change: transform;
}

/* “Sticking” stamps on first paint (collected only). --plonk-delay set in JS: grid order TL→TR, then BL→BR, 0.5s apart among collected only. */
.stamp-book-board:not(.stamp-book-settled) .stamp-slot--collected .stamp-slot-stack {
  animation: stamp-stack-plonk var(--plonk-dur, 0.7s) cubic-bezier(0.34, 1.28, 0.48, 1) both;
  animation-delay: var(--plonk-delay, 0s);
}

.stamp-book-board:not(.stamp-book-settled) .stamp-slot--collected .stamp-slot-rotate {
  animation: stamp-rotate-plonk var(--plonk-dur, 0.7s) cubic-bezier(0.34, 1.28, 0.48, 1) both;
  animation-delay: var(--plonk-delay, 0s);
}

/* Per-character plonk tuning (data-stamp-id — matches board layout, not DOM nth-child). */
.stamp-book-board:not(.stamp-book-settled) .stamp-slot[data-stamp-id='kyo'].stamp-slot--collected {
  --plonk-dur: 0.7s;
  --plonk-y0: -0.82rem;
  --plonk-s0: 1.12;
  --plonk-r0: 19deg;
  --plonk-y-mid: 4px;
  --plonk-r-mid: -6deg;
  --plonk-s-mid: 0.94;
}
.stamp-book-board:not(.stamp-book-settled) .stamp-slot[data-stamp-id='elise'].stamp-slot--collected {
  --plonk-dur: 0.78s;
  --plonk-y0: -1.12rem;
  --plonk-s0: 1.18;
  --plonk-r0: -11deg;
  --plonk-y-mid: 7px;
  --plonk-r-mid: 5deg;
  --plonk-s-mid: 0.93;
}
.stamp-book-board:not(.stamp-book-settled) .stamp-slot[data-stamp-id='alyra'].stamp-slot--collected {
  --plonk-dur: 0.64s;
  --plonk-y0: -0.95rem;
  --plonk-s0: 1.15;
  --plonk-r0: 14deg;
  --plonk-y-mid: 6px;
  --plonk-r-mid: -4deg;
  --plonk-s-mid: 0.96;
}
.stamp-book-board:not(.stamp-book-settled) .stamp-slot[data-stamp-id='momo'].stamp-slot--collected {
  --plonk-dur: 0.73s;
  --plonk-y0: -1.05rem;
  --plonk-s0: 1.1;
  --plonk-r0: -17deg;
  --plonk-y-mid: 3px;
  --plonk-r-mid: 7deg;
  --plonk-s-mid: 0.95;
}
.stamp-book-board:not(.stamp-book-settled) .stamp-slot[data-stamp-id='mars'].stamp-slot--collected {
  --plonk-dur: 0.81s;
  --plonk-y0: -0.88rem;
  --plonk-s0: 1.17;
  --plonk-r0: 9deg;
  --plonk-y-mid: 8px;
  --plonk-r-mid: -2.5deg;
  --plonk-s-mid: 0.92;
}
.stamp-book-board:not(.stamp-book-settled) .stamp-slot[data-stamp-id='vivi'].stamp-slot--collected {
  --plonk-dur: 0.67s;
  --plonk-y0: -1.18rem;
  --plonk-s0: 1.13;
  --plonk-r0: -22deg;
  --plonk-y-mid: 5px;
  --plonk-r-mid: 8deg;
  --plonk-s-mid: 0.97;
}

/* Hard stop: undiscovered slots never run the landing animation (plonk or any stray rule). */
.stamp-book-board:not(.stamp-book-settled) .stamp-slot:not(.stamp-slot--collected) .stamp-slot-stack {
  animation: none !important;
  animation-delay: 0s !important;
}

.stamp-book-board:not(.stamp-book-settled) .stamp-slot:not(.stamp-slot--collected) .stamp-slot-rotate {
  animation: none !important;
  animation-delay: 0s !important;
}

/* Which wiggle curve runs on hover (settled only — see @media below) */
.stamp-slot:nth-child(1),
.stamp-slot:nth-child(4) {
  --stamp-wiggle: stamp-rotate-wiggle;
}
.stamp-slot:nth-child(2),
.stamp-slot:nth-child(5) {
  --stamp-wiggle: stamp-rotate-wiggle-b;
}
.stamp-slot:nth-child(3),
.stamp-slot:nth-child(6) {
  --stamp-wiggle: stamp-rotate-wiggle-c;
}

/* Per-slot “sloppy stamp” offsets (px + rem) — bar stays square to grid; disc jitters inside */
.stamp-slot:nth-child(1) {
  --jx: 0.1rem;
  --jy: -0.14rem;
}
.stamp-slot:nth-child(2) {
  --jx: -0.12rem;
  --jy: 0.08rem;
}
.stamp-slot:nth-child(3) {
  --jx: 0.14rem;
  --jy: 0.1rem;
}
.stamp-slot:nth-child(4) {
  --jx: -0.08rem;
  --jy: -0.1rem;
}
.stamp-slot:nth-child(5) {
  --jx: 0.11rem;
  --jy: 0.12rem;
}
.stamp-slot:nth-child(6) {
  --jx: -0.13rem;
  --jy: -0.07rem;
}

.stamp-book-board .stamp-slot:nth-child(1) {
  --slot-z: 60;
}
.stamp-book-board .stamp-slot:nth-child(2) {
  --slot-z: 59;
}
.stamp-book-board .stamp-slot:nth-child(3) {
  --slot-z: 58;
}
.stamp-book-board .stamp-slot:nth-child(4) {
  --slot-z: 57;
}
.stamp-book-board .stamp-slot:nth-child(5) {
  --slot-z: 56;
}
.stamp-book-board .stamp-slot:nth-child(6) {
  --slot-z: 55;
}

.stamp-slot-visual {
  position: relative;
  height: auto;
  aspect-ratio: 1;
  max-width: 100%;
  border-radius: 50%;
  overflow: hidden;
  isolation: isolate;
  pointer-events: auto;
  cursor: pointer;
  border: 2px solid rgba(74, 62, 58, 0.28);
  box-shadow:
    2px 3px 0 rgba(74, 62, 58, 0.1),
    0 4px 12px rgba(0, 0, 0, 0.12);
  background: var(--stamp-paper);
  /* Own layer; parent stack is translate-only, rotation is on .stamp-slot-rotate */
  transform: translateZ(0);
  transform-origin: var(--peel-ox) var(--peel-oy);
  transition:
    transform 0.28s var(--ease-out),
    border-color 0.28s var(--ease-out),
    box-shadow 0.28s var(--ease-out);
}

/* Definite base = art cell (.stamp-slot-upper), not shrink-wrapped stack (fixes desktop). */
@supports (width: 1cqw) {
  .stamp-slot-visual {
    width: min(92cqw, 92cqh, 12rem);
  }
}

@supports not (width: 1cqw) {
  .stamp-slot-visual {
    width: min(90%, 11.75rem);
  }
}

/*
 * Narrow viewports: size discs to the *upper* cell (art area only).
 * Container on .stamp-slot was wrong — cqh included the name bar, so min(cqw,cqh) could exceed
 * the flex region and Safari/board overflow clipped the circle (often worse at the bottom).
 */
@media (max-width: 900px) {
  /* Taller board → taller .stamp-slot-upper → larger cqh so the disc isn’t only height-capped */
  .stamp-book-board {
    min-height: clamp(23rem, 84.5vw, 31.75rem);
  }

  .stamp-slot-upper {
    flex-direction: column;
    align-items: stretch;
    justify-content: center;
    /* Minimal vertical padding so cqh stays large; shadows handled via collected overflow:visible */
    padding-block: 0.05rem;
    box-sizing: border-box;
  }

  .stamp-slot-stack {
    width: 100%;
    box-sizing: border-box;
  }

  .stamp-slot-rotate {
    width: 100%;
    box-sizing: border-box;
  }

  /* Fill the art cell; higher rem cap for large phones / short slots where cqh was the limiter */
  @supports (width: 1cqw) {
    .stamp-slot-visual {
      width: min(100cqw, 100cqh, 16rem);
    }
  }

  @supports not (width: 1cqw) {
    .stamp-slot-visual {
      width: min(98%, 14.5rem);
    }
  }

  /* Collected: outer shadow + border sit outside the padding box — overflow:hidden clips them in WebKit */
  .stamp-slot--collected .stamp-slot-visual {
    overflow: visible;
  }

  /* Parent can’t clip the circle here — round the img so corners don’t square off. */
  .stamp-slot--collected .stamp-slot-visual img {
    border-radius: 50%;
  }

  /*
   * Per-slot --jx/--jy nudges read as “stamp slid in the cell” on narrow boards and meet overflow clips.
   * Keep rotation (--sr); drop translation on small viewports only.
   */
  .stamp-slot {
    --jx: 0 !important;
    --jy: 0 !important;
  }
}

/*
 * Small phones (≤430px CSS width — typical handset viewports): 100cqw/100cqh fills the art cell so the disc border,
 * shadow, and slight rotation read past the dashed stamp boxes. Shrink a few % so the ink stays inside the grid.
 */
@media (max-width: 430px) {
  @supports (width: 1cqw) {
    .stamp-book-board .stamp-slot-visual {
      width: min(94cqw, 94cqh, 15.25rem);
    }
  }

  @supports not (width: 1cqw) {
    .stamp-book-board .stamp-slot-visual {
      width: min(92%, 14rem);
    }
  }
}

/* Grain only on locked stamps — avoids soft “out of focus” look on collected art */
.stamp-slot:not(.stamp-slot--collected) .stamp-slot-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='s'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23s)' opacity='0.14'/%3E%3C/svg%3E");
  mix-blend-mode: multiply;
  opacity: 0.5;
}

.stamp-slot-visual img {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  /* Clip only from .stamp-slot-visual — matching border-radius here doubled AA / soft edges. */
  border-radius: 0;
  display: block;
  transition: filter 0.35s ease, opacity 0.35s ease;
}

/* Locked: real art, blurred + greyscale (no filter transition — avoids a “stamp-in” blur on load) */
.stamp-slot:not(.stamp-slot--collected) .stamp-slot-visual img {
  filter: grayscale(1) blur(5px) brightness(0.88);
  opacity: 0.95;
  transition: none;
}

/*
 * Collected: rotation is on .stamp-slot-rotate — no img counter-rotate. No transform transition on
 * the disc so hover scale snaps sharp immediately.
 */
.stamp-slot--collected .stamp-slot-visual {
  border-color: rgba(74, 62, 58, 0.32);
  transform-origin: 50% 50%;
  transition:
    border-color 0.28s var(--ease-out),
    box-shadow 0.28s var(--ease-out);
  box-shadow:
    2px 3px 0 rgba(74, 62, 58, 0.1),
    0 4px 12px rgba(0, 0, 0, 0.12);
}

.stamp-slot--collected .stamp-slot-visual::before,
.stamp-slot--collected .stamp-slot-visual::after {
  content: none !important;
}

.stamp-slot--collected .stamp-slot-visual img {
  mix-blend-mode: normal;
  opacity: 1;
}

/* Mobile: same outer-only shadow as desktop for collected (inset removed for sharper art). */
@media (max-width: 900px) {
  .stamp-slot--collected .stamp-slot-visual {
    box-shadow:
      2px 3px 0 rgba(74, 62, 58, 0.1),
      0 4px 12px rgba(0, 0, 0, 0.12);
  }
}

/* Flush to bottom of dashed cell; bottom radius echoes SVG grid rx (~2 / 95 of cell) */
.stamp-slot-name-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  min-height: 1.48rem;
  margin: 0;
  padding: 0.32rem 0.28rem 0.36rem;
  box-sizing: border-box;
  width: 100%;
  pointer-events: none;
  background: var(--stamp-book-cover-grad);
  border: 1px solid rgba(253, 242, 167, 0.1);
  border-top: 1px solid rgba(0, 0, 0, 0.28);
  /* Bottom radius tracks SVG rect rx=2 vs cell width 95 */
  border-radius: 0 0 calc(100% * 2 / 95) calc(100% * 2 / 95);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.05) inset;
}

/* Match .stamp-book-cover-sub (“Ocha stamps” line): DM Sans, tracked caps */
.stamp-slot-name {
  font-family: var(--font-sans);
  font-size: clamp(0.62rem, 2.4vw, 0.68rem);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.2;
  text-align: center;
  max-width: 100%;
  pointer-events: none;
}

@media (hover: hover) and (pointer: fine) {
  /* Wiggle after entrance finished (.stamp-book-settled), so we don’t replace the plonk animation */
  .stamp-book-board.stamp-book-settled .stamp-slot:hover .stamp-slot-rotate {
    animation: var(--stamp-wiggle, stamp-rotate-wiggle) 0.52s ease-in-out 1 forwards;
  }

  .stamp-book-board.stamp-book-settled .stamp-slot:hover .stamp-slot-visual {
    transform: translateZ(0) scale(1.05);
    box-shadow:
      3px 8px 16px rgba(0, 0, 0, 0.16),
      0 0 0 1px rgba(255, 255, 255, 0.3) inset,
      -1px 2px 6px rgba(74, 62, 58, 0.12);
  }
}

/* ── Hint modal (viewport overlay; excluded from body > * in 02-reset) ── */
#stamp-hint-modal.stamp-book-modal {
  position: fixed !important;
  inset: 0;
  z-index: 10025;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
  box-sizing: border-box;
}

#stamp-hint-modal.stamp-book-modal[hidden] {
  display: none !important;
}

.stamp-book-modal-backdrop {
  position: absolute;
  inset: 0;
  /* No backdrop-filter: full-viewport blur is expensive and reads as “slow” on many devices */
  background: rgba(10, 8, 12, 0.82);
  opacity: 0;
  transition: opacity 0.08s linear;
}

.stamp-book-modal.is-visible .stamp-book-modal-backdrop {
  opacity: 1;
}

.stamp-book-modal-dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 30rem);
  max-height: min(92vh, 42rem);
  overflow-y: auto;
  padding: 1.35rem 1.25rem 1.25rem;
  background: var(--bg2);
  border: 1px solid rgba(233, 77, 142, 0.28);
  border-radius: 1.15rem;
  box-shadow:
    0 24px 48px rgba(0, 0, 0, 0.5),
    0 0 0 1px rgba(253, 242, 167, 0.08);
  transform: scale(0.99) translateY(2px);
  opacity: 0;
  transition:
    transform 0.08s var(--ease-out),
    opacity 0.07s linear;
}

.stamp-book-modal.is-visible .stamp-book-modal-dialog {
  transform: scale(1) translateY(0);
  opacity: 1;
}

.stamp-book-modal-close {
  position: absolute;
  top: 0.45rem;
  right: 0.45rem;
  z-index: 2;
  width: 2.5rem;
  height: 2.5rem;
  border: none;
  border-radius: 50%;
  background: var(--surface);
  color: var(--muted);
  cursor: pointer;
  display: grid;
  place-items: center;
  padding: 0;
  margin: 0;
  line-height: 0;
  transition: color 0.15s, background 0.15s;
  -webkit-tap-highlight-color: transparent;
}

.stamp-book-modal-close svg {
  display: block;
  width: 1.1rem;
  height: 1.1rem;
  pointer-events: none;
}

.stamp-book-modal-close:hover {
  color: var(--cream);
  background: var(--bg3);
}

.stamp-book-modal-stamp-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 1.1rem 0 1.35rem;
  padding: 0.5rem 1rem 1rem;
  perspective: 800px;
  box-sizing: border-box;
}

/* Modal: clear art (no book ink overlays); simple paper disc + drop shadow */
.stamp-book-modal-stamp {
  position: relative;
  width: min(13rem, calc(100vw - 3.5rem));
  height: min(13rem, calc(100vw - 3.5rem));
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(74, 62, 58, 0.32);
  background: var(--stamp-paper);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.35);
  transform-origin: 50% 100%;
}

@media (min-width: 901px) {
  .stamp-book-modal-stamp {
    width: min(15.25rem, calc(100vw - 3.5rem));
    height: min(15.25rem, calc(100vw - 3.5rem));
  }
}

/* Modal opens: stamp “lands” with a couple of small hops (honors reduced motion below) */
@keyframes stamp-modal-stamp-land {
  0% {
    opacity: 0.88;
    transform: translateY(-3rem) scale(1.16);
  }
  30% {
    opacity: 1;
    transform: translateY(0) scale(0.91);
  }
  48% {
    transform: translateY(-0.75rem) scale(1.07);
  }
  64% {
    transform: translateY(0) scale(0.96);
  }
  78% {
    transform: translateY(-0.3rem) scale(1.025);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.stamp-book-modal-stamp.stamp-book-modal-stamp--landing {
  animation: stamp-modal-stamp-land 0.72s cubic-bezier(0.33, 1.32, 0.52, 1) both;
}

/* Not collected: no landing hop — stays static (JS skips triggering landing; this blocks animation if classes overlap) */
.stamp-book-modal-stamp.stamp-book-modal-stamp--locked {
  animation: none;
}

.stamp-book-modal-stamp img {
  position: relative;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: filter 0.25s ease, opacity 0.25s ease;
}

.stamp-book-modal-stamp--locked img {
  filter: grayscale(1) blur(6px) brightness(0.88);
}

.stamp-book-modal-title {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  color: var(--cream);
  text-align: center;
  margin: 0 2rem 0.5rem;
}

.stamp-book-modal-bio {
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--muted);
  margin-bottom: 0.45rem;
}

.stamp-book-modal-bio p {
  margin: 0 0 0.65rem;
}

.stamp-book-modal-bio p:last-child {
  margin-bottom: 0;
}

.stamp-book-modal-bio a {
  color: var(--teal);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.stamp-book-modal-bio a:hover {
  color: var(--cream);
}

.stamp-book-modal-quote-wrap {
  margin-top: 0.5rem;
}

.stamp-book-modal-quote-wrap:empty {
  display: none;
}

.stamp-book-modal-hint-wrap {
  margin-top: 0.85rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--border);
}

.stamp-book-modal-hint-wrap:empty {
  display: none;
}

.stamp-book-modal-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--text);
  margin: 0 0 0.35rem !important;
  padding-left: 0.65rem;
  border-left: 2px solid rgba(233, 77, 142, 0.35);
}

.stamp-book-modal-hint {
  margin: 0 !important;
  padding: 0;
  border: none;
  font-size: 0.88rem !important;
  line-height: 1.6 !important;
  color: var(--muted) !important;
}

.stamp-book-modal-hint a {
  color: var(--teal);
}

/* Undiscovered stamp: bio & quote hidden until collected */
.stamp-book-modal-unknown-kicker {
  display: block;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 0.2rem;
}

.stamp-book-modal-unknown-desc {
  margin: 0 0 0.75rem !important;
  padding: 0.65rem 0.75rem;
  background: rgba(0, 0, 0, 0.2);
  border-radius: 0.5rem;
  border: 1px dashed rgba(233, 77, 142, 0.28);
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.55;
}

.stamp-book-modal-unknown-quote {
  margin: 0 0 0.75rem !important;
  padding: 0.65rem 0.75rem 0.7rem;
  padding-left: 0.75rem;
  border-left: 2px solid rgba(107, 155, 160, 0.35);
  background: rgba(0, 0, 0, 0.12);
  border-radius: 0 0.5rem 0.5rem 0;
  font-family: var(--font-serif);
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--muted);
}

.stamp-book-modal-unknown-muted {
  letter-spacing: 0.25em;
  color: rgba(200, 190, 200, 0.35);
  font-style: normal;
  user-select: none;
}

.stamp-book-modal-unknown-note {
  font-style: italic;
  font-weight: 400;
  color: var(--muted);
}

.stamps-complete {
  margin-top: 2.5rem;
  margin-left: auto;
  margin-right: auto;
  max-width: 40rem;
  padding: 1.5rem 1.25rem;
  text-align: center;
  background: linear-gradient(135deg, rgba(233, 77, 142, 0.12), rgba(107, 155, 160, 0.09));
  border: 1px solid rgba(233, 77, 142, 0.25);
  border-radius: 1.25rem;
}

.stamps-complete h2 {
  font-family: var(--font-serif);
  font-size: 1.35rem;
  color: var(--cream);
  margin-bottom: 0.5rem;
}

.stamps-complete p {
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.6;
  max-width: 32rem;
  margin: 0 auto;
}

.stamps-reset-wrap {
  margin-top: 2rem;
  text-align: center;
}

.stamps-reset {
  background: transparent;
  border: none;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.8rem;
  letter-spacing: 0.04em;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  cursor: pointer;
  padding: 0.5rem;
}

.stamps-reset:hover {
  color: var(--text);
}

@media (prefers-reduced-motion: reduce) {
  .stamp-book.stamp-book--complete.stamp-book--glow-on::before {
    animation: none !important;
    opacity: 1;
  }

  .stamp-book-board:not(.stamp-book-settled) .stamp-slot-stack {
    animation: none !important;
    animation-delay: 0s !important;
    opacity: 1;
    transform: translate3d(var(--jx, 0), var(--jy, 0), 0.5px);
  }

  .stamp-book-board:not(.stamp-book-settled) .stamp-slot-rotate {
    animation: none !important;
    animation-delay: 0s !important;
    transform: rotate(var(--sr));
  }

  .stamp-slot-stack,
  .stamp-slot-rotate,
  .stamp-slot-upper,
  .stamp-slot-frame,
  .stamp-slot-visual,
  .stamp-book-modal-dialog,
  .stamp-book-modal-backdrop {
    transition-duration: 0.01ms;
  }

  .stamp-book-modal-stamp.stamp-book-modal-stamp--landing {
    animation: none !important;
  }

  @media (hover: hover) {
    .stamp-book-board.stamp-book-settled .stamp-slot:hover .stamp-slot-rotate {
      animation: none !important;
    }
    .stamp-book-board.stamp-book-settled .stamp-slot:hover .stamp-slot-visual,
    .stamp-slot:hover .stamp-slot-visual {
      transform: none;
    }
  }
}

/*
 * ═══ Stamp page fuzz debug (stamps.js: parseStampPageDebugHash) ═══
 * Open the stamp page with a hash, hard-refresh, compare sharpness:
 *   #debug-stamps           — zero tilt/offsets, no plonk/wiggle, no visual translateZ/isolation (GPU/transform A/B).
 *   #debug-stamps-nograin   — hide .stamp-book-board paper ::before/::after only (board blend B/B).
 *   #debug-stamps-all       — both. Combos: #debug-stamps-flat-nograin
 * Remove the hash when done; this is for diagnosis only.
 */
html.ocha-debug-stamps--nograin #stamps-album .stamp-book-board::before,
html.ocha-debug-stamps--nograin #stamps-album .stamp-book-board::after {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

html.ocha-debug-stamps--flat #stamps-album .stamp-slot {
  --sr: 0deg !important;
  --jx: 0 !important;
  --jy: 0 !important;
}

html.ocha-debug-stamps--flat #stamps-album .stamp-slot-stack {
  animation: none !important;
  transform: translate3d(0, 0, 0) !important;
}

html.ocha-debug-stamps--flat
  #stamps-album
  .stamp-book-board:not(.stamp-book-settled)
  .stamp-slot--collected
  .stamp-slot-stack {
  animation: none !important;
}

html.ocha-debug-stamps--flat
  #stamps-album
  .stamp-book-board:not(.stamp-book-settled)
  .stamp-slot--collected
  .stamp-slot-rotate {
  animation: none !important;
}

html.ocha-debug-stamps--flat #stamps-album .stamp-slot-rotate {
  transform: rotate(0deg) !important;
}

html.ocha-debug-stamps--flat #stamps-album .stamp-slot-visual {
  isolation: auto !important;
  transform: none !important;
}

@media (hover: hover) and (pointer: fine) {
  html.ocha-debug-stamps--flat #stamps-album .stamp-book-board.stamp-book-settled .stamp-slot:hover .stamp-slot-rotate {
    animation: none !important;
  }

  html.ocha-debug-stamps--flat #stamps-album .stamp-book-board.stamp-book-settled .stamp-slot:hover .stamp-slot-visual {
    transform: none !important;
  }
}

/* ── Stamp acquisition toast (achievement-style) ─────────── */
/* ID + class so specificity wins over body > *:not(...) in 02-reset.css */
/* Above #ocha-lightbox (10050) so “stamp collected” toasts show while the gallery lightbox is open */
#ocha-stamp-toast-host.stamp-toast-host {
  position: fixed;
  z-index: 10060;
  pointer-events: none;
  bottom: 1.35rem;
  right: 1.35rem;
  left: auto;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.65rem;
  max-width: calc(100vw - 2rem);
}

@media (max-width: 700px) {
  #ocha-stamp-toast-host.stamp-toast-host {
    right: auto;
    left: 50%;
    transform: translateX(-50%);
    align-items: center;
    width: min(94vw, 24rem);
    max-width: min(94vw, 24rem);
  }
}

.stamp-toast {
  pointer-events: auto;
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 0.75rem 1rem 0.75rem 0.85rem;
  max-width: min(100%, 19rem);
  box-sizing: border-box;
  background: var(--bg2);
  border: 1px solid rgba(233, 77, 142, 0.38);
  border-radius: 1rem;
  box-shadow:
    0 12px 40px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(168, 184, 216, 0.1),
    0 0 14px 2px rgba(233, 77, 142, 0.06);
  animation:
    stamp-toast-in 0.45s var(--ease-out) both,
    stamp-toast-glow-ring 1.2s ease-out 0.06s both;
  cursor: pointer;
  text-align: left;
}

/* Soft “pop” glow on appear — settles to a faint rim (not looping). */
@keyframes stamp-toast-glow-ring {
  from {
    box-shadow:
      0 12px 40px rgba(0, 0, 0, 0.45),
      0 0 0 1px rgba(158, 184, 188, 0.12),
      0 0 0 0 rgba(233, 77, 142, 0);
  }
  40% {
    box-shadow:
      0 14px 44px rgba(0, 0, 0, 0.48),
      0 0 0 1px rgba(253, 242, 167, 0.28),
      0 0 26px 8px rgba(233, 77, 142, 0.2),
      0 0 36px 10px rgba(107, 155, 160, 0.14);
  }
  to {
    box-shadow:
      0 12px 40px rgba(0, 0, 0, 0.45),
      0 0 0 1px rgba(168, 184, 216, 0.12),
      0 0 16px 3px rgba(233, 77, 142, 0.09);
  }
}

@media (max-width: 700px) {
  .stamp-toast {
    width: 100%;
    max-width: min(100%, 24rem);
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }
  .stamp-toast--album-complete {
    width: 100%;
    max-width: min(100%, 26rem);
  }
}

.stamp-toast--album-complete {
  max-width: min(100%, 22rem);
  border-color: rgba(253, 242, 167, 0.35);
  animation:
    stamp-toast-in 0.45s var(--ease-out) both,
    stamp-toast-glow-ring-album 1.35s ease-out 0.06s both;
}

@keyframes stamp-toast-glow-ring-album {
  from {
    box-shadow:
      0 12px 40px rgba(0, 0, 0, 0.45),
      0 0 0 1px rgba(253, 242, 167, 0.15),
      0 0 0 0 rgba(232, 207, 138, 0);
  }
  42% {
    box-shadow:
      0 14px 44px rgba(0, 0, 0, 0.48),
      0 0 0 1px rgba(253, 242, 167, 0.4),
      0 0 32px 10px rgba(232, 207, 138, 0.22),
      0 0 28px 8px rgba(233, 77, 142, 0.12);
  }
  to {
    box-shadow:
      0 12px 40px rgba(0, 0, 0, 0.45),
      0 0 0 1px rgba(253, 242, 167, 0.22),
      0 0 18px 4px rgba(232, 207, 138, 0.1);
  }
}

.stamp-toast-body--wide {
  padding: 0.1rem 0;
}

.stamp-toast-kicker--gold {
  color: var(--accent-warm);
}

.stamp-toast--out {
  animation: stamp-toast-out 0.35s var(--ease-out) both;
}

@keyframes stamp-toast-in {
  from {
    opacity: 0;
    transform: translateY(14px) scale(0.94);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes stamp-toast-out {
  to {
    opacity: 0;
    transform: translateY(10px) scale(0.96);
  }
}

.stamp-toast-figure {
  flex-shrink: 0;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(233, 77, 142, 0.42);
  background: var(--stamp-paper);
}

.stamp-toast-figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform-origin: 50% 60%;
  animation: stamp-toast-wobble 0.38s ease-in-out 5 alternate;
}

@keyframes stamp-toast-wobble {
  from {
    transform: rotate(-7deg);
  }
  to {
    transform: rotate(7deg);
  }
}

.stamp-toast-body {
  min-width: 0;
  flex: 1;
}

.stamp-toast-kicker {
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 0.2rem;
}

.stamp-toast-title {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--cream);
  line-height: 1.2;
}

.stamp-toast-hint {
  font-size: 0.72rem;
  color: var(--muted);
  margin-top: 0.35rem;
}

.stamp-toast-album-link {
  font-weight: 500;
}

@media (prefers-reduced-motion: reduce) {
  .stamp-toast,
  .stamp-toast--album-complete {
    animation: stamp-toast-in 0.01ms both;
  }
  .stamp-toast--out {
    animation-duration: 0.01ms;
  }
  .stamp-toast-figure img {
    animation: none;
    transform: none;
  }
}

/* ── Direction A — tea house surfaces (CSS-only polish) ──────
   Warm rims, soft paper veils, coaster-like cards. Tuned for contrast;
   tweak --ocha-* in 01-variables.css if you want stronger/weaker. */

/* ── Section rhythm (pages that use <main><section>…</section>) ── */
main > section + section {
  border-top: 1px solid var(--ocha-rim-soft);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

/* Inner pages: same rim between major bands when <div class="ocha-page">…</div> is used instead of <section> */
main > .ocha-page + .ocha-page,
.commissions-page > .ocha-page + .ocha-page,
.stamps-page > .ocha-page + .ocha-page,
.comics-landing-section .comics-page-hero.ocha-page + .comics-list.ocha-page {
  border-top: 1px solid var(--ocha-rim-soft);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
  padding-top: 2.25rem;
}
.commissions-page > .commissions-page-hero + .tos-section {
  margin-top: 2rem;
}

/* Featured grid band: faint “menu paper” veil over --bg2 */
.gallery-section {
  position: relative;
}
.gallery-section::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.45;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)' opacity='0.05'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.gallery-section > * {
  position: relative;
  z-index: 1;
}

/* About strip: soft lamplight pool (very low) */
.about-section {
  position: relative;
}
.about-section::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse 90% 55% at 50% 0%, rgba(253, 242, 167, 0.05), transparent 58%);
  mix-blend-mode: screen;
}

/* Small “seal” dot after section labels & hero eyebrow */
.section-label::after,
.hero-eyebrow::after {
  content: '';
  flex-shrink: 0;
  width: 7px;
  height: 7px;
  margin-left: 0.2rem;
  border-radius: 50%;
  border: 1px solid rgba(107, 155, 160, 0.45);
  box-shadow:
    0 0 0 2px rgba(253, 242, 167, 0.04),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
  background: radial-gradient(circle at 32% 28%, rgba(255, 255, 255, 0.14), transparent 52%);
}

/* Nav: thin warm shelf edge under the bar */
nav {
  border-bottom: 1px solid var(--ocha-rim-soft);
}

/* Age gate card: inn desk mat feel (content stays readable) */
.gate-inner {
  padding: 1.75rem 1.5rem 2rem;
  border-radius: 1.25rem;
  border: 1px solid var(--ocha-rim);
  background: rgba(22, 24, 28, 0.72);
  box-shadow:
    0 1px 0 var(--ocha-inset-shine) inset,
    0 28px 64px rgba(0, 0, 0, 0.5);
}

/* Gallery tiles & comic cards: rim + inset highlight (coaster) */
.gallery-item {
  box-shadow:
    0 0 0 1px var(--ocha-rim-soft),
    0 1px 0 var(--ocha-inset-shine) inset,
    var(--ocha-card-shadow);
}

.comics-card {
  border: 1px solid var(--ocha-rim-soft);
  box-shadow:
    0 1px 0 var(--ocha-inset-shine) inset,
    var(--ocha-card-shadow);
}

/* Gallery hero filter chips only — avoid styling every future .filter-btn site-wide */
.gallery-page-hero .filter-btn {
  box-shadow: 0 1px 0 var(--ocha-inset-shine) inset;
}
.gallery-page-hero .filter-btn.active {
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.12) inset,
    0 0 0 1px var(--accent-yuzu-soft);
}

/* Commissions & about link cards */
.price-card,
.link-card {
  border-color: var(--ocha-rim-soft);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.2),
    0 1px 0 var(--ocha-inset-shine) inset,
    0 10px 28px rgba(0, 0, 0, 0.22);
}

.commissions-cta-panel {
  border: 1px solid var(--ocha-rim-soft);
  box-shadow:
    0 1px 0 var(--ocha-inset-shine) inset,
    0 16px 40px rgba(0, 0, 0, 0.28);
}

/* Keep left accent strip from 09-commission-cta; add only top inner highlight */
.commission-cta {
  box-shadow: 0 1px 0 var(--ocha-inset-shine) inset;
}

/* Newsletter: soft mat behind the form block */
.newsletter-inner {
  padding: 2rem 1.5rem 2.25rem;
  border-radius: 1.15rem;
  border: 1px solid var(--ocha-rim-soft);
  background: rgba(26, 29, 34, 0.35);
  box-shadow:
    0 1px 0 var(--ocha-inset-shine) inset,
    0 14px 36px rgba(0, 0, 0, 0.22);
}

/* Stamp rally progress pill */
.stamps-progress {
  box-shadow: 0 1px 0 var(--ocha-inset-shine) inset;
}

@media (prefers-reduced-motion: reduce) {
  .gate-inner {
    animation: none !important;
  }
}
