/* =============================================================
   Olvire LTD — site styles (layered on Velocity Brew tokens)
   ============================================================= */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

/* ----- Tokens we override locally ----- */
:root {
  --olv-accent: var(--crema);
  --olv-accent-deep: var(--crema-deep);
  --olv-accent-soft: var(--crema-soft);
  --olv-accent-glow: var(--crema-glow);
  --olv-accent-fg: var(--fg-on-crema);

  --container: 1240px;
  --gutter: 32px;

  --section-pad-y: 80px;

  /* Nav glass backdrop — themed */
  --nav-bg: rgba(5,5,5,0.72);
}
[data-density="compact"]  { --section-pad-y: 56px; }
[data-density="comfy"]    { --section-pad-y: 112px; }

/* ============================================================
   COMFY THEME — warm cream canvas, espresso text, roasted amber
   The product mockups keep their native dark styling (scoped).
   ============================================================ */
[data-theme="comfy"] {
  --bg-0: #F2E9D6;
  --bg-1: #FBF5E8;
  --bg-2: #EEE3CC;
  --bg-3: #E5D6B7;
  --line: rgba(74, 51, 25, 0.12);
  --line-strong: rgba(74, 51, 25, 0.22);

  --fg-1: #2A1E14;
  --fg-2: #6B5642;
  --fg-3: #998669;
  --fg-on-crema: #FFFFFF;

  /* Deepen crema for legibility on cream */
  --crema: #C26913;
  --crema-deep: #8E4A0A;
  --crema-soft: #E08A2C;
  --crema-glow: rgba(194, 105, 19, 0.22);

  --jade: #1F8A5B;
  --ignition: #C2331A;

  --section-pad-y: 100px;
  --container: 1180px;
  --gutter: 40px;
  --nav-bg: rgba(248, 240, 222, 0.78);
}
[data-theme="comfy"][data-density="compact"] { --section-pad-y: 64px; }
[data-theme="comfy"][data-density="comfy"]   { --section-pad-y: 140px; }

[data-theme="comfy"] body {
  letter-spacing: -0.003em;
}

/* Product mockups (phone + dashboard) keep dark identity in both themes */
[data-theme="comfy"] .phone,
[data-theme="comfy"] .dash {
  --bg-0: #050505;
  --bg-1: #0E0E0F;
  --bg-2: #18181B;
  --bg-3: #232327;
  --line: #2A2A2E;
  --line-strong: #3A3A40;
  --fg-1: #FAFAF7;
  --fg-2: #A4A4A8;
  --fg-3: #6B6B6E;
  --crema: var(--olv-accent, #FF9F1C);
  --crema-deep: var(--olv-accent-deep, #C97A0E);
  --crema-soft: var(--olv-accent-soft, #FFB347);
  --crema-glow: var(--olv-accent-glow, rgba(255,159,28,0.35));
  --fg-on-crema: #1A0F00;
  color: #FAFAF7;
}
/* Phone shell hardware stays dark too */
.phone { background: #1A1A1A; }

/* ============================================================
   ABSTRACT placeholders — branded silhouettes, no committed UI
   ============================================================ */
.ab-bar {
  display: block;
  background: var(--fg-3);
  border-radius: 999px;
  opacity: 0.55;
}
.ab-bar:where([style*="--olv-accent"]),
.ab-bar:where([style*="--fg-1"]) { opacity: 0.92; }

.ab-dot {
  width: 18px; height: 18px;
  border-radius: 999px;
  background: var(--fg-3);
  opacity: 0.55;
  flex-shrink: 0;
}
.ab-row { display: flex; align-items: center; }

.ab-pad { padding: 18px; }

.ab-card {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  padding: 14px;
}
.ab-square {
  width: 64px; height: 64px;
  border-radius: 10px;
  background: linear-gradient(160deg, var(--olv-accent-deep), #2a1908);
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}
.ab-square::after {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 8px;
  background: linear-gradient(180deg, transparent 30%, var(--olv-accent-glow) 60%);
}
.ab-tile {
  flex: 1;
  aspect-ratio: 1;
  border-radius: 10px;
  background: linear-gradient(160deg, var(--olv-accent-deep), #2a1908);
  position: relative;
  overflow: hidden;
}
.ab-tile::after {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 8px;
  background: linear-gradient(180deg, transparent 30%, var(--olv-accent-glow) 60%);
}
.ab-cta {
  margin-top: 14px;
  height: 36px;
  border-radius: var(--r-button);
  background: var(--olv-accent);
}
.ab-pill {
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 10px;
  width: 50px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 999px;
  flex-shrink: 0;
}

.phone-abstract .phone-screen { background: var(--bg-0); }
.dash-abstract .dash-main { padding: 18px 22px; }

/* Hide entire mockup containers when preview mode is hidden */
[data-preview="hidden"] .preview-only { display: none !important; }

/* ----- Comfy-specific style adjustments ----- */
[data-theme="comfy"] .hero {
  padding: 56px 0 100px;
}
[data-theme="comfy"] .hero::before {
  opacity: 0.45;
  width: 820px;
  height: 820px;
}
[data-theme="comfy"] .hero::after {
  opacity: 0.10;
  background-size: 64px 64px;
}
[data-theme="comfy"] .hero-title,
[data-theme="comfy"] .section-title {
  font-variation-settings: "wdth" 95, "opsz" 96;
  font-weight: 600;
  letter-spacing: -0.025em;
}
[data-theme="comfy"] .hero-title { line-height: 0.96; }
[data-theme="comfy"] .hero-sub,
[data-theme="comfy"] .section-sub {
  font-size: 18px;
  line-height: 1.6;
  font-weight: 400;
}
[data-theme="comfy"] .hero-pill {
  background: var(--bg-1);
  border-color: var(--line);
}
[data-theme="comfy"] .hero-stats {
  margin-top: 64px;
  padding-top: 32px;
  border-top-color: var(--line-strong);
}
[data-theme="comfy"] .marquee {
  background: var(--bg-1);
  border-color: var(--line);
}
[data-theme="comfy"] .product-card,
[data-theme="comfy"] .tier {
  border-radius: 24px;
  padding: 40px;
}
[data-theme="comfy"] .product-card h3 {
  font-variation-settings: "wdth" 92, "opsz" 96;
  font-weight: 600;
  font-size: 38px;
  letter-spacing: -0.02em;
}
[data-theme="comfy"] .section,
[data-theme="comfy"] .hero {
  /* a touch of warm tone variation per section, not hard banding */
}
[data-theme="comfy"] .tour-item h4 {
  font-size: 19px;
  font-weight: 500;
  color: var(--fg-3);
  transition: none;
}
[data-theme="comfy"] .tour-item[data-active="true"] h4 {
  font-weight: 700;
  color: var(--fg-1);
}
[data-theme="comfy"] .tour-item[data-active="true"] p {
  color: var(--fg-2);
}
[data-theme="comfy"] .pulse { animation: none; box-shadow: var(--shadow-glow); }
[data-theme="comfy"] .process {
  border-radius: 24px;
}
[data-theme="comfy"] .process-step h4 {
  font-variation-settings: "wdth" 92, "opsz" 96;
  font-weight: 600;
}
[data-theme="comfy"] .faq-q {
  font-variation-settings: "wdth" 95, "opsz" 48;
  font-weight: 500;
  font-size: 24px;
}
[data-theme="comfy"] .contact {
  border-radius: 28px;
  padding: 72px;
}
[data-theme="comfy"] .contact-info h3 {
  font-variation-settings: "wdth" 92, "opsz" 96;
  font-weight: 600;
  font-size: 48px;
}
[data-theme="comfy"] .btn-primary {
  font-weight: 500;
}
[data-theme="comfy"] .footer {
  background: var(--bg-1);
  border-top-color: var(--line);
  padding-top: 100px;
}
[data-theme="comfy"] .section { padding-bottom: calc(var(--section-pad-y) - 16px); }

@media (max-width: 960px) {
  [data-theme="comfy"] .contact { padding: 40px; }
}

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

.section {
  padding: var(--section-pad-y) 0;
  position: relative;
}

.section-eyebrow {
  font-family: var(--font-ui);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fg-2);
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.section-eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--olv-accent);
}

.section-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-variation-settings: "wdth" 78, "opsz" 96;
  font-size: clamp(40px, 4.6vw, 64px);
  line-height: 0.96;
  letter-spacing: -0.022em;
  margin: 18px 0 14px;
  text-wrap: balance;
}
.section-sub {
  font-size: 17px;
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 56ch;
  text-wrap: pretty;
}

.accent { color: var(--olv-accent); }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--nav-bg);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur) var(--ease-precision);
}
.nav[data-scrolled="true"] {
  border-bottom-color: var(--line);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}
