/*
  CLIENT: Cromen Barber — Cherooty Road, Kozhikode
  TYPE: Local premium men's barbershop
  ART DIRECTION: Editorial magazine meets vintage Americana barber. The brand's actual identity is monochrome — bone-white on ink-black with a single saturated barber-pole red. Bold display type with Fraunces italic accents. Big poster type, contact-sheet gallery, ledger-style tables, film grain, sharp edges. Feels like Issue 01 of a print magazine, not a SaaS template.
  PALETTE: ink (#0c0c0c), bone (#f5f1ea), red (#d92121), warm-grey (#a8a29a)
  TYPOGRAPHY: Bricolage Grotesque (display, variable opsz) + Inter Tight (body) + Fraunces (italic accents)
  DENSITY: Editorial — generous breathing at section level, dense info modules
*/

:root {
  --font-display: "Bricolage Grotesque", "Inter Tight", system-ui, sans-serif;
  --font-body: "Inter Tight", system-ui, -apple-system, sans-serif;
  --font-italic: "Fraunces", "Bricolage Grotesque", Georgia, serif;

  --fs-mega: clamp(4rem, 13vw, 12rem);
  --fs-h1: clamp(3rem, 7.4vw, 7rem);
  --fs-h2: clamp(2.4rem, 5vw, 4.4rem);
  --fs-h3: 1.4rem;
  --fs-lead: clamp(1.05rem, 1.4vw, 1.2rem);
  --fs-body: 1rem;
  --fs-eyebrow: 0.78rem;

  --s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:24px;
  --s-6:32px;--s-7:48px;--s-8:64px;--s-9:96px;--s-10:128px;--s-11:160px;

  --t-fast: 220ms cubic-bezier(.2,.7,.3,1);
  --t-med: 380ms cubic-bezier(.2,.7,.3,1);
  --t-slow: 700ms cubic-bezier(.2,.7,.3,1);

  /* Light theme — bone white paper + ink */
  --bg: #f5f1ea;
  --bg-deep: #ece6dc;
  --paper: #f8f4ed;
  --ink: #0c0c0c;
  --ink-2: #1a1a1a;
  --line: #1a1a1a;
  --line-soft: rgba(12,12,12,.14);
  --text: #0c0c0c;
  --text-muted: #4a4744;
  --text-faint: #8a8580;
  --red: #d92121;
  --red-deep: #b51717;
  --bone: #f5f1ea;
  --shadow: 0 1px 0 rgba(12,12,12,.06), 0 8px 24px -8px rgba(12,12,12,.18);
  --grain-op: 0.045;
}

[data-theme="dark"] {
  --bg: #0c0c0c;
  --bg-deep: #050505;
  --paper: #161616;
  --ink: #f5f1ea;
  --ink-2: #d6d2cb;
  --line: #f5f1ea;
  --line-soft: rgba(245,241,234,.14);
  --text: #f5f1ea;
  --text-muted: #a8a29a;
  --text-faint: #6f6a64;
  --red: #ff3838;
  --red-deep: #d92121;
  --shadow: 0 8px 30px rgba(0,0,0,.6);
  --grain-op: 0.08;
}

/* MAGAZINE-INVERTED SECTIONS — always render as a dark spread regardless of
   page theme. Without this, dark mode flips --ink to a light color and the
   poster/book/footer end up light-on-light = invisible text. */
.poster, .book, .foot, .m-row-feat, .m-badge-soft {
  --bg: #0c0c0c;
  --bg-deep: #050505;
  --paper: #161616;
  --ink: #0c0c0c;
  --ink-2: #1a1a1a;
  --line: #f5f1ea;
  --line-soft: rgba(245,241,234,.18);
  --text: #f5f1ea;
  --text-muted: #c4bfb8;
  --text-faint: #8a857f;
  --bone: #f5f1ea;
  --red: #ff3838;
}
[data-theme="light"] .poster,
[data-theme="light"] .book,
[data-theme="light"] .foot,
[data-theme="light"] .m-row-feat,
[data-theme="light"] .m-badge-soft { --red: #d92121; }

/* Inside the .book section, the .book-form card is meant to be a LIGHT card
   on the dark page. Reset variables back to light-card values for that card. */
.book .book-form {
  --bg: #f5f1ea;
  --bg-deep: #ece6dc;
  --paper: #f8f4ed;
  --ink: #0c0c0c;
  --line: #1a1a1a;
  --line-soft: rgba(12,12,12,.18);
  --text: #0c0c0c;
  --text-muted: #4a4744;
  --text-faint: #8a8580;
}

/* Reset */
*,*::before,*::after { box-sizing: border-box; margin:0; padding:0; }
html, body { overflow-x: clip; overscroll-behavior-y: none; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.5;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01","ss02";
  transition: background var(--t-med), color var(--t-med);
}
img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background:none; border:0; cursor:pointer; }
a { color: inherit; text-decoration: none; }
input, select, textarea { font: inherit; color: inherit; }

::selection { background: var(--red); color: var(--bone); }

.container { width: min(1320px, calc(100% - 56px)); margin-inline: auto; }
@media (max-width: 720px) { .container { width: calc(100% - 32px); } }

