/* =============================================================================
   2K CRAFT CO., DESIGN SYSTEM
   -----------------------------------------------------------------------------
   Aesthetic:        Bold. Premium craft cannabis brand on the Hwy 36 corridor.
   Corner language:  SHARP (--radius-base: 0). Locked tokens.
   Type:             Montserrat Bold (display) + Montserrat Regular (body).
                     Single family, weight contrast does the work. We push
                     900-weight at large sizes and tighten tracking hard.
   Palette:          Near-black ground (#111111) with high-key chartreuse
                     accent (#B7FF2A). Paper neutral for one warm interlude.
                     Saturated, opinionated, not muted. WCAG AA+ enforced:
                     accent text reserved for dark grounds (12:1+); accent
                     buttons use INK text, never white.
   Spacing scale:    8pt base. 4 / 8 / 12 / 16 / 24 / 32 / 48 / 64 / 96 / 128.
   Motion:           ease-out-quint for reveals (.6s), out-expo for hover.
                     Reveal-safety contract: visible by default, hidden only
                     when `html.js` AND IntersectionObserver are present;
                     4s fail-safe + reduced-motion bypass in main.js.
   Hero pattern:     Full-bleed dark photo with directional veil, word-by-word
                     stagger reveal, left-anchored text with substantial
                     padding. NOT centered, NOT fade-up.
   Signature moves:  Ledger-numbered sections (01/02/03 with rule + content),
                     full-bleed chartreuse statement bands as contrast moments,
                     wordmark + circle SVG mark in lounge band, age strip
                     above the header (running ticker pattern).
   ========================================================================== */