.nav-left, .nav-center, .nav-right {
  display: flex;
  align-items: center;
  gap: 28px;
}
.nav-links {
  display: flex;
  gap: 28px;
  font-size: 14px;
  color: var(--fg-2);
}
.nav-links a {
  position: relative;
  transition: color var(--dur) var(--ease-precision);
}
.nav-links a:hover { color: var(--fg-1); }

.brand-mark {
  display: flex;
  align-items: center;
  gap: 9px;
  text-decoration: none;
}
.brand-wordmark {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 23px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  line-height: 1;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 18px;
  border-radius: var(--r-button);
  font-size: 14px;
  font-weight: 600;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-precision),
              opacity var(--dur) var(--ease-precision),
              background var(--dur) var(--ease-precision);
  white-space: nowrap;
}
.btn-primary {
  background: var(--olv-accent);
  color: var(--olv-accent-fg);
}
.btn-primary:hover { opacity: 0.92; }
.btn-primary:active { transform: scale(0.97); }

.btn-ghost {
  background: transparent;
  color: var(--fg-1);
  border-color: var(--line);
}
.btn-ghost:hover { background: var(--bg-2); }
.btn-ghost:active { transform: scale(0.97); }

.btn-lg { padding: 15px 24px; font-size: 15px; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  padding: 88px 0 100px;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  top: -100px; right: -120px;
  width: 720px; height: 720px;
  background: radial-gradient(circle, var(--olv-accent-glow) 0%, transparent 60%);
  opacity: 0.6;
  pointer-events: none;
  z-index: 0;
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, var(--line) 1px, transparent 1px),
    linear-gradient(to bottom, var(--line) 1px, transparent 1px);
  background-size: 48px 48px;
  opacity: 0.18;
  mask-image: radial-gradient(circle at 30% 40%, black 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(circle at 30% 40%, black 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.3fr);
  gap: 56px;
  align-items: center;
}

.hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 6px 6px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 12px;
  color: var(--fg-2);
}
.hero-pill .dot {
  width: 7px; height: 7px;
  border-radius: 999px;
  background: var(--jade);
  box-shadow: 0 0 0 4px rgba(0,200,150,0.15);
}
.hero-pill .pill-tag {
  padding: 3px 9px;
  border-radius: 999px;
  background: var(--bg-2);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--fg-1);
}

.hero-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-variation-settings: "wdth" 75, "opsz" 96;
  font-size: clamp(40px, 4.8vw, 72px);
  line-height: 1.0;
  letter-spacing: -0.025em;
  margin: 24px 0 0;
  text-wrap: balance;
}
.hero-sub {
  margin-top: 24px;
  font-size: 19px;
  line-height: 1.5;
  color: var(--fg-2);
  max-width: 52ch;
  text-wrap: pretty;
}
.hero-cta {
  margin-top: 36px;
  display: flex;
  gap: 20px;
  align-items: center;
  flex-wrap: wrap;
}
.hero-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 15px;
  font-weight: 600;
  color: var(--fg-2);
  text-decoration: none;
  transition: color 0.15s;
  white-space: nowrap;
}
.hero-link:hover { color: var(--fg-1); }

