/*
  CLIENT: Cafficana
  PALETTE (real, from their actual brand):
    - Coral red #E84F36 (the logo color, the brand uniform color)
    - Deep forest green #1B3022 (their poster bg, painted-wall accent)
    - Warm parchment #F4ECDB (their packaging cup)
    - Cream #FAF6EC, off-white surfaces
    - Concrete grey accents #DDD6C4
  TYPE:
    - Display: Bricolage Grotesque (variable, opinionated, modern bold sans)
    - Body: Inter
    - Hand: Caveat / Permanent Marker (mimicking their handwritten IG overlays)
  MOOD: bright, witty, editorial, Calicut-young, modern-Kerala, slightly indie magazine
*/

:root {
  /* light theme tokens (default) */
  --c-bg: #F4ECDB;
  --c-bg-2: #FAF6EC;
  --c-surface: #FFFEFA;
  --c-surface-2: #ECE3CD;
  --c-ink: #1B3022;
  --c-ink-soft: #344A39;
  --c-ink-muted: #55614F;
  --c-accent: #E84F36;
  --c-accent-deep: #C73E27;
  --c-accent-soft: rgba(232, 79, 54, 0.10);
  --c-green: #1B3022;
  --c-green-2: #243C2D;
  --c-green-soft: rgba(27, 48, 34, 0.08);
  --c-cream: #F4ECDB;
  --c-border: rgba(27, 48, 34, 0.12);
  --c-border-2: rgba(27, 48, 34, 0.06);

  --grain-opacity: 0.045;

  /* type */
  --f-display: "Bricolage Grotesque", "Inter Tight", system-ui, sans-serif;
  --f-body: "Inter", system-ui, -apple-system, sans-serif;
  --f-hand: "Caveat", cursive;
  --f-marker: "Permanent Marker", "Caveat", cursive;

  /* spacing 4px */
  --s-1: 4px; --s-2: 8px; --s-3: 12px; --s-4: 16px; --s-5: 20px;
  --s-6: 24px; --s-8: 32px; --s-10: 40px; --s-12: 48px; --s-14: 56px;
  --s-16: 64px; --s-20: 80px; --s-24: 96px; --s-32: 128px; --s-40: 160px;

  /* radius */
  --r-sm: 4px; --r-md: 10px; --r-lg: 18px; --r-xl: 28px; --r-pill: 999px;

  /* easing */
  --ease-out: cubic-bezier(.22, .8, .32, 1);
  --ease-spring: cubic-bezier(.34, 1.56, .64, 1);

  /* shadows */
  --sh-sm: 0 1px 2px rgba(27, 48, 34, .08);
  --sh-md: 0 12px 32px rgba(27, 48, 34, .10);
  --sh-lg: 0 28px 60px rgba(27, 48, 34, .14);
  --sh-card: 0 4px 18px rgba(27, 48, 34, .07);

  --container: 1340px;
}

[data-theme="dark"] {
  --c-bg: #16271C;
  --c-bg-2: #0E1C13;
  --c-surface: #1F3527;
  --c-surface-2: #1A2B1F;
  --c-ink: #F4ECDB;
  --c-ink-soft: #C9D2C5;
  --c-ink-muted: #95A095;
  --c-accent: #FF6A50;
  --c-accent-deep: #E84F36;
  --c-accent-soft: rgba(255, 106, 80, 0.14);
  --c-green: #F4ECDB;
  --c-green-2: #C9D2C5;
  --c-green-soft: rgba(244, 236, 219, 0.08);
  --c-cream: #F4ECDB;
  --c-border: rgba(244, 236, 219, 0.10);
  --c-border-2: rgba(244, 236, 219, 0.05);
  --grain-opacity: 0.06;
  --sh-card: 0 4px 18px rgba(0, 0, 0, .25);
}

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; scroll-padding-top: 90px; }
body {
  font-family: var(--f-body);
  font-size: 16px;
  line-height: 1.55;
  color: var(--c-ink);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  transition: background .5s var(--ease-out), color .5s var(--ease-out);
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
input, select, textarea { font-family: inherit; font-size: inherit; color: inherit; }
ul, ol { list-style: none; }
em { font-style: italic; }

/* paper grain background */
body::before {
  content: "";
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.7'/%3E%3C/svg%3E");
  opacity: var(--grain-opacity);
  pointer-events: none;
  z-index: 1000;
  mix-blend-mode: multiply;
}

/* ---------- CONTAINER & TYPE ---------- */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 64px);
}

.eyebrow {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--f-body);
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: var(--s-5);
}
.eyebrow::before {
  content: ""; width: 22px; height: 1px; background: currentColor; opacity: .9;
}
.eyebrow-light { color: #FF8B73; }

.display {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(2.4rem, 5.6vw, 5.6rem);
  line-height: 0.96;
  letter-spacing: -0.035em;
  color: var(--c-ink);
}
.display em {
  font-style: italic; font-weight: 600;
  color: var(--c-accent);
  font-feature-settings: "ss01";
}
.display-light { color: var(--c-cream); }
.display-light em { color: #FF8B73; }

.lede {
  font-size: clamp(1rem, 1.2vw, 1.15rem);
  color: var(--c-ink-soft);
  max-width: 56ch;
  margin-bottom: var(--s-5);
}
.lede-light { color: rgba(244, 236, 219, 0.78); }

.section-head { max-width: 760px; margin: 0 0 var(--s-16); }
.section-head .display { margin-bottom: var(--s-5); }
.section-head-row {
  max-width: none;
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: var(--s-12); align-items: end;
}
.head-side { color: var(--c-ink-soft); font-size: 1rem; max-width: 42ch; }
@media (max-width: 768px) {
  .section-head-row { grid-template-columns: 1fr; gap: var(--s-6); }
}

/* hand-drawn marker highlight */
.ink-marker {
  display: inline-block; position: relative;
  padding: 0 8px;
  background: linear-gradient(110deg, transparent 0%, var(--c-accent-soft) 12%, var(--c-accent-soft) 88%, transparent 100%);
  font-style: italic;
  color: var(--c-accent);
}
.ink-marker::after {
  content: "";
  position: absolute; bottom: -4px; left: 6%; right: 6%; height: 3px;
  background: var(--c-accent); opacity: .35;
  border-radius: 2px;
  transform: rotate(-1deg);
}
.ink-marker-light { color: #FF8B73; }
.ink-marker-light::after { background: #FF8B73; opacity: .45; }

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--s-2);
  padding: 14px 22px;
  font-family: var(--f-body);
  font-size: 14px; font-weight: 600;
  letter-spacing: 0.01em;
  border-radius: var(--r-pill);
  transition: transform .35s var(--ease-out), background .25s var(--ease-out), color .25s var(--ease-out), box-shadow .35s var(--ease-out), border-color .25s var(--ease-out);
  white-space: nowrap;
  position: relative;
  border: 1.5px solid transparent;
  will-change: transform;
}
.btn-accent {
  background: var(--c-accent); color: #fff;
  box-shadow: 0 6px 18px rgba(232, 79, 54, 0.25);
}
.btn-accent:hover { background: var(--c-accent-deep); transform: translateY(-1px); box-shadow: 0 12px 28px rgba(232, 79, 54, 0.35); }
.btn-ink {
  background: var(--c-ink); color: var(--c-cream);
}
.btn-ink:hover { background: var(--c-green-2); transform: translateY(-1px); }
.btn-cream {
  background: var(--c-cream); color: var(--c-ink);
}
.btn-cream:hover { background: #fff; transform: translateY(-1px); }
.btn-outline {
  border-color: var(--c-border); color: var(--c-ink);
}
.btn-outline:hover { background: var(--c-surface); border-color: var(--c-ink-soft); }
.btn-lg { padding: 18px 28px; font-size: 15px; }
.btn-sm { padding: 10px 16px; font-size: 13px; }
.btn-block { width: 100%; }

/* ---------- TOPBAR ---------- */
.topbar {
  background: var(--c-green);
  color: var(--c-cream);
  padding: 8px 0;
  overflow: hidden;
  border-bottom: 1px solid var(--c-border-2);
}
.topbar-track {
  display: flex; align-items: center; gap: var(--s-4);
  white-space: nowrap;
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.04em;
  animation: marquee 50s linear infinite;
}
.topbar-track .dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--c-accent);
  margin-right: var(--s-1);
  vertical-align: 0;
}

@keyframes marquee { to { transform: translateX(-50%); } }

/* ---------- NAV ---------- */
.nav {
  position: sticky; top: 0; z-index: 80;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-6);
  padding: 14px clamp(20px, 4vw, 56px);
  background: var(--c-bg);
  border-bottom: 1px solid transparent;
  transition: all .4s var(--ease-out);
}
.nav.scrolled {
  background: oklch(from var(--c-bg) l c h / 0.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom-color: var(--c-border);
}
.nav-logo { display: flex; align-items: center; gap: var(--s-2); color: var(--c-ink); }
.nav-logo-mark { display: inline-flex; color: var(--c-accent); }
.nav-wordmark {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 1.45rem;
  letter-spacing: 0.04em;
  color: var(--c-ink);
}

.nav-links { display: flex; gap: var(--s-8); }
.nav-links a {
  font-size: 14px; font-weight: 500;
  color: var(--c-ink-soft);
  position: relative; padding: 6px 0;
  transition: color .25s var(--ease-out);
}
.nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: 2px;
  width: 0; height: 2px; background: var(--c-accent);
  transition: width .35s var(--ease-out);
  border-radius: 2px;
}
.nav-links a:hover { color: var(--c-ink); }
.nav-links a:hover::after { width: 100%; }