:root {
  /* Color (LOCKED) */
  --color-bg:     var(--theme-background, #111111);
  --color-ink:    var(--theme-text, #F5F5F5);
  --color-muted:  var(--theme-muted, #A0A0A0);
  --color-border: var(--theme-border, #333333);
  --color-accent: var(--theme-accent, #B7FF2A);

  /* Derived */
  --color-paper:    #F2EFE6;
  --color-paper-2:  #E6E2D5;
  --color-deep:     #0A0A0A;
  --color-card:     #1A1A1A;
  --color-card-2:   #1E1E1E;
  --color-ink-on-paper: #141414;
  --color-muted-on-paper: #5C5C5C;

  /* Corners (LOCKED, sharp) */
  --radius-sm:    0;
  --radius-base:  var(--theme-radius, 0);
  --radius-lg:    0;
  --radius-xl:    0;
  --radius-full:  9999px;

  /* Fonts */
  --font-display: var(--theme-heading-font, 'Montserrat', system-ui, sans-serif);
  --font-body:    var(--theme-body-font, 'Montserrat', system-ui, sans-serif);

  /* Type scale (fluid) */
  --fs-eyebrow: 0.75rem;
  --fs-body:    1.0625rem;
  --fs-lede:    clamp(1.125rem, 0.95rem + 0.7vw, 1.375rem);
  --fs-h3:      clamp(1.25rem, 1rem + 1vw, 1.625rem);
  --fs-h2:      clamp(2rem, 1.4rem + 2.6vw, 3.75rem);
  --fs-h1:      clamp(2.5rem, 1.6rem + 4.4vw, 5.75rem);
  --fs-display: clamp(3rem, 1.6rem + 6vw, 7.5rem);

  /* Space */
  --space-1:  calc(4px * var(--theme-density, 1));
  --space-2:  calc(8px * var(--theme-density, 1));
  --space-3:  calc(12px * var(--theme-density, 1));
  --space-4:  calc(16px * var(--theme-density, 1));
  --space-5:  calc(24px * var(--theme-density, 1));
  --space-6:  calc(32px * var(--theme-density, 1));
  --space-7:  calc(48px * var(--theme-density, 1));
  --space-8:  calc(64px * var(--theme-density, 1));
  --space-9:  calc(96px * var(--theme-density, 1));
  --space-10: calc(128px * var(--theme-density, 1));

  /* Shadow */
  --shadow-1: 0 1px 0 rgba(255,255,255,0.04) inset;
  --shadow-2: 0 16px 40px -20px rgba(0,0,0,0.6);
  --shadow-3: 0 28px 80px -30px rgba(0,0,0,0.7);

  /* Motion */
  --ease-out-quint: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-expo:  cubic-bezier(0.2, 0.7, 0.2, 1);
  --ease-in-quint:  cubic-bezier(0.7, 0, 0.84, 0);

  --dur-fast:  calc(120ms * var(--theme-motion, 1));
  --dur-base:  calc(220ms * var(--theme-motion, 1));
  --dur-mid:   calc(480ms * var(--theme-motion, 1));
  --dur-long:  calc(640ms * var(--theme-motion, 1));

  /* Layout */
  --container: 1280px;
  --gutter: calc(clamp(20px, 4vw, 56px) * var(--theme-density, 1));
}

/* ---------- Reset ---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body, h1, h2, h3, h4, h5, h6, p, ul, ol, dl, dd, figure, blockquote { margin: 0; }
ul, ol { padding: 0; list-style: none; }
img, svg, video { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; padding: 0; }
a { color: inherit; }

/* Wrapping defaults */
h1, h2, h3, h4, h5, h6 { text-wrap: balance; }
p { text-wrap: pretty; }
main :is(p, blockquote, li) { max-width: none; }

/* ---------- Base ----------------------------------------------------------- */
html, body { background: var(--color-bg); color: var(--color-ink); }
body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: 400;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: var(--color-accent); color: var(--color-bg); }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.skip-link {
  position: absolute; left: -9999px; top: 0;
}
.skip-link:focus {
  left: 1rem; top: 1rem; z-index: 9999;
  padding: 0.75rem 1rem;
  background: var(--color-accent); color: var(--color-bg);
  font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
  outline: 2px solid var(--color-ink);
}

:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: var(--gutter);
}

/* ---------- Typography helpers -------------------------------------------- */
.display {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: var(--fs-display);
  line-height: 0.92;
  letter-spacing: -0.035em;
  text-transform: uppercase;
}
.display-2 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: var(--fs-h1);
  line-height: 0.95;
  letter-spacing: -0.03em;
  text-transform: uppercase;
}

.eyebrow {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.eyebrow--accent { color: var(--color-accent); }
.eyebrow--ink { color: var(--color-bg); }

.link-underline {
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none;
  position: relative;
  padding-bottom: 4px;
  border-bottom: 1px solid currentColor;
  transition: color var(--dur-base) var(--ease-out-expo);
}
.link-underline::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px; height: 1px;
  background: var(--color-accent);
  transform: scaleX(0); transform-origin: left center;
  transition: transform var(--dur-base) var(--ease-out-expo);
}
.link-underline:hover { color: var(--color-accent); }
.link-underline:hover::after { transform: scaleX(1); }

/* ---------- Buttons ------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 16px 28px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 0.9375rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1.5px solid transparent;
  border-radius: var(--radius-base);
  transition: transform var(--dur-base) var(--ease-out-expo),
              background var(--dur-base) var(--ease-out-expo),
              color var(--dur-base) var(--ease-out-expo),
              border-color var(--dur-base) var(--ease-out-expo);
  min-height: 48px;
  white-space: nowrap;
}
.btn--sm { padding: 10px 18px; font-size: 0.8125rem; min-height: 40px; }

.btn-primary {
  background: var(--color-accent);
  color: var(--color-bg);
  border-color: var(--color-accent);
}
.btn-primary:hover {
  transform: translateY(-2px);
  background: #C9FF55;
  border-color: #C9FF55;
  box-shadow: 0 14px 32px -16px rgba(183,255,42,0.6);
}
.btn-primary:active { transform: translateY(0); }

.btn-ghost {
  background: transparent;
  color: var(--color-ink);
  border-color: var(--color-ink);
}
.btn-ghost:hover {
  transform: translateY(-2px);
  background: var(--color-ink);
  color: var(--color-bg);
}

.btn-ink {
  background: var(--color-bg);
  color: var(--color-accent);
  border-color: var(--color-bg);
}
.btn-ink:hover {
  transform: translateY(-2px);
  background: var(--color-deep);
}

/* ---------- Age strip + Age gate ------------------------------------------ */
.age-strip {
  background: var(--color-accent);
  color: var(--color-bg);
  text-align: center;
  font-weight: 700;
  font-size: 0.75rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 8px 16px;
  margin: 0;
}

.age-gate {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-5);
  background: rgba(10,10,10,0.94);
  backdrop-filter: blur(8px);
}
.age-gate__card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  padding: clamp(28px, 5vw, 56px);
  max-width: 520px;
  width: 100%;
  text-align: center;
}
.age-gate__card .eyebrow { color: var(--color-accent); margin-bottom: var(--space-4); }
.age-gate__card h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(1.75rem, 1.2rem + 1.5vw, 2.5rem);
  line-height: 1; letter-spacing: -0.03em; text-transform: uppercase;
  margin-bottom: var(--space-4);
}
.age-gate__card p { color: var(--color-muted); margin-bottom: var(--space-6); }
.age-gate__actions {
  display: flex; flex-direction: column; gap: var(--space-3);
}
@media (min-width: 540px) {
  .age-gate__actions { flex-direction: row; justify-content: center; }
}