.hero-value {
  margin-top: 56px;
  display: grid;
  gap: 18px;
  border-top: 1px solid var(--line);
  padding-top: 28px;
  max-width: 560px;
}
.hv-item {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 14px;
  align-items: start;
}
.hv-item > svg, .hv-item > span:first-child { margin-top: 2px; }
.hv-h {
  font-size: 15px;
  font-weight: 600;
  color: var(--fg-1);
}
.hv-p {
  font-size: 13.5px;
  color: var(--fg-2);
  margin-top: 3px;
  line-height: 1.45;
}

/* Hero stage with dashboard + phone */
.stage {
  position: relative;
  height: 640px;
}

/* ============================================================
   COHORT BANNER — replaces fake customer marquee
   ============================================================ */
.cohort-banner {
  background: #2A1E14;
  padding: 10px 0;
  position: relative;
  overflow: hidden;
}
.cohort-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 60% 50%, var(--olv-accent-glow), transparent 65%);
  pointer-events: none;
}
.cohort-inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 48px;
}
@media (max-width: 640px) {
  .cohort-inner { grid-template-columns: 1fr; gap: 28px; }
}
.cohort-left { display: flex; flex-direction: column; gap: 10px; }
.cohort-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--olv-accent);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cohort-tag::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--olv-accent);
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.7); }
}
.cohort-headline {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.8vw, 34px);
  font-weight: 700;
  line-height: 1.15;
  color: #FAF7F2;
  letter-spacing: -0.02em;
}
.cohort-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}
.cohort-slots { display: flex; gap: 8px; }
.cohort-slots .slot {
  width: 36px; height: 8px;
  border-radius: 999px;
  background: rgba(250,247,242,0.15);
  border: 1px solid rgba(250,247,242,0.2);
}
.cohort-slots .slot.taken { background: var(--olv-accent); border-color: var(--olv-accent); }
.cohort-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: rgba(250,247,242,0.45);
  text-transform: uppercase;
}

/* ============================================================
   WHAT YOU GET
   ============================================================ */
.split-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 56px;
}
.product-card {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 32px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 540px;
}
.product-card .tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--olv-accent);
  text-transform: uppercase;
}
.product-card h3 {
  font-family: var(--font-display);
  font-variation-settings: "wdth" 78, "opsz" 96;
  font-weight: 700;
  font-size: 36px;
  line-height: 1;
  margin: 12px 0 14px;
  letter-spacing: -0.018em;
}
.product-card .lede {
  color: var(--fg-2);
  font-size: 15px;
  line-height: 1.5;
  max-width: 38ch;
}
.feature-list {
  list-style: none;
  padding: 0;
  margin: 28px 0 0;
  display: grid;
  gap: 10px;
}
.feature-list li {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 12px;
  align-items: start;
  font-size: 14px;
  color: var(--fg-1);
}
.feature-list li .ic {
  margin-top: 1px;
  color: var(--olv-accent);
}
.feature-list li .desc {
  display: block;
  color: var(--fg-3);
  font-size: 13px;
  margin-top: 2px;
}
.product-card .visual {
  margin-top: auto;
  padding-top: 32px;
}

/* ============================================================
   FEATURE TOURS
   ============================================================ */
.tour {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 64px;
  align-items: center;
  margin-top: 56px;
}
.tour.reverse { grid-template-columns: 1.15fr 1fr; }
.tour-list {
  display: grid;
  gap: 4px;
}
.tour-item {
  border-top: 1px solid var(--line);
  padding: 22px 0;
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 18px;
  cursor: pointer;
  transition: opacity var(--dur) var(--ease-precision);
}
.tour-item:last-child { border-bottom: 1px solid var(--line); }
.tour-item .n {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-3);
  letter-spacing: 0.05em;
  margin-top: 4px;
}
.tour-item h4 {
  margin: 0 0 6px;
  font-size: 17px;
  font-weight: 600;
  color: var(--fg-3);
  transition: color var(--dur) var(--ease-precision);
}
.tour-item p {
  margin: 0;
  font-size: 14px;
  color: var(--fg-3);
  line-height: 1.5;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height var(--dur-slow) var(--ease-precision), opacity var(--dur) var(--ease-precision), margin var(--dur-slow) var(--ease-precision);
}
.tour-item[data-active="true"] h4 { color: var(--fg-1); }
.tour-item[data-active="true"] .n { color: var(--olv-accent); }
.tour-item[data-active="true"] p {
  max-height: 120px;
  opacity: 1;
  margin-top: 6px;
  color: var(--fg-2);
}

/* ============================================================
   PROCESS
   ============================================================ */
.process {
  margin-top: 64px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
}
.process-step {
  background: var(--bg-0);
  padding: 32px 28px 36px;
  min-height: 240px;
  display: flex;
  flex-direction: column;
  position: relative;
}
.process-step .n {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--olv-accent);
  letter-spacing: 0.05em;
}
.process-step .week {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.04em;
  position: absolute;
  top: 32px;
  right: 28px;
}
.process-step h4 {
  font-family: var(--font-display);
  font-variation-settings: "wdth" 80, "opsz" 48;
  font-weight: 600;
  font-size: 24px;
  line-height: 1.05;
  margin: 18px 0 12px;
  letter-spacing: -0.012em;
}
.process-step p {
  font-size: 13px;
  line-height: 1.55;
  color: var(--fg-2);
  margin: 0 0 18px;
}
.process-step ul {
  list-style: none;
  padding: 0;
  margin: auto 0 0;
  display: grid;
  gap: 6px;
}
.process-step li {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.03em;
  display: flex;
  align-items: center;
  gap: 8px;
}
.process-step li::before {
  content: "";
  width: 4px; height: 4px;
  background: var(--olv-accent);
  border-radius: 999px;
  flex-shrink: 0;
}