.nav-actions { display: flex; align-items: center; gap: var(--s-3); }
.theme-toggle {
  width: 40px; height: 40px;
  border: 1.5px solid var(--c-border);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
  color: var(--c-ink);
  transition: all .25s var(--ease-out);
}
.theme-toggle:hover { background: var(--c-surface); border-color: var(--c-ink-soft); }
.theme-toggle svg { position: absolute; width: 18px; height: 18px; transition: transform .45s var(--ease-spring), opacity .25s; }
[data-theme="light"] .i-sun { transform: translateY(0); opacity: 1; }
[data-theme="light"] .i-moon { transform: translateY(28px); opacity: 0; }
[data-theme="dark"] .i-sun { transform: translateY(-28px); opacity: 0; }
[data-theme="dark"] .i-moon { transform: translateY(0); opacity: 1; }

.hamburger {
  display: none;
  width: 40px; height: 40px;
  flex-direction: column; justify-content: center; align-items: center; gap: 6px;
  border: 1.5px solid var(--c-border); border-radius: 50%;
}
.hamburger span { width: 16px; height: 1.8px; background: var(--c-ink); transition: all .3s var(--ease-out); }
.hamburger.open span:nth-child(1) { transform: translateY(4.8px) rotate(45deg); }
.hamburger.open span:nth-child(2) { transform: translateY(-3px) rotate(-45deg); }

@media (max-width: 1024px) {
  .nav-links { display: none; }
  .nav-cta { display: none; }
  .hamburger { display: flex; }
}

/* mobile menu */
.mobile-menu {
  position: fixed; inset: 0; z-index: 70;
  background: var(--c-bg);
  padding: 110px clamp(24px, 7vw, 56px) 40px;
  display: flex; flex-direction: column; justify-content: space-between;
  transform: translateY(-100%);
  transition: transform .55s var(--ease-out);
  overflow-y: auto;
}
.mobile-menu.open { transform: translateY(0); }
.mobile-menu nav { display: flex; flex-direction: column; gap: var(--s-3); }
.mobile-menu nav a {
  display: flex; align-items: baseline; gap: var(--s-3);
  font-family: var(--f-display);
  font-size: clamp(2rem, 8vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--c-ink);
  padding: var(--s-3) 0;
  border-bottom: 1px solid var(--c-border);
  transition: color .25s var(--ease-out);
}
.mobile-menu nav a:hover { color: var(--c-accent); }
.m-num {
  font-family: var(--f-body);
  font-size: 14px; font-weight: 600;
  color: var(--c-accent);
  letter-spacing: 0.1em;
}
.mobile-foot { display: flex; flex-direction: column; gap: var(--s-3); margin-top: var(--s-8); }

/* ---------- HERO ---------- */
.hero {
  position: relative;
  padding: clamp(40px, 6vw, 90px) clamp(20px, 4vw, 48px) clamp(60px, 8vw, 100px);
  overflow: hidden;
}
.hero-grid {
  max-width: var(--container); margin: 0 auto;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
  min-height: calc(100vh - 200px);
}
@media (max-width: 968px) {
  .hero-grid { grid-template-columns: 1fr; gap: var(--s-12); min-height: 0; }
}

.hero-text { position: relative; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: var(--s-2);
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-pill);
  padding: 8px 14px;
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--c-ink-soft);
  margin-bottom: var(--s-8);
}
.hero-eyebrow svg { color: var(--c-accent); }

.hero-title {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(3.5rem, 11vw, 9.5rem);
  line-height: 0.88;
  letter-spacing: -0.045em;
  color: var(--c-ink);
  margin-bottom: var(--s-8);
}
.hl-line { display: block; overflow: hidden; padding: 0 0.02em; }
.hl-line em {
  font-style: italic; font-weight: 600;
  color: var(--c-accent);
  display: inline-block;
  position: relative;
}
.hl-line em::after {
  content: ""; position: absolute; left: -2%; right: -2%; bottom: 0.08em;
  height: 0.08em; background: var(--c-accent);
  opacity: 0.18;
  border-radius: 4px;
  transform: rotate(-1deg);
}
.hl-amp {
  font-family: var(--f-display); font-weight: 400;
  font-style: italic;
  color: var(--c-ink-muted);
  font-size: 0.7em;
  vertical-align: 0.05em;
  padding: 0 0.06em;
}

.hero-sub {
  font-size: clamp(1rem, 1.25vw, 1.18rem);
  color: var(--c-ink-soft);
  max-width: 56ch;
  margin-bottom: var(--s-10);
  line-height: 1.55;
}

.hero-cta {
  display: flex; gap: var(--s-3); flex-wrap: wrap;
  margin-bottom: var(--s-8);
}

.hero-stamp {
  position: absolute;
  bottom: 0; right: 0;
  color: var(--c-ink-soft);
  opacity: 0.5;
  transform: rotate(-6deg);
  pointer-events: none;
  animation: spin 30s linear infinite;
}
@media (max-width: 968px) { .hero-stamp { display: none; } }
@keyframes spin { to { transform: rotate(354deg); } }

/* hero visual */
.hero-visual {
  position: relative;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  grid-template-rows: 1fr auto;
  gap: var(--s-3);
  align-items: stretch;
}
.hero-img {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--c-surface);
  box-shadow: var(--sh-card);
}
.hero-img img { width: 100%; height: 100%; object-fit: cover; }
.hero-img-1 {
  grid-row: span 2;
  aspect-ratio: 3 / 4.2;
}
.hero-img-2 {
  aspect-ratio: 1 / 1;
}
.hero-img figcaption {
  position: absolute; left: var(--s-3); right: var(--s-3); bottom: var(--s-3);
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 12px;
  background: rgba(244, 236, 219, 0.95);
  backdrop-filter: blur(8px);
  border-radius: var(--r-md);
  font-size: 12px; font-weight: 600;
  color: var(--c-ink);
  letter-spacing: 0.02em;
}
.hero-img figcaption span:last-child { color: var(--c-accent); font-weight: 700; }

.hero-quote {
  position: relative;
  background: var(--c-green);
  color: var(--c-cream);
  padding: var(--s-6) var(--s-6);
  border-radius: var(--r-lg);
  display: flex; flex-direction: column;
  font-family: var(--f-display);
  overflow: hidden;
}
.hero-quote-mark {
  position: absolute; top: -8px; left: 14px;
  font-family: var(--f-display);
  font-size: 6rem; line-height: 1;
  color: var(--c-accent);
  font-weight: 800;
  opacity: 0.85;
}
.hero-quote p {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(1.05rem, 1.5vw, 1.4rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: var(--s-4);
  position: relative;
  z-index: 1;
}
.hero-quote p em { color: #FF8B73; font-style: italic; }
.hero-quote-by {
  font-family: var(--f-body);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(244, 236, 219, 0.6);
}

.hero-scroll {
  position: absolute;
  bottom: 28px; left: 50%; transform: translateX(-50%);
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--c-ink-muted);
  padding: 8px 16px;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-pill);
}
@media (max-width: 968px) { .hero-scroll { display: none; } }

/* ---------- TRUST STRIP ---------- */
.trust {
  background: var(--c-surface);
  border-block: 1px solid var(--c-border);
  padding: var(--s-12) 0;
}
.trust-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr) 1.6fr;
  gap: var(--s-6);
  align-items: center;
}
@media (max-width: 968px) { .trust-grid { grid-template-columns: repeat(2, 1fr); } .trust-cell-quote { grid-column: span 2; } }

.trust-cell { display: flex; flex-direction: column; gap: var(--s-1); }
.trust-num {
  font-family: var(--f-display);
  font-size: clamp(2.4rem, 4vw, 3.2rem);
  font-weight: 700; line-height: 1;
  letter-spacing: -0.04em;
  color: var(--c-ink);
}
.trust-num .trust-star { color: var(--c-accent); font-size: 0.7em; vertical-align: 0.18em; margin-left: 4px; }
.trust-num .trust-hr { font-size: 0.5em; vertical-align: 0.4em; color: var(--c-ink-muted); margin-left: 4px; font-weight: 400; }
.trust-label { font-size: 12px; color: var(--c-ink-muted); line-height: 1.4; letter-spacing: 0.02em; }