/* ---------- Header -------------------------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(17,17,17,0.94);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-border);
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 18px; padding-bottom: 18px;
  gap: var(--space-5);
}

.brand {
  display: inline-flex; align-items: center; gap: 10px;
  text-decoration: none; color: var(--color-ink);
  transition: color var(--dur-base) var(--ease-out-expo);
}
.brand:hover { color: var(--color-accent); }
.brand__mark {
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--color-accent);
  transition: transform var(--dur-base) var(--ease-out-expo);
}
.brand:hover .brand__mark { transform: rotate(-6deg); }
.brand__name {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 0.9375rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.primary-nav { display: flex; align-items: center; }
.primary-nav ul {
  display: flex; align-items: center; gap: var(--space-5);
}
.primary-nav a {
  text-decoration: none;
  font-weight: 600;
  font-size: 0.875rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-ink);
  position: relative;
  padding: 6px 0;
  transition: color var(--dur-base) var(--ease-out-expo);
}
.primary-nav a::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
  background: var(--color-accent);
  transform: scaleX(0); transform-origin: left center;
  transition: transform var(--dur-base) var(--ease-out-expo);
}
.primary-nav a:hover { color: var(--color-accent); }
.primary-nav a:hover::after,
.primary-nav a[aria-current="page"]::after { transform: scaleX(1); }
.primary-nav a[aria-current="page"] { color: var(--color-accent); }

.nav-cta {
  padding: 10px 18px !important;
  border: 1.5px solid var(--color-ink);
  transition: background var(--dur-base) var(--ease-out-expo),
              color var(--dur-base) var(--ease-out-expo),
              border-color var(--dur-base) var(--ease-out-expo);
}
.nav-cta::after { display: none !important; }
.nav-cta:hover {
  background: var(--color-accent);
  color: var(--color-bg) !important;
  border-color: var(--color-accent);
}
.nav-cta[aria-current="page"] {
  background: var(--color-accent); color: var(--color-bg) !important;
  border-color: var(--color-accent);
}

.nav-toggle {
  display: none;
  width: 44px; height: 44px;
  position: relative;
  border: 1px solid var(--color-border);
}
.nav-toggle__bar {
  display: block;
  width: 20px; height: 2px;
  background: var(--color-ink);
  margin: 4px auto;
  transition: transform var(--dur-base) var(--ease-out-expo),
              opacity var(--dur-base) var(--ease-out-expo);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) { transform: translateY(6px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(4) { transform: translateY(-6px) rotate(-45deg); }

@media (max-width: 880px) {
  .nav-toggle { display: block; }
  .primary-nav ul {
    position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
    padding: var(--space-5) var(--gutter);
    transform: translateY(-8px); opacity: 0; pointer-events: none;
    transition: transform var(--dur-base) var(--ease-out-expo),
                opacity var(--dur-base) var(--ease-out-expo);
  }
  .primary-nav ul li { border-bottom: 1px solid var(--color-border); }
  .primary-nav ul li:last-child { border-bottom: 0; }
  .primary-nav a {
    display: block; padding: 18px 0;
    font-size: 1rem;
  }
  .nav-cta {
    display: inline-flex; margin-top: var(--space-3);
    padding: 14px 18px !important;
  }
  .primary-nav.is-open ul {
    transform: translateY(0); opacity: 1; pointer-events: auto;
  }
}

/* ---------- Sections ------------------------------------------------------ */
.band {
  padding-block: clamp(72px, 9vw, 144px);
  background: var(--color-bg);
}
.band--dark { background: var(--color-deep); }
.band--paper {
  background: var(--color-paper);
  color: var(--color-ink-on-paper);
}
.band--paper .eyebrow { color: var(--color-muted-on-paper); }
.band--accent {
  background: var(--color-accent);
  color: var(--color-bg);
}
.band--accent .eyebrow { color: var(--color-bg); opacity: 0.7; }

.section-head {
  margin-bottom: clamp(40px, 5vw, 72px);
  max-width: 900px;
}
.section-head .eyebrow { margin-bottom: var(--space-4); }
.section-head h2 { color: inherit; }

/* ---------- HERO ---------------------------------------------------------- */
.hero {
  position: relative;
  min-height: clamp(620px, 92svh, 920px);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding-block: clamp(48px, 8vw, 96px);
  padding-inline: 0;
  overflow: hidden;
  isolation: isolate;
}
.hero__bg {
  position: absolute; inset: 0; z-index: -1;
}
.hero__bg img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.hero__veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(17,17,17,0.55) 0%, rgba(17,17,17,0.35) 38%, rgba(17,17,17,0.92) 100%),
    linear-gradient(110deg, rgba(17,17,17,0.7) 0%, rgba(17,17,17,0.2) 50%, rgba(17,17,17,0) 100%);
}
.hero__grain {
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 3px 3px;
  mix-blend-mode: overlay;
  pointer-events: none;
}

.hero__content {
  position: relative;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 clamp(24px, 6vw, 96px);
  text-align: left;
}
.hero__content .eyebrow { margin-bottom: var(--space-5); }
.hero h1 {
  margin-bottom: var(--space-5);
  text-shadow: 0 2px 18px rgba(0,0,0,0.45);
}
.hero__word {
  display: inline-block;
  margin-right: 0.15em;
}
.hero__word--accent { color: var(--color-accent); }