/* ============================================================
   PRICING
   ============================================================ */
.founding-card {
  margin-top: 48px;
  background: var(--bg-1);
  border: 1px solid var(--olv-accent);
  border-radius: 24px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 30px 80px rgba(0,0,0,0.18);
}
.founding-card::before {
  content: "";
  position: absolute;
  top: -160px; right: -160px;
  width: 480px; height: 480px;
  background: radial-gradient(circle, var(--olv-accent-glow), transparent 60%);
  opacity: 0.7;
  pointer-events: none;
}
.founding-header {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 40px;
  padding: 44px 48px;
  align-items: center;
  position: relative;
  border-bottom: 1px solid var(--line);
}
.founding-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--olv-accent);
  background: var(--olv-accent-glow);
  padding: 6px 12px;
  border-radius: 999px;
  font-weight: 600;
  margin-bottom: 18px;
}
.founding-name {
  font-family: var(--font-display);
  font-variation-settings: "wdth" 90, "opsz" 96;
  font-weight: 700;
  font-size: 36px;
  line-height: 1.05;
  letter-spacing: -0.018em;
  color: var(--fg-1);
}
[data-theme="comfy"] .founding-name {
  font-variation-settings: "wdth" 95, "opsz" 96;
  font-weight: 600;
}
.founding-desc {
  margin-top: 14px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 38ch;
}
.founding-price-block {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: center;
}
.setup-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--fg-3);
  font-weight: 500;
}
.setup-prices {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-top: 8px;
}
.setup-was {
  font-family: var(--font-mono);
  font-size: 18px;
  color: var(--fg-3);
  text-decoration: line-through;
}
.setup-now {
  font-family: var(--font-mono);
  font-size: 36px;
  font-weight: 600;
  letter-spacing: -0.022em;
  color: var(--olv-accent);
}
.monthly-amount {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin-top: 8px;
}
.monthly-amount .amount {
  font-family: var(--font-mono);
  font-size: 36px;
  font-weight: 600;
  letter-spacing: -0.022em;
  color: var(--fg-1);
}
.monthly-amount .unit {
  font-size: 13px;
  color: var(--fg-3);
}
.setup-meta {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--fg-3);
  margin-top: 10px;
  letter-spacing: 0.04em;
  line-height: 1.4;
  max-width: 26ch;
}
.founding-divider {
  width: 1px;
  height: 70px;
  background: var(--line);
}
.founding-features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  padding: 40px 48px;
  border-bottom: 1px solid var(--line);
  position: relative;
}
.founding-group {
  padding: 0 24px;
  border-right: 1px solid var(--line);
}
.founding-group:first-child { padding-left: 0; }
.founding-group:last-child { padding-right: 0; border-right: 0; }
.founding-group-h {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--olv-accent);
  font-weight: 600;
  margin-bottom: 16px;
}
.founding-group ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
}
.founding-group li {
  display: grid;
  grid-template-columns: 16px 1fr;
  gap: 10px;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--fg-1);
  align-items: start;
}
.founding-group li svg { color: var(--olv-accent); margin-top: 3px; }
.founding-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 28px 48px;
  gap: 20px;
  flex-wrap: wrap;
  position: relative;
}
.founding-foot-left {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.pricing-fineprint {
  margin-top: 24px;
  font-size: 12px;
  color: var(--fg-3);
  text-align: center;
  max-width: 64ch;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.5;
}
@media (max-width: 960px) {
  .founding-header { grid-template-columns: 1fr; padding: 28px; gap: 28px; }
  .founding-features { grid-template-columns: 1fr; padding: 28px; gap: 24px; }
  .founding-group { padding: 0; border-right: 0; border-bottom: 1px solid var(--line); padding-bottom: 24px; }
  .founding-group:last-child { border-bottom: 0; padding-bottom: 0; }
  .founding-foot { padding: 24px 28px; flex-direction: column; align-items: stretch; }
  .founding-foot .btn { justify-content: center; }
}
.price-toggle button {
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: var(--fg-2);
  cursor: pointer;
  transition: all var(--dur) var(--ease-precision);
}
.price-toggle button[data-active="true"] {
  background: var(--fg-1);
  color: var(--bg-0);
}
.price-toggle .save {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  color: var(--olv-accent);
  margin-left: 6px;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 48px;
}
.tier {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  min-height: 580px;
  position: relative;
}
.tier.featured {
  border-color: var(--olv-accent);
  background: linear-gradient(180deg, var(--olv-accent-glow) -50%, var(--bg-1) 40%);
}
.tier .badge {
  position: absolute;
  top: -10px;
  right: 24px;
  background: var(--olv-accent);
  color: var(--olv-accent-fg);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 999px;
  font-weight: 600;
}
.tier .name {
  font-family: var(--font-display);
  font-variation-settings: "wdth" 80, "opsz" 48;
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.01em;
}
.tier .desc {
  color: var(--fg-2);
  font-size: 14px;
  line-height: 1.5;
  margin: 8px 0 24px;
  min-height: 42px;
}
.tier .price-row {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.tier .price-row .amount {
  font-family: var(--font-mono);
  font-size: 44px;
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1;
}
.tier .price-row .unit {
  color: var(--fg-3);
  font-size: 13px;
}
.tier .setup {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.04em;
  margin-top: 10px;
}
.tier ul {
  list-style: none;
  padding: 0;
  margin: 24px 0;
  display: grid;
  gap: 12px;
  flex: 1;
}
.tier li {
  display: grid;
  grid-template-columns: 16px 1fr;
  gap: 10px;
  align-items: start;
  font-size: 13.5px;
  color: var(--fg-1);
  line-height: 1.45;
}
.tier li .ic { color: var(--olv-accent); margin-top: 2px; }
.tier li.dim { color: var(--fg-3); }
.tier li.dim .ic { color: var(--fg-3); }
.tier .cta {
  margin-top: auto;
  width: 100%;
  justify-content: center;
}

/* ============================================================
   FAQ
   ============================================================ */
.faq {
  margin-top: 48px;
  display: grid;
  grid-template-columns: 1fr;
  border-top: 1px solid var(--line);
}
.faq-item {
  border-bottom: 1px solid var(--line);
}
.faq-q {
  width: 100%;
  background: transparent;
  border: 0;
  text-align: left;
  padding: 24px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--fg-1);
  -webkit-text-fill-color: currentColor;
  font-family: var(--font-display);
  font-variation-settings: "wdth" 88, "opsz" 48;
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.012em;
  cursor: pointer;
  transition: color var(--dur) var(--ease-precision);
}
.faq-q:hover { color: var(--olv-accent); }
.faq-q .plus {
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 18px;
  color: var(--fg-3);
  flex-shrink: 0;
  margin-left: 24px;
  transition: transform var(--dur-slow) var(--ease-precision);
}
.faq-item[data-open="true"] .faq-q .plus { transform: rotate(45deg); color: var(--olv-accent); }
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--dur-slow) var(--ease-precision), padding var(--dur-slow) var(--ease-precision);
  padding: 0 24px 0 0;
  color: var(--fg-2);
  font-size: 15px;
  line-height: 1.55;
  max-width: 70ch;
}
.faq-item[data-open="true"] .faq-a {
  max-height: 400px;
  padding-bottom: 24px;
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact {
  margin-top: 56px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 56px;
  position: relative;
  overflow: hidden;
}
.contact::before {
  content: "";
  position: absolute;
  top: -150px; left: -150px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, var(--olv-accent-glow), transparent 60%);
  opacity: 0.5;
  pointer-events: none;
}
.contact-info { position: relative; z-index: 1; }
.contact-info h3 {
  font-family: var(--font-display);
  font-variation-settings: "wdth" 78, "opsz" 96;
  font-weight: 700;
  font-size: 44px;
  line-height: 0.95;
  letter-spacing: -0.022em;
  margin: 0 0 18px;
}
.contact-info p {
  color: var(--fg-2);
  font-size: 16px;
  line-height: 1.55;
  margin: 0;
}
.contact-info .talk-to {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}
.contact-info .talk-to .who {
  display: flex;
  align-items: center;
  gap: 12px;
}
.contact-info .talk-to .avatar {
  width: 44px; height: 44px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--olv-accent), var(--olv-accent-deep));
  display: grid;
  place-items: center;
  color: var(--olv-accent-fg);
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 14px;
}
.contact-info .talk-to .name {
  font-size: 14px;
  color: var(--fg-1);
  font-weight: 500;
}
.contact-info .talk-to .role {
  font-size: 12px;
  color: var(--fg-3);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-top: 2px;
}