.trust-cell-quote {
  border-left: 1.5px solid var(--c-border);
  padding-left: var(--s-6);
}
.trust-cell-quote p {
  font-family: var(--f-display);
  font-weight: 500; font-style: italic;
  font-size: clamp(0.95rem, 1.2vw, 1.1rem);
  line-height: 1.4;
  color: var(--c-ink);
  margin-bottom: var(--s-2);
}
.trust-cell-quote span { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-ink-muted); }

/* ---------- MARQUEE ---------- */
.marquee {
  background: var(--c-accent);
  color: #fff;
  padding: var(--s-5) 0;
  overflow: hidden;
  border-block: 1px solid rgba(255,255,255,0.15);
}
.marquee-track {
  display: flex; align-items: center; gap: var(--s-5);
  white-space: nowrap;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(1.4rem, 3vw, 2rem);
  letter-spacing: -0.02em;
  animation: marquee 30s linear infinite;
}
.marquee-track em { font-style: italic; font-weight: 600; opacity: 0.85; }
.m-dot { font-size: 0.5em; opacity: 0.7; }

/* ---------- STORY ---------- */
.story { padding: clamp(80px, 12vw, 160px) 0; }
.story-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: center;
}
@media (max-width: 968px) { .story-grid { grid-template-columns: 1fr; } }

.story-art {
  position: relative;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: 1.3fr 1fr;
  gap: var(--s-3);
  aspect-ratio: 1 / 1.05;
}
.story-card {
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--c-surface);
  box-shadow: var(--sh-card);
}
.story-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease-out); }
.story-card:hover img { transform: scale(1.05); }
.story-card-main {
  grid-row: span 2;
  aspect-ratio: auto;
}

.story-stamp {
  background: var(--c-bg);
  border-radius: 50%;
  padding: var(--s-4);
  color: var(--c-accent);
  box-shadow: var(--sh-card);
  animation: spin 35s linear infinite;
  display: flex; align-items: center; justify-content: center;
  align-self: start;
  justify-self: end;
}
/* contain the decorative stamp so it never leaks horizontal scroll on small screens */
@media (max-width: 720px) {
  .story { overflow-x: clip; }
  .story-stamp svg { width: 76px; height: 76px; }
}

.story-quote-card {
  background: var(--c-green);
  color: var(--c-cream);
  padding: var(--s-6);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-md);
  transform: rotate(-1.5deg);
  display: flex; align-items: center;
  position: relative;
}
.story-quote-card .hand {
  position: absolute; top: -2px; left: 12px;
  font-family: var(--f-display);
  font-size: 5rem; line-height: 1;
  color: var(--c-accent);
}
.story-quote-card p {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(1.1rem, 1.7vw, 1.5rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  position: relative; z-index: 1;
}
.story-quote-card p em { color: #FF8B73; font-style: italic; }

.story-text { max-width: 540px; }
.story-text .display { margin-bottom: var(--s-6); }
.story-text p { color: var(--c-ink-soft); margin-bottom: var(--s-4); }

.story-points {
  margin: var(--s-6) 0 var(--s-8);
  display: flex; flex-direction: column; gap: var(--s-2);
}
.story-points li {
  display: flex; gap: var(--s-2);
  font-size: 14px;
  color: var(--c-ink-soft);
}
.story-points span { color: var(--c-accent); font-weight: 700; }

.story-sig { display: flex; align-items: center; gap: var(--s-4); }
.story-sig svg { color: var(--c-accent); }
.story-sig strong { font-family: var(--f-display); font-size: 1.1rem; font-weight: 700; }
.story-sig span { font-size: 12px; color: var(--c-ink-muted); letter-spacing: 0.05em; text-transform: uppercase; }

/* ---------- BREWS ---------- */
.brews {
  padding: clamp(80px, 12vw, 160px) 0;
  background: var(--c-bg-2);
  border-block: 1px solid var(--c-border);
}
.brew-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
}
@media (max-width: 968px) { .brew-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .brew-grid { grid-template-columns: 1fr; } }

.brew-card {
  position: relative;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-8);
  display: flex; flex-direction: column;
  min-height: 360px;
  overflow: hidden;
  transition: all .35s var(--ease-out);
  isolation: isolate;
}
.brew-card::before {
  content: ""; position: absolute; inset: 0;
  background: var(--c-accent);
  opacity: 0; z-index: -1;
  transition: opacity .4s var(--ease-out);
}
.brew-card:hover { border-color: var(--c-accent); transform: translateY(-4px); box-shadow: var(--sh-md); }
.brew-card:hover::before { opacity: 1; }
.brew-card:hover .brew-num,
.brew-card:hover .brew-name,
.brew-card:hover .brew-desc,
.brew-card:hover .brew-tag,
.brew-card:hover .brew-time,
.brew-card:hover .brew-illu { color: #fff; }
.brew-card:hover .brew-illu { transform: rotate(-4deg) scale(1.06); }

.brew-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--s-8); }
.brew-num {
  font-family: var(--f-display);
  font-size: 14px; font-weight: 700;
  color: var(--c-accent);
  letter-spacing: 0.18em;
  transition: color .35s var(--ease-out);
}
.brew-time {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 500;
  color: var(--c-ink-muted);
  transition: color .35s var(--ease-out);
}
.brew-name {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: -0.025em;
  line-height: 1;
  margin-bottom: var(--s-2);
  color: var(--c-ink);
  transition: color .35s var(--ease-out);
}
.brew-tag {
  display: block;
  font-size: 11px; font-weight: 600;
  color: var(--c-ink-muted);
  letter-spacing: 0.1em; text-transform: uppercase;
  margin-bottom: var(--s-5);
  transition: color .35s var(--ease-out);
}
.brew-desc {
  color: var(--c-ink-soft); font-size: 14px; line-height: 1.55;
  flex-grow: 1;
  transition: color .35s var(--ease-out);
}
.brew-illu {
  position: absolute;
  right: var(--s-5); bottom: var(--s-5);
  width: 64px; height: 80px;
  color: var(--c-ink);
  opacity: 0.2;
  transition: all .5s var(--ease-spring);
}
.brew-card:hover .brew-illu { opacity: 1; }

.brew-card-help {
  background: var(--c-green); color: var(--c-cream);
  border-color: var(--c-green);
}
.brew-card-help::before { display: none; }
.brew-card-help:hover { background: var(--c-ink); border-color: var(--c-ink); transform: translateY(-4px); }
.brew-card-help .brew-name { color: var(--c-cream); }
.brew-card-help .brew-desc { color: rgba(244, 236, 219, 0.78); }
.brew-help-art { color: var(--c-accent); margin-bottom: var(--s-6); }
.brew-help-link {
  display: inline-block;
  margin-top: var(--s-6);
  font-size: 14px; font-weight: 600;
  color: var(--c-accent);
  border-bottom: 1.5px solid var(--c-accent);
  padding-bottom: 2px;
}
.brew-help-link:hover { color: #FF8B73; border-color: #FF8B73; }

/* ---------- SPOTLIGHT ---------- */
.spotlight {
  padding: clamp(80px, 12vw, 160px) 0;
  background: var(--c-bg);
}
.spotlight-grid {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 64px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: center;
}
@media (max-width: 968px) { .spotlight-grid { grid-template-columns: 1fr; } }

.spotlight-img {
  position: relative;
  border-radius: var(--r-xl);
  overflow: hidden;
  background: var(--c-surface);
  aspect-ratio: 1 / 1;
  box-shadow: var(--sh-lg);
}
.spotlight-img img { width: 100%; height: 100%; object-fit: cover; }
.spotlight-img figcaption {
  position: absolute; bottom: var(--s-4); left: var(--s-4); right: var(--s-4);
  background: var(--c-bg);
  padding: var(--s-4) var(--s-5);
  border-radius: var(--r-md);
  font-size: 12px; font-weight: 600;
  color: var(--c-ink);
  letter-spacing: 0.02em;
  display: flex; gap: var(--s-2); flex-wrap: wrap; justify-content: center;
}

.spotlight-text { max-width: 540px; }
.spotlight-text .display { margin-bottom: var(--s-5); }
.spotlight-text .lede { margin-bottom: var(--s-8); }

.spotlight-list {
  display: flex; flex-direction: column;
  margin: var(--s-8) 0;
  border-top: 1.5px solid var(--c-border);
}
.spotlight-list li {
  display: flex; align-items: baseline; gap: var(--s-3);
  padding: var(--s-4) 0;
  border-bottom: 1.5px dashed var(--c-border);
  font-family: var(--f-display);
  transition: padding .25s var(--ease-out);
}
.spotlight-list li:hover { padding-left: 8px; }
.sl-name { font-size: 1.1rem; font-weight: 600; letter-spacing: -0.01em; }
.sl-name em { color: var(--c-ink-muted); font-style: italic; font-weight: 500; font-size: 0.85em; margin-left: 4px; }
.sl-dot { flex: 1; height: 2px; background: linear-gradient(90deg, var(--c-border) 50%, transparent 50%); background-size: 6px 2px; margin: 0 var(--s-2); transform: translateY(-3px); }
.sl-price { font-size: 1.05rem; font-weight: 700; color: var(--c-accent); }

/* ---------- MENU ---------- */
.menu { padding: clamp(80px, 12vw, 160px) 0; }
.menu-tabs {
  display: flex; gap: var(--s-2); flex-wrap: wrap;
  margin-bottom: var(--s-12);
  padding: 6px;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-pill);
  width: fit-content;
}
@media (max-width: 600px) { .menu-tabs { width: 100%; overflow-x: auto; } }