.hero__lede {
  font-size: var(--fs-lede);
  max-width: 640px;
  color: var(--color-ink);
  margin-bottom: var(--space-6);
  text-shadow: 0 2px 16px rgba(0,0,0,0.5);
}

.hero__ctas {
  display: flex; flex-wrap: wrap; gap: var(--space-3);
  margin-bottom: var(--space-6);
}

.hero__meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-3);
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-ink);
  font-weight: 600;
}
.hero__meta strong { color: var(--color-accent); }
.hero__meta-dot {
  width: 6px; height: 6px; background: var(--color-accent);
}

.hero__scroll {
  position: absolute;
  bottom: 24px; right: clamp(24px, 6vw, 96px);
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.6875rem; letter-spacing: 0.22em; text-transform: uppercase;
  font-weight: 700;
  text-decoration: none;
  color: var(--color-ink);
  opacity: 0.85;
}
.hero__scroll svg { animation: scrollNudge 1.6s ease-in-out infinite; }
@keyframes scrollNudge {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(4px); }
}

/* ---------- PAGE HERO ----------------------------------------------------- */
.page-hero {
  padding-block: clamp(80px, 10vw, 160px) clamp(56px, 7vw, 96px);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
}
.page-hero__inner {
  text-align: left;
}
.page-hero .eyebrow { margin-bottom: var(--space-5); }
.page-hero h1 { margin-bottom: var(--space-5); max-width: 1100px; }
.page-hero__lede {
  font-size: var(--fs-lede);
  max-width: 720px;
  color: var(--color-muted);
}

.menu-jump {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border);
}
.menu-jump a {
  display: inline-block;
  padding: 8px 14px;
  border: 1px solid var(--color-border);
  text-decoration: none;
  font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  transition: border-color var(--dur-base) var(--ease-out-expo),
              color var(--dur-base) var(--ease-out-expo),
              background var(--dur-base) var(--ease-out-expo);
}
.menu-jump a:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

/* ---------- LEDGER (numbered ledger pattern) ----------------------------- */
.ledger {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--color-border);
}
.band--paper .ledger { border-top-color: rgba(0,0,0,0.15); }

.ledger__row {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: var(--space-5);
  align-items: start;
  padding-block: clamp(28px, 4vw, 48px);
  border-bottom: 1px solid var(--color-border);
  transition: background var(--dur-base) var(--ease-out-expo);
}
.band--paper .ledger__row { border-bottom-color: rgba(0,0,0,0.15); }
.ledger__row:hover {
  background: rgba(183,255,42,0.04);
}
.band--paper .ledger__row:hover { background: rgba(0,0,0,0.025); }

.ledger__num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(1.5rem, 1rem + 1vw, 2rem);
  letter-spacing: 0;
  color: var(--color-accent);
  line-height: 1;
  padding-top: 6px;
}
.band--paper .ledger__num { color: var(--color-ink-on-paper); }

.ledger__body h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(1.5rem, 1.1rem + 1.2vw, 2.25rem);
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: var(--space-3);
}
.ledger__body p { color: var(--color-muted); max-width: 60ch; }
.band--paper .ledger__body p { color: var(--color-muted-on-paper); }

.ledger__cta {
  text-decoration: none;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink);
  white-space: nowrap;
  padding-top: 14px;
  transition: color var(--dur-base) var(--ease-out-expo),
              transform var(--dur-base) var(--ease-out-expo);
}
.ledger__cta span { display: inline-block; transition: transform var(--dur-base) var(--ease-out-expo); }
.ledger__cta:hover { color: var(--color-accent); }
.ledger__cta:hover span { transform: translateX(4px); }

.ledger--tight .ledger__row {
  padding-block: clamp(20px, 3vw, 32px);
  grid-template-columns: 60px 1fr;
}
.ledger--tight .ledger__num {
  font-size: 1.25rem;
  color: var(--color-accent);
}

@media (max-width: 720px) {
  .ledger__row {
    grid-template-columns: 56px 1fr;
    gap: var(--space-4);
  }
  .ledger__cta {
    grid-column: 1 / -1;
    padding-top: var(--space-3);
  }
}

/* ---------- STATEMENT (contrast moment) ----------------------------------- */
.statement {
  background: var(--color-accent);
  color: var(--color-bg);
  padding-block: clamp(96px, 12vw, 200px);
  text-align: center;
}
.statement .eyebrow { margin-bottom: var(--space-6); }
.statement__quote {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(2rem, 1.2rem + 4vw, 5rem);
  line-height: 1;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  max-width: 1100px;
  margin: 0 auto;
}
.statement__attr {
  margin-top: var(--space-6);
  font-weight: 700;
  font-size: 0.875rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.7;
}