.contact-form {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 14px;
}
.field {
  display: grid;
  gap: 6px;
}
.field label {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-2);
  font-weight: 500;
}
.field input, .field select, .field textarea {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-input);
  padding: 13px 14px;
  color: var(--fg-1);
  font-family: var(--font-ui);
  font-size: 14px;
  outline: none;
  transition: border-color var(--dur) var(--ease-precision), background var(--dur) var(--ease-precision);
}
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--olv-accent);
  background: var(--bg-2);
}
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  border-top: 1px solid var(--line);
  background: var(--bg-0);
  padding: 80px 0 32px;
  margin-top: 80px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--line);
}
.footer-grid h5 {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin: 0 0 18px;
  font-weight: 500;
}
.footer-grid ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.footer-grid a { color: var(--fg-2); font-size: 14px; transition: color var(--dur) var(--ease-precision); }
.footer-grid a:hover { color: var(--fg-1); }

.footer-bottom {
  padding-top: 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.04em;
}

/* ============================================================
   PHONE MOCKUP — screen variant helpers
   ============================================================ */

/* Shared icon button (top-left back arrow, etc.) */
.phone-icon-btn {
  width: 32px; height: 32px;
  border-radius: 999px;
  background: var(--bg-2);
  display: grid;
  place-items: center;
  color: var(--fg-2);
  flex-shrink: 0;
}

/* Push-notification banner (notif screen) */
.phone-notif {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: var(--bg-2);
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  padding: 10px 12px;
  margin: 10px 0 4px;
}
.notif-app {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--fg-3);
  letter-spacing: 0.1em;
  margin-bottom: 3px;
}
.notif-msg {
  font-size: 11.5px;
  color: var(--fg-1);
  line-height: 1.3;
}
.notif-time {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--fg-3);
  flex-shrink: 0;
  margin-top: 1px;
}

/* Quick-menu tile labels */
.phone-quick .tile .tile-label {
  position: absolute;
  bottom: 8px;
  left: 8px;
  right: 8px;
  z-index: 2;
}
.phone-quick .tile .tile-name {
  font-size: 10px;
  font-weight: 600;
  color: var(--fg-1);
  line-height: 1.2;
}
.phone-quick .tile .tile-price {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--olv-accent);
  margin-top: 2px;
}

/* Loyalty screen — stars card */
.phone-loyalty-card {
  margin-top: 16px;
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  padding: 18px;
  text-align: center;
}
.loyalty-stars {
  display: flex;
  justify-content: center;
  gap: 3px;
  margin-bottom: 6px;
}