.menu-tab {
  padding: 12px 22px;
  font-size: 14px; font-weight: 600;
  border-radius: var(--r-pill);
  color: var(--c-ink-soft);
  white-space: nowrap;
  transition: all .25s var(--ease-out);
}
.menu-tab:hover { color: var(--c-ink); }
.menu-tab.active {
  background: var(--c-ink); color: var(--c-cream);
}

.menu-panel { display: none; }
.menu-panel.active { display: block; animation: fadeIn .5s var(--ease-out); }
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

.menu-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
}
@media (max-width: 968px) { .menu-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .menu-grid { grid-template-columns: 1fr; } }

.m-item {
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: all .35s var(--ease-out);
}
.m-item:hover { transform: translateY(-3px); box-shadow: var(--sh-md); border-color: var(--c-accent); }
.m-img { aspect-ratio: 4 / 3; overflow: hidden; }
.m-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease-out); }
.m-item:hover .m-img img { transform: scale(1.06); }
.m-body { padding: var(--s-6); display: flex; flex-direction: column; gap: var(--s-2); flex-grow: 1; }
.m-row { display: flex; justify-content: space-between; align-items: baseline; gap: var(--s-3); }
.m-row h3 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 1.15;
  letter-spacing: -0.01em;
}
.m-price {
  font-family: var(--f-display);
  font-weight: 700;
  color: var(--c-accent);
  font-size: 1.05rem;
}
.m-item p { font-size: 14px; color: var(--c-ink-soft); line-height: 1.5; flex-grow: 1; }
.m-tag {
  display: inline-block;
  align-self: flex-start;
  padding: 4px 10px;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  border-radius: var(--r-pill);
}
.m-tag-popular { background: var(--c-accent-soft); color: var(--c-accent); }
.m-tag-signature { background: var(--c-green); color: var(--c-cream); }

.m-item-feature .m-row h3 { font-size: 1.45rem; }
.m-item-feature { grid-column: span 1; }
@media (min-width: 600px) { .m-item-feature { grid-column: span 1; } }

.menu-foot {
  margin-top: var(--s-12);
  padding-top: var(--s-6);
  border-top: 1.5px dashed var(--c-border);
  font-size: 13px; color: var(--c-ink-muted);
  letter-spacing: 0.01em;
  font-style: italic;
}

/* ---------- CUP ---------- */
.cup {
  padding: clamp(80px, 12vw, 160px) 0;
  background: var(--c-surface-2);
  border-block: 1px solid var(--c-border);
}
.cup-grid {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 64px);
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: center;
}
@media (max-width: 968px) { .cup-grid { grid-template-columns: 1fr; } }

.cup-text { max-width: 520px; }
.cup-text .display { margin-bottom: var(--s-6); }

.cup-detail {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5); margin-top: var(--s-10);
  padding-top: var(--s-6);
  border-top: 1.5px solid var(--c-border);
}
@media (max-width: 600px) { .cup-detail { grid-template-columns: 1fr; gap: var(--s-3); } }
.cup-detail strong {
  display: block;
  font-family: var(--f-display);
  font-size: 1.6rem; font-weight: 700;
  color: var(--c-accent);
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.cup-detail span { font-size: 12px; color: var(--c-ink-soft); line-height: 1.4; }

.cup-img {
  border-radius: var(--r-xl);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  box-shadow: var(--sh-lg);
}
.cup-img img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- LATE BREW HOUR ---------- */
.late {
  position: relative;
  padding: clamp(80px, 12vw, 160px) 0;
  overflow: hidden;
  isolation: isolate;
  color: var(--c-cream);
}
.late-bg { position: absolute; inset: 0; z-index: -2; }
.late-bg img { width: 100%; height: 100%; object-fit: cover; }
.late-bg::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(15,30,18,0.92) 0%, rgba(15,30,18,0.88) 50%, rgba(15,30,18,0.94) 100%);
}
.late-inner { max-width: 720px; }
.late-inner .display { margin-bottom: var(--s-6); }
.late-inner .lede { margin-bottom: var(--s-12); max-width: 56ch; }

.late-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
  margin-bottom: var(--s-10);
}
@media (max-width: 768px) { .late-cards { grid-template-columns: 1fr; } }

.late-card {
  background: rgba(244, 236, 219, 0.05);
  border: 1.5px solid rgba(244, 236, 219, 0.15);
  backdrop-filter: blur(8px);
  border-radius: var(--r-lg);
  padding: var(--s-6);
}
.late-card-num {
  display: inline-block;
  font-family: var(--f-display);
  font-size: 1.3rem; font-weight: 700;
  color: #FF8B73;
  margin-bottom: var(--s-3);
  letter-spacing: -0.02em;
}
.late-card h4 {
  font-family: var(--f-display);
  font-size: 1.15rem; font-weight: 600;
  margin-bottom: var(--s-2);
}
.late-card p { font-size: 13px; color: rgba(244, 236, 219, 0.7); line-height: 1.5; }

/* ---------- WHY ---------- */
.why { padding: clamp(80px, 12vw, 160px) 0; }
.why-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-4);
}
@media (max-width: 768px) { .why-grid { grid-template-columns: 1fr; } }

.why-card {
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-10);
  position: relative;
  overflow: hidden;
  transition: all .35s var(--ease-out);
}
.why-card:hover { border-color: var(--c-accent); transform: translateY(-3px); box-shadow: var(--sh-md); }
.why-num {
  display: inline-block;
  font-family: var(--f-display);
  font-size: 1.4rem; font-weight: 700;
  color: var(--c-accent);
  margin-bottom: var(--s-5);
  letter-spacing: 0.06em;
}
.why-card h3 {
  font-family: var(--f-display);
  font-size: 1.6rem; font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin-bottom: var(--s-3);
}
.why-card p {
  font-size: 15px; color: var(--c-ink-soft); line-height: 1.6;
  max-width: 50ch;
}

/* ---------- LOCATIONS ---------- */
.locations {
  padding: clamp(80px, 12vw, 160px) 0;
  background: var(--c-bg-2);
  border-block: 1px solid var(--c-border);
}
.loc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
@media (max-width: 968px) { .loc-grid { grid-template-columns: 1fr; max-width: 600px; margin: 0 auto; } }

.loc-card {
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: all .4s var(--ease-out);
}
.loc-card:hover { transform: translateY(-6px); box-shadow: var(--sh-lg); border-color: var(--c-accent); }
.loc-img { position: relative; aspect-ratio: 4 / 3; overflow: hidden; }
.loc-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease-out); }
.loc-card:hover .loc-img img { transform: scale(1.06); }
.loc-badge {
  position: absolute; top: var(--s-4); left: var(--s-4);
  padding: 6px 12px;
  background: var(--c-bg);
  color: var(--c-accent);
  border-radius: var(--r-pill);
  font-size: 10px; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase;
}
.loc-badge-alt { background: var(--c-ink); color: var(--c-cream); }
.loc-badge-new { background: var(--c-accent); color: #fff; }

.loc-body { padding: var(--s-6); display: flex; flex-direction: column; gap: var(--s-3); flex-grow: 1; }
.loc-city {
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-accent);
}
.loc-card h3 {
  font-family: var(--f-display);
  font-size: 1.6rem; font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.05;
}
.loc-sub {
  display: block;
  font-weight: 400; font-style: italic;
  color: var(--c-ink-muted);
  font-size: 0.7em;
  margin-top: 4px;
}
.loc-card address {
  font-style: normal;
  font-size: 13px;
  color: var(--c-ink-soft); line-height: 1.5;
}
.loc-meta {
  display: flex; flex-direction: column;
  margin-top: var(--s-2);
  border-top: 1.5px dashed var(--c-border);
}
.loc-meta-row {
  display: flex; gap: var(--s-3);
  padding: var(--s-2) 0;
  border-bottom: 1.5px dashed var(--c-border-2);
  font-size: 13px;
}
.loc-meta-row:last-child { border-bottom: 0; }
.lm-key { width: 70px; flex-shrink: 0; color: var(--c-ink-muted); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; padding-top: 2px; }
.lm-val { color: var(--c-ink); }
.lm-val a { color: var(--c-accent); border-bottom: 1px solid currentColor; }
.loc-actions { display: flex; gap: var(--s-2); margin-top: var(--s-3); flex-wrap: wrap; }