/* ── FILM GRAIN — always-on subtle texture ─────────────── */
.grain {
  position: fixed; inset: 0; z-index: 1000; pointer-events: none;
  opacity: var(--grain-op);
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='280' height='280' viewBox='0 0 280 280'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.95 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
[data-theme="dark"] .grain { mix-blend-mode: screen; }

/* ── HOURS BAR (top) ─────────────────────────────────────── */
.hours-bar {
  border-bottom: 1px solid var(--line);
  background: var(--ink);
  color: var(--bg);
  font-size: 0.74rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 9px 0;
  position: relative; z-index: 50;
  font-weight: 500;
}
.hours-bar .hb-phone:hover { color: var(--red); }
.hb-row { display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.hb-status { display: flex; align-items: center; gap: 10px; }
.dot { width: 7px; height: 7px; border-radius: 50%; background: var(--red); display: inline-block; }
.dot.live { animation: pulse 1.6s ease-in-out infinite; }
@keyframes pulse {
  0%,100% { transform: scale(1); opacity: 1; box-shadow: 0 0 0 0 rgba(217,33,33,.5); }
  70% { transform: scale(1.1); opacity: .9; box-shadow: 0 0 0 6px rgba(217,33,33,0); }
}
.hb-meta { display: flex; align-items: center; gap: 16px; }
.hb-meta .bar { width: 1px; height: 10px; background: currentColor; opacity: .35; }
.hb-phone { font-weight: 600; }
.hb-phone:hover { color: var(--red); }

@media (max-width: 760px) {
  .hb-meta { display: none; }
}

/* ── NAV ─────────────────────────────────────── */
.nav {
  position: sticky; top: 0; z-index: 100;
  background: var(--bg);
  border-bottom: 1px solid transparent;
  transition: background var(--t-med), border-color var(--t-med);
}
.nav.scrolled {
  background: color-mix(in srgb, var(--bg) 85%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom-color: var(--line-soft);
}
.nav-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 0;
  gap: 24px;
}

.brand { display: flex; align-items: center; gap: 12px; color: var(--ink); }
.brand-mark {
  flex-shrink: 0;
  width: 44px; height: 52px;
  object-fit: contain;
  mix-blend-mode: multiply;
}
[data-theme="dark"] .brand-mark {
  mix-blend-mode: screen;
  filter: invert(1);
}
.brand-text { display: flex; flex-direction: column; line-height: 0.95; }
.brand-text strong {
  font-family: var(--font-display);
  font-weight: 700; font-size: 1.6rem;
  letter-spacing: -0.03em; font-variation-settings: "opsz" 96;
}
.brand-text em {
  font-style: normal;
  font-size: 0.7rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--text-faint);
  margin-top: 4px;
}

.primary { display: flex; gap: 28px; }
.primary a {
  font-size: 0.92rem; font-weight: 500;
  color: var(--text-muted);
  position: relative;
  transition: color var(--t-fast);
  padding: 4px 0;
}
.primary a::after {
  content: ""; position: absolute; left: 0; bottom: 0;
  width: 0; height: 1px; background: var(--ink);
  transition: width var(--t-med);
}
.primary a:hover { color: var(--ink); }
.primary a:hover::after { width: 100%; }

.actions { display: flex; align-items: center; gap: 14px; }

.theme {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  border: 1px solid var(--line-soft);
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  font-weight: 600;
}
.theme-l, .theme-r { color: var(--text-faint); transition: color var(--t-fast); }
.theme-track {
  width: 28px; height: 14px; border-radius: 999px;
  background: var(--ink);
  position: relative;
}
.theme-dot {
  position: absolute; left: 2px; top: 2px;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--bg);
  transition: transform var(--t-med);
}
[data-theme="dark"] .theme-dot { transform: translateX(14px); }
[data-theme="dark"] .theme-l { color: var(--text-faint); }
[data-theme="dark"] .theme-r { color: var(--text); }
[data-theme="light"] .theme-l { color: var(--text); }

.cta-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 16px;
  background: var(--ink); color: var(--bg);
  font-weight: 600; font-size: 0.85rem;
  border-radius: 0;  /* SHARP — no rounded */
  transition: background var(--t-fast), color var(--t-fast);
}
.cta-pill:hover { background: var(--red); color: #fff; }

.hamb {
  display: none; width: 40px; height: 40px;
  border: 1px solid var(--line-soft);
  flex-direction: column; gap: 5px; align-items: center; justify-content: center;
}
.hamb span { width: 16px; height: 1.5px; background: var(--ink); transition: var(--t-fast); }
.hamb.open span:nth-child(1) { transform: translateY(3.25px) rotate(45deg); }
.hamb.open span:nth-child(2) { transform: translateY(-3.25px) rotate(-45deg); }

@media (max-width: 980px) {
  .primary { display: none; }
  .hamb { display: flex; }
  .cta-pill { display: none; }
}

/* Mobile menu */
.mob {
  position: fixed; inset: 0; z-index: 95;
  background: var(--bg); padding-top: 100px;
  transform: translateY(-100%);
  transition: transform 500ms cubic-bezier(.7,0,.3,1);
}
.mob.open { transform: translateY(0); }
.mob-inner { padding: 32px 24px; }
.mob a {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--font-display); font-weight: 700;
  font-size: 2.4rem; padding: 18px 0;
  border-bottom: 1px solid var(--line-soft);
  font-variation-settings: "opsz" 96;
  letter-spacing: -0.03em;
}
.mob a i { font-style: normal; font-size: 0.7rem; color: var(--text-faint); letter-spacing: 0.2em; }
.mob-foot { display: flex; justify-content: space-between; padding-top: 28px; }
.mob-foot a { font-size: 0.95rem; padding: 0; border: 0; font-family: var(--font-body); }

/* ══════════════════════════════════════════════════════════
   HERO — split editorial cover.
   Image stage uses aspect-ratio: 3/4 so source photos (1440×1920 = 3:4)
   render at their natural shape with ZERO cropping or stretching.
   Stage HEIGHT is the responsive variable; width derives from aspect-ratio.
   ══════════════════════════════════════════════════════════ */
.hero {
  position: relative;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.hero-grid {
  display: flex;
  align-items: center;
  gap: clamp(24px, 4vw, 64px);
  padding: clamp(20px, 3vw, 48px) clamp(20px, 4vw, 64px);
  min-height: 86dvh;
}

/* LEFT: content side — flexes to fill remaining width */
.hero-content {
  flex: 1 1 0;
  min-width: 0;
  display: flex; flex-direction: column;
  justify-content: center;
  gap: 26px;
  position: relative;
  background: var(--bg);
  max-width: 640px;
}

.hero-folio {
  display: flex; align-items: center; gap: 14px;
  color: var(--ink);
  font-family: var(--font-display);
}
.hero-folio .folio {
  font-weight: 700; font-size: 1rem;
  letter-spacing: 0.02em;
  font-variation-settings: "opsz" 14;
}
.hero-folio .folio-bar { display: block; width: 32px; height: 1px; background: var(--ink); opacity: .8; }
.hero-folio .folio-meta {
  font-size: 0.74rem; letter-spacing: 0.18em; text-transform: uppercase;
  font-weight: 500; color: var(--text-muted);
}

.hero-copy { display: flex; flex-direction: column; gap: 22px; max-width: 560px; }

.hero-h1 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(3rem, 6.5vw, 6.4rem);
  line-height: 0.86;
  letter-spacing: -0.04em;
  color: var(--ink);
  font-variation-settings: "opsz" 96;
}
.hh-line { display: block; }
.hh-italic {
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  letter-spacing: -0.025em;
  color: var(--text-muted);
}

.hero-tagline {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  letter-spacing: 0.02em;
  color: var(--ink);
  margin-top: -8px;
}
.hero-meta {
  font-size: 0.95rem;
  color: var(--text-muted);
  line-height: 1.55;
  margin-top: -14px;
}

