/* ============================================================================
   Talin marketing — ELEVATED layer.
   Same warm-paper / one-green / Inter system as the product, pushed to an
   editorial marketing scale: a literary serif-italic accent voice, product UI
   floated *frameless* on the paper with soft diffuse elevation + a green
   spotlight + connector annotations, more air, and quiet scroll motion.
   ============================================================================ */
@import url('../colors_and_type.css');
@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400;1,6..72,500;1,6..72,600&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&display=swap');

/* The decorative stage halo (.stage::before) extends past the viewport at
   some widths; it's purely visual, so clip it instead of growing scrollWidth. */
html, body { overflow-x: clip; }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--bg-app); color: var(--fg);
  font-family: var(--font-sans); -webkit-font-smoothing: antialiased;
  font-weight: var(--weight-medium);
  /* whisper-faint warm wash so the paper has depth, never a "gradient" */
  background-image:
    radial-gradient(120% 80% at 80% -10%, rgba(56,161,105,0.05), transparent 60%),
    radial-gradient(90% 60% at -10% 0%, rgba(24,24,27,0.025), transparent 55%);
  background-attachment: fixed;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
::selection { background: rgba(56,161,105,.22); }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 4px; }

:root {
  --maxw: 1200px;
  --gut: 32px;
  --display: clamp(44px, 6.4vw, 82px); /* @kind font */
  --h2: clamp(31px, 3.7vw, 47px); /* @kind font */
  --lead: clamp(17px, 1.35vw, 20px); /* @kind font */

  --font-serif: 'Newsreader';

  /* elevated marketing shadows — soft, wide, low-opacity (Pin-style lift) */
  --lift-sm: 0 1px 2px rgba(24,24,27,.05), 0 4px 12px -6px rgba(24,24,27,.10);
  --lift-md: 0 1px 2px rgba(24,24,27,.04), 0 10px 24px -10px rgba(24,24,27,.14);
  --lift-lg: 0 1px 1px rgba(24,24,27,.04),
             0 12px 28px -12px rgba(24,24,27,.16),
             0 40px 72px -32px rgba(24,24,27,.20);
  --hair: 1px solid var(--border-frame);
}

/* accent-typeface tweak hooks */
[data-accentface="instrument"] { --font-serif: 'Instrument Serif'; }
[data-accentface="inter"]      { --font-serif: var(--font-sans); }