/* ---------- RECEIPTS ---------- */
.receipts { padding: clamp(80px, 12vw, 160px) 0; }
.receipt-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
}
@media (max-width: 968px) { .receipt-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .receipt-grid { grid-template-columns: 1fr; } }

.receipt {
  background: var(--c-surface);
  border-radius: 0;
  padding: var(--s-6);
  display: flex; flex-direction: column;
  position: relative;
  box-shadow: 0 4px 14px rgba(27, 48, 34, .06);
  transition: transform .35s var(--ease-out);
  /* perforated edges */
  --notch: 8px;
  -webkit-mask:
    radial-gradient(circle at 0 var(--notch), transparent var(--notch), #000 calc(var(--notch) + 1px)) 0 0/100% calc(2 * var(--notch)) repeat-y,
    radial-gradient(circle at 100% var(--notch), transparent var(--notch), #000 calc(var(--notch) + 1px)) 100% 0/100% calc(2 * var(--notch)) repeat-y;
  -webkit-mask-composite: source-in;
          mask:
    radial-gradient(circle at 0 var(--notch), transparent var(--notch), #000 calc(var(--notch) + 1px)) 0 0/100% calc(2 * var(--notch)) repeat-y,
    radial-gradient(circle at 100% var(--notch), transparent var(--notch), #000 calc(var(--notch) + 1px)) 100% 0/100% calc(2 * var(--notch)) repeat-y;
          mask-composite: intersect;
}
.receipt:hover { transform: translateY(-4px) rotate(-0.5deg); }

.r-head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: var(--s-3);
  border-bottom: 2px dashed var(--c-border);
  margin-bottom: var(--s-4);
}
.r-logo { font-family: var(--f-display); font-weight: 800; letter-spacing: 0.1em; font-size: 14px; color: var(--c-ink); }
.r-no { font-size: 11px; color: var(--c-ink-muted); letter-spacing: 0.06em; font-family: var(--f-body); }
.r-body { flex-grow: 1; padding-bottom: var(--s-4); border-bottom: 2px dashed var(--c-border); margin-bottom: var(--s-3); }
.r-body p {
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 1.05rem;
  line-height: 1.4;
  color: var(--c-ink);
  margin-bottom: var(--s-3);
}
.r-stars { color: var(--c-accent); font-size: 14px; letter-spacing: 0.18em; }
.r-foot {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 11px; color: var(--c-ink-muted);
  letter-spacing: 0.04em;
}
.r-foot strong { color: var(--c-ink); font-weight: 700; }

.receipt-feature { background: var(--c-accent); color: #fff; }
.receipt-feature .r-logo { color: #fff; }
.receipt-feature .r-head { border-bottom-color: rgba(255,255,255,0.4); }
.receipt-feature .r-body { border-bottom-color: rgba(255,255,255,0.4); }
.receipt-feature .r-body p { color: #fff; }
.receipt-feature .r-stars { color: #fff; }
.receipt-feature .r-foot { color: rgba(255,255,255,0.7); }
.receipt-feature .r-foot strong { color: #fff; }
.receipt-feature .r-no { color: rgba(255,255,255,0.7); }

/* ---------- WALL POSTER ---------- */
.wall {
  background: var(--c-green);
  color: var(--c-cream);
  padding: clamp(80px, 12vw, 140px) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.wall::before, .wall::after {
  content: "";
  position: absolute; top: 0; bottom: 0;
  width: 12px;
  background: repeating-linear-gradient(45deg, var(--c-accent) 0 8px, var(--c-cream) 8px 16px);
  opacity: 0.6;
}
.wall::before { left: 0; }
.wall::after { right: 0; }
.wall-eyebrow {
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: #FF8B73;
  margin-bottom: var(--s-6);
  display: inline-block;
}
.wall-display {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: clamp(2.8rem, 9vw, 8rem);
  line-height: 0.92;
  letter-spacing: -0.04em;
  color: var(--c-cream);
}
.wall-line { display: block; }
.wall-line em { font-style: italic; font-weight: 700; color: #FF8B73; }
.wall-meta {
  margin-top: var(--s-6);
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(244, 236, 219, 0.55);
}

/* ---------- VISIT ---------- */
.visit { padding: clamp(80px, 12vw, 160px) 0; }
.visit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
@media (max-width: 968px) { .visit-grid { grid-template-columns: 1fr; } }

.visit-text { max-width: 520px; }
.visit-text .display { margin-bottom: var(--s-5); }

.visit-quick {
  display: flex; flex-direction: column;
  gap: var(--s-3);
  margin-top: var(--s-8);
}
.vq-card {
  display: flex; align-items: center; gap: var(--s-4);
  padding: var(--s-5);
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-lg);
  transition: all .25s var(--ease-out);
}
.vq-card:hover { border-color: var(--c-accent); transform: translateX(4px); background: var(--c-bg-2); }
.vq-card svg { color: var(--c-accent); flex-shrink: 0; }
.vq-card strong { display: block; font-family: var(--f-display); font-size: 1.15rem; font-weight: 600; letter-spacing: -0.01em; }
.vq-card span { display: block; font-size: 12px; color: var(--c-ink-muted); margin-top: 2px; }

/* form */
.visit-form {
  position: relative;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--s-10);
}
@media (max-width: 600px) { .visit-form { padding: var(--s-6); } }

.form-stamp {
  position: absolute;
  top: -18px; right: 24px;
  background: var(--c-accent); color: #fff;
  padding: 6px 14px;
  border-radius: var(--r-sm);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.15em; text-transform: uppercase;
  transform: rotate(2deg);
}
.form-title {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 1.8rem;
  letter-spacing: -0.025em;
  margin-bottom: var(--s-2);
}
.form-sub { font-size: 13px; color: var(--c-ink-muted); margin-bottom: var(--s-6); }

.form-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--s-3); margin-bottom: var(--s-3);
}
.form-row label.full { grid-column: span 2; }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } .form-row label.full { grid-column: span 1; } }

.form-row label { display: flex; flex-direction: column; gap: 6px; }
.form-row label span { font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-ink-muted); }
.form-row input, .form-row select, .form-row textarea {
  padding: 13px 14px;
  background: var(--c-bg-2);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-md);
  font-size: 14px;
  color: var(--c-ink);
  transition: border-color .25s var(--ease-out), background .25s var(--ease-out);
  font-family: inherit;
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus {
  outline: none;
  border-color: var(--c-accent);
  background: var(--c-surface);
}
.form-row textarea { resize: vertical; }
.form-thanks { display: block; opacity: 0; margin-top: var(--s-3); text-align: center; color: #2A8E5C; font-size: 13px; transition: opacity .4s; }
.form-thanks.show { opacity: 1; }

/* ---------- NEWSLETTER ---------- */
.newsletter { padding: 0 0 clamp(80px, 12vw, 160px); }
.news-card {
  background: var(--c-ink);
  color: var(--c-cream);
  border-radius: var(--r-xl);
  padding: clamp(40px, 6vw, 80px);
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--s-10);
  align-items: center;
  position: relative;
  overflow: hidden;
}
.news-card::before {
  content: ""; position: absolute;
  top: -100px; right: -80px; width: 300px; height: 300px;
  background: radial-gradient(circle, var(--c-accent-soft), transparent 70%);
  opacity: 0.6;
}
@media (max-width: 768px) { .news-card { grid-template-columns: 1fr; } }

.news-text .display { margin-bottom: var(--s-3); font-size: clamp(2rem, 4.5vw, 3.5rem); }
.news-form { display: flex; gap: var(--s-2); position: relative; }
@media (max-width: 600px) { .news-form { flex-direction: column; } }

.news-form input {
  flex-grow: 1;
  padding: 16px 20px;
  background: rgba(244, 236, 219, 0.08);
  border: 1.5px solid rgba(244, 236, 219, 0.2);
  border-radius: var(--r-pill);
  color: var(--c-cream);
  font-size: 14px;
}
.news-form input::placeholder { color: rgba(244, 236, 219, 0.5); }
.news-form input:focus { outline: none; border-color: var(--c-accent); background: rgba(244, 236, 219, 0.12); }
.news-thanks {
  position: absolute; bottom: -28px; left: 0;
  font-size: 13px; color: #FF8B73; opacity: 0; transition: opacity .4s;
}
.news-thanks.show { opacity: 1; }

/* ---------- FAQ ---------- */
.faq {
  padding: clamp(80px, 12vw, 160px) 0;
  background: var(--c-bg-2);
  border-block: 1px solid var(--c-border);
}
.faq-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
@media (max-width: 968px) { .faq-grid { grid-template-columns: 1fr; } }

.faq-side { position: sticky; top: 100px; }
@media (max-width: 968px) { .faq-side { position: static; } }
.faq-side .display { margin-bottom: var(--s-5); }
.faq-side p { color: var(--c-ink-soft); margin-bottom: var(--s-6); }
.faq-side-cta { display: flex; gap: var(--s-2); flex-wrap: wrap; }

.faq-list { display: flex; flex-direction: column; }
.faq-item {
  border-bottom: 1.5px solid var(--c-border);
  padding: var(--s-5) 0;
}
.faq-item:first-child { border-top: 1.5px solid var(--c-border); }
.faq-item summary {
  list-style: none; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center; gap: var(--s-4);
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  color: var(--c-ink);
  transition: color .25s var(--ease-out);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  font-family: var(--f-display); font-weight: 400;
  font-size: 1.6rem;
  color: var(--c-accent);
  transition: transform .3s var(--ease-out);
  flex-shrink: 0;
}
.faq-item[open] summary { color: var(--c-accent); }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item p {
  margin-top: var(--s-3); padding-right: 30px;
  color: var(--c-ink-soft); font-size: 15px; line-height: 1.6;
  max-width: 60ch;
}
.faq-item p a { color: var(--c-accent); border-bottom: 1px solid currentColor; }

/* ---------- FOOTER ---------- */
.footer {
  background: var(--c-ink);
  color: var(--c-cream);
  padding: clamp(60px, 8vw, 100px) 0 var(--s-6);
  position: relative;
  overflow: hidden;
}
.footer-top {
  display: grid;
  grid-template-columns: 1.3fr 2fr;
  gap: clamp(40px, 6vw, 80px);
  padding-bottom: var(--s-12);
  border-bottom: 1px solid rgba(244, 236, 219, 0.15);
}
@media (max-width: 768px) { .footer-top { grid-template-columns: 1fr; } }

.footer-brand { position: relative; }
.footer-logo { display: flex; align-items: center; gap: var(--s-3); margin-bottom: var(--s-5); }
.footer-logo svg { color: var(--c-accent); }
.footer-logo span { font-family: var(--f-display); font-size: 1.6rem; font-weight: 800; letter-spacing: 0.04em; color: var(--c-cream); }
.footer-tag { font-size: 14px; line-height: 1.6; color: rgba(244, 236, 219, 0.65); max-width: 380px; }
.footer-stamp {
  position: absolute; bottom: -6px; right: 24px;
  color: var(--c-accent);
  opacity: 0.6;
  animation: spin 30s linear infinite;
}
@media (max-width: 768px) { .footer-stamp { display: none; } }

.footer-cols {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-6);
}
@media (max-width: 600px) { .footer-cols { grid-template-columns: repeat(2, 1fr); } }

.footer-cols h4 {
  font-family: var(--f-body);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--c-cream);
  margin-bottom: var(--s-4);
}
.footer-cols a {
  display: block;
  font-size: 14px;
  color: rgba(244, 236, 219, 0.65);
  padding: 4px 0;
  transition: color .25s, transform .25s;
}
.footer-cols a:hover { color: var(--c-accent); transform: translateX(3px); }

.footer-credo {
  display: flex; gap: var(--s-3);
  flex-wrap: wrap;
  align-items: baseline;
  padding: var(--s-8) 0;
  font-family: var(--f-display);
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 600;
  font-style: italic;
  color: var(--c-cream);
  letter-spacing: -0.015em;
  border-bottom: 1px solid rgba(244, 236, 219, 0.15);
}
.footer-dot { font-size: 0.6em; color: var(--c-accent); transform: translateY(-3px); }

.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: var(--s-5);
  font-size: 12px;
  color: rgba(244, 236, 219, 0.45);
  flex-wrap: wrap; gap: var(--s-3);
}
.footer-bottom .ink-marker { color: #FF8B73; }
.footer-bottom .ink-marker::after { background: #FF8B73; }
.footer-credit {
  margin-left: auto;
  font-family: var(--f-display);
  font-style: italic;
  letter-spacing: 0.01em;
  color: rgba(244, 236, 219, 0.55);
}
.footer-credit a {
  color: var(--c-accent);
  font-weight: 600;
  font-style: normal;
  border-bottom: 1px solid rgba(232, 79, 54, 0.4);
  padding-bottom: 1px;
  transition: color .25s, border-color .25s;
}
.footer-credit a:hover { color: #FF8B73; border-bottom-color: #FF8B73; }

/* ---------- HERITAGE TIMELINE ---------- */
.heritage {
  padding: clamp(80px, 12vw, 160px) 0 clamp(60px, 8vw, 120px);
  background: var(--c-bg);
  position: relative;
}
.heritage-track-wrap {
  position: relative;
  padding: var(--s-8) 0 var(--s-16);
  overflow: hidden;
}
.heritage-track-wrap::before,
.heritage-track-wrap::after {
  content: ""; position: absolute; top: 0; bottom: 0; width: 80px;
  z-index: 2;
  pointer-events: none;
}
.heritage-track-wrap::before { left: 0; background: linear-gradient(90deg, var(--c-bg), transparent); }
.heritage-track-wrap::after { right: 0; background: linear-gradient(-90deg, var(--c-bg), transparent); }

.heritage-track {
  display: flex; gap: var(--s-5);
  padding: 0 clamp(20px, 5vw, 64px) var(--s-10);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  scrollbar-color: var(--c-border) transparent;
}
.heritage-track::-webkit-scrollbar { height: 6px; }
.heritage-track::-webkit-scrollbar-track { background: transparent; }
.heritage-track::-webkit-scrollbar-thumb { background: var(--c-border); border-radius: 3px; }

.h-step {
  flex: 0 0 320px;
  scroll-snap-align: start;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex; flex-direction: column;
  position: relative;
  transition: all .35s var(--ease-out);
}
.h-step:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: var(--c-accent); }

.h-step-num {
  font-family: var(--f-display);
  font-size: 2.6rem; font-weight: 800;
  color: var(--c-accent);
  letter-spacing: -0.04em;
  line-height: 1;
}
.h-step-line {
  width: 40px; height: 2px;
  background: var(--c-accent);
  margin: var(--s-3) 0 var(--s-4);
  border-radius: 2px;
}
.h-step h3 {
  font-family: var(--f-display);
  font-size: 1.4rem; font-weight: 600;
  letter-spacing: -0.02em;
  margin-bottom: var(--s-3);
}
.h-step p {
  font-size: 14px; color: var(--c-ink-soft);
  line-height: 1.55; flex-grow: 1;
  margin-bottom: var(--s-4);
}
.h-step-tag {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--c-ink-muted);
  padding-top: var(--s-3);
  border-top: 1.5px dashed var(--c-border);
}

.h-step-feature {
  flex: 0 0 380px;
  background: var(--c-green);
  color: var(--c-cream);
  border-color: var(--c-green);
}
.h-step-feature .h-step-num { color: #FF8B73; }
.h-step-feature h3 { color: var(--c-cream); }
.h-step-feature p { color: rgba(244, 236, 219, 0.78); }
.h-step-feature .h-step-tag { color: rgba(244, 236, 219, 0.55); border-top-color: rgba(244, 236, 219, 0.18); }
.h-step-img {
  margin-top: var(--s-4);
  border-radius: var(--r-md);
  overflow: hidden;
  aspect-ratio: 16 / 9;
}
.h-step-img img { width: 100%; height: 100%; object-fit: cover; }

.h-step-now {
  background: var(--c-accent); color: #fff; border-color: var(--c-accent);
}
.h-step-now .h-step-num { color: #fff; }
.h-step-now h3 { color: #fff; }
.h-step-now p { color: rgba(255,255,255,0.85); }
.h-step-now .h-step-line { background: #fff; }
.h-step-now .h-step-tag { color: rgba(255,255,255,0.7); border-top-color: rgba(255,255,255,0.25); }

/* ---------- BEAN JOURNEY ---------- */
.journey {
  padding: clamp(80px, 12vw, 160px) 0;
  background: var(--c-surface-2);
  border-block: 1px solid var(--c-border);
  position: relative;
  overflow: hidden;
}
.journey-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s-4);
  margin-top: var(--s-8);
}
@media (max-width: 1100px) { .journey-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px) { .journey-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .journey-grid { grid-template-columns: 1fr; } }

.j-line {
  position: absolute; top: 60px; left: 0; right: 0;
  height: 80px;
  color: var(--c-accent);
  opacity: 0.4;
  z-index: 0;
  pointer-events: none;
}
.j-line svg { width: 100%; height: 100%; }
@media (max-width: 1100px) { .j-line { display: none; } }

.j-step {
  position: relative; z-index: 1;
  background: var(--c-bg);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex; flex-direction: column;
  transition: all .35s var(--ease-out);
}
.j-step:hover { transform: translateY(-4px); border-color: var(--c-accent); box-shadow: var(--sh-md); }
.j-step:hover .j-art { color: var(--c-accent); }

.j-num {
  font-family: var(--f-display);
  font-size: 12px; font-weight: 700;
  color: var(--c-accent);
  letter-spacing: 0.18em;
  margin-bottom: var(--s-3);
}
.j-art {
  width: 80px; height: 80px;
  margin: 0 0 var(--s-4) auto;
  color: var(--c-ink);
  transition: color .35s var(--ease-out), transform .5s var(--ease-spring);
}
.j-step:hover .j-art { transform: rotate(-4deg) scale(1.05); }

.j-step h3 {
  font-family: var(--f-display);
  font-size: 1.35rem; font-weight: 600;
  letter-spacing: -0.02em;
  margin-bottom: var(--s-1);
}
.j-meta {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--c-ink-muted);
  display: block;
  margin-bottom: var(--s-3);
}
.j-step p { font-size: 13px; color: var(--c-ink-soft); line-height: 1.55; flex-grow: 1; }
.j-step-final { background: var(--c-accent); color: #fff; border-color: var(--c-accent); }
.j-step-final .j-num { color: rgba(255,255,255,0.85); }
.j-step-final .j-art { color: #fff; }
.j-step-final h3 { color: #fff; }
.j-step-final .j-meta { color: rgba(255,255,255,0.85); }
.j-step-final p { color: rgba(255,255,255,0.9); }

/* ---------- PAIRINGS ---------- */
.pairings { padding: clamp(80px, 12vw, 160px) 0; background: var(--c-bg); }
.pair-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-6);
}
@media (max-width: 800px) { .pair-grid { grid-template-columns: 1fr; } }

.pair {
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--s-8);
  display: flex; flex-direction: column;
  gap: var(--s-6);
  transition: all .4s var(--ease-out);
}
.pair:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: var(--c-accent); }
.pair-flip { flex-direction: column-reverse; }

.pair-imgs {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--s-4);
  align-items: center;
}
.pair-imgs figure {
  aspect-ratio: 1 / 1;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--c-surface-2);
}
.pair-imgs img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease-out); }
.pair:hover .pair-imgs img { transform: scale(1.05); }
.pair-x {
  font-family: var(--f-display);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 700;
  color: var(--c-accent);
  text-align: center;
  font-style: italic;
}