/* ---------- SPLIT --------------------------------------------------------- */
.split {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: start;
}
@media (min-width: 960px) {
  .split { grid-template-columns: 5fr 7fr; gap: var(--space-9); }
  .split--reverse .split__copy { order: 2; }
  .split--reverse .split__photo { order: 1; }
}
.split__copy h2 { margin-bottom: var(--space-4); }
.split__copy p { color: var(--color-muted); margin-bottom: var(--space-4); }
.band--paper .split__copy p { color: var(--color-muted-on-paper); }
.band--accent .split__copy p { color: var(--color-bg); }
.split__copy .eyebrow { margin-bottom: var(--space-4); }
.split__photo img {
  width: 100%; height: auto;
  filter: contrast(1.05) saturate(1.05);
}
.split__photo {
  position: relative;
  overflow: hidden;
}

.split__cards {
  display: grid; gap: var(--space-5);
}

/* ---------- Product cards (home preview) --------------------------------- */
.prod-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  display: grid;
  grid-template-columns: 140px 1fr;
  overflow: hidden;
  transition: transform var(--dur-base) var(--ease-out-expo),
              border-color var(--dur-base) var(--ease-out-expo);
}
.prod-card:hover {
  transform: translateY(-3px);
  border-color: var(--color-accent);
}
.prod-card__img {
  overflow: hidden;
  background: var(--color-deep);
}
.prod-card__img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--dur-mid) var(--ease-out-expo);
}
.prod-card:hover .prod-card__img img { transform: scale(1.05); }
.prod-card__body {
  padding: var(--space-4) var(--space-5);
  display: flex; flex-direction: column; justify-content: center;
}
.prod-card__cat {
  font-size: 0.6875rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 6px;
}
.prod-card__body h3 {
  font-family: var(--font-display);
  font-weight: 900; font-size: 1.5rem;
  letter-spacing: -0.02em; text-transform: uppercase;
  line-height: 1; margin-bottom: var(--space-2);
}
.prod-card__body p { color: var(--color-muted); font-size: 0.9375rem; margin-bottom: var(--space-3); }
.prod-card__meta {
  display: flex; gap: var(--space-4);
  font-size: 0.8125rem; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--color-ink);
}
.prod-card__meta span:last-child { color: var(--color-accent); }

@media (max-width: 540px) {
  .prod-card { grid-template-columns: 1fr; }
  .prod-card__img { aspect-ratio: 4/3; }
}

/* ---------- Lounge band (accent) ----------------------------------------- */
.lounge {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  align-items: center;
}
@media (min-width: 880px) { .lounge { grid-template-columns: 1.5fr 1fr; } }

.lounge__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(2.5rem, 1.4rem + 4vw, 5.5rem);
  line-height: 0.9; letter-spacing: -0.035em; text-transform: uppercase;
  color: var(--color-bg);
  margin-bottom: var(--space-5);
}
.lounge__copy p {
  color: var(--color-bg);
  font-size: var(--fs-lede);
  margin-bottom: var(--space-6);
  max-width: 50ch;
}
.lounge__mark {
  width: 100%;
  max-width: 320px;
  margin-left: auto;
  color: var(--color-bg);
}
@media (prefers-reduced-motion: no-preference) {
  .lounge__mark {
    animation: slowSpin 28s linear infinite;
  }
}
@keyframes slowSpin { to { transform: rotate(360deg); } }

/* ---------- Testimonials -------------------------------------------------- */
.testimonials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 960px) { .testimonials { grid-template-columns: 1fr; } }

.testimonial {
  display: flex; flex-direction: column;
  padding: var(--space-6);
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-left: 3px solid var(--color-accent);
  transition: transform var(--dur-base) var(--ease-out-expo),
              border-color var(--dur-base) var(--ease-out-expo);
}
.testimonial:hover {
  transform: translateY(-3px);
}
.testimonial blockquote p {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 1.0625rem;
  line-height: 1.5;
  margin-bottom: var(--space-5);
}
.testimonial figcaption {
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
  display: flex; flex-direction: column; gap: 4px;
}
.testimonial__name {
  font-weight: 700; font-size: 0.9375rem;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.testimonial__role {
  font-size: 0.8125rem; color: var(--color-muted);
}

/* ---------- Final CTA ----------------------------------------------------- */
.cta-final {
  background: var(--color-bg);
  padding-block: clamp(80px, 10vw, 140px);
  border-top: 1px solid var(--color-border);
  text-align: left;
}
.cta-final__inner { max-width: 1100px; }
.cta-final h2 { margin-bottom: var(--space-4); }
.cta-final > .container > p,
.cta-final p {
  color: var(--color-muted);
  font-size: var(--fs-lede);
  margin-bottom: var(--space-6);
}

/* ---------- Story chapters ------------------------------------------------ */
.chapter {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--space-5);
  max-width: 1100px;
}
@media (min-width: 880px) {
  .chapter { grid-template-columns: 120px 1fr; gap: var(--space-8); }
  .chapter--reverse { grid-template-columns: 1fr 120px; }
  .chapter--reverse .chapter__num { order: 2; text-align: left; }
  .chapter--reverse .chapter__body { order: 1; }
}
.chapter__num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(3rem, 2rem + 3vw, 5rem);
  line-height: 0.9;
  color: var(--color-accent);
  letter-spacing: -0.04em;
}
.band--paper .chapter__num,
.chapter__num--ink { color: var(--color-ink-on-paper); }
.band--accent .chapter__num { color: var(--color-bg); }