/* Loyalty screen — available reward row */
.phone-reward-item {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  background: rgba(255,159,28,0.06);
  border: 1px solid rgba(255,159,28,0.3);
  border-radius: var(--r-card);
  padding: 12px 14px;
}

/* ============================================================
   PHONE MOCKUP
   ============================================================ */
.phone {
  width: 280px;
  border-radius: 38px;
  background: #111;
  border: 1px solid rgba(255,255,255,0.08);
  padding: 8px;
  box-shadow:
    0 2px 4px  rgba(0,0,0,0.35),
    0 8px 20px rgba(0,0,0,0.45),
    0 30px 60px rgba(0,0,0,0.55),
    0 0 0 0.5px rgba(255,255,255,0.05);
  position: relative;
}
/* Left-edge highlight — simulates curved glass edge lit from upper-left */
.phone::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(160deg, rgba(255,255,255,0.07) 0%, transparent 35%);
  pointer-events: none;
  z-index: 1;
}
.phone-screen {
  background: var(--bg-0);
  border-radius: 30px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 9/19.5;
}
/* Sharp image rendering for the screenshot img */
.phone-screen img {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
/* Screen glass glare — diagonal highlight top-left corner */
.phone-screen::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(145deg, rgba(255,255,255,0.08) 0%, transparent 48%);
  pointer-events: none;
  z-index: 30;
  border-radius: inherit;
}
/* ── iOS phone — pronounced squircle corners, silver-edged ── */
.phone-ios {
  border-radius: 52px;
  border-color: rgba(255,255,255,0.13);
}
.phone-ios .phone-screen { border-radius: 44px; }

/* iPhone hardware buttons */
.phone-ios .hw-mute     { position:absolute; left:-3px; top: 86px; width:3px; height:18px; background:#242424; border-radius:2px 0 0 2px; }
.phone-ios .hw-vol-up   { position:absolute; left:-3px; top:118px; width:3px; height:30px; background:#242424; border-radius:2px 0 0 2px; }
.phone-ios .hw-vol-down { position:absolute; left:-3px; top:158px; width:3px; height:30px; background:#242424; border-radius:2px 0 0 2px; }
.phone-ios .hw-power    { position:absolute; right:-3px;top:136px; width:3px; height:58px; background:#242424; border-radius:0 2px 2px 0; }

/* ── Android phone — slightly squarer, wider, taller ── */
.phone-android {
  width: 292px;
  border-radius: 36px;
  border-color: rgba(255,255,255,0.06);
  background: #0e0e0e;
}
.phone-android .phone-screen {
  border-radius: 28px;
  aspect-ratio: 9/20;   /* Android is taller than iPhone */
}

/* Android hardware buttons — power + volume both on right (Samsung/Pixel style) */
.phone-android .hw-power { position:absolute; right:-3px; top: 96px; width:3px; height:36px; background:#1e1e1e; border-radius:0 2px 2px 0; }
.phone-android .hw-vol   { position:absolute; right:-3px; top:150px; width:3px; height:58px; background:#1e1e1e; border-radius:0 2px 2px 0; }

.phone-statusbar {
  height: 36px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 18px 0 22px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  position: relative;
}
.phone-statusbar .notch {
  position: absolute;
  left: 50%;
  top: 6px;
  transform: translateX(-50%);
  width: 88px;
  height: 22px;
  background: #000;
  border-radius: 999px;
}
.phone-statusbar .right {
  display: flex; gap: 6px; align-items: center;
}
.phone-statusbar svg { display: block; }

.phone-content { padding: 6px 18px 18px; }

.phone-greeting {
  font-family: var(--font-display);
  font-variation-settings: "wdth" 78, "opsz" 96;
  font-weight: 700;
  font-size: 32px;
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 16px 0 4px;
}
.phone-greeting .crema { color: var(--olv-accent); }
.phone-eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--fg-2);
  text-transform: uppercase;
}
.phone-loyalty {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-2);
  letter-spacing: 0.04em;
  margin-top: 8px;
}
.phone-loyalty .star { color: var(--olv-accent); }

.phone-card {
  margin-top: 16px;
  background: var(--bg-1);
  border-radius: var(--r-card);
  padding: 14px;
  border: 1px solid var(--line);
}
.phone-card .top {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
}
.phone-card .top .l { color: var(--olv-accent); }
.phone-card .top .r { color: var(--fg-3); }
.phone-card .body {
  display: grid; grid-template-columns: 64px 1fr; gap: 12px;
  margin-top: 12px;
  align-items: center;
}
.phone-card .cup {
  width: 64px; height: 64px;
  border-radius: 10px;
  background: linear-gradient(160deg, #6b4015 0%, #2a1908 100%);
  position: relative;
  overflow: hidden;
}
.phone-card .cup::before {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 8px;
  background: linear-gradient(180deg, transparent 30%, rgba(255,159,28,0.18) 60%);
}
.phone-card .cup::after {
  content: "";
  position: absolute;
  top: 8px; left: 8px; right: 16px; height: 6px;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(255,255,255,0.18), transparent);
}
.phone-card .drink-name {
  font-size: 15px;
  font-weight: 600;
  line-height: 1.1;
}
.phone-card .drink-spec {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-2);
  margin-top: 4px;
  letter-spacing: 0.03em;
}
.phone-card .price-row {
  display: flex; align-items: baseline; gap: 4px;
  margin-top: 6px;
}
.phone-card .price-row .p {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 14px;
}
.phone-card .pull-up {
  margin-top: 14px;
  background: var(--olv-accent);
  color: var(--olv-accent-fg);
  border-radius: var(--r-button);
  padding: 12px;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.phone-section-label {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--fg-2);
  text-transform: uppercase;
  margin: 20px 0 10px;
}
.phone-section-label .see { color: var(--olv-accent); text-transform: none; letter-spacing: 0.02em; }

.phone-quick {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.phone-quick .tile {
  aspect-ratio: 1;
  border-radius: 10px;
  background: linear-gradient(160deg, #6b4015 0%, #2a1908 100%);
  position: relative;
}
.phone-quick .tile::after {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 8px;
  background: linear-gradient(180deg, transparent 30%, rgba(255,159,28,0.22) 60%);
}

.phone-nav {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: rgba(5,5,5,0.92);
  backdrop-filter: blur(12px);
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding: 10px 12px 16px;
  gap: 4px;
}
.phone-nav .pn {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  color: var(--fg-3);
  text-transform: uppercase;
}
.phone-nav .pn.active { color: var(--olv-accent); }

/* ============================================================
   DASHBOARD MOCKUP
   ============================================================ */
.dash {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  position: relative;
  font-family: var(--font-ui);
}
.dash-chrome {
  height: 42px;
  background: var(--bg-2);
  display: flex;
  align-items: center;
  padding: 0 16px;
  gap: 8px;
  border-bottom: 1px solid var(--line);
}
.dash-chrome .dot {
  width: 10px; height: 10px;
  border-radius: 999px;
  background: var(--line);
}
.dash-chrome .url {
  margin-left: 14px;
  padding: 4px 12px;
  border-radius: 6px;
  background: var(--bg-0);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-2);
  display: flex;
  align-items: center;
  gap: 6px;
}
.dash-chrome .url .lock { color: var(--jade); }

.dash-body {
  display: grid;
  grid-template-columns: 200px 1fr;
  min-height: 540px;
}

.dash-side {
  background: var(--bg-1);
  border-right: 1px solid var(--line);
  padding: 20px 14px;
}
.dash-shop {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px;
  border-radius: 8px;
  background: var(--bg-2);
  margin-bottom: 22px;
}
.dash-shop .logo {
  width: 28px; height: 28px;
  border-radius: 6px;
  background: var(--olv-accent);
  color: var(--olv-accent-fg);
  display: grid;
  place-items: center;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
}
.dash-shop .meta {
  flex: 1;
  min-width: 0;
}
.dash-shop .nm { font-size: 12px; font-weight: 600; line-height: 1.1; }
.dash-shop .loc {
  font-family: var(--font-mono);
  font-size: 9.5px;
  color: var(--fg-3);
  letter-spacing: 0.04em;
  margin-top: 2px;
}
.dash-shop .chev { color: var(--fg-3); }

.dash-nav {
  display: grid;
  gap: 2px;
}
.dash-nav .item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 6px;
  font-size: 12.5px;
  color: var(--fg-2);
  cursor: pointer;
  transition: all var(--dur) var(--ease-precision);
}
.dash-nav .item:hover { color: var(--fg-1); background: var(--bg-2); }
.dash-nav .item.active {
  background: var(--bg-2);
  color: var(--fg-1);
}
.dash-nav .item.active .ic { color: var(--olv-accent); }
.dash-nav .ic { width: 16px; display: grid; place-items: center; color: var(--fg-3); }
.dash-nav .badge {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  background: var(--olv-accent);
  color: var(--olv-accent-fg);
  padding: 1px 6px;
  border-radius: 999px;
  font-weight: 600;
}
.dash-nav .sect {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-3);
  padding: 18px 10px 6px;
}

.dash-main {
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.dash-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 22px;
}
.dash-top h2 {
  font-family: var(--font-display);
  font-variation-settings: "wdth" 84, "opsz" 48;
  font-weight: 600;
  font-size: 22px;
  line-height: 1;
  letter-spacing: -0.012em;
  margin: 0;
}
.dash-top .sub {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--fg-3);
  letter-spacing: 0.06em;
  margin-top: 4px;
}