.hero-cta-row {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  margin-top: 4px;
}

.btn-hero {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 26px;
  background: var(--ink);
  color: var(--bg);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
  border: 1px solid var(--ink);
  font-variation-settings: "opsz" 14;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
  box-shadow: 0 12px 30px -10px rgba(0,0,0,.35);
}
.btn-hero:hover { background: var(--red); color: #fff; border-color: var(--red); }

.hero-link-arrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 600; color: var(--ink);
  font-size: 0.92rem;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: color var(--t-fast);
}
.hero-link-arrow:hover { color: var(--red); }
.hero-link-arrow svg { transition: transform var(--t-fast); }
.hero-link-arrow:hover svg { transform: translateX(4px); }

.hero-rating {
  display: flex; align-items: center; gap: 12px;
  margin-top: 10px;
  padding-top: 16px;
  border-top: 1px solid var(--line-soft);
  flex-wrap: wrap;
}
.hr-stars { color: var(--red); letter-spacing: 0.18em; font-size: 0.95rem; }
.hr-text { font-size: 0.84rem; color: var(--text-muted); }
.hr-text b { font-family: var(--font-display); font-weight: 700; color: var(--ink); }

.hero-foot-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
  padding-top: 20px;
  border-top: 1px solid var(--line-soft);
}
.hero-live-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 7px 13px;
  border: 1px solid var(--ink);
  font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase;
  font-weight: 600;
  color: var(--ink);
}
.hero-live-pill .dot { width: 7px; height: 7px; }

.hero-credit-inline {
  display: flex; align-items: baseline; gap: 8px;
  font-family: var(--font-italic);
}
.hero-credit-inline em {
  font-style: normal;
  font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--text-faint); font-weight: 600;
}
.hero-credit-inline span {
  font-style: italic;
  font-size: 1rem;
  color: var(--ink);
}

/* RIGHT: image stage — fixed height, aspect 3:4 derives width.
   Source photos are 1440×1920 (3:4) so cover does not crop. */
.hero-stage {
  flex: 0 0 auto;
  position: relative;
  height: clamp(440px, 76vh, 820px);
  aspect-ratio: 3 / 4;
  width: auto;
  background: #1a1a1a;
  overflow: hidden;
  border: 1px solid var(--ink);
  box-shadow: 0 18px 60px -18px rgba(0,0,0,.35);
}
.hero-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0;
  transition: opacity 1200ms cubic-bezier(.45,.05,.25,1);
  will-change: opacity;
}
.hero-img.active { opacity: 1; }
/* Per-image fine-tuning of object-position so faces stay centred when the
   source image isn't exactly 3:4. */
.hero-img[src*="shop-interior"] { object-position: 60% center; }
.hero-img[src*="hero-fade"]     { object-position: 60% 35%; }
.hero-img[src*="portrait-fade"] { object-position: 55% 20%; }
.hero-img.active { animation: kenburns 26s ease-in-out infinite alternate; }
@keyframes kenburns {
  0%   { transform: scale(1.0); }
  100% { transform: scale(1.04); }
}

.hero-stage-overlay {
  position: absolute;
  bottom: 20px; left: 20px; right: 20px;
  z-index: 3;
  display: flex; align-items: center; justify-content: space-between;
  pointer-events: none;
}
.hso-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  color: #f5f1ea;
  text-shadow: 0 1px 6px rgba(0,0,0,.6);
}
.hero-dots {
  display: flex; gap: 8px;
  pointer-events: auto;
}
.hero-dots button {
  width: 28px; height: 2px;
  background: rgba(245,241,234,.45);
  border: 0; padding: 0; cursor: pointer;
  transition: background var(--t-fast), width var(--t-fast);
}
.hero-dots button.active { background: #f5f1ea; width: 36px; }

/* ── Tablet ── */
@media (max-width: 1080px) {
  .hero-grid { gap: 32px; min-height: 76dvh; }
  .hero-stage { height: clamp(420px, 70vh, 700px); }
  .hero-h1 { font-size: clamp(2.6rem, 6.5vw, 4.6rem); }
}

/* ── Stack on smaller laptop / tablet portrait ── */
@media (max-width: 880px) {
  .hero-grid {
    flex-direction: column;
    align-items: stretch;
    gap: 28px;
    padding: 28px clamp(20px, 5vw, 32px) 36px;
    min-height: 0;
  }
  .hero-stage {
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 4;
    order: -1; /* image first */
    max-height: 80vh;
  }
  .hero-content {
    max-width: none;
    gap: 20px;
  }
  .hero-h1 { font-size: clamp(2.6rem, 10vw, 4.2rem); line-height: 0.88; }
  .hero-tagline { font-size: 1.05rem; }
  .hero-meta { font-size: 0.92rem; }
  .hero-cta-row { gap: 12px; }
  .btn-hero { padding: 14px 22px; }
  .hero-foot-row { padding-top: 16px; }
  .hero-live-pill { font-size: 0.66rem; padding: 6px 10px; }
}

/* ── Very small phones ── */
@media (max-width: 420px) {
  .btn-hero { width: 100%; justify-content: center; }
  .hero-cta-row { flex-direction: column; align-items: stretch; }
  .hero-link-arrow { justify-content: center; }
}

/* ══════════════════════════════════════════════════════════
   POSTER MOMENT — big editorial type + image inset (after marquee)
   ══════════════════════════════════════════════════════════ */
.poster-moment {
  padding: var(--s-11) 0;
  border-bottom: 1px solid var(--line);
}
.pm-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 64px;
  align-items: end;
}
.pm-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(3rem, 8vw, 7.5rem);
  line-height: 0.86;
  letter-spacing: -0.045em;
  color: var(--ink);
  font-variation-settings: "opsz" 96;
  margin: 32px 0 28px;
}
.pm-line { display: block; }
.pm-italic {
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 500;
  color: var(--text-muted);
  font-variation-settings: "opsz" 144;
}
.pm-red { color: var(--red); }
.pm-sub {
  font-size: var(--fs-lead);
  color: var(--text-muted);
  max-width: 50ch;
  line-height: 1.55;
  margin-bottom: 28px;
}
.pm-actions { display: flex; gap: 12px; }

.pm-fig {
  position: relative;
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 12px;
}
.pm-fig img {
  width: 100%; aspect-ratio: 3/4;
  object-fit: cover;
  display: block;
}
.pm-fig figcaption {
  display: flex; align-items: baseline; gap: 12px;
  padding: 10px 4px 4px;
  margin-top: 8px;
  border-top: 1px solid var(--ink);
  font-family: var(--font-display);
}
.pm-fig figcaption span {
  font-weight: 800; color: var(--red); font-size: 1.1rem;
}
.pm-fig figcaption em {
  font-style: normal; font-size: 0.74rem;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-muted); font-weight: 600;
}