.pair-text { padding: 0 var(--s-2); }
.pair-label {
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-accent);
  margin-bottom: var(--s-3);
  display: block;
}
.pair h3 {
  font-family: var(--f-display);
  font-size: clamp(1.4rem, 2vw, 1.75rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin-bottom: var(--s-3);
}
.pair p { font-size: 14px; color: var(--c-ink-soft); line-height: 1.6; margin-bottom: var(--s-3); }
.pair-price {
  font-family: var(--f-display);
  font-size: 13px; font-weight: 600;
  color: var(--c-ink-muted);
  font-style: italic;
}

.pair-cta {
  margin-top: var(--s-12);
  text-align: center;
  padding: var(--s-8);
  background: var(--c-green);
  color: var(--c-cream);
  border-radius: var(--r-lg);
}
.pair-cta p {
  font-family: var(--f-display);
  font-size: clamp(1.1rem, 1.5vw, 1.4rem);
  font-weight: 500;
  letter-spacing: -0.01em;
}
.pair-cta em { color: #FF8B73; font-style: italic; font-weight: 600; }

/* ---------- CUP STACK (updated) ---------- */
.cup-stack {
  position: relative;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: var(--s-3);
  aspect-ratio: 1 / 1.05;
}
.cup-img-main { grid-row: span 2; aspect-ratio: auto; }
.cup-img-sub { aspect-ratio: 1 / 1; align-self: end; }
.cup-tag {
  position: absolute;
  bottom: 10%; right: -10px;
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: 8px 14px;
  background: var(--c-accent); color: #fff;
  border-radius: var(--r-pill);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  box-shadow: var(--sh-md);
  transform: rotate(-3deg);
}

/* ---------- INTERIOR GALLERY ---------- */
.gallery { padding: clamp(80px, 12vw, 160px) 0; background: var(--c-bg-2); border-block: 1px solid var(--c-border); }
.gallery-mason {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: var(--s-3);
}
@media (max-width: 968px) { .gallery-mason { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 180px; } }
@media (max-width: 600px) { .gallery-mason { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; } }

.g-cell {
  position: relative;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--c-surface);
  cursor: pointer;
}
.g-cell img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease-out); }
.g-cell:hover img { transform: scale(1.08); }
.g-cell figcaption {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: var(--s-3) var(--s-4);
  background: linear-gradient(0deg, rgba(27,48,34,0.85) 0%, rgba(27,48,34,0) 100%);
  color: var(--c-cream);
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.04em;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .35s, transform .35s;
}
.g-cell:hover figcaption { opacity: 1; transform: translateY(0); }
.g-tall { grid-row: span 2; }
.g-wide { grid-column: span 2; }
@media (max-width: 600px) {
  .g-tall { grid-row: span 2; }
  .g-wide { grid-column: span 2; }
}