.dash-kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 22px;
}
.kpi {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 16px 18px;
}
.kpi .label {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.kpi .v {
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-top: 8px;
}
.kpi .delta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--jade);
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 3px;
}
.kpi .delta.down { color: var(--ignition); }
.kpi.crema .v { color: var(--olv-accent); }

.dash-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 16px;
}
.dash-tabs .tab {
  padding: 10px 14px;
  font-size: 12px;
  color: var(--fg-2);
  border-bottom: 2px solid transparent;
  cursor: pointer;
  font-weight: 500;
  transition: all var(--dur) var(--ease-precision);
  margin-bottom: -1px;
}
.dash-tabs .tab.active { color: var(--fg-1); border-bottom-color: var(--olv-accent); }
.dash-tabs .tab:hover { color: var(--fg-1); }
.dash-tabs .tab .n {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  margin-left: 6px;
}

.dash-queue {
  display: grid;
  gap: 12px;
  flex: 1;
}
.order-row {
  display: grid;
  grid-template-columns: 50px 1.2fr 1.4fr 0.9fr 0.9fr 110px;
  gap: 18px;
  padding: 16px 20px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  align-items: center;
  font-size: 12px;
  transition: all var(--dur) var(--ease-precision);
}
.order-row:hover { border-color: var(--line-strong); }
.order-row[data-status="pulling"] {
  border-color: var(--crema);
  background: linear-gradient(90deg, rgba(255,159,28,0.06), var(--bg-2) 40%);
}
.order-row[data-status="ready"] {
  border-color: rgba(0,200,150,0.4);
}

.order-row .order-id {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-3);
}
.order-row .customer .nm { font-weight: 600; font-size: 13px; }
.order-row .customer .meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: 0.04em;
  margin-top: 2px;
}
.order-row .items { color: var(--fg-2); line-height: 1.4; }
.order-row .items .x { color: var(--fg-3); font-family: var(--font-mono); margin-right: 4px; }