@media (max-width: 880px) {
  .pm-grid { grid-template-columns: 1fr; gap: 32px; }
  .pm-right { max-width: 380px; }
}

/* === Legacy hero rules below — unused selectors, kept inert.
   .btn-solid and .btn-line are still used elsewhere on the page. === */

.hero-wm {
  position: absolute;
  bottom: -2vw; left: 50%; transform: translateX(-50%);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(10rem, 24vw, 28rem);
  line-height: 0.78;
  letter-spacing: -0.06em;
  color: var(--ink);
  opacity: 0.06;
  white-space: nowrap;
  pointer-events: none;
  z-index: 0;
  font-variation-settings: "opsz" 96, "wdth" 100;
}

/* (legacy 3-col hero-grid removed — new split layout defined above) */

/* Left rail — vertical metadata */
.rail {
  display: flex; flex-direction: column; justify-content: space-between;
  height: 100%;
  padding-top: 8px;
  position: sticky; top: 100px;
}
.rail-stack { display: flex; flex-direction: column; gap: 14px; }
.folio {
  font-family: var(--font-display);
  font-weight: 700; font-size: 1rem;
  letter-spacing: 0.04em;
  font-variation-settings: "opsz" 14;
}
.rail-line { display: block; width: 32px; height: 1px; background: var(--ink); }
.rail-meta {
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 500;
}
.rail-bot { display: flex; flex-direction: column; gap: 4px; }
.rail-photog {
  font-size: 0.7rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--text-faint);
}
.rail-photog-name {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: 1.1rem; color: var(--text);
  font-weight: 500;
}

/* Centre — poster type */
.hero-poster { display: flex; flex-direction: column; gap: 32px; min-width: 0; }

.hero-tag {
  display: inline-flex; align-items: center; gap: 10px; align-self: flex-start;
  padding: 7px 14px;
  border: 1px solid var(--ink);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
}
.hero-tag-dot {
  width: 5px; height: 5px; background: var(--red);
  border-radius: 50%;
  animation: pulse 1.6s ease-in-out infinite;
}

.hero-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--fs-h1);
  line-height: 0.88;
  letter-spacing: -0.045em;
  color: var(--ink);
  font-variation-settings: "opsz" 96, "wdth" 100;
}
.ht-line { display: block; }
.ht-italic {
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  letter-spacing: -0.03em;
  color: var(--text-muted);
}
.ht-red { color: var(--red); position: relative; display: inline-block; }
.ht-red::after {
  content: ""; position: absolute; right: -0.15em; bottom: 0.05em;
  width: 0.18em; height: 0.18em; border-radius: 50%;
  background: var(--red);
}

.hero-foot {
  display: flex; gap: 48px; align-items: flex-end;
  padding-top: 28px;
  border-top: 1px solid var(--ink);
  flex-wrap: wrap;
}
.hero-sub {
  flex: 1; min-width: 280px; max-width: 52ch;
  font-size: var(--fs-lead);
  line-height: 1.55;
  color: var(--text-muted);
}
.hero-sub em { color: var(--ink); font-style: normal; font-weight: 600; }

.hero-actions { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }

.btn-solid {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 22px;
  background: var(--ink); color: var(--bg);
  font-weight: 600; font-size: 0.95rem;
  border: 1px solid var(--ink);
  transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast);
}
.btn-solid:hover { background: var(--red); border-color: var(--red); color: #fff; }
.btn-line {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 22px;
  background: transparent; color: var(--ink);
  font-weight: 600; font-size: 0.95rem;
  border: 1px solid var(--ink);
  transition: background var(--t-fast), color var(--t-fast);
}
.btn-line:hover { background: var(--ink); color: var(--bg); }

/* Hero pic / poster card */
.hero-pic {
  position: relative;
  align-self: stretch;
}
.poster-card {
  position: relative;
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 12px;
  box-shadow: var(--shadow);
}
.poster-card .ph {
  width: 100%;
  aspect-ratio: 3/4;
  margin-bottom: 12px;
}
.poster-card figcaption {
  display: flex; gap: 14px; padding: 4px 4px 6px;
  font-family: var(--font-display);
  border-top: 1px solid var(--ink);
  padding-top: 10px;
  margin-top: 4px;
}
.cap-num { font-weight: 800; color: var(--red); font-size: 1.2rem; line-height: 1; }
.cap-text { font-size: 0.76rem; color: var(--text-muted); letter-spacing: 0.06em; text-transform: uppercase; line-height: 1.4; font-weight: 500; }

.sticker {
  position: absolute; top: -14px; right: -28px;
  width: 84px; height: 84px;
  color: var(--red);
  z-index: 4;
  animation: rotate 24s linear infinite;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.18));
}
@keyframes rotate { to { transform: rotate(360deg); } }

@media (max-width: 720px) {
  .hero-grid { grid-template-columns: 1fr; gap: 24px; }
  .rail { position: static; flex-direction: row; gap: 24px; align-items: center; }
  .rail-stack { flex-direction: row; flex-wrap: wrap; align-items: center; }
  .rail-line { display: none; }
  .rail-bot { display: none; }
  .hero-foot { gap: 24px; }
}

/* Image holder — real photos fill, fallback placeholder pattern shows for empty .ph */
.ph {
  position: relative;
  display: flex; align-items: flex-end; justify-content: flex-start;
  overflow: hidden;
  background:
    linear-gradient(135deg, transparent 49.5%, var(--line-soft) 49.5%, var(--line-soft) 50.5%, transparent 50.5%),
    linear-gradient(45deg, transparent 49.5%, var(--line-soft) 49.5%, var(--line-soft) 50.5%, transparent 50.5%),
    var(--bg-deep);
  border: 1px solid var(--line-soft);
}
.ph img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 800ms cubic-bezier(.2,.7,.3,1);
}
.frame:hover .ph img,
.poster-card:hover .ph img,
.block-figure:hover .ph img { transform: scale(1.04); }
.ph::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.42));
  opacity: 0;
  transition: opacity var(--t-med);
  pointer-events: none;
}
.frame:hover .ph::after { opacity: 1; }
.ph-label {
  position: relative; z-index: 2;
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-faint);
  font-weight: 500;
  font-family: monospace;
  background: var(--paper);
  padding: 4px 8px;
  margin: 14px;
  border: 1px solid var(--line-soft);
}
[data-theme="dark"] .ph { background: #1f1f1f; }

/* Hero strip marquee — always inverse from page */
.hero-strip {
  border-top: 1px solid var(--line);
  background: var(--ink);
  color: var(--bg);
  overflow: hidden;
  padding: 14px 0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 24;
}
.strip-track {
  display: flex; gap: 0;
  white-space: nowrap;
  animation: marquee 50s linear infinite;
  width: max-content;
}
.strip-track span {
  padding: 0 16px;
}
@keyframes marquee {
  to { transform: translateX(-50%); }
}

/* ── DISPLAY HEADING (used in many sections) ─────────── */
.display-h {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--fs-h2);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-variation-settings: "opsz" 96;
  max-width: 18ch;
}
.display-h em {
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
}
.dh-light { color: var(--bone); }