.chapter__body h2 { margin-bottom: var(--space-5); }
.chapter__body p {
  font-size: var(--fs-lede);
  margin-bottom: var(--space-4);
}
.band--dark .chapter__body p { color: var(--color-muted); }
.band--accent .chapter__body p { color: var(--color-bg); max-width: 60ch; }

/* ---------- Principles list ----------------------------------------------- */
.principles {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--color-border);
  margin-top: var(--space-6);
}
@media (max-width: 720px) { .principles { grid-template-columns: 1fr; } }
.principles__row {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: var(--space-4);
  align-items: start;
  padding: var(--space-6) var(--space-5) var(--space-6) 0;
  border-bottom: 1px solid var(--color-border);
}
.principles__row:nth-child(odd) {
  border-right: 1px solid var(--color-border);
  padding-right: var(--space-6);
}
@media (max-width: 720px) {
  .principles__row:nth-child(odd) { border-right: 0; padding-right: 0; }
}
.principles__num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.5rem;
  color: var(--color-accent);
  letter-spacing: 0;
  line-height: 1;
}
.principles__row h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.25rem;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-2);
}
.principles__row p { color: var(--color-muted); }

/* ---------- Team / founders ---------------------------------------------- */
.team {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  align-items: center;
}
@media (min-width: 880px) { .team { grid-template-columns: 6fr 5fr; gap: var(--space-9); } }
.team__copy h2 { margin-bottom: var(--space-5); }
.team__copy p { font-size: var(--fs-lede); margin-bottom: var(--space-4); color: var(--color-muted-on-paper); }
.team__photo img { width: 100%; }
.team__photo figcaption {
  margin-top: var(--space-3);
  font-size: 0.8125rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted-on-paper);
}

/* ---------- Menu list ----------------------------------------------------- */
.menu-head { margin-bottom: clamp(40px, 5vw, 64px); }
.menu-head__num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1rem;
  color: var(--color-accent);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-3);
}
.menu-head h2 { margin-bottom: var(--space-3); max-width: 900px; }
.menu-head__note { color: var(--color-muted); max-width: 60ch; }
.menu-head--ink .menu-head__num--ink,
.menu-head--ink .menu-head__note { color: var(--color-bg); opacity: 0.7; }
.menu-head--ink .menu-head__note { opacity: 0.85; }

.menu-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--color-border);
}
.menu-list--ink { border-top-color: rgba(0,0,0,0.2); }

.menu-item {
  padding-block: clamp(20px, 3vw, 32px);
  border-bottom: 1px solid var(--color-border);
  transition: background var(--dur-base) var(--ease-out-expo);
}
.menu-list--ink .menu-item { border-bottom-color: rgba(0,0,0,0.2); }
.menu-item:hover { background: rgba(183,255,42,0.04); }
.menu-list--ink .menu-item:hover { background: rgba(0,0,0,0.05); }

.menu-item__head {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: var(--space-4);
  margin-bottom: var(--space-2);
}
.menu-item__head h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(1.25rem, 1rem + 0.7vw, 1.625rem);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.menu-item__price {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.125rem;
  color: var(--color-accent);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.menu-list--ink .menu-item__price { color: var(--color-bg); }
.menu-item__price span {
  font-weight: 400;
  font-size: 0.875rem;
  color: var(--color-muted);
  margin-left: 4px;
}
.menu-list--ink .menu-item__price span { color: var(--color-bg); opacity: 0.7; }

.menu-item__meta {
  display: flex; flex-wrap: wrap; gap: var(--space-4);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: var(--space-3);
}
.menu-list--ink .menu-item__meta { color: var(--color-bg); opacity: 0.75; }

.menu-item p {
  color: var(--color-muted);
  max-width: 60ch;
}
.menu-list--ink .menu-item > p { color: var(--color-bg); opacity: 0.85; }

@media (max-width: 540px) {
  .menu-item__head { flex-direction: column; align-items: flex-start; gap: 4px; }
}

/* ---------- Visit grid ---------------------------------------------------- */
.visit-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 880px) { .visit-grid { grid-template-columns: 1fr; } }
.visit-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-top: 3px solid var(--color-accent);
  padding: var(--space-6);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.visit-card .eyebrow { color: var(--color-accent); }