.gallery-foot {
  margin-top: var(--s-10);
  padding-top: var(--s-6);
  border-top: 1.5px dashed var(--c-border);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: var(--s-3);
}
.gallery-foot span { font-family: var(--f-display); font-size: 1rem; color: var(--c-ink-soft); }
.gallery-foot em { color: var(--c-accent); font-style: italic; font-weight: 600; }

/* ---------- PRESS ---------- */
.press {
  background: var(--c-bg);
  padding: var(--s-12) 0;
  border-bottom: 1px solid var(--c-border);
}
.press-row {
  display: flex; align-items: center; gap: var(--s-6);
  flex-wrap: wrap;
}
.press-label {
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--c-ink-muted);
  flex-shrink: 0;
}
.press-logos {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--s-4);
  flex-grow: 1;
}
.p-logo {
  font-family: var(--f-display);
  font-size: clamp(0.95rem, 1.4vw, 1.2rem);
  font-weight: 600;
  font-style: italic;
  letter-spacing: -0.005em;
  color: var(--c-ink-soft);
  transition: color .25s;
}
.p-logo:hover { color: var(--c-accent); }
.p-dot {
  font-size: 0.5em; color: var(--c-accent); opacity: 0.7;
}

/* ---------- VISIBILITY FIXES ---------- */
.spotlight-list .sl-name em { color: var(--c-ink-muted); }
.brew-tag { color: var(--c-ink-soft); }
.late-card p { color: rgba(244, 236, 219, 0.85); }
.faq-side p { color: var(--c-ink-soft); font-size: 1rem; line-height: 1.6; max-width: 42ch; }
.cup-detail span { color: var(--c-ink-soft); font-size: 13px; }
.r-foot { font-size: 12px; }

/* ---------- VIDEO FEATURE ---------- */
.video-feature {
  padding: clamp(80px, 12vw, 160px) 0;
  background: var(--c-bg);
}
.video-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(40px, 6vw, 90px);
  align-items: center;
}
@media (max-width: 968px) { .video-grid { grid-template-columns: 1fr; } }

.video-text { max-width: 480px; }
.video-text .display { margin-bottom: var(--s-5); }
.video-points {
  margin: var(--s-6) 0 var(--s-8);
  display: flex; flex-direction: column; gap: var(--s-2);
}
.video-points li {
  font-size: 14px; color: var(--c-ink-soft);
  display: flex; gap: var(--s-2);
}
.video-points span { color: var(--c-accent); font-weight: 700; }