.circled {
  display: inline-block;
  position: relative;
}
.circled::after {
  content: ""; position: absolute;
  inset: -8% -10%;
  border: 2px solid var(--red);
  border-radius: 50%;
  transform: rotate(-3deg);
  pointer-events: none;
}

.folio-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 24px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--ink);
  font-variation-settings: "opsz" 14;
}
.folio-tag::before {
  content: ""; width: 6px; height: 6px; background: var(--red); border-radius: 50%;
  display: inline-block;
}
.folio-light { color: var(--bone); border-bottom-color: var(--bone); }

/* ── THE CHAIR (about) ─────────────────────────────────── */
.chair {
  padding: var(--s-11) 0 var(--s-9);
  border-bottom: 1px solid var(--line);
}
.chair-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr 0.9fr;
  gap: var(--s-8);
  align-items: start;
  margin-bottom: var(--s-9);
}
.chair-mid p { color: var(--text-muted); margin-bottom: 16px; line-height: 1.7; max-width: 50ch; }
.big-p {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.35;
  color: var(--ink) !important;
  letter-spacing: -0.015em;
  font-variation-settings: "opsz" 24;
}

.chair-right { padding-top: 60px; }
.block-figure {
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 12px;
}
.block-figure .ph { aspect-ratio: 3/4; width: 100%; }
.ph-tall { aspect-ratio: 3/4; }
.block-figure figcaption {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: 0.92rem;
  color: var(--text-muted);
  padding: 10px 4px 4px;
}

@media (max-width: 1080px) {
  .chair-grid { grid-template-columns: 1fr 1fr; gap: 48px; }
  .chair-right { grid-column: span 2; padding-top: 0; max-width: 480px; }
}
@media (max-width: 720px) {
  .chair-grid { grid-template-columns: 1fr; gap: 32px; }
  .chair-right { grid-column: span 1; }
}

/* Ledger stats */
.ledger {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border: 1px solid var(--ink);
  background: var(--paper);
}
.led-cell {
  padding: 28px 22px;
  border-right: 1px solid var(--ink);
  display: flex; flex-direction: column; gap: 8px;
}
.led-cell:last-child { border-right: 0; }
.led-label {
  font-size: 0.7rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--text-faint);
  font-weight: 500;
}
.led-cell strong {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 3.4vw, 3rem);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-variation-settings: "opsz" 48;
}
.stat-num-static { color: var(--red) !important; }

@media (max-width: 1080px) {
  .ledger { grid-template-columns: repeat(2, 1fr); }
  .led-cell { border-right: 0; border-bottom: 1px solid var(--ink); }
  .led-cell:nth-child(odd) { border-right: 1px solid var(--ink); }
  .led-cell:last-child { grid-column: span 2; border-bottom: 0; }
}

/* ── MENU (services as magazine list) ─────────── */
.menu {
  padding: var(--s-11) 0;
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}
.menu-head {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 48px;
  align-items: end;
  margin-bottom: var(--s-9);
  padding-bottom: 32px;
  border-bottom: 1px solid var(--ink);
}
.menu-head-r p { color: var(--text-muted); margin-bottom: 12px; }
.link-arrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 600; color: var(--ink);
  position: relative;
}
.link-arrow span { transition: transform var(--t-fast); display: inline-block; }
.link-arrow:hover span { transform: translateX(4px); }
.link-arrow:hover { color: var(--red); }

.menu-list { border-top: 1px solid var(--ink); }
.m-row {
  display: grid;
  grid-template-columns: 80px 1fr 200px;
  gap: 32px;
  padding: 32px 0;
  border-bottom: 1px solid var(--ink);
  align-items: center;
  position: relative;
  transition: padding var(--t-med);
}
.m-row:hover { padding-left: 16px; padding-right: 16px; background: var(--bg); }

.m-row-feat {
  background: var(--ink);
  color: var(--bone);
  margin: 0 -32px;
  padding: 32px;
  border-bottom-color: var(--ink);
}
.m-row-feat .m-num { color: var(--red); }
.m-row-feat .m-name h3, .m-row-feat .m-price strong { color: var(--bone); }
.m-row-feat .m-name p, .m-row-feat .m-time, .m-row-feat .m-price em { color: var(--text-muted); }
.m-row-feat .m-num { color: var(--red); }
.m-row-feat:hover { padding-left: 32px; padding-right: 32px; background: var(--ink); }

.m-num {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 2.4rem;
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.04em;
  font-variation-settings: "opsz" 48;
}
.m-name h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
  color: var(--ink);
  font-variation-settings: "opsz" 24;
}
.m-name p { color: var(--text-muted); max-width: 56ch; line-height: 1.55; margin-bottom: 8px; }
.m-time {
  font-size: 0.72rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--text-faint); font-weight: 600;
}
.m-badge {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.66rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--red); color: var(--bone);
  padding: 3px 8px;
  margin-left: 8px;
  vertical-align: middle;
  font-weight: 700;
}
.m-badge-soft { background: var(--ink); }
.m-row-feat .m-badge { background: var(--red); }

.m-price {
  text-align: right;
  display: flex; flex-direction: column; align-items: flex-end; gap: 4px;
}
.m-price em {
  font-style: normal; font-size: 0.7rem;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-faint);
  font-weight: 500;
}
.m-price strong {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.8rem;
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 24;
}

@media (max-width: 880px) {
  .menu-head { grid-template-columns: 1fr; gap: 24px; }
  .m-row { grid-template-columns: 50px 1fr; }
  .m-price { grid-column: span 2; align-items: flex-start; flex-direction: row; gap: 12px; padding-left: 50px; }
  .m-row-feat { margin: 0 -16px; padding: 24px 16px; }
}