.visit-card__big {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(1.25rem, 1rem + 0.7vw, 1.625rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
  text-transform: uppercase;
}
.visit-card__big a { text-decoration: none; }
.visit-card__big a:hover { color: var(--color-accent); }

.hours {
  display: flex; flex-direction: column;
  font-variant-numeric: tabular-nums;
}
.hours > div {
  display: flex; justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px dashed var(--color-border);
  font-size: 0.9375rem;
}
.hours > div:last-child { border-bottom: 0; }
.hours dt { font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; font-size: 0.8125rem; color: var(--color-ink); }
.hours dd { color: var(--color-muted); }

.band--map { padding: 0; }

/* ---------- Contact / form ------------------------------------------------ */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}
@media (min-width: 960px) {
  .contact-grid { grid-template-columns: 4fr 7fr; gap: var(--space-9); align-items: start; }
}

.contact-aside { display: flex; flex-direction: column; gap: var(--space-6); }
.contact-aside .eyebrow { color: var(--color-muted-on-paper); margin-bottom: var(--space-2); }
.contact-aside__big {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(1.25rem, 1rem + 0.7vw, 1.5rem);
  letter-spacing: -0.01em;
  text-transform: uppercase;
  line-height: 1.15;
  color: var(--color-ink-on-paper);
  margin-bottom: var(--space-2);
}
.contact-aside__big a { text-decoration: none; }
.contact-aside__big a:hover { color: var(--color-bg); border-bottom: 2px solid var(--color-accent); }
.contact-aside__block p { color: var(--color-muted-on-paper); }

.form {
  background: var(--color-bg);
  color: var(--color-ink);
  padding: clamp(24px, 4vw, 48px);
  border: 1px solid var(--color-border);
  position: relative;
}
.form .eyebrow { color: var(--color-accent); margin-bottom: var(--space-3); }
.form__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(1.5rem, 1.1rem + 1.4vw, 2.25rem);
  line-height: 1; letter-spacing: -0.02em; text-transform: uppercase;
  margin-bottom: var(--space-6);
}

.field { display: flex; flex-direction: column; gap: 8px; margin-bottom: var(--space-5); }
.field label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.field input, .field select, .field textarea {
  background: transparent;
  border: 0;
  border-bottom: 1.5px solid var(--color-border);
  padding: 12px 0;
  color: var(--color-ink);
  font: inherit;
  font-size: 1rem;
  transition: border-color var(--dur-base) var(--ease-out-expo);
  border-radius: 0;
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none;
  border-bottom-color: var(--color-accent);
}
.field select option { background: var(--color-bg); color: var(--color-ink); }
.field textarea { resize: vertical; min-height: 140px; }

.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 var(--space-5);
}
@media (max-width: 640px) { .field-row { grid-template-columns: 1fr; gap: 0; } }

.field--check {
  flex-direction: row; align-items: flex-start; gap: var(--space-3);
  margin-bottom: var(--space-6);
}
.field--check input { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; accent-color: var(--color-accent); }
.field--check label {
  font-size: 0.875rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--color-ink);
  font-weight: 500;
  line-height: 1.5;
}

.cf-turnstile { margin-bottom: var(--space-5); }

.form-status {
  margin: var(--space-4) 0 0;
  font-size: 0.9375rem;
}
.form-status--success { color: var(--color-accent); }
.form-status--error { color: #FF6B6B; }

/* ---------- FAQ ----------------------------------------------------------- */
.faq {
  border-top: 1px solid var(--color-border);
  max-width: 1100px;
}
.faq details {
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-5) 0;
}
.faq summary {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1rem, 0.9rem + 0.4vw, 1.25rem);
  letter-spacing: -0.01em;
  text-transform: uppercase;
  cursor: pointer;
  list-style: none;
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--space-4);
  transition: color var(--dur-base) var(--ease-out-expo);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: '+';
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.5rem;
  color: var(--color-accent);
  transition: transform var(--dur-base) var(--ease-out-expo);
  line-height: 1;
}
.faq details[open] summary::after { transform: rotate(45deg); }
.faq summary:hover { color: var(--color-accent); }
.faq details p {
  margin-top: var(--space-4);
  color: var(--color-muted);
  max-width: 65ch;
}

/* ---------- Footer -------------------------------------------------------- */
.site-footer {
  background: var(--color-deep);
  color: var(--color-ink);
  border-top: 1px solid var(--color-border);
}
.site-footer__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  padding-top: clamp(64px, 8vw, 96px);
  padding-bottom: clamp(40px, 5vw, 64px);
}
@media (min-width: 880px) {
  .site-footer__inner { grid-template-columns: 5fr 7fr; gap: var(--space-8); }
}
.site-footer__brand p {
  color: var(--color-muted);
  margin-top: var(--space-4);
  max-width: 38ch;
}
.brand--light { color: var(--color-ink); }
.brand--light:hover { color: var(--color-accent); }