.video-frame {
  position: relative;
  border-radius: var(--r-xl);
  overflow: hidden;
  background: var(--c-ink);
  aspect-ratio: 9 / 16;
  box-shadow: var(--sh-lg);
  max-height: 720px;
}
@media (min-width: 768px) {
  .video-frame { aspect-ratio: 4 / 5; max-height: 640px; }
}
.video-el {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.video-tag {
  position: absolute;
  top: var(--s-4); left: var(--s-4);
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  background: var(--c-accent); color: #fff;
  border-radius: var(--r-pill);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  box-shadow: var(--sh-md);
  pointer-events: none;
}
.video-tag svg { transform: translateX(-1px); }

.video-mute {
  position: absolute;
  bottom: var(--s-4); right: var(--s-4);
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(27, 48, 34, 0.65);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  border: 1.5px solid rgba(255,255,255,0.2);
  transition: background .25s var(--ease-out), transform .25s var(--ease-out);
}
.video-mute:hover { background: var(--c-accent); transform: scale(1.06); border-color: var(--c-accent); }
.video-mute .vm-on { display: block; }
.video-mute .vm-off { display: none; }
.video-mute.unmuted .vm-on { display: none; }
.video-mute.unmuted .vm-off { display: block; }

/* ---------- DATA-REVEAL: subtle fade + slide on scroll ----------
   Items are visible by default. The reveal class adds a soft entrance
   only when JS confirms the element is in viewport on first scroll-in.
   If JS fails or page is throttled, content stays fully visible. */
.js [data-reveal]:not(.in) {
  opacity: 0;
  transform: translateY(28px);
}
.js [data-reveal] {
  transition: opacity .7s cubic-bezier(.22,.8,.32,1), transform .7s cubic-bezier(.22,.8,.32,1);
  will-change: opacity, transform;
}
.js [data-reveal].in {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   PREMIUM LAYER  (premium.js / premium.css)
   ============================================================ */

/* ---- 1. INTRO LOADER ---- */
.intro {
  position: fixed; inset: 0; z-index: 4000;
  background: var(--c-bg);
  display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: var(--s-5);
  animation: introOut .9s cubic-bezier(.76,0,.24,1) 1.5s forwards;
}
.intro-inner { display: flex; flex-direction: column; align-items: center; gap: var(--s-4); overflow: hidden; }
.intro-mark {
  width: 64px; height: 64px;
  display: grid; place-items: center;
  opacity: 0; transform: scale(.6) rotate(-18deg);
  animation: introMark .9s cubic-bezier(.34,1.56,.64,1) .1s forwards;
}
.intro-mark img { width: 100%; height: 100%; object-fit: contain; }
.intro-word {
  font-family: var(--f-display);
  font-weight: 600; font-style: italic;
  font-size: clamp(1.1rem, 2.4vw, 1.7rem);
  letter-spacing: -0.01em;
  color: var(--c-ink);
  opacity: 0; transform: translateY(120%);
  animation: introWord .8s cubic-bezier(.22,.8,.32,1) .55s forwards;
}
.intro-word em { color: var(--c-accent); font-style: italic; }
.intro::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 0;
  background: var(--c-green);
  animation: introBar 1.4s cubic-bezier(.76,0,.24,1) .15s forwards;
}
@keyframes introMark { to { opacity: 1; transform: scale(1) rotate(0); } }
@keyframes introWord { to { opacity: 1; transform: translateY(0); } }
@keyframes introBar { 0%{height:0} 60%{height:100%; bottom:0} 100%{height:0; bottom:100%} }
@keyframes introOut { to { opacity: 0; visibility: hidden; transform: translateY(-12px); } }
body.intro-lock { overflow: hidden; }

/* ---- 2. CUSTOM CURSOR ---- */
.cf-has-cursor,
.cf-has-cursor a, .cf-has-cursor button, .cf-has-cursor .btn,
.cf-has-cursor .menu-tab, .cf-has-cursor summary { cursor: none; }
.cf-has-cursor input, .cf-has-cursor textarea, .cf-has-cursor select { cursor: auto; }
.cf-cursor-dot, .cf-cursor-ring {
  position: fixed; top: 0; left: 0; z-index: 5000;
  pointer-events: none;
  margin-left: 0; margin-top: 0;
  opacity: 0; transition: opacity .3s ease;
}
.cf-cursor-dot.on, .cf-cursor-ring.on { opacity: 1; }
.cf-cursor-dot {
  width: 7px; height: 7px; margin: -3.5px 0 0 -3.5px;
  background: var(--c-accent); border-radius: 50%;
}
.cf-cursor-ring {
  width: 38px; height: 38px; margin: -19px 0 0 -19px;
  border: 1.5px solid var(--c-accent);
  border-radius: 50%;
  display: grid; place-items: center;
  transition: width .3s var(--ease-spring), height .3s var(--ease-spring),
              background .3s ease, border-color .3s ease, opacity .3s ease;
}
.cf-cursor-ring.hover { width: 64px; height: 64px; background: var(--c-accent-soft); border-color: var(--c-accent); }
.cf-cursor-ring.down { width: 30px; height: 30px; }
.cf-cursor-ring.labeled { width: 88px; height: 88px; background: var(--c-accent); border-color: var(--c-accent); }
.cf-cursor-label {
  font-family: var(--f-body); font-size: 10px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: #fff; opacity: 0; transition: opacity .2s ease .05s; text-align: center; line-height: 1.1;
}
.cf-cursor-ring.labeled .cf-cursor-label { opacity: 1; }

/* ---- 3. HOVER IMAGE PREVIEW ---- */
.cf-prev {
  position: fixed; top: 0; left: 0; z-index: 4500;
  width: clamp(180px, 18vw, 248px); aspect-ratio: 4 / 5;
  margin: 0; pointer-events: none;
  border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--sh-lg);
  opacity: 0; scale: .82;
  transition: opacity .35s var(--ease-out), scale .45s var(--ease-spring);
  will-change: transform;
}
.cf-prev.show { opacity: 1; scale: 1; }
.cf-prev img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cf-prev::after {
  content: "View"; position: absolute; bottom: 10px; left: 10px;
  background: var(--c-accent); color: #fff;
  font-size: 10px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill);
}
.has-prev-cue { position: relative; }

/* ---- 4. MARQUEE PAUSE ---- */
.marquee.paused .marquee-track,
.press-strip.paused .press-track,
.topbar.paused .topbar-track { animation-play-state: paused; }

/* ---- 5. FROM THE FARM band ---- */
.farm {
  position: relative; isolation: isolate;
  color: var(--c-cream);
  padding: clamp(90px, 13vw, 180px) 0;
  overflow: hidden;
}
.farm-bg { position: absolute; inset: 0; z-index: -2; }
.farm-bg img { width: 100%; height: 100%; object-fit: cover; }
.farm-bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(105deg, rgba(15,30,18,.93) 0%, rgba(15,30,18,.78) 46%, rgba(15,30,18,.30) 100%);
}
.farm-inner { max-width: 680px; }
.farm-eyebrow { color: #FF8B73; }
.farm h2 {
  font-family: var(--f-display); font-weight: 700;
  font-size: clamp(2.1rem, 4.6vw, 4rem); line-height: 1.02;
  letter-spacing: -0.035em; color: var(--c-cream);
  margin-bottom: var(--s-6);
}
.farm h2 em { font-style: italic; color: #FF8B73; }
.farm-poem {
  font-family: var(--f-display); font-weight: 400; font-style: italic;
  font-size: clamp(1.05rem, 1.6vw, 1.4rem); line-height: 1.5;
  color: rgba(244,236,219,.9); max-width: 52ch; margin-bottom: var(--s-6);
}
.farm-body { color: rgba(244,236,219,.72); max-width: 50ch; margin-bottom: var(--s-8); font-size: 1rem; }
.farm-stats { display: flex; gap: clamp(20px,4vw,56px); flex-wrap: wrap; }
.farm-stat strong {
  display: block; font-family: var(--f-display); font-weight: 700;
  font-size: clamp(1.6rem,2.6vw,2.3rem); color: #FF8B73; letter-spacing: -0.02em;
}
.farm-stat span { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(244,236,219,.6); }

/* ---- 6. CELEBRATED QUOTE band ---- */
.qband { background: var(--c-accent); color: #fff; padding: clamp(60px,9vw,120px) 0; text-align: center; }
.qband-inner { max-width: 900px; margin: 0 auto; padding: 0 clamp(20px,5vw,64px); }
.qband-mark { font-family: var(--f-display); font-weight: 800; font-size: 4rem; line-height: 0; display: block; margin-bottom: var(--s-6); opacity: .55; }
.qband blockquote {
  font-family: var(--f-display); font-weight: 600;
  font-size: clamp(1.6rem, 4vw, 3.1rem); line-height: 1.08;
  letter-spacing: -0.025em;
}
.qband cite {
  display: block; margin-top: var(--s-6);
  font-family: var(--f-body); font-style: normal;
  font-size: 12px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,.82);
}

/* ---- 7. data-tilt base ---- */
[data-tilt] { transition: transform .4s var(--ease-out); transform-style: preserve-3d; }

/* ---------- ANIM HELPERS ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .topbar-track, .marquee-track { animation: none; }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
  .intro { display: none !important; }
}
@media (pointer: coarse) {
  .cf-cursor-dot, .cf-cursor-ring, .cf-prev { display: none !important; }
}