.menu-foot {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: var(--s-7); gap: 24px; flex-wrap: wrap;
}
.menu-foot p { color: var(--text-muted); font-size: 0.92rem; max-width: 50ch; }

/* ── POSTER BREAK ─────────────────────────────────────── */
.poster {
  background: var(--ink); color: var(--bone);
  padding: var(--s-11) 0;
  position: relative; overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.poster .container { text-align: center; position: relative; z-index: 2; }
.poster-rail {
  display: inline-flex; gap: 16px; align-items: center;
  font-size: 0.74rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: 32px;
}
.poster-rail .bar { width: 24px; height: 1px; background: var(--text-faint); }
.poster-h {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--fs-mega);
  line-height: 0.86;
  letter-spacing: -0.05em;
  font-variation-settings: "opsz" 96;
  display: flex; flex-direction: column; gap: 4px;
}
.poster-h span:first-child, .poster-h span:nth-child(3) { color: var(--bone); }
.poster-italic {
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 500;
  color: var(--text-muted) !important;
  font-variation-settings: "opsz" 144;
}
.poster-red { color: var(--red) !important; }
.poster-fine {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: 1rem;
  color: var(--text-faint);
  margin-top: 32px;
}

/* ── FEED (gallery — contact sheet) ─────────── */
.feed {
  padding: var(--s-11) 0;
  border-bottom: 1px solid var(--line);
}
.feed-head {
  display: flex; justify-content: space-between; align-items: end;
  margin-bottom: var(--s-8);
  gap: 24px; flex-wrap: wrap;
}
.ig-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px;
  background: var(--ink); color: var(--bg);
  font-size: 0.85rem; font-weight: 500;
  transition: background var(--t-fast), color var(--t-fast);
}
.ig-pill:hover { background: var(--red); color: #fff; }

.sheet {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.frame {
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 8px;
  position: relative;
  overflow: hidden;
  display: flex; flex-direction: column;
  aspect-ratio: 4 / 5;
}
.frame .ph {
  flex: 1;
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  min-height: 0;
}
.frame figcaption {
  padding: 8px 4px 2px;
  font-family: var(--font-display);
  display: flex; justify-content: space-between; align-items: baseline;
  border-top: 1px dashed var(--line-soft);
  margin-top: 8px;
  gap: 10px;
}
.frame figcaption span {
  font-weight: 800; color: var(--red);
  font-size: 0.95rem;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 14;
}
.frame figcaption em {
  font-style: normal;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-muted);
}
/* Uniform 4:5 portrait frames — works cleanly with portrait-source photos */
@media (max-width: 880px) {
  .sheet { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
}
@media (max-width: 460px) {
  .sheet { grid-template-columns: 1fr; }
}

.feed-foot {
  margin-top: 24px;
  text-align: center;
  font-family: var(--font-italic);
  font-style: italic;
  color: var(--text-muted);
  font-size: 0.95rem;
}
.feed-foot a { color: var(--ink); border-bottom: 1px solid currentColor; }
.feed-foot a:hover { color: var(--red); }

/* ── RITUAL — sticky image + numbered list ──────── */
.ritual {
  padding: var(--s-11) 0;
  border-bottom: 1px solid var(--line);
}
.ritual-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: clamp(40px, 6vw, 96px);
  align-items: start;
}
.ritual-aside {
  position: sticky; top: 100px;
  display: flex; flex-direction: column; gap: 28px;
}
.ritual-fig {
  position: relative;
  border: 1px solid var(--ink);
  background: var(--paper);
  padding: 10px;
  overflow: hidden;
}
.ritual-fig img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}
.ritual-fig figcaption {
  display: flex; align-items: baseline; gap: 12px;
  padding: 12px 4px 4px;
  margin-top: 6px;
  border-top: 1px solid var(--ink);
  font-family: var(--font-display);
}
.rf-num { font-weight: 800; color: var(--red); font-size: 1.1rem; }
.ritual-fig figcaption em {
  font-style: normal; font-size: 0.74rem;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-muted); font-weight: 600;
}
.ritual-aside-meta .display-h { max-width: 16ch; }

.rituals {
  list-style: none;
  display: flex; flex-direction: column;
  border-top: 1px solid var(--ink);
}
.rituals li {
  border-bottom: 1px solid var(--ink);
  padding: 26px 0;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 20px;
  align-items: baseline;
  position: relative;
  transition: padding-left var(--t-med);
}
.rituals li:hover { padding-left: 12px; }
.r-num {
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 500;
  font-size: 1.8rem;
  color: var(--red);
  font-variation-settings: "opsz" 24;
  line-height: 1;
}
.rituals h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--ink);
  font-variation-settings: "opsz" 24;
  margin-bottom: 8px;
}
.rituals p {
  color: var(--text-muted);
  line-height: 1.6;
  font-size: 0.98rem;
  max-width: 46ch;
}

@media (max-width: 980px) {
  .ritual-grid { grid-template-columns: 1fr; gap: 48px; }
  .ritual-aside { position: static; }
  .ritual-aside { flex-direction: column-reverse; }
  .ritual-fig img { aspect-ratio: 16 / 10; }
}
@media (max-width: 540px) {
  .rituals li { grid-template-columns: 40px 1fr; gap: 14px; padding: 22px 0; }
  .r-num { font-size: 1.4rem; }
  .rituals h3 { font-size: 1.2rem; }
}

/* ── BAND — full-bleed cinematic photo break ──────── */
.band {
  position: relative;
  min-height: clamp(420px, 64vh, 680px);
  display: grid; align-items: center;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  background: #0c0c0c;
}
.band-img { position: absolute; inset: 0; }
.band-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 30%;
}
.band-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(8,8,8,.86) 0%, rgba(8,8,8,.55) 45%, rgba(8,8,8,.2) 100%),
    linear-gradient(180deg, rgba(8,8,8,.3) 0%, rgba(8,8,8,0) 30%, rgba(8,8,8,.4) 100%);
}
.band-content {
  position: relative; z-index: 2;
  color: #f5f1ea;
  padding-block: 64px;
}
.band-eyebrow {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: #ff3838;
  margin-bottom: 24px;
}
.band-quote {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.7rem, 4vw, 3.4rem);
  line-height: 1.16;
  letter-spacing: -0.02em;
  max-width: 20ch;
  color: #f5f1ea;
  font-variation-settings: "opsz" 48;
  text-shadow: 0 2px 30px rgba(0,0,0,.5);
}
.band-quote em {
  font-family: var(--font-italic);
  font-style: italic;
  color: #ff3838;
  font-weight: 500;
}
.band-sign {
  display: flex; align-items: center; gap: 16px;
  margin-top: 32px;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  color: rgba(245,241,234,.8);
}
.band-line { width: 48px; height: 1px; background: rgba(245,241,234,.5); }