/* accent-color tweak hooks (stay in the green family) */
[data-accent="forest"] { --accent: #2C7A4B; --accent-hover: #245F3B; }
[data-accent="pine"]   { --accent: #1F7A5A; --accent-hover: #186049; }
[data-accent="sage"]   { --accent: #4F9D6B; --accent-hover: #3F8457; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gut); }
section { padding: 112px 0; position: relative; }
.section-tight { padding: 76px 0; }

/* ---- editorial accent: bold sans in brand green, ONE word per heading ---- */
/* Accent word uses the same sans (Inter) as the rest of the heading, just in
   brand green and bold — a pure color highlight, no serif, no italics. */
.ink { font-style: normal; color: var(--accent); font-family: var(--font-sans); font-weight: var(--weight-bold); }

/* ---- eyebrow + headings ---- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font: var(--weight-semibold) 12.5px/1 var(--font-sans);
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent);
  margin: 0 0 20px;
}
.eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 1.5px;
  background: var(--accent); transform: rotate(45deg); }
h1, h2, h3 { margin: 0; letter-spacing: -0.025em; text-wrap: balance; }
.display { font-weight: var(--weight-bold); font-size: var(--display); line-height: 0.98; }
.h2 { font-weight: var(--weight-bold); font-size: var(--h2); line-height: 1.06; }
.lead { font-size: var(--lead); line-height: 1.55; color: var(--fg-secondary);
  font-weight: var(--weight-regular); text-wrap: pretty; }

/* ---- buttons ---- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 46px; padding: 0 22px; border-radius: var(--radius-full);
  font: var(--weight-semibold) 15px/1 var(--font-sans); cursor: pointer;
  border: 1px solid transparent; white-space: nowrap;
  transition: background .16s ease, border-color .16s ease, transform .14s ease, box-shadow .16s ease; }
.btn:active { transform: translateY(1px); }
.btn svg { width: 17px; height: 17px; transition: transform .18s ease; }
.btn .ph { font-size: 17px; line-height: 0; transition: transform .18s ease; }
.btn-green { background: var(--accent); color: #fff; box-shadow: var(--shadow-green), inset 0 1px 0 rgba(255,255,255,.16); }
.btn-green:hover { background: var(--accent-hover); transform: translateY(-1px);
  box-shadow: var(--shadow-green), 0 8px 20px -8px rgba(36,127,39,.45); }
.btn-green:hover svg, .btn-green:hover .ph { transform: translateX(2px); }
.btn-dark { background: var(--solid); color: #fff; }
.btn-dark:hover { background: #000; transform: translateY(-1px); }
.btn-dark:hover svg, .btn-dark:hover .ph { transform: translateX(2px); }
.btn-outline { background: rgba(255,255,255,.7); color: var(--fg); border-color: var(--border); backdrop-filter: blur(4px); }
.btn-outline:hover { background: #fff; border-color: var(--border-strong); }
.btn-ghost { background: transparent; color: var(--fg); }
.btn-ghost:hover { background: var(--bg-muted); }
.btn-sm { height: 40px; padding: 0 17px; font-size: 14px; }
.btn-lg { height: 54px; padding: 0 28px; font-size: 16.5px; }

/* ---- nav ---- */
.nav { position: sticky; top: 0; z-index: 50; background: rgba(250,249,246,0.72);
  backdrop-filter: saturate(150%) blur(14px); border-bottom: 1px solid transparent;
  transition: border-color .2s ease, background .2s ease; }
.nav.scrolled { border-bottom-color: var(--border-frame); background: rgba(250,249,246,0.85); }
.nav-in { display: flex; align-items: center; gap: 30px; height: 74px; }
.nav .logo { height: 27px; }
.nav-links { display: flex; align-items: center; gap: 28px; margin-left: 12px; }
.nav-links a { position: relative; font: var(--weight-medium) 14.5px/1 var(--font-sans); color: var(--fg-secondary); padding: 4px 0; }
.nav-links a::after { content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1.5px;
  background: var(--accent); transition: right .22s ease; }
.nav-links a:hover { color: var(--fg); }
.nav-links a:hover::after { right: 0; }
.nav-cta { margin-left: auto; display: flex; align-items: center; gap: 12px; }

/* ---- hero ---- */
.hero { padding: 100px 0 92px; overflow: visible; }
.hero-grid { display: grid; grid-template-columns: 1fr 1.38fr; gap: 52px; align-items: center; }
.hero .stage { margin-right: -9%; }
.hero h1 { margin-bottom: 4px; }
.hero .display { font-size: clamp(46px, 7vw, 90px); line-height: 0.94; letter-spacing: -0.035em; }
.hero .lead { margin: 28px 0 34px; max-width: 33ch; font-size: clamp(18px, 1.5vw, 21px); }
.hero-cta { display: flex; gap: 13px; flex-wrap: wrap; }
.hero-note { margin-top: 22px; font: var(--weight-regular) 13px/1.5 var(--font-sans); color: var(--fg-muted);
  display: inline-flex; align-items: center; gap: 9px; }
.hero-note::before { content:""; width:6px; height:6px; border-radius:50%; background: var(--accent);
  box-shadow: 0 0 0 4px rgba(56,161,105,.16); }
.hero .stage::before { inset: -14% -10% -20% -10%;
  background: radial-gradient(56% 56% at 60% 40%, rgba(56,161,105,.22), transparent 70%); filter: blur(30px); }
.hero .device { box-shadow: var(--lift-lg), 0 48px 96px -40px rgba(24,24,27,.26); }

/* ---- hero layout: centered (talin.ai structure) ---- */
[data-herolayout="centered"] .hero { padding: 88px 0 96px; }
[data-herolayout="centered"] .hero-grid { grid-template-columns: 1fr; gap: 58px; }
[data-herolayout="centered"] .hero-grid > div:first-child { display: flex; flex-direction: column; align-items: center; text-align: center; }
[data-herolayout="centered"] .hero .display { font-size: clamp(48px, 7.4vw, 98px); }
[data-herolayout="centered"] .hero .lead { max-width: 42ch; margin: 26px auto 32px; }
[data-herolayout="centered"] .hero-cta { justify-content: center; }
[data-herolayout="centered"] .hero .stage { margin-right: 0; width: min(1120px, 100%); margin-inline: auto; }
[data-herolayout="centered"] .hero .stage.stage-wide { width: 100%; }
.hero-toggle { display: flex; flex-direction: column; align-items: center; gap: 11px; margin-top: 40px; }
.hero-toggle::before { content: "See it for your desk"; font: var(--weight-semibold) 11px/1 var(--font-sans);
  letter-spacing: .06em; text-transform: uppercase; color: var(--fg-muted); }
[data-herolayout="split"] .hero-toggle { align-items: flex-start; }
[data-herolayout="centered"] .hero .stage::before { inset: -9% -7% -14% -7%;
  background: radial-gradient(52% 56% at 50% 34%, rgba(56,161,105,.2), transparent 70%); }

/* hero entrance on load — base state is VISIBLE; animation has NO fill-mode,
   so any context where the timeline doesn't advance (capture/print/bundle/throttled)
   falls back to the visible base instead of a stuck hidden frame */
@media (prefers-reduced-motion: no-preference) {
  .hero [data-rise] { animation: heroRise .7s cubic-bezier(.22,.61,.36,1); }
  .hero [data-rise="1"] { animation-delay: .05s; }
  .hero [data-rise="2"] { animation-delay: .13s; }
  .hero [data-rise="3"] { animation-delay: .21s; }
  .hero [data-rise="4"] { animation-delay: .29s; }
  .hero .stage { animation: heroRiseScale .85s cubic-bezier(.22,.61,.36,1) .24s; }
  @keyframes heroRise { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
  @keyframes heroRiseScale { from { opacity: 0; transform: translateY(24px) scale(.985); } to { opacity: 1; transform: none; } }
}

/* ---- FRAMELESS floating product (the core elevation) ---- */
.stage { position: relative; isolation: isolate; }
.stage::before {                      /* green spotlight lifting the UI off the paper */
  content: ""; position: absolute; inset: -10% -8% -16% -8%; z-index: -1;
  background: radial-gradient(58% 56% at 62% 38%, rgba(56,161,105,.16), transparent 72%);
  filter: blur(26px); pointer-events: none;
}
[data-spotlight="off"] .stage::before { display: none; }

/* ---- interactive shortlist mock (whole-desk fold) ---- */
.desk-toggle { display: inline-flex; gap: 4px; padding: 4px; border: 1px solid var(--border);
  border-radius: 999px; background: var(--bg-app, #f3f3f1); position: relative; }
.dt-btn { appearance: none; border: 0; cursor: pointer; border-radius: 999px; padding: 10px 20px;
  font: var(--weight-semibold) 13.5px/1 var(--font-sans); color: var(--fg-muted); background: transparent;
  position: relative; z-index: 1; transition: color .25s; }
.dt-btn:hover { color: var(--fg); }
.dt-btn.active { color: var(--accent); }
.dt-thumb { position: absolute; top: 4px; bottom: 4px; border-radius: 999px; background: #fff;
  border: 1px solid var(--border); box-shadow: 0 1px 3px rgba(24,24,27,.1); z-index: 0;
  transition: left .32s cubic-bezier(.22,.61,.36,1), width .32s cubic-bezier(.22,.61,.36,1); }

#sl-mount { position: relative; overflow: hidden; background: #fff; }
.sl-frame { position: absolute; left: 0; top: 0; width: 1322px; height: 869px; transform-origin: 0 0;
  background: #fff; display: flex; flex-direction: column; font-family: var(--font-sans); color: var(--fg);
  transition: opacity .16s ease, filter .16s ease; }
.sl-frame.sl-fading { opacity: 0; filter: blur(2px); }
.sl-frame i { line-height: 1; }
@media (prefers-reduced-motion: no-preference) {
  .sl-frame .sl-row { animation: slIn .42s cubic-bezier(.22,.61,.36,1) both; animation-delay: calc(var(--i, 0) * 34ms); }
  .sl-frame .sl-panel > * { animation: slIn .42s cubic-bezier(.22,.61,.36,1) both; animation-delay: calc(60ms + var(--i, 0) * 40ms); }
  .sl-frame .sl-title, .sl-frame .sl-tabs { animation: slIn .32s ease both; }
  @keyframes slIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
}

.sl-stepper { display: flex; gap: 28px; padding: 0 28px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.sl-step { position: relative; flex: 1; display: flex; align-items: center; gap: 9px; height: 52px;
  font: var(--weight-regular) 13.5px/1 var(--font-sans); color: var(--fg-muted); white-space: nowrap; }
.sl-step b { font-weight: var(--weight-semibold); color: var(--fg); }
.sl-step .mut { color: var(--fg-muted); }
.sl-step-n { width: 21px; height: 21px; border-radius: 50%; background: var(--zinc-100, #f4f4f5); color: var(--fg-muted);
  display: inline-flex; align-items: center; justify-content: center; font: var(--weight-semibold) 11.5px/1 var(--font-sans); flex-shrink: 0; }
.sl-step.on .sl-step-n { background: var(--accent); color: #fff; }
.sl-bar { position: absolute; left: 0; right: 0; bottom: 0; height: 4px; border-radius: 4px 4px 0 0; background: var(--zinc-200, #e4e4e7); }
.sl-bar.g { background: var(--accent); }
.sl-step .sl-bar.b2 { left: 52%; }
.sl-step .sl-bar.g:not(.b2) { right: 52%; }

.sl-body { display: flex; flex: 1; min-height: 0; }
.sl-rail { width: 56px; border-right: 1px solid var(--border); display: flex; flex-direction: column;
  align-items: center; gap: 22px; padding: 20px 0; color: var(--fg-muted); font-size: 17px; flex-shrink: 0; }
.sl-rail .on { color: var(--fg); }
.sl-rail-sp { flex: 1; }
.sl-rail-av { width: 28px; height: 28px; border-radius: 50%; background: #18181b; color: #fff;
  display: flex; align-items: center; justify-content: center; font: var(--weight-semibold) 10px/1 var(--font-sans); }

.sl-main { flex: 1; min-width: 0; padding: 26px 34px 0; }
.sl-title { margin: 0 0 18px; font: var(--weight-bold) 26px/1.2 var(--font-sans); letter-spacing: -0.02em; }
.sl-title span { color: var(--zinc-400, #a1a1aa); font-weight: var(--weight-semibold); }
.sl-tabs { display: flex; border-bottom: 1px solid var(--border); margin-bottom: 20px; }
.sl-tabs span { flex: 1; text-align: center; padding: 12px 0 13px; font: var(--weight-medium) 13.5px/1 var(--font-sans);
  color: var(--fg-muted); border-bottom: 2px solid transparent; }
.sl-tabs span.on { color: var(--fg); border-bottom-color: var(--accent); font-weight: var(--weight-semibold); }
.sl-tabs span { cursor: pointer; transition: color .15s; }
.sl-tabs span:hover { color: var(--fg); }
.sl-tabs .ct { font-size: 11px; color: var(--zinc-400, #a1a1aa); margin-left: 6px; font-weight: var(--weight-medium); }
.sl-empty { display: flex; align-items: center; justify-content: center; gap: 9px; padding: 64px 0;
  color: var(--fg-muted); font: var(--weight-medium) 14px/1 var(--font-sans); border: 1px dashed var(--border); border-radius: 11px; }
.sl-empty i { font-size: 19px; }
.sl-list { display: flex; flex-direction: column; gap: 12px; }
.sl-row { display: grid; grid-template-columns: 16px minmax(0, 252px) 32px 1fr 24px; gap: 16px; align-items: center;
  border: 1px solid var(--border); border-radius: 11px; padding: 13px 16px; background: #fff;
  box-shadow: 0 1px 2px rgba(24,24,27,.04);
  cursor: pointer; transition: border-color .18s, box-shadow .18s, opacity .2s, transform .2s; }
.sl-row:hover { border-color: var(--zinc-300, #d4d4d8); }
.sl-row.sel { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 1px 2px rgba(24,24,27,.04); }
.sl-row.sel .sl-check { background: var(--accent); }
.sl-row.out { opacity: 0; transform: translateX(16px); pointer-events: none; }
.sl-check { width: 15px; height: 15px; border-radius: 4px; background: var(--zinc-200, #e4e4e7); flex-shrink: 0; }
.sl-id { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.sl-name { font: var(--weight-semibold) 14.5px/1.2 var(--font-sans); display: flex; align-items: center; gap: 6px; }
.sl-name i { color: #0a66c2; font-size: 14px; }
.sl-sub { font: var(--weight-regular) 12.5px/1.3 var(--font-sans); color: var(--fg-muted);
  display: flex; align-items: center; gap: 5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sl-ring { border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.sl-ring span { width: calc(100% - 9px); height: calc(100% - 9px); border-radius: 50%; background: #fff;
  display: flex; align-items: center; justify-content: center; font: var(--weight-semibold) 11px/1 var(--font-sans); }
.sl-crit { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.sl-critline { font: var(--weight-medium) 13px/1.3 var(--font-sans); display: flex; align-items: center; gap: 7px; }
.sl-critline i { color: var(--accent); font-size: 15px; flex-shrink: 0; }
.sl-sigline { display: flex; gap: 16px; }
.sl-sig { font: var(--weight-medium) 12.5px/1 var(--font-sans); color: var(--fg-soft, #52525b);
  display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }
.sl-sig i { color: #6d28d9; font-size: 14px; }
.sl-x { width: 24px; height: 24px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  color: var(--fg-muted); font-size: 13px; border: 1px solid transparent; cursor: pointer;
  transition: color .15s, border-color .15s, background .15s; }
.sl-row:hover .sl-x { border-color: var(--border); }
.sl-x:hover { background: #FEF2F2; color: #DC2626; border-color: #FECACA; }
.sl-arrows i { cursor: pointer; transition: color .15s; }
.sl-arrows i:hover { color: var(--fg); }

.sl-panel { width: 408px; border-left: 1px solid var(--border); padding: 16px 20px; flex-shrink: 0;
  display: flex; flex-direction: column; gap: 12px; overflow: hidden; }
.sl-phead { display: flex; justify-content: space-between; align-items: center;
  font: var(--weight-regular) 12.5px/1 var(--font-sans); color: var(--fg-muted); padding: 2px 2px 0; }
.sl-arrows { display: flex; gap: 14px; font-size: 14px; color: var(--fg); }
.sl-person { border: 1px solid var(--border); border-radius: 12px; background: var(--paper-100, #fafaf9); padding: 13px 15px; }
.sl-prow1 { display: flex; align-items: center; gap: 9px; margin-bottom: 8px; }
.sl-prow1 b { font: var(--weight-semibold) 15px/1.2 var(--font-sans); flex: 1; }
.sl-pline { font: var(--weight-regular) 12.5px/1.5 var(--font-sans); color: var(--fg-soft, #52525b);
  display: block; margin-top: 3px; }
.sl-pline i { margin-right: 4px; vertical-align: -1px; }
.sl-pline b { font-weight: var(--weight-semibold); color: var(--fg); }
.sl-insight { border: 1px solid var(--border); border-radius: 12px; padding: 13px 15px; }
.sl-insight-check { color: var(--accent); font-size: 16px; display: block; margin-bottom: 8px; }
.sl-insight p { margin: 0 0 9px; font: var(--weight-regular) 12.8px/1.5 var(--font-sans); color: var(--fg-soft, #3f3f46); }
.sl-insight p:last-child { margin-bottom: 0; }
.sl-insight b { font-weight: var(--weight-bold); color: var(--fg); }
.sl-card { border-radius: 12px; background: #f5f3fc; padding: 12px 15px; }
.sl-card-h { font: var(--weight-semibold) 13px/1 var(--font-sans); display: flex; align-items: center; gap: 7px; margin-bottom: 7px; }
.sl-card-h i { color: #6d28d9; font-size: 14px; }
.sl-card p { margin: 0; font: var(--weight-regular) 12.5px/1.5 var(--font-sans); color: var(--fg-soft, #3f3f46); }
.sl-more { text-align: right; font: var(--weight-regular) 12px/1 var(--font-sans); color: var(--fg-muted);
  display: flex; justify-content: flex-end; align-items: center; gap: 3px; }
.sl-company { border: 1px solid var(--border); border-radius: 12px; padding: 13px 15px; }
.sl-co-label { font: var(--weight-medium) 12.5px/1 var(--font-sans); color: var(--fg-soft, #3f3f46); margin-bottom: 10px; }
.sl-co-name { display: flex; align-items: center; gap: 9px; font: var(--weight-bold) 15px/1 var(--font-sans); margin-bottom: 9px; }
.sl-co-logo { width: 26px; height: 26px; border-radius: 6px; background: var(--zinc-200, #e4e4e7); }
.sl-co-meta { display: flex; flex-wrap: wrap; gap: 6px 14px; margin-bottom: 8px; }
.sl-co-meta span { font: var(--weight-medium) 12px/1 var(--font-sans); color: var(--fg-soft, #3f3f46);
  display: inline-flex; align-items: center; gap: 5px; }
.sl-co-desc { margin: 0; font: var(--weight-regular) 12.3px/1.5 var(--font-sans); color: var(--fg-soft, #52525b); }

/* dramatic full-bleed product moment (showcase) */
.stage-wide { width: 100%; margin: 8px auto 0; }
.stage-wide .device { box-shadow: var(--lift-lg), 0 64px 120px -44px rgba(24,24,27,.30); }
.stage-wide::before { inset: -8% -6% -14% -6%;
  background: radial-gradient(50% 56% at 50% 36%, rgba(56,161,105,.18), transparent 70%); }
.device { border-radius: 18px; background: #fff; border: var(--hair);
  box-shadow: var(--lift-lg); overflow: hidden; }
.device.tilt { transform: perspective(1800px) rotateY(-3deg) rotateX(1.2deg); transform-origin: center; }
.device img { display: block; width: 100%; }
.device-cap { display: flex; align-items: center; gap: 8px; height: 34px; padding: 0 14px;
  border-bottom: var(--hair); background: var(--paper-200); }
.device-cap .d { width: 9px; height: 9px; border-radius: 2px; background: var(--accent); transform: rotate(45deg); }
.device-cap .t { font: var(--weight-medium) 11.5px/1 var(--font-sans); color: var(--fg-muted); letter-spacing: .02em; }

/* connector annotations (Pin-style) */
.annote { position: absolute; z-index: 3; display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 13px 9px 11px; background: #fff; border: var(--hair); border-radius: var(--radius-full);
  box-shadow: var(--lift-md); font: var(--weight-semibold) 12.5px/1 var(--font-sans); color: var(--fg);
  white-space: nowrap; }
.annote .dot { width: 16px; height: 16px; border-radius: 50%; flex: 0 0 auto;
  background: var(--green-subtle-bg); color: var(--green-subtle-fg);
  display: flex; align-items: center; justify-content: center; }
.annote .dot svg { width: 10px; height: 10px; }
.annote .dot .ph { font-size: 10px; line-height: 0; }
.annote.tl { top: 8%; left: -26px; }
.annote.br { bottom: 11%; right: -22px; }
.annote::after { content: ""; position: absolute; width: 34px; height: 34px;
  border: 0 dashed var(--border-strong); }
.annote.tl::after { border-bottom-width: 1.5px; border-left-width: 1.5px; border-bottom-left-radius: 10px;
  left: 14px; top: 100%; }
.annote.br::after { border-top-width: 1.5px; border-right-width: 1.5px; border-top-right-radius: 10px;
  right: 14px; bottom: 100%; }
[data-annotations="off"] .annote { display: none; }

/* generic mini app mock pieces */
.mk-name { font: var(--weight-semibold) 13px/1.3 var(--font-sans); }
.mk-sub { font: var(--weight-regular) 11px/1 var(--font-sans); color: var(--fg-muted); margin-top: 3px; }

/* ---- stats (editorial strip — hairlines, no box) ---- */
.stat-row { display: grid; grid-template-columns: 0.8fr 1.55fr; gap: 56px; align-items: center; }
.stat-head .eyebrow { margin-bottom: 14px; }
.stat-head .h2 { font-size: clamp(23px, 2.2vw, 30px); line-height: 1.12; }
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }
.stat { padding: 6px 24px; position: relative; }
.stat:first-child { padding-left: 0; }
.stat + .stat { border-left: var(--hair); }
.stat .num { font: var(--weight-bold) clamp(36px,3.4vw,48px)/1 var(--font-sans); letter-spacing: -0.045em; color: var(--fg); font-variant-numeric: tabular-nums; white-space: nowrap; }
.stat .num .accent { color: var(--accent); }
.stat .num .ndash { display: inline-block; font-size: .58em; font-weight: var(--weight-semibold); transform: translateY(-.42em); margin: 0 .04em; }
[data-accentface="newsreader"] .stat .num .accent,
[data-accentface="instrument"] .stat .num .accent { font-family: var(--font-serif); font-weight: 600; letter-spacing: -0.02em; }
.stat p { margin: 10px 0 0; color: var(--fg-secondary); font-size: 13.5px; font-weight: var(--weight-regular); max-width: 20ch; line-height: 1.45; }

/* ---- generic card ---- */
.card { background: #fff; border: var(--hair); border-radius: var(--radius-lg); box-shadow: var(--lift-md); }
.pad { padding: 30px; }

/* ---- unified mini-product surface (feature mocks share the device chrome) ---- */
.mock { background: #fff; border: var(--hair); border-radius: 16px; box-shadow: var(--lift-lg); overflow: hidden; }
.split-media .mock { position: relative; }
.split-media .mock::before { content: ""; position: absolute; inset: 6% -4% -8% -4%; z-index: -1;
  background: radial-gradient(56% 60% at 50% 40%, rgba(56,161,105,.12), transparent 72%); filter: blur(22px); }
.split-media { position: relative; isolation: isolate; }
.mock-cap { display: flex; align-items: center; gap: 9px; height: 40px; padding: 0 16px;
  border-bottom: var(--hair); background: var(--paper-200); }
.mock-cap .d { width: 9px; height: 9px; border-radius: 2px; background: var(--accent); transform: rotate(45deg); flex: 0 0 auto; }
.mock-cap .t { font: var(--weight-semibold) 12px/1 var(--font-sans); color: var(--fg-muted); letter-spacing: .03em; text-transform: uppercase; white-space: nowrap; }
.mock-body { padding: 24px; }

/* feature split */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.split.rev .split-media { order: -1; }
.feature-tags { display: flex; flex-direction: column; gap: 4px; margin: 30px 0 0; }
.feature-tag { display: flex; align-items: center; gap: 14px; font: var(--weight-medium) 15.5px/1.3 var(--font-sans);
  color: var(--fg); padding: 12px 0; border-bottom: 1px solid var(--border-frame); }
.feature-tag:last-child { border-bottom: none; }
.feature-tag .ic { width: 40px; height: 40px; border-radius: 10px; flex: 0 0 auto; display: flex; align-items: center; justify-content: center;
  background: var(--green-subtle-bg); color: var(--green-subtle-fg); }
.feature-tag .ic svg { width: 18px; height: 18px; }
.feature-tag .ic .ph { font-size: 20px; line-height: 0; }
.feature-body { color: var(--fg-secondary); font-weight: var(--weight-regular); font-size: 16.5px; line-height: 1.65; margin-top: 20px; }

/* ---- integrations (uniform tile grid) ---- */
.intg-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.intg { display: flex; align-items: center; gap: 11px; padding: 14px 16px; border-radius: 14px;
  border: var(--hair); background: #fff; font: var(--weight-semibold) 14px/1.2 var(--font-sans); color: var(--fg);
  box-shadow: var(--lift-sm); transition: transform .15s ease, box-shadow .15s ease; }
.intg:hover { transform: translateY(-2px); box-shadow: var(--lift-md); }
.intg-mark { width: 26px; height: 26px; object-fit: contain; flex: 0 0 auto; }
.intg-more { justify-content: center; border-style: dashed; color: var(--fg-muted);
  font-weight: var(--weight-medium); box-shadow: none; background: transparent; }
.intg-more:hover { transform: none; box-shadow: none; }

/* ---- checklist ---- */
.checklist { list-style: none; margin: 26px 0 0; padding: 0; display: flex; flex-direction: column; gap: 0; }
.checklist li { display: flex; align-items: center; gap: 14px; font-size: 16.5px; color: var(--fg); font-weight: var(--weight-medium);
  padding: 15px 0; border-bottom: 1px solid var(--border-frame); }
.checklist li:last-child { border-bottom: none; }
.checklist li .ck { width: 28px; height: 28px; border-radius: 8px; background: var(--green-subtle-bg); color: var(--green-subtle-fg);
  display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.checklist li .ck svg { width: 13px; height: 13px; }
.checklist li .ck .ph { font-size: 16px; line-height: 0; }

/* ---- broken stack: big typographic statement ---- */
.broken-stmt { padding: 132px 0; }
.broken-head { font-weight: var(--weight-bold); font-size: clamp(40px, 5.7vw, 78px);
  line-height: 0.97; letter-spacing: -0.032em; max-width: 15ch; text-wrap: balance; }
.broken-lead { margin: 28px 0 0; max-width: 44ch; font-size: clamp(18px, 1.5vw, 21px); }
.chips { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 34px; max-width: 660px; }
.broken-stmt .chips { margin-top: 42px; max-width: 900px; gap: 14px; }
.broken-stmt .chip-x { font-size: 15.5px; padding: 12px 18px; }
.broken-stmt .chip-x img { width: 16px; height: 16px; }

/* live pill: solid, real logo in color */
.chip-x { position: relative; display: inline-flex; align-items: center; gap: 9px; padding: 10px 16px; border-radius: 999px;
  border: 1px solid var(--border-strong); color: var(--fg-secondary); font: var(--weight-medium) 14px/1 var(--font-sans);
  background: #fff; box-shadow: var(--lift-sm);
  transition: color .35s ease, background .35s ease, box-shadow .35s ease, border-color .35s ease; }
.chip-x img { width: 15px; height: 15px; border-radius: 4px; flex: 0 0 auto;
  transition: filter .35s ease, opacity .35s ease; }

/* the marker strike draws across, pill dies down to a ghost */
.chip-x::after { content: ""; position: absolute; left: 12px; right: 12px; top: 50%; height: 2px; border-radius: 2px;
  background: var(--zinc-900); transform: scaleX(0) rotate(-3deg); transform-origin: 0 50%;
  transition: transform .38s cubic-bezier(.6, 0, .25, 1); }
.chip-x.struck::after { transform: scaleX(1) rotate(-3deg); }
.chip-x.struck { color: var(--fg-muted); border-style: dashed; background: rgba(255,255,255,.45); box-shadow: none; }
.chip-x.struck img { filter: grayscale(1); opacity: .5; }

/* hover a struck pill: it comes back to life — strike retracts, logo recolors.
   leave: it gets crossed out all over again. */
.chip-x.struck:hover { color: var(--fg-secondary); border-style: solid; background: #fff; box-shadow: var(--lift-sm); }
.chip-x.struck:hover::after { transform: scaleX(0) rotate(-3deg); }
.chip-x.struck:hover img { filter: none; opacity: 1; }

/* the payoff pill */
.chip-talin { display: inline-flex; align-items: center; gap: 10px; padding: 12px 19px; border-radius: 999px;
  background: var(--accent); color: #fff; font: var(--weight-semibold) 15px/1 var(--font-sans);
  box-shadow: var(--shadow-green); }
.chip-talin .d { width: 9px; height: 9px; border-radius: 2px; background: #fff; transform: rotate(45deg); flex: 0 0 auto; }
.chips.will-strike .chip-talin { opacity: 0; transform: translateY(8px) scale(.95); }
.chips.will-strike.done .chip-talin { opacity: 1; transform: none;
  transition: opacity .5s ease, transform .55s cubic-bezier(.2, .8, .3, 1.18); }

/* ---- pricing (compact) ---- */
.price-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 36px; align-items: start; }
.price { background: #fff; border: var(--hair); border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--lift-sm);
  transition: transform .18s ease, box-shadow .18s ease; }
.price:hover { transform: translateY(-3px); box-shadow: var(--lift-md); }
.price.feat { border: 1.5px solid var(--accent); box-shadow: var(--lift-lg); position: relative; }
.price .tier { font: var(--weight-semibold) 12.5px/1 var(--font-sans); color: var(--accent); text-transform: uppercase; letter-spacing: 0.1em; }
.price .amt { font: var(--weight-bold) 36px/1 var(--font-sans); letter-spacing: -0.03em; margin: 12px 0 2px; }
.price .amt span { font-size: 15px; font-weight: var(--weight-medium); color: var(--fg-muted); letter-spacing: 0; }
.price .credits { color: var(--fg-secondary); font-weight: var(--weight-regular); font-size: 13px; margin-bottom: 16px; }
.price .btn { width: 100%; }
.price-tag { position: absolute; top: -13px; right: 24px; background: var(--accent); color: #fff;
  font: var(--weight-semibold) 11px/1 var(--font-sans); padding: 7px 13px; border-radius: 999px; letter-spacing: 0.04em;
  white-space: nowrap; box-shadow: var(--shadow-green); }
.price ul { list-style: none; margin: 18px 0 0; padding: 18px 0 0; border-top: 1px solid var(--border-frame); display: flex; flex-direction: column; gap: 10px; }
.price ul li { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--fg); font-weight: var(--weight-medium); }
.price ul li .ck { color: var(--accent); display: inline-flex; }
.price ul li .ck svg { width: 15px; height: 15px; }
.price ul li .ck .ph { font-size: 15px; line-height: 0; }

/* ---- testimonials ---- */
.tgrid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 48px; }
.quote { background: #fff; border: var(--hair); border-radius: var(--radius-lg); padding: 30px; box-shadow: var(--lift-sm);
  display: flex; flex-direction: column; position: relative; }
.quote::before { content: "\201C"; position: absolute; top: 6px; right: 24px; font: 600 60px/1 var(--font-serif);
  font-style: normal; color: var(--accent); opacity: .14; }
.quote .stars { display: flex; gap: 3px; color: var(--accent); margin-bottom: 16px; }
.quote .stars svg { width: 15px; height: 15px; }
.quote .stars .ph { font-size: 15px; line-height: 0; }
.quote p { margin: 0 0 24px; font-size: 15.5px; line-height: 1.62; color: var(--fg-secondary); font-weight: var(--weight-regular); flex: 1; }
.quote .who { display: flex; align-items: center; gap: 12px; }
.avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--zinc-900); color: #fff;
  display: flex; align-items: center; justify-content: center; font: var(--weight-semibold) 14px/1 var(--font-sans); flex: 0 0 auto; }
img.avatar { object-fit: cover; }
.quote .who b { display: block; font: var(--weight-semibold) 14px/1.3 var(--font-sans); color: var(--fg); }
.quote .who span { font: var(--weight-regular) 13px/1.3 var(--font-sans); color: var(--fg-muted); }

/* ---- faq ---- */
.faq { max-width: 800px; margin: 48px auto 0; }
.faq-item { border-bottom: 1px solid var(--border-frame); }
.faq-q { display: flex; align-items: center; justify-content: space-between; gap: 16px; width: 100%;
  background: none; border: none; cursor: pointer; padding: 24px 4px; text-align: left;
  font: var(--weight-semibold) 18.5px/1.4 var(--font-sans); color: var(--fg); transition: color .15s ease; }
.faq-q:hover { color: var(--accent); }
.faq-q svg { width: 20px; height: 20px; color: var(--fg-muted); flex: 0 0 auto; transition: transform .2s ease, color .15s ease; }
.faq-q .ph { font-size: 20px; line-height: 0; color: var(--fg-muted); flex: 0 0 auto; transition: transform .2s ease, color .15s ease; }
.faq-item.open .faq-q svg, .faq-item.open .faq-q .ph { transform: rotate(45deg); color: var(--accent); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .28s ease; }
.faq-a p { margin: 0 4px 24px; font-size: 16px; line-height: 1.65; color: var(--fg-secondary); font-weight: var(--weight-regular); }

/* ---- CTA band — the bold green moment ---- */
.cta-band { position: relative; background: #0E3D27; color: #fff; border-radius: 26px; padding: 88px 64px; text-align: center;
  overflow: hidden; box-shadow: var(--lift-lg), 0 40px 80px -36px rgba(14,61,39,.55); }
.cta-band::before { content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(64% 120% at 50% -18%, rgba(56,161,105,.55), transparent 58%),
    radial-gradient(50% 80% at 88% 8%, rgba(110,231,160,.22), transparent 60%); }
.cta-band::after { content: ""; position: absolute; inset: 0; opacity: .6;
  background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,.09) 1px, transparent 0); background-size: 22px 22px;
  -webkit-mask-image: radial-gradient(120% 100% at 50% 0%, #000, transparent 75%); mask-image: radial-gradient(120% 100% at 50% 0%, #000, transparent 75%); }
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 { color: #fff; font-size: clamp(34px, 4.2vw, 56px); }
.cta-band .ink { color: #B8F2D2; }
.cta-band .lead { color: rgba(255,255,255,0.82); margin: 18px auto 34px; max-width: 46ch; }
.cta-band .btns { display: flex; gap: 13px; justify-content: center; flex-wrap: wrap; }
.cta-band .btn-green { background: #fff; color: #0E3D27; box-shadow: 0 8px 24px -10px rgba(0,0,0,.4); }
.cta-band .btn-green:hover { background: #EAFBF1; transform: translateY(-1px); }
.cta-band .btn-outline { background: rgba(255,255,255,.08); color: #fff; border-color: rgba(255,255,255,0.30); backdrop-filter: none; }
.cta-band .btn-outline:hover { background: rgba(255,255,255,0.16); border-color: rgba(255,255,255,0.5); }

/* ---- footer ---- */
.footer { background: var(--bg-app); border-top: 1px solid var(--border-frame); padding: 64px 0 44px; }
.footer-grid { display: flex; flex-wrap: wrap; gap: 48px; justify-content: space-between; }
.footer .logo { height: 25px; margin-bottom: 16px; }
.footer p, .footer a { font: var(--weight-regular) 14px/1.6 var(--font-sans); color: var(--fg-secondary); }
.footer h4 { font: var(--weight-semibold) 13px/1 var(--font-sans); text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-muted); margin: 0 0 14px; }
.footer a:hover { color: var(--fg); }
.foot-bottom { display: flex; flex-wrap: wrap; gap: 12px 24px; justify-content: space-between; align-items: center;
  margin-top: 52px; padding-top: 26px; border-top: 1px solid var(--border-frame);
  font: var(--weight-regular) 13px/1.5 var(--font-sans); color: var(--fg-muted); }
.foot-bottom a { color: var(--fg-muted); }
.foot-bottom a:hover { color: var(--fg); }

/* section header center */
.center { text-align: center; max-width: 760px; margin: 0 auto; }
.center .eyebrow { display: inline-flex; }
.center .h2 { font-size: clamp(30px, 3.4vw, 44px); }

/* ---- scroll reveal ---- */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(16px); transition: opacity .6s cubic-bezier(.22,.61,.36,1), transform .6s cubic-bezier(.22,.61,.36,1); }
  .reveal.in { opacity: 1; transform: none; }
  .reveal.d1 { transition-delay: .07s; } .reveal.d2 { transition-delay: .14s; } .reveal.d3 { transition-delay: .21s; }
}

/* responsive */
.menu-btn { display: none; }
@media (max-width: 920px) {
  section { padding: 76px 0; }
  .hero { padding: 56px 0 64px; }
  .hero .stage { margin-right: 0; }
  .hero-grid, .split, .split.rev .split-media { grid-template-columns: 1fr; }
  .stat-row { grid-template-columns: 1fr; gap: 28px; }
  .split.rev .split-media { order: 0; }
  .stats { grid-template-columns: 1fr; }
  .stat { padding: 18px 0; }
  .price-grid, .tgrid { grid-template-columns: 1fr; }
  .stat + .stat { border-left: none; border-top: var(--hair); }
  .nav-links { display: none; }
  .device.tilt { transform: none; }
  .annote { display: none; }
  .cta-band { padding: 56px 28px; }
  .broken-stmt { padding: 76px 0; }
}