.site-footer__nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
@media (max-width: 600px) {
  .site-footer__nav { grid-template-columns: 1fr; gap: var(--space-6); }
}
.site-footer__nav .eyebrow {
  color: var(--color-accent);
  margin-bottom: var(--space-4);
}
.site-footer__nav ul { display: flex; flex-direction: column; gap: 8px; }
.site-footer__nav a {
  text-decoration: none;
  color: var(--color-muted);
  font-size: 0.9375rem;
  transition: color var(--dur-base) var(--ease-out-expo);
}
.site-footer__nav a:hover { color: var(--color-accent); }
.site-footer__nav li { color: var(--color-muted); font-size: 0.9375rem; }

.site-footer__bar {
  border-top: 1px solid var(--color-border);
  padding: var(--space-5) var(--gutter);
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-4);
  font-size: 0.8125rem;
  color: var(--color-muted);
  max-width: var(--container);
  margin: 0 auto;
}
.site-footer__warn {
  max-width: 50ch;
  text-align: right;
}
@media (max-width: 720px) { .site-footer__warn { text-align: left; } }

/* ---------- Legal pages --------------------------------------------------- */
.legal { padding-block: clamp(72px, 9vw, 128px); }
.legal h1 { margin-bottom: var(--space-3); }
.legal .eyebrow { color: var(--color-accent); margin-bottom: var(--space-4); }
.legal__updated { color: var(--color-muted); margin-bottom: var(--space-8); }
.legal section { margin-bottom: var(--space-7); }
.legal h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: 1.25rem; text-transform: uppercase;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-5);
}
.legal section:first-of-type h2 { border-top: 0; padding-top: 0; }
.legal p { margin-bottom: var(--space-3); line-height: 1.7; color: var(--color-ink); }
.legal a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 4px; }
.legal-list {
  list-style: none; padding: 0; margin: 0 0 var(--space-3) 0;
}
.legal-list li {
  padding-left: 24px; position: relative;
  margin-bottom: var(--space-3); line-height: 1.6;
}
.legal-list li::before {
  content: ''; position: absolute; left: 0; top: 12px;
  width: 12px; height: 2px; background: var(--color-accent);
}

/* ---------- Cookie banner ------------------------------------------------- */
.cookie-banner {
  position: fixed;
  left: 16px; right: 16px; bottom: 16px;
  z-index: 100;
  padding: 18px 20px;
  background: var(--color-bg);
  color: var(--color-ink);
  border: 1px solid var(--color-accent);
  box-shadow: var(--shadow-3);
}
.cookie-banner__content {
  display: flex; flex-direction: column; gap: var(--space-3);
}
.cookie-banner__text {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.5;
}
.cookie-banner__text a { color: var(--color-accent); text-decoration: underline; }
.cookie-banner__actions { display: flex; gap: var(--space-2); }
@media (min-width: 768px) {
  .cookie-banner {
    left: auto; right: 24px; bottom: 24px;
    max-width: 460px;
  }
}

/* ---------- Reveal animations --------------------------------------------- */
/* Visible by default. Hidden states gated behind html.js (Reveal Safety) */
.reveal-fade, .reveal-clip { opacity: 1; transform: none; clip-path: none; }

html.js .reveal-fade {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--dur-long) var(--ease-out-quint),
              transform var(--dur-long) var(--ease-out-quint);
}
html.js .reveal-fade.is-visible {
  opacity: 1; transform: none;
}

html.js .reveal-clip {
  opacity: 0;
  clip-path: inset(0 100% 0 0);
  transition: opacity var(--dur-long) var(--ease-out-quint),
              clip-path 700ms var(--ease-out-quint);
}
html.js .reveal-clip.is-visible {
  opacity: 1;
  clip-path: inset(0 0 0 0);
}

html.js .hero__word {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 500ms var(--ease-out-quint),
              transform 500ms var(--ease-out-quint);
}
html.js .hero h1.is-visible .hero__word { opacity: 1; transform: none; }
html.js .hero h1.is-visible .hero__word:nth-child(1) { transition-delay: 80ms; }
html.js .hero h1.is-visible .hero__word:nth-child(2) { transition-delay: 180ms; }
html.js .hero h1.is-visible .hero__word:nth-child(3) { transition-delay: 280ms; }
html.js .hero h1.is-visible .hero__word:nth-child(4) { transition-delay: 380ms; }

/* ---------- Reduced motion ------------------------------------------------ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  html.js .reveal-fade,
  html.js .reveal-clip,
  html.js .hero__word { opacity: 1 !important; transform: none !important; clip-path: none !important; }
  .lounge__mark { animation: none !important; }
}