@media (max-width: 720px) {
  .band-overlay {
    background: linear-gradient(180deg, rgba(8,8,8,.45) 0%, rgba(8,8,8,.55) 50%, rgba(8,8,8,.8) 100%);
  }
}

/* ── PREMIUM: cursor follower (desktop) ──── */
.cursor-dot {
  position: fixed; top: 0; left: 0;
  width: 10px; height: 10px;
  margin: -5px 0 0 -5px;
  border-radius: 50%;
  background: var(--red);
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: normal;
  transition: width .25s, height .25s, margin .25s, background .25s, opacity .25s;
  will-change: transform;
}
.cursor-dot--grow {
  width: 44px; height: 44px;
  margin: -22px 0 0 -22px;
  background: transparent;
  border: 1px solid var(--red);
}

/* ── PREMIUM: clip-path image reveal on scroll ──── */
.reveal-img { position: relative; }
.reveal-img img {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1100ms cubic-bezier(.7,0,.2,1);
  transform: scale(1.04);
}
.reveal-img.revealed img {
  clip-path: inset(0 0 0 0);
  transform: scale(1);
  transition: clip-path 1100ms cubic-bezier(.7,0,.2,1), transform 1400ms cubic-bezier(.7,0,.2,1);
}
@media (prefers-reduced-motion: reduce) {
  .reveal-img img { clip-path: none !important; transform: none !important; }
}

/* ── REVIEWS / TESTIMONIALS ─────────────────────── */
.reviews {
  padding: var(--s-10) 0;
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}
.reviews-row {
  display: grid;
  grid-template-columns: 60px 1fr 1fr;
  gap: 48px;
  align-items: start;
}
.rv-mark { color: var(--red); }
.rv-quote {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.5rem, 3vw, 2.4rem);
  line-height: 1.25;
  color: var(--ink);
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 48;
}
.rv-quote em {
  font-family: var(--font-italic);
  font-style: italic;
  color: var(--red);
  font-weight: 500;
}
.rv-by { margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--ink); }
.rv-by strong {
  font-family: var(--font-display); font-weight: 700;
  font-size: 1.05rem; display: block;
}
.rv-by span { font-size: 0.85rem; color: var(--text-muted); }

.rv-list { display: flex; flex-direction: column; gap: 18px; }
.rv-mini {
  padding: 18px;
  border: 1px solid var(--ink);
  background: var(--bg);
}
.rv-mini .rv-stars { color: var(--red); font-size: 0.85rem; letter-spacing: 0.1em; }
.rv-mini p { font-size: 0.95rem; color: var(--ink); margin: 8px 0; line-height: 1.5; }
.rv-mini em { font-style: normal; font-size: 0.74rem; color: var(--text-muted); letter-spacing: 0.06em; }

@media (max-width: 1080px) { .reviews-row { grid-template-columns: 1fr; } .rv-mark { display: none; } }

/* ── BOOK ─────────────────────────────────────── */
.book {
  background: var(--ink);
  color: var(--bone);
  padding: var(--s-11) 0;
  position: relative; overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.book-grid {
  display: grid;
  grid-template-columns: 1fr 460px;
  gap: 64px;
  align-items: start;
}
.book-blurb { color: var(--text-faint); margin: 16px 0 32px; max-width: 50ch; line-height: 1.6; }

.visit-card {
  border: 1px solid var(--bone);
  background: var(--ink);
  position: relative;
}
.vc-head {
  display: flex; justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--bone);
  background: var(--bone); color: var(--ink);
  font-family: var(--font-display);
}
.vc-stamp {
  font-weight: 700; font-size: 0.78rem;
  letter-spacing: 0.2em;
  font-variation-settings: "opsz" 14;
}
.vc-num { font-weight: 800; font-size: 1rem; color: var(--red); }
.vc-body { padding: 18px; display: flex; flex-direction: column; gap: 14px; }
.vc-row { display: grid; grid-template-columns: 130px 1fr; gap: 14px; align-items: baseline; padding-bottom: 12px; border-bottom: 1px dashed rgba(245,241,234,.18); }
.vc-row:last-child { border-bottom: 0; padding-bottom: 0; }
.vc-row em {
  font-style: normal; font-size: 0.7rem;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-faint); font-weight: 500;
}
.vc-row strong { font-family: var(--font-display); font-weight: 600; font-size: 0.95rem; color: var(--bone); line-height: 1.4; }
.vc-row strong a { color: var(--red); }
.vc-foot {
  display: flex; align-items: center; gap: 8px;
  padding: 14px 18px;
  border-top: 1px solid var(--bone);
  font-size: 0.74rem; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 600; color: var(--bone);
}

/* form */
.book-form {
  background: var(--bone);
  color: var(--ink);
  border: 1px solid var(--bone);
  position: relative;
}
.bf-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 18px;
  border-bottom: 1px dashed rgba(12,12,12,.25);
  font-family: var(--font-display);
}
.bf-tag { font-weight: 700; font-size: 0.78rem; letter-spacing: 0.2em; }
.bf-num { color: var(--red); font-weight: 800; }
.book-form { overflow: hidden; }
.bf-body {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
  padding: 24px;
  min-width: 0;
}
.book-form label { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.book-form .full { grid-column: span 2; }
.book-form span {
  font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-muted); font-weight: 600;
}
.book-form span i { font-style: normal; text-transform: none; letter-spacing: 0.02em; color: var(--text-faint); }
.book-form input, .book-form select, .book-form textarea {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
  background: var(--paper);
  border: 1px solid var(--line-soft);
  padding: 12px 14px;
  font-size: 0.95rem;
  color: var(--ink);
  transition: border-color var(--t-fast), background var(--t-fast);
  font-family: inherit;
  display: block;
}
.book-form input:focus, .book-form select:focus, .book-form textarea:focus {
  outline: 0; border-color: var(--ink); background: var(--bone);
}
.book-form textarea { resize: vertical; min-height: 60px; }

.bf-submit {
  width: 100%; padding: 18px;
  background: var(--ink); color: var(--bone);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0.04em;
  display: flex; justify-content: center; align-items: center; gap: 10px;
  transition: background var(--t-fast);
  font-variation-settings: "opsz" 14;
}
.bf-submit:hover { background: var(--red); }