.lane {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--bg-0);
  border: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
}
.lane.lane-1 { color: var(--olv-accent); border-color: rgba(255,159,28,0.3); }
.lane.lane-2 { color: var(--jade); border-color: rgba(0,200,150,0.3); }
.lane.counter { color: var(--fg-2); }
.lane .ind { width: 6px; height: 6px; border-radius: 999px; background: currentColor; }

.timer {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 13px;
}
.timer.warn { color: var(--olv-accent); }
.timer.alert { color: var(--ignition); }
.timer.ok { color: var(--jade); }

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  background: var(--bg-0);
  border: 1px solid var(--line);
  color: var(--fg-2);
  justify-self: end;
}
.status-pill.queued { color: var(--fg-2); }
.status-pill.pulling {
  color: var(--olv-accent);
  border-color: rgba(255,159,28,0.3);
  background: rgba(255,159,28,0.06);
}
.status-pill.pulling .ind { animation: pulse-ind 1.4s ease-in-out infinite; }
.status-pill.ready {
  color: var(--jade);
  border-color: rgba(0,200,150,0.3);
  background: rgba(0,200,150,0.06);
}
.status-pill .ind {
  width: 6px; height: 6px;
  border-radius: 999px;
  background: currentColor;
}
/* ── Phone skeleton shimmer ─────────────────────────────────── */
@keyframes skel-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}
.skel-l {
  background: linear-gradient(90deg, #d4cfc8 25%, #e0dad2 50%, #d4cfc8 75%);
  background-size: 200% 100%;
  animation: skel-shimmer 1.4s ease-in-out infinite;
  border-radius: 4px;
}
.skel-d {
  background: linear-gradient(90deg, #231c14 25%, #2e2419 50%, #231c14 75%);
  background-size: 200% 100%;
  animation: skel-shimmer 1.4s ease-in-out infinite;
  border-radius: 4px;
}

@keyframes pulse-ind {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}

/* Dashboard alt views (menu, analytics) */
.dash-menu-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.menu-item {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
  display: grid;
  gap: 8px;
}
.menu-item .name { font-weight: 600; font-size: 14px; }
.menu-item .row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-2);
}
.menu-item .stock {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.menu-item .stock.live { color: var(--jade); }
.menu-item .stock.low { color: var(--olv-accent); }
.menu-item .stock.off { color: var(--fg-3); }

.dash-analytics {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 14px;
  flex: 1;
}
.chart-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 18px;
  display: flex;
  flex-direction: column;
}
.chart-card h4 {
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.chart-card h4 .meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: 0.06em;
  font-weight: 400;
}
.chart-svg { margin-top: 12px; width: 100%; }

/* ============================================================
   Responsive — keep desktop-first but compress
   ============================================================ */
@media (max-width: 960px) {
  .hero-inner { grid-template-columns: 1fr; }
  .split-2, .tour, .tour.reverse { grid-template-columns: 1fr; }
  .pricing-grid, .process { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .contact      { grid-template-columns: minmax(0, 1fr); padding: 32px; }
  .contact-form { min-width: 0; width: 100%; }
  .field-row    { grid-template-columns: 1fr; }
  .dash-body { grid-template-columns: 1fr; }
  .dash-side { display: none; }

  /* Gutter + section spacing */
  :root                { --gutter: 20px; --section-pad-y: 64px; }
  [data-theme="comfy"] { --gutter: 20px; --section-pad-y: 64px; }

  /* Nav — hide links, keep logo + CTA */
  .nav-links, .nav-center { display: none; }

  /* Hero stage — both phones side by side, no dashboard, above the copy */
  .stage {
    display: block !important;
    height: 360px;
    order: -1;
    margin-bottom: 8px;
  }
  .stage-dash-wrap { display: none; }
  .stage-phone-left {
    left: 4% !important;
    right: auto !important;
    bottom: -10px !important;
    transform: rotate(-5deg) scale(0.62) !important;
    transform-origin: bottom left !important;
  }
  .stage-phone-right {
    right: 4% !important;
    left: auto !important;
    bottom: -10px !important;
    transform: rotate(5deg) scale(0.62) !important;
    transform-origin: bottom right !important;
  }

  /* Founding price block — 2-col instead of 3 */
  .founding-price-block { grid-template-columns: 1fr 1fr; gap: 16px; }
  .founding-divider     { display: none; }

  /* FAQ + dashboard bullets */
  .faq-grid           { grid-template-columns: 1fr !important; gap: 40px !important; }
  .dashboard-bullets  { grid-template-columns: 1fr !important; gap: 16px !important; }
}

/* Small mobile — 640px and below */
@media (max-width: 640px) {
  :root                { --gutter: 20px; --section-pad-y: 52px; }
  [data-theme="comfy"] { --gutter: 20px; --section-pad-y: 52px; }

  /* Hero — reduce top padding so phones aren't pushed far down */
  .hero       { padding: 32px 0 64px; }
  .hero-value { margin-top: 36px; }

  /* Founding card */
  .founding-price-block { grid-template-columns: 1fr; }
  .founding-name        { font-size: 24px; line-height: 1.1; }
  .setup-now            { font-size: 28px; }
  .founding-header      { padding: 24px; }

  /* Contact — prevent form from overflowing container */
  [data-theme="comfy"] .contact { padding: 24px; border-radius: 18px; }
  .contact                   { padding: 24px; }
  .contact-form              { min-width: 0; width: 100%; }
  .field-row                 { grid-template-columns: 1fr; }

  /* Footer — full single column */
  .footer-grid { grid-template-columns: 1fr; gap: 32px; }

  /* Founder portrait */
  .portrait-mark { width: 180px; height: 210px; }

  /* Process steps */
  .process-step { padding: 24px; }

  /* Product cards */
  .product-card { min-height: unset; padding: 24px; }
}