.bf-fine {
  text-align: center; padding: 12px; font-size: 0.74rem;
  color: var(--text-muted); border-top: 1px dashed rgba(12,12,12,.18);
}

@media (max-width: 980px) {
  .book-grid { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 600px) { .bf-body { grid-template-columns: 1fr; } .book-form .full { grid-column: span 1; } }

/* ── FAQ ─────────────────────────────────────── */
.faq {
  padding: var(--s-11) 0;
  border-bottom: 1px solid var(--line);
}
.faq-grid {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 64px;
  align-items: start;
}
.faq-head { position: sticky; top: 100px; }

.faq-list { border-top: 1px solid var(--ink); }
.faq details {
  border-bottom: 1px solid var(--ink);
  padding: 24px 0;
}
.faq summary {
  list-style: none;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(1.2rem, 2.5vw, 1.5rem);
  letter-spacing: -0.02em;
  color: var(--ink); cursor: pointer;
  font-variation-settings: "opsz" 24;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary .x {
  width: 28px; height: 28px;
  border: 1px solid var(--ink);
  position: relative; flex-shrink: 0;
  transition: background var(--t-fast);
}
.faq summary .x::before, .faq summary .x::after {
  content: ""; position: absolute; left: 50%; top: 50%;
  width: 12px; height: 1.5px; background: var(--ink);
  transform: translate(-50%, -50%);
  transition: transform var(--t-med);
}
.faq summary .x::after { transform: translate(-50%, -50%) rotate(90deg); }
.faq details[open] summary .x { background: var(--red); border-color: var(--red); }
.faq details[open] summary .x::before, .faq details[open] summary .x::after { background: var(--bone); }
.faq details[open] summary .x::after { transform: translate(-50%, -50%); }
.faq details p {
  margin-top: 14px; padding-right: 56px;
  color: var(--text-muted); line-height: 1.6; max-width: 60ch;
}

@media (max-width: 880px) { .faq-grid { grid-template-columns: 1fr; gap: 32px; } .faq-head { position: static; } }

/* ── FOOTER ─────────────────────────────────────── */
.foot {
  background: var(--ink); color: var(--bone);
  padding: var(--s-9) 0 0;
  position: relative;
  overflow: hidden;
}
.foot-top {
  display: grid; grid-template-columns: auto 1fr minmax(280px, 360px);
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--bone);
  align-items: start;
}
.foot-top > * { min-width: 0; }
.foot-brand { color: var(--bone); display: inline-block; }
.foot-mark {
  width: 74px; height: 88px;
  object-fit: contain;
  filter: invert(1);
  mix-blend-mode: screen;
}
.foot-tag h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  letter-spacing: -0.02em;
  line-height: 1.2;
  font-variation-settings: "opsz" 32;
  color: var(--bone);
}

.foot-newsletter { min-width: 0; }
.foot-newsletter span {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--red);
  display: block; margin-bottom: 8px;
}
.foot-newsletter p { color: var(--text-faint); font-size: 0.92rem; margin-bottom: 18px; line-height: 1.5; }
.news-form {
  display: flex;
  border: 1px solid var(--bone);
  width: 100%;
  max-width: 100%;
  min-width: 0;
}
.news-form input {
  flex: 1 1 0;
  min-width: 0;
  width: 100%;
  padding: 12px 14px;
  background: transparent;
  color: var(--bone);
  border: 0; outline: 0;
  font-size: 0.92rem;
}
.news-form input::placeholder { color: var(--text-faint); }
.news-form button {
  flex-shrink: 0;
  padding: 12px 18px;
  background: var(--bone); color: var(--ink);
  font-weight: 700; font-size: 0.85rem;
  white-space: nowrap;
  transition: background var(--t-fast);
}
.news-form button:hover { background: var(--red); color: var(--bone); }

.foot-cols {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 32px;
  padding: 48px 0 32px;
}
.foot-cols > * { min-width: 0; }
.foot-cols h4 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--red);
  margin-bottom: 16px;
}
.foot-cols a, .foot-cols p {
  display: block; color: var(--text-faint);
  font-size: 0.92rem; padding: 4px 0; line-height: 1.55;
  transition: color var(--t-fast);
}
.foot-cols a:hover { color: var(--bone); }

.foot-mega {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(5rem, 16vw, 14rem);
  line-height: 0.86;
  letter-spacing: -0.05em;
  color: var(--bone);
  opacity: 0.06;
  text-align: center;
  margin: 32px 0 -1vw;
  padding: 0 24px;
  font-variation-settings: "opsz" 96;
  pointer-events: none;
  user-select: none;
  width: 100%;
  white-space: nowrap;
  overflow: hidden;
}

.foot-bot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 24px 0;
  border-top: 1px solid rgba(245,241,234,.2);
  font-size: 0.82rem; color: var(--text-faint);
  flex-wrap: wrap; gap: 12px 28px;
}
.foot-bot a { color: var(--red); }
.foot-bot a:hover { color: var(--bone); }
.built-by {
  display: inline-flex; align-items: center; gap: 6px;
  margin-left: auto;
  padding: 6px 12px;
  border: 1px solid rgba(245,241,234,.18);
  background: rgba(245,241,234,.04);
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: var(--text-faint);
  transition: border-color var(--t-fast), color var(--t-fast), background var(--t-fast);
}
.built-by a { color: var(--bone); font-weight: 600; }
.built-by svg { color: var(--red); transition: transform var(--t-fast); }
.built-by:hover { border-color: var(--bone); color: var(--bone); background: rgba(245,241,234,.08); }
.built-by:hover svg { transform: translate(2px, -2px); color: var(--bone); }
.built-by:hover a { color: var(--red); }

@media (max-width: 980px) {
  .foot-top { grid-template-columns: 1fr; gap: 32px; }
  .foot-cols { grid-template-columns: repeat(2, 1fr); }
}

/* Sticky mobile CTA — hides when booking form or footer is in view */
.mob-cta {
  display: none;
  position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 80;
  background: var(--ink); color: var(--bg);
  padding: 16px 22px;
  font-weight: 700;
  font-family: var(--font-display);
  align-items: center; justify-content: center; gap: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,.3);
  transition: transform 350ms cubic-bezier(.4,0,.2,1), opacity 250ms ease;
  transform: translateY(0);
  opacity: 1;
}
.mob-cta.hidden {
  transform: translateY(calc(100% + 24px));
  opacity: 0;
  pointer-events: none;
}
@media (max-width: 980px) { .mob-cta { display: inline-flex; } }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
