/* =====================================================
   Livescraper — Soft Design System
   Shared stylesheet (palette, type, components)
   ===================================================== */

/* Distinctive serif used only for the brand mark "L" */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&display=swap');

/* Defensive net: hide any legacy/cached dropdown markup so a stale page
   never renders the menu items inline in the nav row. */
nav.links .menu{display:none !important}
nav.links > ul,nav.links li.nav-item{list-style:none}
nav.links .has-menu > .mega{visibility:hidden;opacity:0}
nav.links .has-menu:hover > .mega,nav.links .has-menu:focus-within > .mega{visibility:visible;opacity:1}

:root{
  /* neutrals — cool, aligned with primary blue */
  --cream:#f5f8fc;          /* soft cool off-white (page bg) */
  --cream-2:#ebf1f8;        /* alt surface */
  --sand:#dfe8f3;           /* soft surface panels */
  --line:#d6dfeb;           /* cool line / border */
  --line-strong:#b8c5d9;
  --ink:#162236;            /* primary headings — deeper for crisp rendering */
  --ink-2:#2f4159;          /* body — slightly stronger contrast */
  --muted:#5e6b81;          /* secondary / labels — AA-strong on every soft bg */

  /* =====================================================
     STYLE GUIDE — Earth-tone palette
     5 hues spaced ~70° apart on the wheel, all in the same
     "muted" register (HSL lightness 60-72%, saturation 25-45%).
     Every other site colour is composed from these tokens.
     ===================================================== */

  /* 1 · Terracotta — primary brand warm (hue 17°) */
  --clay:#5d8bc1;
  --clay-deep:#26426d;
  --clay-tint:#d6e2ef;

  /* 2 · Sage — calm secondary (hue 142°) */
  --sage:#8ea99a;
  --sage-deep:#3a574a;
  --sage-tint:#d6e1d6;

  /* 3 · Slate-blue — cool accent (hue 218°) */
  --dusk:#8694b1;
  --dusk-deep:#34405e;
  --dusk-tint:#d8dfeb;

  /* 4 · Ochre — warm accent (hue 41°) */
  --butter:#cfb37a;
  --butter-deep:#7d6321;
  --butter-tint:#f0e3bd;

  /* 5 · Mauve — dusty rose (hue 354°) */
  --blush:#c69097;
  --blush-deep:#7a3e48;
  --blush-tint:#ecd0d3;

  /* ── Semantic role tokens (ALWAYS reference these in components) ── */
  --brand:           var(--clay);
  --brand-deep:      var(--clay-deep);
  --brand-tint:      var(--clay-tint);

  --accent-cool:     var(--sage);
  --accent-cool-deep:var(--sage-deep);
  --accent-cool-tint:var(--sage-tint);

  --accent-tech:     var(--dusk);
  --accent-tech-deep:var(--dusk-deep);
  --accent-tech-tint:var(--dusk-tint);

  --accent-warm:     var(--butter);
  --accent-warm-deep:var(--butter-deep);
  --accent-warm-tint:var(--butter-tint);

  --accent-soft:     var(--blush);
  --accent-soft-deep:var(--blush-deep);
  --accent-soft-tint:var(--blush-tint);

  /* ── SHADOWS ── */
  --shadow:0 1px 0 rgba(29,42,60,.04), 0 14px 36px -22px rgba(29,42,60,.22);
  --shadow-sm:0 1px 2px rgba(29,42,60,.06);
  --shadow-md:0 4px 14px -4px rgba(29,42,60,.12);
  --shadow-lg:0 14px 36px -22px rgba(29,42,60,.22);
  --shadow-xl:0 24px 60px -28px rgba(29,42,60,.22),0 2px 4px rgba(29,42,60,.04);

  /* ── RADIUS ── */
  --radius-sm:8px;
  --radius-md:14px;
  --radius:18px;
  --radius-lg:28px;
  --radius-pill:999px;

  /* ── TYPOGRAPHY · families ── */
  --font-display:'Inter',ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;            /* headlines, italic emphasis */
  --font-body:'Inter',ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-mono:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;
  --font-mark:'DM Serif Display','Fraunces',serif;     /* (legacy) brand-mark "L" */

  /* ── TYPOGRAPHY · scale ── */
  --text-xs:11.5px;     /* eyebrows, kbd hints */
  --text-sm:13px;       /* meta, captions */
  --text-base:14.5px;   /* nav links, ui */
  --text-md:16px;       /* body */
  --text-lg:18px;       /* lede */
  --text-xl:22px;       /* small h4 */
  --text-2xl:30px;      /* tool h3, card headings */
  --text-3xl:36px;      /* api section h2 */
  --text-4xl:48px;      /* page-hero h1 */
  --text-5xl:56px;      /* section title */
  --text-6xl:84px;      /* home display h1 */

  /* ── TYPOGRAPHY · line heights ── */
  --leading-tight:1.05;
  --leading-snug:1.25;
  --leading-normal:1.6;
  --leading-relaxed:1.78;

  /* ── TYPOGRAPHY · weights ── */
  --weight-regular:400;
  --weight-medium:500;
  --weight-semibold:600;
  --weight-bold:700;

  /* ── TYPOGRAPHY · letter-spacing ── */
  --tracking-tight:-.02em;     /* big display */
  --tracking-normal:-.005em;   /* body */
  --tracking-wide:.06em;       /* small caps / labels */
  --tracking-wider:.16em;      /* eyebrows */

  /* ── SPACING scale ── */
  --space-xs:4px;
  --space-sm:8px;
  --space-md:16px;
  --space-lg:24px;
  --space-xl:36px;
  --space-2xl:56px;
  --space-3xl:80px;
  --space-4xl:120px;

  /* ── MOTION ── */
  --motion-fast:0.15s ease;
  --motion-base:0.22s cubic-bezier(.4,0,.2,1);
  --motion-slow:0.55s ease;
  --motion-spring:0.35s cubic-bezier(.4,1.6,.5,1);

  /* ── LAYOUT ── */
  --container-max:1180px;
  --container-pad:28px;
  --section-pad:96px;        /* unified vertical rhythm — every full-width section uses this */

  /* ── Z-INDEX scale ── */
  --z-nav:50;
  --z-mega:60;
  --z-fab:100;
  --z-overlay:200;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{
  margin:0;padding:0;background:var(--cream);color:var(--ink-2);
  font-family:var(--font-body);
  font-size:16px;line-height:1.55;
  font-weight:430;                        /* slightly heavier than 400 for crispness against soft bg */
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","cv11","kern";
  letter-spacing:-.011em
}
/* Always use the darkest ink for headings */
h1,h2,h3,h4,h5,h6{color:var(--ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad)}

::selection{background:var(--clay-tint);color:var(--clay-deep)}

/* =====================================================
   ACCESSIBILITY — focus rings, skip-link, visible kbd nav
   ===================================================== */

/* Skip-to-content (keyboard users — first focusable element on every page) */
.skip-link{position:fixed;top:-100px;left:14px;z-index:300;padding:10px 16px;background:var(--clay);color:#fff;border-radius:10px;font-weight:600;font-size:14px;box-shadow:var(--shadow-md);transition:top .15s ease}
.skip-link:focus,.skip-link:focus-visible{top:14px;outline:none}

/* Visible focus ring for every interactive element — clay 2px with 2px offset */
:focus{outline:none}
:focus-visible{outline:2px solid var(--clay);outline-offset:2px;border-radius:6px}
button:focus-visible,a:focus-visible,.btn:focus-visible,.cmdk-item:focus-visible,.tab-btn:focus-visible{outline:2px solid var(--clay);outline-offset:3px}
.input:focus-visible,.textarea:focus-visible,select.input:focus-visible{outline:none;border-color:var(--clay);box-shadow:0 0 0 3px var(--clay-tint)}
/* Don't ring elements only focused via mouse click */
*:focus:not(:focus-visible){outline:none}

/* Container — single source of layout alignment.
   Header, footer, every section, every full-width block
   should wrap content in `.container` so they all share
   the same edges as the logo and the "Get Started" button.
   The token is declared once — see line ~168. */

/* Tabular numerals in data UI (canvas, stats) */
.row-result .num,.canvas .label,.stat .num{font-feature-settings:"tnum","ss01"}

/* Display headlines — Inter at heavy weights with very tight tracking,
   matching Apollo.io's editorial-tech aesthetic. */
.serif,
h1.display,h2.section-title,
.tool h3,.case h4,.post h4,.split h2,.gdpr h2,.cta-card h2,
.quote blockquote,.price-card .price,.stat .num,.step .num,
.page-hero h1,.plan-card .price,.plan-card h3,
.faq-q,.contact-card h3{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:-.03em;
  font-feature-settings:"ss01","cv11"
}
/* huge display headers — even tighter, weight 800 */
h1.display,.cta-card h2{font-weight:800;letter-spacing:-.04em}
/* mid-size — weight 700, slightly tighter */
h2.section-title,.split h2,.gdpr h2,.page-hero h1,.price-card .price{font-weight:700;letter-spacing:-.035em}
/* small headings — weight 600 */
.tool h3,.case h4,.post h4,.plan-card h3,.faq-q,.contact-card h3,.step .num,.stat .num{font-weight:600;letter-spacing:-.022em}
/* blockquote — italic for the editorial moment */
.quote blockquote{font-weight:500;font-style:italic;letter-spacing:-.02em}
/* emphasis — weight 800 + accent colour (no italic — Apollo style) */
.serif em,em.serif,h1.display em,h2.section-title em,.split h2 em,.gdpr h2 em,.cta-card h2 em,.page-hero h1 em,.quote blockquote em{font-style:normal;color:var(--clay-deep);font-weight:800}

/* ───── Top bar ───── */
header.nav{position:sticky;top:0;z-index:50;background:rgba(245,248,252,.85);backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid rgba(214,223,235,.7)}
.nav-row{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-body);font-weight:700;letter-spacing:-.03em;font-size:19px;color:var(--ink);min-width:0}
.brand-logo-icon{width:36px;height:36px;min-width:36px;min-height:36px;flex:0 0 36px;display:block;transition:transform .25s ease;filter:drop-shadow(0 4px 14px rgba(38,66,109,.22));overflow:visible}
.brand:hover .brand-logo-icon{transform:translateY(-1px) scale(1.04)}
.brand-mark{
  position:relative;
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--clay) 0%,var(--clay-deep) 100%);
  display:flex;align-items:center;justify-content:center;
  font-size:0;                /* hides any text content (e.g. "L") */
  overflow:hidden;            /* contain the ripple inside the badge */
  box-shadow:0 4px 14px -4px rgba(38,66,109,.5),0 1px 2px rgba(38,66,109,.18),inset 0 1px 0 rgba(255,255,255,.22);
  transition:.25s ease
}
/* shared centring rules for the dot + the wave ring */
.brand-mark::before,
.brand-mark::after{
  content:"";
  position:absolute;
  top:50%;left:50%;
  width:6px;height:6px;
  border-radius:50%;
  box-sizing:border-box;       /* keep the border INSIDE the 6px so both pseudos share one centre */
  transform:translate(-50%,-50%);
  transform-origin:center center;
  pointer-events:none
}
/* steady cream "live" dot — sits dead-centre */
.brand-mark::after{
  background:#ffffff;
  box-shadow:0 0 6px rgba(251,244,234,.55);
  z-index:3
}
/* expanding wave ring — radiates outward from the dot's centre */
.brand-mark::before{
  border:1.5px solid rgba(251,244,234,.85);
  background:transparent;
  z-index:2;
  animation:brand-wave 1.8s cubic-bezier(.4,0,.2,1) infinite
}
@keyframes brand-wave{
  0%  {transform:translate(-50%,-50%) scale(1);   opacity:.9}
  80% {transform:translate(-50%,-50%) scale(5.5); opacity:0}
  100%{transform:translate(-50%,-50%) scale(5.5); opacity:0}
}
.brand:hover .brand-mark{transform:translateY(-1px);box-shadow:0 6px 18px -4px rgba(38,66,109,.55),0 1px 2px rgba(38,66,109,.18),inset 0 1px 0 rgba(255,255,255,.24)}
@media (prefers-reduced-motion:reduce){
  .brand-mark::after{animation:none}
}
nav.links{display:flex;gap:22px;font-size:14.5px;color:var(--ink-2);align-items:center;font-weight:450}
nav.links > a,nav.links .has-menu > a{padding:8px 2px;border-bottom:none;transition:color .2s;position:relative;color:var(--ink-2)}
nav.links > a:hover,nav.links .has-menu:hover > a{color:var(--ink)}
nav.links > a.active,nav.links .has-menu.active > a{color:var(--ink)}
nav.links > a.active::after,nav.links .has-menu.active > a::after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--clay);border-radius:2px}

/* ───── Mega menu (Apollo-style) ───── */
nav.links .has-menu{position:relative}
nav.links .has-menu > a{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
nav.links .has-menu > a::before{content:"";display:inline-block;width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-bottom:2px;opacity:.6;transition:transform .25s ease,margin .25s ease}
nav.links .has-menu:hover > a::before{transform:rotate(225deg);margin-bottom:-3px;opacity:.9}
/* invisible bridge so cursor doesn't lose hover when crossing the gap */
nav.links .has-menu::after{content:"";position:absolute;top:100%;left:-30px;right:-30px;height:18px}
.mega{
  position:absolute;top:calc(100% + 16px);left:50%;
  transform:translateX(-50%) translateY(-8px);
  background:#fff;border:1px solid var(--line);border-radius:22px;
  padding:22px;min-width:540px;
  box-shadow:0 24px 60px -28px rgba(29,42,60,.22),0 2px 4px rgba(29,42,60,.04);
  display:grid;grid-template-columns:1.05fr 1fr;gap:18px;
  opacity:0;visibility:hidden;
  transition:opacity .22s ease,transform .22s ease,visibility .22s;
  z-index:60
}
.has-menu:hover .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
/* allow wider mega menus to align flush-left from the trigger if they would clip the viewport */
.has-menu.mega-right .mega{left:auto;right:-12px;transform:translateY(-8px)}
.has-menu.mega-right:hover .mega{transform:translateY(0)}

.mega-section{display:flex;flex-direction:column;gap:2px;min-width:0}
.mega-section h6{font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 8px;padding:0 12px}
.mega-section a{display:flex;gap:12px;align-items:flex-start;padding:10px 12px;border-radius:12px;color:var(--ink-2);transition:background .18s ease,color .18s ease}
.mega-section a:hover{background:var(--cream-2);color:var(--ink)}
.mega-section a .ico{width:34px;height:34px;border-radius:10px;background:var(--clay-tint);color:var(--clay-deep);display:grid;place-items:center;flex:0 0 34px;transition:transform .2s}
.mega-section a:hover .ico{transform:scale(1.05)}
/* 5-hue rotation in mega menu icons (clay → sage → dusk → butter → blush, then loops) */
.mega-section a:nth-of-type(5n+2) .ico{background:var(--sage-tint);  color:var(--sage-deep)}
.mega-section a:nth-of-type(5n+3) .ico{background:var(--dusk-tint);  color:var(--dusk-deep)}
.mega-section a:nth-of-type(5n+4) .ico{background:var(--butter-tint);color:var(--butter-deep)}
.mega-section a:nth-of-type(5n+5) .ico{background:var(--blush-tint); color:var(--blush-deep)}
.mega-section a strong{display:block;font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:2px;letter-spacing:-.005em}
.mega-section a span.s{display:block;font-size:12px;color:var(--muted);line-height:1.45}

/* Featured spotlight card (right side of mega menu) */
.mega-featured{
  background:linear-gradient(135deg,var(--clay-tint) 0%,var(--sand) 70%);
  border-radius:16px;padding:20px;
  display:flex;flex-direction:column;gap:10px;
  position:relative;overflow:hidden;border:1px solid rgba(214,223,235,.6)
}
.mega-featured::after{content:"";position:absolute;width:140px;height:140px;border-radius:50%;background:radial-gradient(closest-side,rgba(93,139,193,.35),transparent 70%);top:-60px;right:-40px;pointer-events:none}
.mega-featured .badge{align-self:flex-start;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--clay-deep);font-weight:600;background:rgba(255,255,255,.6);padding:4px 9px;border-radius:999px;border:1px solid rgba(214,223,235,.7);position:relative;z-index:1}
.mega-featured h5{font-family:'Fraunces',serif;font-weight:400;font-size:22px;line-height:1.18;color:var(--ink);margin:4px 0 0;font-variation-settings:"opsz" 36,"SOFT" 60;letter-spacing:-.01em;position:relative;z-index:1}
.mega-featured h5 em{font-style:italic;color:var(--clay-deep)}
.mega-featured p{font-size:12.5px;color:var(--ink-2);line-height:1.5;margin:2px 0 0;position:relative;z-index:1}
.mega-featured .spot-link{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--clay-deep);margin-top:auto;padding-top:6px;position:relative;z-index:1}
.mega-featured .spot-link::after{content:"";display:inline-block;width:7px;height:7px;border-right:1.6px solid currentColor;border-top:1.6px solid currentColor;transform:rotate(45deg);transition:transform .2s}
.mega-featured .spot-link:hover::after{transform:rotate(45deg) translate(2px,-2px)}

/* Two-column mega without featured card (e.g. Resources) */
.mega.two-col{grid-template-columns:1fr 1fr;min-width:480px}
.nav-cta{display:flex;gap:10px;align-items:center}
.mob-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--ink);padding:6px}

/* ───── Buttons ───── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border-radius:999px;font-weight:500;font-size:14.5px;border:1px solid transparent;cursor:pointer;transition:transform .15s ease,background .2s ease,border-color .2s ease,color .2s ease;line-height:1;font-family:inherit;text-align:center;justify-content:center}
.btn .arr{width:14px;height:14px;display:inline-block;border-right:1.6px solid currentColor;border-top:1.6px solid currentColor;transform:rotate(45deg);position:relative;top:-1px}
.btn-primary{background:var(--clay);color:#ffffff}
.btn-primary:hover{background:var(--clay-deep);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{background:var(--cream-2);border-color:var(--ink-2)}
.btn-soft{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-soft:hover{background:var(--cream-2)}
.btn-block{width:100%}
.pill{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;font-size:13px;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:999px}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--clay);box-shadow:0 0 0 4px rgba(93,139,193,.20)}

/* ───── Sections shared ───── */
section{padding:var(--section-pad) 0}
.eyebrow{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--clay-deep);font-weight:500;display:inline-flex;align-items:center;gap:8px}
.eyebrow::before{content:"";display:inline-block;width:18px;height:1px;background:var(--clay);opacity:.7}
h2.section-title{font-weight:400;font-size:56px;line-height:1.02;letter-spacing:-.02em;margin:18px 0 16px}
h2.section-title em{font-style:italic;color:var(--clay-deep)}
p.section-lede{font-size:17.5px;color:var(--ink-2);max-width:640px;line-height:1.62;margin:0;letter-spacing:-.003em}

/* ───── Page hero (compact for inner pages) ───── */
.page-hero{position:relative;padding:var(--section-pad) 0;overflow:hidden}
.page-hero .blob{position:absolute;width:560px;height:560px;border-radius:50%;filter:blur(70px);opacity:.5;pointer-events:none;background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);top:-220px;right:-180px}
.page-hero .blob.b2{background:radial-gradient(closest-side,var(--sage-tint),transparent 70%);top:auto;bottom:-280px;right:auto;left:-220px;opacity:.5}
.page-hero .crumb{font-size:13px;color:var(--muted);margin-bottom:18px;letter-spacing:.04em}
.page-hero .crumb a:hover{color:var(--clay-deep)}
.page-hero h1{position:relative;font-weight:400;font-size:64px;line-height:1.02;letter-spacing:-.018em;margin:0 0 18px;max-width:820px}
.page-hero h1 em{font-style:italic;color:var(--clay-deep)}
.page-hero p.lede{font-size:18.5px;line-height:1.55;color:var(--ink-2);max-width:640px;margin:0 0 28px}
.page-hero .hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.page-hero .meta{margin-top:22px;font-size:13.5px;color:var(--muted);display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.page-hero .meta .sep{width:4px;height:4px;border-radius:50%;background:var(--line-strong)}

/* ───── Hero (home) ───── */
.hero{position:relative;padding:var(--section-pad) 0;overflow:hidden}
.hero .blob{position:absolute;width:680px;height:680px;border-radius:50%;filter:blur(70px);opacity:.55;pointer-events:none}
.hero .blob.b1{background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);top:-180px;right:-160px}
.hero .blob.b2{background:radial-gradient(closest-side,var(--sage-tint),transparent 70%);bottom:-260px;left:-220px;width:760px;height:760px;opacity:.6}
.hero-grid{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
h1.display{font-weight:400;font-size:84px;line-height:.98;letter-spacing:-.02em;margin:18px 0 22px}
h1.display em{font-style:italic;color:var(--clay-deep)}
.lede{font-size:18px;line-height:1.6;color:var(--ink-2);max-width:540px;margin-bottom:30px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-meta{margin-top:24px;font-size:13.5px;color:var(--muted);display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-meta .sep{width:4px;height:4px;border-radius:50%;background:var(--line-strong)}

/* Hero canvas (mock UI) */
.canvas{position:relative;border-radius:var(--radius-lg);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);padding:22px}
.canvas .topline{display:flex;align-items:center;gap:8px;margin-bottom:18px}
.canvas .topline .dotc{width:11px;height:11px;border-radius:50%;background:var(--clay-tint)}
.canvas .topline .dotc:nth-child(2){background:var(--sand)}
.canvas .topline .dotc:nth-child(3){background:var(--sage-tint)}
.canvas .topline .label{margin-left:8px;font-size:12.5px;color:var(--muted);font-feature-settings:"tnum"}
.field{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:14px;padding:12px 14px;background:var(--cream);font-size:14px;color:var(--ink-2);margin-bottom:10px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 14px}
.chip{font-size:12.5px;padding:6px 10px;border-radius:999px;background:var(--clay-tint);color:var(--clay-deep);border:1px solid #abc1de}
.chip.alt{background:var(--sage-tint);color:var(--sage-deep);border-color:#bccdc1}
.chip.alt2{background:var(--dusk-tint);color:var(--dusk-deep);border-color:#bfc9dd}
.row-result{display:grid;grid-template-columns:1.5fr 1fr 1.1fr 28px;align-items:center;gap:10px;padding:11px 14px;border:1px solid var(--line);border-radius:12px;background:#fff;margin-bottom:8px;font-size:13.5px}
.row-result .name{font-weight:500;color:var(--ink)}
.row-result .pill-tag{background:var(--sand);border:1px solid var(--line-strong);color:var(--ink-2);padding:3px 8px;border-radius:999px;font-size:12px;justify-self:start}
.row-result .num{color:var(--muted);font-size:13px;font-feature-settings:"tnum";letter-spacing:.01em}
.row-result .check{width:22px;height:22px;border-radius:50%;background:var(--sage-tint);color:var(--sage-deep);display:grid;place-items:center;font-size:13px}
.canvas .footnote{margin-top:14px;font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:8px}
.canvas .footnote .pulse{width:8px;height:8px;border-radius:50%;background:var(--sage-deep);box-shadow:0 0 0 4px var(--sage-tint)}

/* ───── Stats strip ───── */
.stats{padding:18px 0 50px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:28px 0}
.stat{padding:0 22px;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat .num{font-weight:400;font-size:42px;line-height:1;letter-spacing:-.01em;color:var(--ink)}
.stat .num em{font-style:italic;color:var(--clay-deep)}
.stats-grid .stat:nth-child(2) .num em{color:var(--sage-deep)}
.stats-grid .stat:nth-child(3) .num em{color:var(--dusk-deep)}
.stats-grid .stat:nth-child(4) .num em{color:var(--butter-deep)}
.stat .label{margin-top:8px;font-size:13.5px;color:var(--muted);line-height:1.4}

/* ───── Tools / product cards ───── */
.tools{background:linear-gradient(180deg,transparent,var(--sand) 30%,var(--sand) 70%,transparent)}
.tools-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:48px}
.tools-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.tool{grid-column:span 6;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;display:flex;flex-direction:column;justify-content:space-between;min-height:280px;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;position:relative;overflow:hidden}
.tool:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.tool .icon{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;margin-bottom:18px}
.tool h3{font-weight:400;font-size:30px;letter-spacing:-.01em;margin:0 0 10px;color:var(--ink)}
.tool p{color:var(--ink-2);font-size:15px;line-height:1.55;margin:0}
.tool .more{margin-top:24px;display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--ink)}
.tool .more .arr{width:10px;height:10px;border-right:1.6px solid currentColor;border-top:1.6px solid currentColor;transform:rotate(45deg);display:inline-block}
.tool.t-clay   .icon{background:var(--clay-tint);  color:var(--clay-deep)}
.tool.t-sage   .icon{background:var(--sage-tint);  color:var(--sage-deep)}
.tool.t-dusk   .icon{background:var(--dusk-tint);  color:var(--dusk-deep)}
.tool.t-butter .icon{background:var(--butter-tint);color:var(--butter-deep)}
.tool.t-blush  .icon{background:var(--blush-tint); color:var(--blush-deep)}
/* legacy alias (was t-lilac) — falls back to butter so no broken render */
.tool.t-lilac  .icon{background:var(--butter-tint);color:var(--butter-deep)}

/* ───── How it works (steps) ───── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;position:relative}
.step .num{font-style:italic;font-size:42px;color:var(--clay);line-height:1;margin-bottom:18px}
.steps .step:nth-child(2) .num{color:var(--sage-deep)}
.steps .step:nth-child(3) .num{color:var(--dusk-deep)}
.step h4{font-size:19px;font-weight:600;margin:0 0 8px;letter-spacing:-.01em;color:var(--ink)}
.step p{color:var(--ink-2);font-size:14.5px;line-height:1.55;margin:0}

/* ───── AI split panel ───── */
.split{background:linear-gradient(135deg,var(--sage-tint) 0%,var(--cream-2) 60%,var(--clay-tint) 130%);border:1px solid var(--line);border-radius:var(--radius-lg);padding:64px;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center;position:relative;overflow:hidden}
.split::before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(closest-side,rgba(93,139,193,.22),transparent 70%);top:-220px;right:-180px;filter:blur(20px)}
.split h2{font-weight:400;font-size:50px;line-height:1.05;letter-spacing:-.015em;margin:14px 0 18px;color:var(--ink)}
.split h2 em{color:var(--clay-deep);font-style:italic}
.split p{color:var(--ink-2);font-size:16.5px;line-height:1.65;max-width:520px;margin:0 0 24px}
.split .features{display:grid;grid-template-columns:1fr;gap:14px;position:relative;z-index:1}
.split .feat{display:flex;gap:14px;padding:18px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.78);backdrop-filter:blur(6px)}
.split .feat .ico{width:36px;height:36px;border-radius:10px;background:var(--clay-tint);color:var(--clay-deep);display:grid;place-items:center;flex:0 0 36px}
.split .feat:nth-child(2) .ico{background:var(--sage-tint);color:var(--sage-deep)}
.split .feat:nth-child(3) .ico{background:var(--dusk-tint);color:var(--dusk-deep)}
.split .feat h5{margin:0 0 4px;font-size:15px;font-weight:600;color:var(--ink)}
.split .feat p{font-size:13.5px;color:var(--muted);margin:0}

/* ───── Use case cards ───── */
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.case{padding:30px;border-radius:var(--radius-lg);border:1px solid var(--line);background:#fff;display:flex;flex-direction:column;gap:14px;transition:transform .2s ease,box-shadow .2s ease}
.case:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.case .tag{align-self:flex-start;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:999px;background:var(--clay-tint);color:var(--clay-deep);border:1px solid #abc1de;font-weight:500}
.case h4{font-weight:400;font-size:26px;line-height:1.15;letter-spacing:-.01em;margin:0;color:var(--ink)}
.case p{color:var(--ink-2);font-size:14.5px;line-height:1.55;margin:0}
.case .ic{margin-top:auto;font-size:13.5px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;padding-top:8px}
.case .ic .arr{width:10px;height:10px;border-right:1.6px solid currentColor;border-top:1.6px solid currentColor;transform:rotate(45deg);display:inline-block}
.case.sage   .tag{background:var(--sage-tint);  color:var(--sage-deep);  border-color:#bccdc1}
.case.dusk   .tag{background:var(--dusk-tint);  color:var(--dusk-deep);  border-color:#bfc9dd}
.case.butter .tag{background:var(--butter-tint);color:var(--butter-deep);border-color:#e2d5a3}
.case.blush  .tag{background:var(--blush-tint); color:var(--blush-deep); border-color:#e8c8cd}
/* legacy alias (was .case.lilac) → falls back to butter */
.case.lilac  .tag{background:var(--butter-tint);color:var(--butter-deep);border-color:#e2d5a3}

/* ───── Quote ───── */
.quote{padding:90px 0}
.quote-card{max-width:880px;margin:0 auto;text-align:center}
.quote .mark{font-style:italic;font-size:80px;line-height:1;color:var(--clay);opacity:.45}
.quote blockquote{font-weight:400;font-size:38px;line-height:1.25;letter-spacing:-.01em;margin:6px 0 28px;color:var(--ink)}
.quote blockquote em{color:var(--clay-deep)}
.quote .who{display:flex;align-items:center;justify-content:center;gap:14px;font-size:14.5px;color:var(--ink-2)}
.quote .who .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--clay-tint),var(--sage-tint));display:grid;place-items:center;font-style:italic;color:var(--clay-deep);font-size:18px}
.quote .who span.role{color:var(--muted)}

/* ───── Pricing teaser (single-card) ───── */
.price-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.price-card::after{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);bottom:-160px;right:-120px;opacity:.6;pointer-events:none}
.price-card .row{display:flex;align-items:baseline;gap:8px;margin-bottom:8px;position:relative}
.price-card .price{font-size:64px;letter-spacing:-.015em;color:var(--ink)}
.price-card .per{color:var(--muted);font-size:15px}
.price-card .label{font-size:12px;color:var(--clay-deep);letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;font-weight:500}
.price-card ul{list-style:none;padding:0;margin:18px 0 26px;position:relative}
.price-card li{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px dashed var(--line);font-size:14.5px;color:var(--ink-2)}
.price-card li:last-child{border-bottom:none}
.price-card li .ck{width:22px;height:22px;border-radius:50%;background:var(--sage-tint);color:var(--sage-deep);display:grid;place-items:center;flex:0 0 22px;font-size:12px}

/* ───── Pricing tiers (full pricing page) ───── */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px}
.plan-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px;display:flex;flex-direction:column;gap:14px;position:relative;transition:transform .2s ease,box-shadow .2s ease}
.plan-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.plan-card.featured{border-color:var(--clay);background:linear-gradient(180deg,#fff,var(--clay-tint) 200%)}
.plan-card .ribbon{position:absolute;top:-12px;right:24px;background:var(--clay);color:#ffffff;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:999px;font-weight:500}
.plan-card .plan-eyebrow{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--clay-deep);font-weight:500}
.plan-card h3{font-size:30px;line-height:1.05;margin:0;color:var(--ink)}
.plan-card .price{font-size:48px;line-height:1;color:var(--ink);margin-top:4px}
.plan-card .price .per{font-size:14px;color:var(--muted);font-family:'DM Sans',sans-serif;margin-left:6px}
.plan-card .desc{font-size:14px;color:var(--ink-2);line-height:1.5}
.plan-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.plan-card li{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--ink-2)}
.plan-card li .ck{width:18px;height:18px;border-radius:50%;background:var(--sage-tint);color:var(--sage-deep);display:grid;place-items:center;flex:0 0 18px;font-size:11px;margin-top:2px}

/* ───── GDPR ───── */
.gdpr{background:var(--sand);border-radius:var(--radius-lg);padding:56px;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;border:1px solid var(--line)}
.gdpr h2{font-weight:400;font-size:44px;line-height:1.05;margin:10px 0 14px;letter-spacing:-.015em;color:var(--ink)}
.gdpr h2 em{font-style:italic;color:var(--clay-deep)}
.gdpr p{color:var(--ink-2);font-size:16px;line-height:1.6;margin:0 0 20px;max-width:520px}
.gdpr .badges{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.gdpr .badge{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;gap:12px;align-items:flex-start}
.gdpr .badge .ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:0 0 34px}
.gdpr .badge:nth-child(1) .ico{background:var(--clay-tint); color:var(--clay-deep)}
.gdpr .badge:nth-child(2) .ico{background:var(--sage-tint); color:var(--sage-deep)}
.gdpr .badge:nth-child(3) .ico{background:var(--dusk-tint); color:var(--dusk-deep)}
.gdpr .badge:nth-child(4) .ico{background:var(--butter-tint);color:var(--butter-deep)}
.gdpr .badge h5{margin:0 0 4px;font-size:14.5px;font-weight:600;color:var(--ink)}
.gdpr .badge p{font-size:13px;color:var(--muted);margin:0;max-width:none}

/* ───── Blog ───── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.post{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}
.post:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
/* 5-hue rotation across blog post thumbnails */
.post .thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--clay-tint),var(--cream))}
.post:nth-child(5n+2) .thumb{background:linear-gradient(135deg,var(--sage-tint),var(--cream))}
.post:nth-child(5n+3) .thumb{background:linear-gradient(135deg,var(--dusk-tint),var(--cream))}
.post:nth-child(5n+4) .thumb{background:linear-gradient(135deg,var(--butter-tint),var(--cream))}
.post:nth-child(5n+5) .thumb{background:linear-gradient(135deg,var(--blush-tint),var(--cream))}
.post .meta{padding:22px 24px 6px;font-size:12px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.post h4{padding:0 24px;font-weight:400;font-size:24px;line-height:1.2;letter-spacing:-.01em;margin:8px 0 10px;color:var(--ink)}
.post p{padding:0 24px 24px;color:var(--ink-2);font-size:14.5px;line-height:1.55;margin:0}

/* ───── Final CTA ───── */
.cta{padding:var(--section-pad) 0}
.cta-card{background:linear-gradient(180deg,var(--cream-2),var(--sand));border:1px solid var(--line);border-radius:var(--radius-lg);padding:80px 56px;text-align:center;position:relative;overflow:hidden}
.cta-card::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);top:-220px;left:50%;transform:translateX(-50%);filter:blur(20px);opacity:.7}
.cta-card h2{position:relative;font-weight:400;font-size:60px;line-height:1.02;letter-spacing:-.015em;margin:0 0 16px;color:var(--ink)}
.cta-card h2 em{font-style:italic;color:var(--clay-deep)}
.cta-card p{position:relative;color:var(--ink-2);font-size:17px;max-width:560px;margin:0 auto 26px;line-height:1.6}
.cta-card .hero-cta{position:relative;justify-content:center}
.cta-card .footnote{position:relative;margin-top:18px;font-size:13px;color:var(--muted)}

/* ───── FAQ accordion ───── */
.faq-list{max-width:820px;margin:50px auto 0;display:flex;flex-direction:column;gap:10px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px 26px;transition:.2s}
.faq-item[open]{border-color:var(--line-strong);box-shadow:var(--shadow)}
.faq-item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:18px;font-size:17.5px;color:var(--ink);font-weight:500}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .plus{width:28px;height:28px;border-radius:50%;background:var(--clay-tint);color:var(--clay-deep);display:grid;place-items:center;flex:0 0 28px;font-size:18px;line-height:1;transition:.2s}
.faq-item[open] summary .plus{transform:rotate(45deg);background:var(--clay);color:#ffffff}
.faq-list .faq-item:nth-child(5n+2) summary .plus{background:var(--sage-tint);color:var(--sage-deep)}
.faq-list .faq-item:nth-child(5n+2)[open] summary .plus{background:var(--sage);color:#ffffff}
.faq-list .faq-item:nth-child(5n+3) summary .plus{background:var(--dusk-tint);color:var(--dusk-deep)}
.faq-list .faq-item:nth-child(5n+3)[open] summary .plus{background:var(--dusk);color:#ffffff}
.faq-list .faq-item:nth-child(5n+4) summary .plus{background:var(--butter-tint);color:var(--butter-deep)}
.faq-list .faq-item:nth-child(5n+4)[open] summary .plus{background:var(--butter);color:#ffffff}
.faq-list .faq-item:nth-child(5n+5) summary .plus{background:var(--blush-tint);color:var(--blush-deep)}
.faq-list .faq-item:nth-child(5n+5)[open] summary .plus{background:var(--blush);color:#ffffff}
.faq-q{font-family:'Fraunces',serif;font-weight:400;font-size:20px;letter-spacing:-.01em;line-height:1.3}
.faq-item .ans{margin-top:14px;color:var(--ink-2);font-size:15px;line-height:1.65}

/* ───── Feature grid (generic 3/4-up) ───── */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px}
.feature .ico{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;margin-bottom:16px;background:var(--clay-tint);color:var(--clay-deep)}
.feature.sage   .ico{background:var(--sage-tint);  color:var(--sage-deep)}
.feature.dusk   .ico{background:var(--dusk-tint);  color:var(--dusk-deep)}
.feature.butter .ico{background:var(--butter-tint);color:var(--butter-deep)}
.feature.blush  .ico{background:var(--blush-tint); color:var(--blush-deep)}
.feature.lilac  .ico{background:var(--butter-tint);color:var(--butter-deep)}
.feature h4{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0 0 8px;color:var(--ink)}
.feature p{color:var(--ink-2);font-size:14.5px;line-height:1.55;margin:0}

/* ───── Field detail (data-fields chip list) ───── */
.fields{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.fields .f{padding:8px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;font-size:13.5px;color:var(--ink-2);display:inline-flex;align-items:center;gap:8px}
.fields .f .dot{width:7px;height:7px;border-radius:50%;background:var(--sage)}
.fields .f.alt .dot{background:var(--clay)}
.fields .f.alt2 .dot{background:var(--dusk)}

/* ───── Two-column feature pairing ───── */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.duo.reverse > div:first-child{order:2}
.duo .visual{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow)}

/* ───── Contact form ───── */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start;margin-top:40px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow)}
.contact-card h3{font-size:30px;letter-spacing:-.012em;margin:0 0 8px;color:var(--ink);font-weight:400}
.contact-card p.sub{font-size:14.5px;color:var(--ink-2);margin:0 0 24px;line-height:1.55}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}
.field-label{display:block;font-size:13px;color:var(--ink-2);margin-bottom:6px;font-weight:500;letter-spacing:.01em}
.input,.textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:13px 15px;font-family:inherit;font-size:14.5px;color:var(--ink);background:var(--cream);transition:.2s;outline:none}
.input:focus,.textarea:focus{border-color:var(--clay);background:#fff;box-shadow:0 0 0 4px var(--clay-tint)}
.textarea{min-height:140px;resize:vertical}
.contact-info{display:flex;flex-direction:column;gap:18px}
.info-card{background:var(--sand);border:1px solid var(--line);border-radius:18px;padding:22px;display:flex;gap:14px;align-items:flex-start}
.info-card .ico{width:40px;height:40px;border-radius:12px;background:var(--clay-tint);color:var(--clay-deep);display:grid;place-items:center;flex:0 0 40px}
.info-card.sage .ico{background:var(--sage-tint);color:var(--sage-deep)}
.info-card.dusk .ico{background:var(--dusk-tint);color:var(--dusk-deep)}
.info-card h5{margin:0 0 4px;font-size:14px;font-weight:600;letter-spacing:.01em;color:var(--ink)}
.info-card p{margin:0;font-size:14px;color:var(--ink-2);line-height:1.5}

/* ───── Blog filter / categories ───── */
.cat-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.cat{padding:8px 16px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:13.5px;color:var(--ink-2);cursor:pointer;transition:.2s}
.cat:hover{border-color:var(--clay);color:var(--clay-deep)}
.cat.active{background:var(--clay);border-color:var(--clay);color:#ffffff}

/* ───── Footer ───── */
footer{margin-top:60px;background:linear-gradient(180deg,var(--cream),var(--cream-2));border-top:1px solid var(--line)}

/* Soft CTA strip at the top of the footer */
.foot-cta{padding:64px 0;border-bottom:1px solid var(--line);background:linear-gradient(135deg,var(--clay-tint) 0%,var(--sand) 70%);position:relative;overflow:hidden}
.foot-cta::before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(closest-side,rgba(93,139,193,.30),transparent 70%);top:-300px;right:-100px;filter:blur(20px);pointer-events:none}
.foot-cta::after{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(closest-side,rgba(158,178,164,.22),transparent 70%);bottom:-260px;left:-80px;filter:blur(20px);pointer-events:none}
.foot-cta-inner{display:flex;justify-content:space-between;align-items:center;gap:32px;position:relative;z-index:1;flex-wrap:wrap}
.foot-cta .eyebrow{margin-bottom:6px}
.foot-cta h3{font-family:'Fraunces',serif;font-weight:400;font-size:42px;line-height:1.04;letter-spacing:-.018em;margin:6px 0 0;color:var(--ink);font-variation-settings:"opsz" 72,"SOFT" 80;max-width:560px}
.foot-cta h3 em{font-style:italic;color:var(--clay-deep)}
.foot-cta .hero-cta{flex-shrink:0}

/* Main 6-column grid (brand + 5 link columns) */
.foot-grid{display:grid;grid-template-columns:1.5fr repeat(5,1fr);gap:36px;padding:64px 0 36px}
@media (max-width:1180px){.foot-grid{gap:28px}}

/* Brand block (column 1) — uses the exact same brand-mark as the header */
.foot-brand{display:flex;flex-direction:column;gap:22px}
.foot-tag{color:var(--ink-2);font-size:14.5px;line-height:1.6;max-width:340px;margin:0;letter-spacing:-.003em}

/* Newsletter signup */
.foot-newsletter{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.foot-newsletter .lbl{font-size:12.5px;letter-spacing:.04em;color:var(--ink-2);font-weight:500}
.foot-news-input{display:flex;gap:8px;max-width:340px}
.foot-news-input .input{flex:1;background:#fff;font-size:14px;padding:11px 14px;border-radius:12px}
.foot-news-input .btn{flex-shrink:0;padding:11px 16px;font-size:13.5px}
.foot-news-input .btn .arr{width:11px;height:11px}

/* Social icon row */
.foot-social{display:flex;gap:8px;margin-top:6px}
.foot-social a{width:38px;height:38px;display:grid;place-items:center;border-radius:11px;background:#fff;border:1px solid var(--line);color:var(--ink-2);transition:transform .2s ease,background .2s ease,color .2s ease,border-color .2s ease}
.foot-social a:hover{background:var(--clay-tint);color:var(--clay-deep);border-color:transparent;transform:translateY(-2px)}
.foot-social a:nth-child(2):hover{background:var(--sage-tint);color:var(--sage-deep)}
.foot-social a:nth-child(3):hover{background:var(--dusk-tint);color:var(--dusk-deep)}
.foot-social a:nth-child(4):hover{background:var(--butter-tint);color:var(--butter-deep)}
.foot-social a:nth-child(5):hover{background:var(--blush-tint);color:var(--blush-deep)}

/* Link columns (2-5) */
.foot-col{display:flex;flex-direction:column;gap:2px;min-width:0}
.foot-col h6{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 16px;font-weight:600}
.foot-col a{display:block;padding:7px 0;font-size:14px;color:var(--ink-2);transition:color .15s,padding-left .2s}
.foot-col a:hover{color:var(--clay-deep);padding-left:4px}

/* Horizontal legal strip — between link grid and bottom bar */
.foot-legal-strip{display:flex;flex-wrap:wrap;gap:22px;padding:18px 0;border-top:1px solid var(--line);font-size:13px;color:var(--muted)}
.foot-legal-strip a{color:var(--muted);transition:color .15s}
.foot-legal-strip a:hover{color:var(--clay-deep)}
.foot-legal-strip .sep{color:var(--line-strong);user-select:none}

/* Bottom strip */
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding:24px 0 32px;border-top:1px solid var(--line);font-size:13px;color:var(--muted);flex-wrap:wrap;gap:18px}
.foot-bottom-left{display:flex;align-items:center;gap:8px}
.foot-bottom-left strong{color:var(--ink-2);font-weight:500}
.foot-bottom-right{display:flex;align-items:center;gap:18px}
.foot-status{display:inline-flex;align-items:center;gap:8px;padding:5px 12px;background:var(--sage-tint);color:var(--sage-deep);border-radius:999px;font-size:12px;font-weight:500;border:1px solid #c4d4c8}
.foot-status-dot{width:6px;height:6px;border-radius:50%;background:#4d7a5c;animation:status-blink 2.4s ease-in-out infinite}
@keyframes status-blink{0%,100%{opacity:1}50%{opacity:.35}}
@media (prefers-reduced-motion:reduce){.foot-status-dot{animation:none}}

/* Footer responsive */
@media (max-width:980px){
  .foot-cta{padding:44px 0}
  .foot-cta-inner{flex-direction:column;align-items:flex-start;gap:24px}
  .foot-cta h3{font-size:32px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px;padding:48px 0 28px}
  .foot-brand{grid-column:1/-1}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:14px}
}

/* =====================================================
   THEME / STYLE-GUIDE page — visual reference for every token.
   Edit values in :root above; this page just shows them.
   ===================================================== */

.theme-page{padding:48px 0 100px}
.theme-page .legal-hero h1 em{color:var(--clay-deep)}
.theme-page .layout{display:grid;grid-template-columns:240px 1fr;gap:56px;align-items:start;padding:32px 0;border-top:1px solid var(--line)}
.theme-toc{position:sticky;top:84px;font-size:13.5px;max-height:calc(100vh - 100px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.theme-toc h6{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:18px 12px 10px}
.theme-toc h6:first-child{margin-top:0}
.theme-toc nav{display:flex;flex-direction:column;gap:1px}
.theme-toc nav a{padding:7px 12px;border-radius:8px;color:var(--ink-2);transition:.15s;font-size:13px}
.theme-toc nav a:hover{background:var(--cream-2);color:var(--ink)}
.theme-toc nav a.active{background:var(--clay-tint);color:var(--clay-deep);font-weight:500}

.theme-section{margin-bottom:64px;scroll-margin-top:90px}
.theme-section > h2{font-family:var(--font-display);font-weight:400;font-size:32px;letter-spacing:-.014em;margin:0 0 8px;color:var(--ink);font-variation-settings:"opsz" 48,"SOFT" 70}
.theme-section > h2 em{font-style:italic;color:var(--clay-deep)}
.theme-section > p.lede-sm{font-size:15px;color:var(--ink-2);margin:0 0 24px;max-width:680px;line-height:1.6}
.theme-section h3{font-family:var(--font-display);font-weight:400;font-size:20px;margin:28px 0 12px;color:var(--ink);font-variation-settings:"opsz" 30,"SOFT" 60}

/* token row */
.tok-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.tok{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:6px;transition:.18s}
.tok:hover{border-color:var(--line-strong)}
.tok .swatch{height:64px;border-radius:9px;border:1px solid var(--line);position:relative;overflow:hidden}
.tok .swatch.has-text{display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;color:rgba(255,255,255,.85)}
.tok .name{font-family:var(--font-mono);font-size:11.5px;color:var(--ink);font-weight:500;letter-spacing:-.005em}
.tok .val{font-family:var(--font-mono);font-size:11px;color:var(--muted);word-break:break-all}
.tok .desc{font-size:12px;color:var(--muted);line-height:1.4;margin-top:2px}

/* type spec */
.type-row{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:center;padding:18px 20px;background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:8px}
.type-row .meta{display:flex;flex-direction:column;gap:3px}
.type-row .meta .name{font-family:var(--font-mono);font-size:12px;color:var(--ink);font-weight:500}
.type-row .meta .spec{font-size:11.5px;color:var(--muted);font-family:var(--font-mono);line-height:1.5}
.type-row .preview{color:var(--ink);overflow:hidden}

/* spacing visualizer */
.space-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.space-row{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:8px}
.space-row .name{font-family:var(--font-mono);font-size:11.5px;color:var(--ink);font-weight:500}
.space-row .val{font-family:var(--font-mono);font-size:11px;color:var(--muted)}
.space-row .bar{height:14px;background:var(--clay-tint);border-radius:4px}

/* radius visualizer */
.rad-row{background:#fff;border:1px solid var(--line);padding:14px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.rad-row .demo{width:100%;height:46px;background:var(--clay-tint);border:1px solid var(--clay)}

/* shadow visualizer */
.shadow-row{background:#fff;padding:24px;border-radius:14px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}

/* component preview frames */
.preview-frame{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;margin-bottom:14px}
.preview-frame .demos{display:flex;flex-wrap:wrap;gap:12px;align-items:center}

/* code snippet */
.code-snip{font-family:var(--font-mono);font-size:12px;background:#1d2a3c;color:#dde6f3;padding:12px 16px;border-radius:10px;overflow-x:auto;margin-top:8px;line-height:1.6}
.code-snip .k{color:#c69097}
.code-snip .v{color:#cfb37a}

@media (max-width:980px){
  .theme-page .layout{grid-template-columns:1fr;gap:24px}
  .theme-toc{position:static;max-height:none;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
  .type-row{grid-template-columns:1fr}
}

/* =====================================================
   TRUST LOGO STRIP — "trusted by"
   ===================================================== */

.trust-strip{padding:30px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--cream)}
.trust-strip .container{display:flex;align-items:center;justify-content:center;gap:34px;flex-wrap:wrap}
.trust-strip .label{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600}
.trust-logos{display:flex;align-items:center;gap:38px;flex-wrap:wrap;justify-content:center}
.trust-logos .logo-wm{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:22px;color:var(--ink-2);opacity:.78;letter-spacing:-.02em;font-variation-settings:"opsz" 36,"SOFT" 80;transition:opacity .2s ease}
.trust-logos .logo-wm:hover{opacity:.85}
.trust-logos .logo-mono{font-family:'JetBrains Mono','SF Mono',Menlo,monospace;font-size:14px;color:var(--ink-2);opacity:.78;font-weight:500;letter-spacing:-.01em}
.trust-logos .logo-bold{font-family:'DM Sans',sans-serif;font-weight:700;font-size:18px;color:var(--ink-2);opacity:.78;letter-spacing:-.02em}
.trust-logos .logo-caps{font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;color:var(--ink-2);opacity:.78;letter-spacing:.18em;text-transform:uppercase}
.trust-logos .logo-bold:hover,.trust-logos .logo-mono:hover,.trust-logos .logo-caps:hover{opacity:.85}

/* Hero trust line — small badges directly under CTAs */
.hero-trust{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:22px;font-size:13px;color:var(--muted);font-weight:500}
.hero-trust .badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:var(--cream-2);border:1px solid var(--line)}
.hero-trust .badge svg{color:var(--clay-deep)}
.hero-trust .badge.sage svg{color:var(--sage-deep)}
.hero-trust .badge.dusk svg{color:var(--dusk-deep)}

/* =====================================================
   PERSONA pill on tool cards ("Best for: …")
   ===================================================== */

.tool .persona{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);margin-top:14px;padding-top:12px;border-top:1px dashed var(--line);line-height:1.4}
.tool .persona svg{flex-shrink:0;color:var(--clay-deep);opacity:.7}
.tool .persona strong{color:var(--ink-2);font-weight:600}

/* =====================================================
   COMPARISON matrix — "vs other tools"
   ===================================================== */

.compare-section{padding:var(--section-pad) 0;position:relative}
.compare-grid{
  display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:0;
  background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;
  margin-top:42px;box-shadow:var(--shadow)
}
.compare-cell{padding:18px 22px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);font-size:14px;color:var(--ink-2);display:flex;align-items:center;gap:8px;min-width:0}
.compare-cell:nth-child(5n){border-right:none}
.compare-cell.head{background:var(--cream-2);font-family:'Fraunces',serif;font-weight:400;font-size:18px;color:var(--ink);font-variation-settings:"opsz" 30,"SOFT" 60;letter-spacing:-.01em;justify-content:flex-start}
.compare-cell.head.us{background:linear-gradient(180deg,var(--clay-tint),#fff);color:var(--clay-deep);font-weight:500;position:relative}
.compare-cell.head.us::after{content:"YOU";position:absolute;top:6px;right:8px;font-family:'DM Sans';font-size:9px;letter-spacing:.16em;background:var(--clay);color:#fff;padding:2px 6px;border-radius:5px;font-weight:600}
.compare-cell.row-label{font-weight:500;color:var(--ink);background:var(--cream)}
.compare-cell.us-col{background:linear-gradient(90deg,rgba(93,139,193,.08),transparent)}
.compare-cell .ck{width:18px;height:18px;border-radius:50%;background:var(--sage-tint);color:var(--sage-deep);display:grid;place-items:center;font-size:11px;flex-shrink:0}
.compare-cell .x{width:18px;height:18px;border-radius:50%;background:var(--cream-2);color:var(--muted);display:grid;place-items:center;font-size:11px;flex-shrink:0;border:1px solid var(--line)}
.compare-cell .partial{width:18px;height:18px;border-radius:50%;background:var(--butter-tint);color:var(--butter-deep);display:grid;place-items:center;font-size:11px;flex-shrink:0}
.compare-grid > .compare-cell:nth-last-child(-n+5){border-bottom:none}

@media (max-width:980px){
  .compare-grid{grid-template-columns:1.4fr 1fr;font-size:13px}
  .compare-cell{border-right:none}
  .compare-grid > *:nth-child(5n){border-right:none}
  .compare-grid > *:nth-child(odd){border-right:1px solid var(--line)}
  .compare-cell.head:nth-child(n+3),.compare-cell:not(.head):not(:nth-child(5n+1)):not(:nth-child(5n+2)){display:none}
}

/* =====================================================
   PRICING teaser — small price card on home
   ===================================================== */

.price-teaser{padding:80px 0;position:relative}
.price-teaser-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.price-teaser h2{font-family:'Fraunces',serif;font-weight:400;font-size:44px;line-height:1.04;letter-spacing:-.018em;margin:8px 0 14px;font-variation-settings:"opsz" 72,"SOFT" 80}
.price-teaser h2 em{font-style:italic;color:var(--clay-deep)}
.price-teaser p{font-size:16.5px;color:var(--ink-2);line-height:1.6;margin:0 0 20px;max-width:480px}

.price-flash{background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.price-flash::after{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);bottom:-160px;right:-120px;opacity:.6;pointer-events:none}
.price-flash .row{display:flex;align-items:baseline;gap:6px;position:relative}
.price-flash .big{font-family:'Fraunces',serif;font-weight:400;font-size:56px;line-height:1;letter-spacing:-.014em;color:var(--ink);font-variation-settings:"opsz" 72,"SOFT" 80}
.price-flash .big em{font-style:italic;color:var(--clay-deep)}
.price-flash .per{font-size:14px;color:var(--muted)}
.price-flash .bullets{list-style:none;padding:0;margin:18px 0 22px;display:flex;flex-direction:column;gap:8px;position:relative}
.price-flash .bullets li{display:flex;gap:10px;align-items:center;font-size:14px;color:var(--ink-2)}
.price-flash .bullets li .ck{width:18px;height:18px;border-radius:50%;background:var(--sage-tint);color:var(--sage-deep);display:grid;place-items:center;font-size:11px}

@media (max-width:820px){
  .price-teaser-grid{grid-template-columns:1fr;gap:28px}
  .price-teaser h2{font-size:32px}
}

/* =====================================================
   STICKY MOBILE BOTTOM CTA
   ===================================================== */

.mobile-cta{display:none}
@media (max-width:820px){
  .mobile-cta{
    display:flex;align-items:center;gap:10px;
    position:fixed;left:12px;right:12px;bottom:12px;z-index:90;
    padding:10px 12px;
    background:rgba(245,248,252,.96);backdrop-filter:saturate(140%) blur(12px);
    -webkit-backdrop-filter:saturate(140%) blur(12px);
    border:1px solid var(--line);border-radius:16px;
    box-shadow:0 10px 30px -8px rgba(29,42,60,.18)
  }
  .mobile-cta .copy{flex:1;font-size:13px;color:var(--ink-2);line-height:1.3;min-width:0}
  .mobile-cta .copy strong{color:var(--ink);display:block;font-size:13.5px;font-weight:600}
  .mobile-cta .btn{padding:10px 14px;font-size:13.5px}
  /* Push the FAB up so it doesn't overlap */
  .ai-fab{bottom:78px}
}

/* =====================================================
   WHAT-NEXT navigation strip
   ===================================================== */

.what-next{padding:80px 0;border-top:1px solid var(--line)}
.what-next .head{text-align:center;margin-bottom:40px}
.what-next .head .eyebrow{margin-bottom:8px}
.what-next .head h3{font-family:'Fraunces',serif;font-weight:400;font-size:32px;letter-spacing:-.014em;color:var(--ink);margin:0;font-variation-settings:"opsz" 48,"SOFT" 80}
.what-next .head h3 em{font-style:italic;color:var(--clay-deep)}
.next-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.next-card{
  display:flex;align-items:flex-start;gap:14px;
  padding:22px;background:#fff;border:1px solid var(--line);border-radius:18px;
  text-decoration:none;color:var(--ink-2);transition:.22s
}
.next-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.next-card .ico{width:42px;height:42px;border-radius:12px;background:var(--clay-tint);color:var(--clay-deep);display:grid;place-items:center;flex-shrink:0}
.next-card.sage .ico  {background:var(--sage-tint);color:var(--sage-deep)}
.next-card.dusk .ico  {background:var(--dusk-tint);color:var(--dusk-deep)}
.next-card.butter .ico{background:var(--butter-tint);color:var(--butter-deep)}
.next-card .meta strong{display:block;font-family:'Fraunces',serif;font-weight:400;font-size:18px;color:var(--ink);font-variation-settings:"opsz" 24,"SOFT" 60;letter-spacing:-.005em;margin-bottom:2px}
.next-card .meta span{display:block;font-size:13px;color:var(--muted);line-height:1.4}
.next-card .arrow{margin-left:auto;color:var(--muted);transition:.18s}
.next-card:hover .arrow{color:var(--clay-deep);transform:translateX(2px)}

@media (max-width:820px){.next-grid{grid-template-columns:1fr}}

/* =====================================================
   TRY-IT v2 — enrichment reveal step
   ===================================================== */

.try-it-results .row.enriched{grid-template-columns:1.4fr .8fr 1fr 70px 60px 28px}
.try-it-results .row .enrich-col{font-size:12.5px;color:var(--ink-2);font-feature-settings:"tnum";opacity:0;transform:translateX(-6px);transition:opacity .35s ease,transform .35s ease}
.try-it-results .row.enriched .enrich-col{opacity:1;transform:translateX(0)}
.try-it-results .row .enrich-col.score{display:flex;align-items:center;gap:6px}
.try-it-results .row .enrich-col.score .bar{width:30px;height:5px;border-radius:3px;background:var(--cream-2);overflow:hidden;position:relative}
.try-it-results .row .enrich-col.score .bar::after{content:"";position:absolute;top:0;left:0;height:100%;border-radius:3px;background:var(--sage);width:var(--w,80%)}
.try-it-results .row .enrich-col.intent{padding:2px 8px;border-radius:999px;font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;text-align:center}
.try-it-results .row .enrich-col.intent.hot {background:var(--clay-tint); color:var(--clay-deep)}
.try-it-results .row .enrich-col.intent.warm{background:var(--butter-tint);color:var(--butter-deep)}
.try-it-results .row .enrich-col.intent.cold{background:var(--dusk-tint);  color:var(--dusk-deep)}

.try-it-enrich-btn{margin-top:14px;display:inline-flex;align-items:center;gap:8px;padding:8px 14px;font-size:13px;background:var(--cream-2);border:1px solid var(--line);border-radius:10px;color:var(--ink);cursor:pointer;font-family:inherit;font-weight:500;transition:.2s}
.try-it-enrich-btn:hover{background:var(--clay-tint);border-color:transparent;color:var(--clay-deep);transform:translateY(-1px)}
.try-it-enrich-btn .spark{display:inline-block;width:14px;height:14px;color:var(--clay-deep)}
.try-it-enrich-btn[disabled]{opacity:.5;cursor:wait}

/* Confetti / pop on summary */
.try-it-summary.pop{animation:summary-pop .55s cubic-bezier(.4,1.6,.5,1) forwards}
@keyframes summary-pop{0%{transform:scale(.95);opacity:0}60%{transform:scale(1.02);opacity:1}100%{transform:scale(1);opacity:1}}

/* =====================================================
   PRODUCT VIDEO / MOTION DEMO
   ===================================================== */

.video-section{padding:var(--section-pad) 0;position:relative}
.video-frame{
  max-width:980px;margin:32px auto 0;
  background:#1d2a3c;border:1px solid var(--line);border-radius:24px;
  box-shadow:0 24px 60px -22px rgba(29,42,60,.4);
  overflow:hidden;position:relative;aspect-ratio:16/9
}
.video-frame::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(closest-side at 30% 30%,rgba(93,139,193,.25),transparent 60%),
    radial-gradient(closest-side at 75% 70%,rgba(158,178,164,.18),transparent 60%),
    linear-gradient(180deg,#243248,#1d2a3c);
  z-index:0
}
.video-frame .topbar{position:absolute;top:0;left:0;right:0;height:36px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;padding:0 14px;gap:8px;z-index:2}
.video-frame .topbar .dotc{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.2)}
.video-frame .topbar .url{margin-left:14px;font-family:'JetBrains Mono',monospace;font-size:11.5px;color:rgba(255,255,255,.78)}
.video-frame .play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:80px;height:80px;border-radius:50%;
  background:#fff;display:grid;place-items:center;cursor:pointer;
  box-shadow:0 12px 36px -8px rgba(0,0,0,.3);
  z-index:3;transition:transform .25s ease;
  border:none
}
.video-frame .play::before{
  content:"";position:absolute;inset:-12px;border-radius:50%;
  background:radial-gradient(closest-side,rgba(93,139,193,.6),transparent 70%);
  z-index:-1;animation:fab-pulse 2.4s ease-in-out infinite
}
.video-frame .play:hover{transform:translate(-50%,-50%) scale(1.06)}
.video-frame .play svg{color:var(--clay-deep);margin-left:4px}
.video-frame .caption{position:absolute;bottom:24px;left:24px;right:24px;display:flex;align-items:center;justify-content:space-between;color:#fff;z-index:3;font-size:13px;flex-wrap:wrap;gap:10px}
.video-frame .caption .duration{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:rgba(255,255,255,.82);background:rgba(0,0,0,.4);padding:3px 8px;border-radius:6px}
.video-frame .caption .title{font-family:'Fraunces',serif;font-size:16px;font-weight:400;font-variation-settings:"opsz" 24,"SOFT" 60;color:rgba(255,255,255,.95)}
.video-frame .scrubber{position:absolute;bottom:60px;left:24px;right:24px;height:3px;background:rgba(255,255,255,.15);border-radius:3px;z-index:3;overflow:hidden}
.video-frame .scrubber::after{content:"";display:block;height:100%;width:32%;background:linear-gradient(90deg,var(--clay),var(--sage));border-radius:3px;animation:scrub 8s linear infinite}
@keyframes scrub{0%{width:0}100%{width:100%}}

/* Floating "live row" hints over the video frame */
.video-frame .ghost-row{position:absolute;background:rgba(255,255,255,.06);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:8px 12px;font-size:11.5px;color:rgba(255,255,255,.7);font-family:'JetBrains Mono',monospace;z-index:2;animation:ghost-float 6s ease-in-out infinite}
.video-frame .ghost-row.r1{top:18%;left:8%;animation-delay:.5s}
.video-frame .ghost-row.r2{top:36%;right:12%;animation-delay:1.5s}
.video-frame .ghost-row.r3{bottom:30%;left:16%;animation-delay:2.5s}
@keyframes ghost-float{0%,100%{transform:translateY(0);opacity:.6}50%{transform:translateY(-6px);opacity:.85}}

/* =====================================================
   TRY-IT — interactive on-page demo
   ===================================================== */

.try-it{padding:90px 0;position:relative;overflow:hidden}
.try-it .blob{position:absolute;width:560px;height:560px;border-radius:50%;filter:blur(70px);opacity:.4;pointer-events:none}
.try-it .blob.b1{background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);top:-200px;left:-150px}
.try-it .blob.b2{background:radial-gradient(closest-side,var(--sage-tint),transparent 70%);bottom:-220px;right:-150px}
.try-it-head{text-align:center;max-width:680px;margin:0 auto 40px;position:relative}
.try-it-head .pill{margin-bottom:14px}
.try-it-head h2{font-family:'Fraunces',serif;font-weight:400;font-size:48px;line-height:1.04;letter-spacing:-.018em;margin:6px 0 14px;color:var(--ink);font-variation-settings:"opsz" 96,"SOFT" 90}
.try-it-head h2 em{font-style:italic;color:var(--clay-deep)}
.try-it-head p{font-size:17px;color:var(--ink-2);line-height:1.6;margin:0}

.try-it-card{
  max-width:780px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:24px;
  padding:28px;box-shadow:var(--shadow);position:relative;z-index:1;overflow:hidden
}
.try-it-form{display:grid;grid-template-columns:1.4fr 1fr auto;gap:10px;align-items:end}
.try-it-form label{display:block;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-weight:600}
.try-it-form .input{padding:13px 15px;font-size:15px}
.try-it-form .btn{height:44px;align-self:end;padding:0 20px}
.try-it-form .btn[disabled]{opacity:.6;cursor:wait}

.try-it-status{margin-top:20px;font-size:13px;color:var(--muted);min-height:22px;display:flex;align-items:center;gap:10px}
.try-it-status .dot-thinking{width:8px;height:8px;border-radius:50%;background:var(--clay);animation:think-pulse 1.2s ease-in-out infinite}
.try-it-status .dot-thinking:nth-child(2){animation-delay:.2s}
.try-it-status .dot-thinking:nth-child(3){animation-delay:.4s}
@keyframes think-pulse{0%,100%{transform:scale(1);opacity:.8}50%{transform:scale(1.4);opacity:.3}}

.try-it-results{margin-top:18px;display:flex;flex-direction:column;gap:8px}
.try-it-results .row{
  opacity:0;transform:translateY(8px);
  display:grid;grid-template-columns:1.6fr .9fr 1fr 28px;gap:12px;align-items:center;
  padding:12px 16px;border:1px solid var(--line);border-radius:12px;background:var(--cream);font-size:14px
}
.try-it-results .row.show{animation:row-in .45s cubic-bezier(.4,0,.2,1) forwards}
.try-it-results .row .name{font-weight:500;color:var(--ink)}
.try-it-results .row .pill-tag{background:var(--sand);border:1px solid var(--line-strong);color:var(--ink-2);padding:3px 9px;border-radius:999px;font-size:12px;justify-self:start}
.try-it-results .row .num{color:var(--muted);font-size:13px;font-feature-settings:"tnum"}
.try-it-results .row .ck{width:22px;height:22px;border-radius:50%;background:var(--sage-tint);color:var(--sage-deep);display:grid;place-items:center;font-size:12px}
.try-it-results .row:nth-child(1){animation-delay:0s}
.try-it-results .row:nth-child(2){animation-delay:.12s}
.try-it-results .row:nth-child(3){animation-delay:.24s}
.try-it-results .row:nth-child(4){animation-delay:.36s}
.try-it-results .row:nth-child(5){animation-delay:.48s}

.try-it-summary{margin-top:18px;padding:16px 20px;background:linear-gradient(135deg,var(--sage-tint),var(--cream-2));border-radius:14px;border:1px solid #c4d4c8;display:none;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:14px}
.try-it-summary.show{display:flex;animation:row-in .4s ease forwards}
.try-it-summary strong{color:var(--sage-deep);font-weight:600}
.try-it-summary .actions{display:flex;gap:8px}
.try-it-summary .actions .btn{padding:8px 14px;font-size:13.5px;height:auto}

@media (max-width:820px){
  .try-it-form{grid-template-columns:1fr}
  .try-it-head h2{font-size:34px}
  .try-it-results .row{grid-template-columns:1fr 70px 24px;font-size:13px;padding:10px 12px}
  .try-it-results .row .num{display:none}
}

/* =====================================================
   ⌘K COMMAND PALETTE — global search dialog
   ===================================================== */

.kbd-hint{display:inline-flex;align-items:center;gap:4px;padding:3px 7px;border-radius:6px;background:var(--cream-2);border:1px solid var(--line);border-bottom-width:2px;font-family:'JetBrains Mono','SF Mono',Menlo,monospace;font-size:11px;color:var(--muted);font-weight:500;cursor:pointer;transition:.18s}
.kbd-hint:hover{background:#fff;color:var(--ink-2);border-color:var(--line-strong)}
.kbd-hint kbd{background:transparent;border:none;font:inherit;color:inherit;padding:0}

.cmdk-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(29,42,60,.32);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:flex;align-items:flex-start;justify-content:center;padding:80px 24px 24px;
  opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s
}
.cmdk-overlay.open{opacity:1;visibility:visible}

.cmdk{
  width:100%;max-width:580px;background:#fff;border-radius:18px;
  box-shadow:0 30px 80px -20px rgba(29,42,60,.35),0 4px 12px rgba(29,42,60,.08);
  overflow:hidden;border:1px solid var(--line);
  transform:translateY(-12px) scale(.96);transition:transform .22s ease;
  display:flex;flex-direction:column;max-height:75vh
}
.cmdk-overlay.open .cmdk{transform:translateY(0) scale(1)}

.cmdk-input{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}
.cmdk-input svg{flex-shrink:0;color:var(--muted)}
.cmdk-input input{flex:1;border:none;outline:none;font-family:inherit;font-size:16px;color:var(--ink);background:transparent;letter-spacing:-.005em}
.cmdk-input input::placeholder{color:var(--muted)}
.cmdk-input .esc{font-family:'JetBrains Mono','SF Mono',monospace;font-size:11px;color:var(--muted);background:var(--cream-2);border:1px solid var(--line);padding:3px 7px;border-radius:6px}

.cmdk-list{overflow-y:auto;padding:8px;flex:1;-webkit-overflow-scrolling:touch}
.cmdk-group{padding:6px 0}
.cmdk-group h6{padding:6px 14px;margin:0;font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.cmdk-item{display:flex;align-items:center;gap:14px;padding:10px 14px;border-radius:10px;cursor:pointer;color:var(--ink-2);font-size:14.5px;text-decoration:none;transition:.15s}
.cmdk-item.active,.cmdk-item:hover{background:var(--cream-2);color:var(--ink)}
.cmdk-item.active{background:var(--clay-tint);color:var(--clay-deep)}
.cmdk-item .ico{width:32px;height:32px;border-radius:9px;background:var(--cream-2);color:var(--ink-2);display:grid;place-items:center;flex-shrink:0;border:1px solid var(--line)}
.cmdk-item.active .ico{background:#fff;color:var(--clay-deep);border-color:transparent}
.cmdk-item .meta{flex:1;min-width:0}
.cmdk-item .meta strong{display:block;font-weight:500;color:inherit;letter-spacing:-.005em}
.cmdk-item .meta span{display:block;font-size:12.5px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmdk-item .arrow{color:var(--muted);flex-shrink:0;opacity:0;transition:.15s}
.cmdk-item.active .arrow{opacity:1;color:var(--clay-deep)}

.cmdk-empty{padding:32px;text-align:center;color:var(--muted);font-size:14px}
.cmdk-empty strong{color:var(--ink-2);display:block;margin-bottom:4px;font-weight:500}

.cmdk-foot{display:flex;align-items:center;gap:14px;padding:10px 18px;border-top:1px solid var(--line);font-size:11.5px;color:var(--muted);background:var(--cream)}
.cmdk-foot kbd{font-family:'JetBrains Mono','SF Mono',monospace;background:#fff;border:1px solid var(--line);border-radius:5px;padding:2px 5px;font-size:10.5px}

@media (max-width:640px){
  .cmdk-overlay{padding:64px 12px 12px}
  .cmdk{max-height:80vh}
}

/* =====================================================
   SCROLL-REVEAL — fade-up sections as they enter view
   ===================================================== */

.reveal{opacity:0;transform:translateY(16px);transition:opacity .55s ease, transform .55s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* =====================================================
   AI / live-feel — hero canvas auto-play, AI band, FAB
   ===================================================== */

/* Hero canvas plays a self-running demo loop */
.canvas.live{position:relative;overflow:hidden}

/* AI scan-bar sweeping across the canvas */
.canvas.live::after{
  content:"";position:absolute;top:0;bottom:0;width:140px;
  background:linear-gradient(90deg,transparent,rgba(93,139,193,.18),transparent);
  animation:ai-scan 6s ease-in-out infinite;
  pointer-events:none;left:-140px
}
@keyframes ai-scan{
  0%,8%   {left:-140px;opacity:0}
  20%     {opacity:1}
  60%     {left:100%;opacity:1}
  72%,100%{left:100%;opacity:0}
}

/* Typing effect in the search field */
.canvas.live .typed{
  display:inline-block;overflow:hidden;white-space:nowrap;vertical-align:bottom;
  border-right:1.5px solid var(--clay);
  animation:typing 2.2s steps(28,end) .4s forwards 1, caret 0.7s step-end infinite
}
@keyframes typing{from{width:0}to{width:18ch}}
@keyframes caret {0%,100%{border-color:transparent}50%{border-color:var(--clay)}}

/* Chips fan in after the query is typed */
.canvas.live .chips .chip{opacity:0;transform:translateY(4px);animation:chip-in .35s ease forwards}
.canvas.live .chips .chip:nth-child(1){animation-delay:2.7s}
.canvas.live .chips .chip:nth-child(2){animation-delay:2.85s}
.canvas.live .chips .chip:nth-child(3){animation-delay:3.0s}
.canvas.live .chips .chip:nth-child(4){animation-delay:3.15s}
.canvas.live .chips .chip:nth-child(5){animation-delay:3.30s}
.canvas.live .chips .chip:nth-child(6){animation-delay:3.45s}
@keyframes chip-in{to{opacity:1;transform:translateY(0)}}

/* Result rows roll in */
.canvas.live .row-result{opacity:0;transform:translateY(8px);animation:row-in .45s cubic-bezier(.4,0,.2,1) forwards}
.canvas.live .row-result:nth-of-type(1){animation-delay:3.9s}
.canvas.live .row-result:nth-of-type(2){animation-delay:4.3s}
.canvas.live .row-result:nth-of-type(3){animation-delay:4.7s}
@keyframes row-in{to{opacity:1;transform:translateY(0)}}

/* Footnote pulse fades in last */
.canvas.live .footnote{opacity:0;animation:foot-in .4s ease forwards 5.1s}
@keyframes foot-in{to{opacity:1}}

/* Reduced-motion: skip the show, present everything immediately */
@media (prefers-reduced-motion:reduce){
  .canvas.live::after{animation:none;display:none}
  .canvas.live .typed{animation:none;border-right:none;width:auto}
  .canvas.live .chips .chip,.canvas.live .row-result,.canvas.live .footnote{opacity:1;transform:none;animation:none}
}

/* =====================================================
   LIVE TICKER — leads-captured rolling counter
   ===================================================== */

.ticker{padding:14px 0;background:linear-gradient(90deg,var(--cream-2),var(--sand),var(--cream-2));border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;position:relative}
.ticker-row{display:flex;align-items:center;justify-content:center;gap:18px;font-size:14px;color:var(--ink-2);flex-wrap:wrap}
.ticker .live-dot{width:8px;height:8px;border-radius:50%;background:#4d7a5c;box-shadow:0 0 0 4px rgba(77,122,92,.18);animation:status-blink 2s ease-in-out infinite;flex-shrink:0}
.ticker .ticker-num{font-family:'Fraunces',serif;font-weight:400;font-size:22px;color:var(--clay-deep);font-variation-settings:"opsz" 36,"SOFT" 80;letter-spacing:-.012em}
.ticker .ticker-label{color:var(--muted);font-size:13.5px}
.ticker .sep{width:4px;height:4px;border-radius:50%;background:var(--line-strong)}
.ticker .recent{font-size:13.5px;color:var(--ink-2)}
.ticker .recent strong{color:var(--ink);font-weight:500}

/* =====================================================
   AI BAND — what the AI does (4 capability cards)
   ===================================================== */

.ai-band{background:linear-gradient(180deg,transparent,var(--cream-2) 30%,var(--cream-2) 70%,transparent);position:relative;overflow:hidden}
.ai-band .deco-dots{opacity:.3}
.ai-band .ai-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:48px;flex-wrap:wrap}
.ai-band .ai-head .pill-ai{display:inline-flex;align-items:center;gap:8px;padding:5px 12px;background:#fff;border:1px solid var(--line);border-radius:999px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--clay-deep);font-weight:600;margin-bottom:14px}
.ai-band .ai-head .pill-ai svg{width:13px;height:13px;color:var(--clay)}

.ai-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.ai-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:8px;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.ai-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.ai-card::before{content:"";position:absolute;width:160px;height:160px;border-radius:50%;background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);top:-80px;right:-50px;filter:blur(10px);opacity:.7;pointer-events:none}
.ai-card.sage::before  {background:radial-gradient(closest-side,var(--sage-tint),transparent 70%)}
.ai-card.dusk::before  {background:radial-gradient(closest-side,var(--dusk-tint),transparent 70%)}
.ai-card.butter::before{background:radial-gradient(closest-side,var(--butter-tint),transparent 70%)}
.ai-card .ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--clay-tint);color:var(--clay-deep);position:relative;z-index:1;margin-bottom:6px}
.ai-card.sage   .ico{background:var(--sage-tint);  color:var(--sage-deep)}
.ai-card.dusk   .ico{background:var(--dusk-tint);  color:var(--dusk-deep)}
.ai-card.butter .ico{background:var(--butter-tint);color:var(--butter-deep)}
.ai-card h4{font-family:'Fraunces',serif;font-weight:400;font-size:22px;letter-spacing:-.012em;color:var(--ink);margin:0;font-variation-settings:"opsz" 30,"SOFT" 60;position:relative;z-index:1}
.ai-card p{font-size:14px;color:var(--ink-2);line-height:1.55;margin:0;position:relative;z-index:1}
.ai-card .demo{margin-top:14px;padding:10px 12px;background:var(--cream);border:1px solid var(--line);border-radius:10px;font-family:'JetBrains Mono','SF Mono',Menlo,monospace;font-size:11.5px;color:var(--ink-2);position:relative;z-index:1;line-height:1.4}
.ai-card .demo .arrow{color:var(--clay-deep);font-weight:500;display:block;margin-top:3px}

@media (max-width:980px){
  .ai-grid{grid-template-columns:1fr 1fr;gap:14px}
}
@media (max-width:640px){
  .ai-grid{grid-template-columns:1fr}
}

/* =====================================================
   FLOATING AI ASSISTANT (FAB + chat panel preview)
   ===================================================== */

.ai-fab{
  position:fixed;bottom:24px;right:24px;z-index:100;
  display:flex;align-items:center;justify-content:center;
  width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,var(--clay) 0%,var(--clay-deep) 100%);
  color:#ffffff;border:none;cursor:pointer;
  box-shadow:0 8px 28px -8px rgba(38,66,109,.55),0 2px 6px rgba(38,66,109,.18);
  transition:transform .2s ease,box-shadow .2s ease
}
.ai-fab::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  background:radial-gradient(closest-side,rgba(93,139,193,.5),transparent 70%);
  z-index:-1;animation:fab-pulse 2.4s ease-in-out infinite
}
@keyframes fab-pulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.25);opacity:.2}}
.ai-fab:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 14px 36px -8px rgba(38,66,109,.65),0 2px 6px rgba(38,66,109,.18)}
.ai-fab svg{width:26px;height:26px;display:block}

.ai-fab-tooltip{
  position:fixed;bottom:36px;right:96px;z-index:99;
  padding:10px 14px;background:var(--ink);color:#ffffff;
  border-radius:12px;font-size:13px;font-weight:500;
  white-space:nowrap;
  opacity:0;visibility:hidden;transform:translateX(8px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s
}
.ai-fab:hover ~ .ai-fab-tooltip,.ai-fab:focus ~ .ai-fab-tooltip{opacity:1;visibility:visible;transform:translateX(0)}
.ai-fab-tooltip::after{content:"";position:absolute;top:50%;right:-6px;transform:translateY(-50%) rotate(45deg);width:10px;height:10px;background:var(--ink)}

/* AI chat preview panel (toggled open via .open class) */
.ai-chat{
  position:fixed;bottom:96px;right:24px;z-index:100;
  width:340px;max-width:calc(100vw - 48px);
  background:#fff;border:1px solid var(--line);border-radius:22px;
  box-shadow:0 24px 60px -20px rgba(29,42,60,.25),0 2px 4px rgba(29,42,60,.06);
  opacity:0;visibility:hidden;transform:translateY(12px) scale(.96);
  transform-origin:bottom right;
  transition:opacity .22s ease,transform .22s ease,visibility .22s
}
.ai-chat.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.ai-chat-head{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.ai-chat-head .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--clay) 0%,var(--clay-deep) 100%);display:grid;place-items:center;color:#ffffff;flex-shrink:0;position:relative;overflow:hidden}
.ai-chat-head .av::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.25),transparent 50%)}
.ai-chat-head .av svg{width:16px;height:16px;position:relative;z-index:1}
.ai-chat-head .who strong{display:block;font-size:14px;color:var(--ink);font-weight:600;line-height:1.2}
.ai-chat-head .who span{display:block;font-size:12px;color:var(--sage-deep);margin-top:2px}
.ai-chat-head .who span::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#4d7a5c;margin-right:5px;vertical-align:middle;animation:status-blink 2.4s ease-in-out infinite}
.ai-chat-close{margin-left:auto;width:30px;height:30px;border-radius:50%;background:var(--cream-2);border:none;cursor:pointer;display:grid;place-items:center;color:var(--ink-2);transition:.18s}
.ai-chat-close:hover{background:var(--clay-tint);color:var(--clay-deep)}
.ai-chat-body{padding:18px;display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto}
.ai-msg{padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.5;max-width:85%}
.ai-msg.bot{background:var(--cream-2);color:var(--ink-2);align-self:flex-start;border-bottom-left-radius:4px}
.ai-msg.user{background:var(--clay);color:#ffffff;align-self:flex-end;border-bottom-right-radius:4px}
.ai-suggest{display:flex;flex-wrap:wrap;gap:6px;padding:0 18px 14px}
.ai-suggest button{font-family:inherit;font-size:12.5px;padding:6px 11px;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--ink-2);cursor:pointer;transition:.18s}
.ai-suggest button:hover{background:var(--clay-tint);color:var(--clay-deep);border-color:transparent}
.ai-chat-input{padding:14px 18px;border-top:1px solid var(--line);display:flex;gap:8px}
.ai-chat-input input{flex:1;border:1px solid var(--line);border-radius:12px;padding:9px 13px;font-family:inherit;font-size:14px;background:var(--cream);outline:none;transition:.2s}
.ai-chat-input input:focus{border-color:var(--clay);background:#fff;box-shadow:0 0 0 3px var(--clay-tint)}
.ai-chat-input button{flex-shrink:0;width:38px;height:38px;border-radius:11px;background:var(--clay);color:#ffffff;border:none;cursor:pointer;display:grid;place-items:center;transition:.18s}
.ai-chat-input button:hover{background:var(--clay-deep)}
.ai-chat-input button svg{width:14px;height:14px}

@media (max-width:640px){
  .ai-fab{bottom:16px;right:16px;width:52px;height:52px}
  .ai-fab svg{width:22px;height:22px}
  .ai-chat{bottom:80px;right:16px;left:16px;width:auto}
  .ai-fab-tooltip{display:none}
}

/* =====================================================
   STATUS page — uptime + incidents
   ===================================================== */

.status-summary{padding:24px 28px;border-radius:18px;background:var(--sage-tint);border:1px solid #bbd0c0;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:32px;flex-wrap:wrap}
.status-summary.warn{background:var(--butter-tint);border-color:#d5c187}
.status-summary.down{background:var(--blush-tint);border-color:#dba9b0}
.status-summary .lead{display:flex;align-items:center;gap:14px}
.status-summary .pulsedot{width:10px;height:10px;border-radius:50%;background:#4d7a5c;animation:status-blink 2.4s ease-in-out infinite;flex-shrink:0}
.status-summary.warn .pulsedot{background:var(--butter-deep)}
.status-summary.down .pulsedot{background:var(--blush-deep)}
.status-summary h2{font-family:'Fraunces',serif;font-weight:400;font-size:24px;margin:0;color:var(--sage-deep);font-variation-settings:"opsz" 36,"SOFT" 60}
.status-summary.warn h2{color:var(--butter-deep)}
.status-summary.down h2{color:var(--blush-deep)}
.status-summary .ts{font-size:12.5px;color:var(--muted);font-family:'JetBrains Mono','SF Mono',Menlo,monospace;letter-spacing:.04em}

.status-grid{display:flex;flex-direction:column;gap:4px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:8px;margin-top:32px}
.status-row{display:grid;grid-template-columns:1fr auto auto;gap:18px;align-items:center;padding:14px 16px;border-radius:12px;transition:background .15s}
.status-row:hover{background:var(--cream-2)}
.status-row .name{font-weight:500;color:var(--ink);font-size:15px}
.status-row .name span.s{display:block;font-size:12.5px;color:var(--muted);margin-top:1px;font-weight:400}
.status-row .uptime{font-family:'JetBrains Mono','SF Mono',Menlo,monospace;font-size:12.5px;color:var(--muted);letter-spacing:.04em;white-space:nowrap}

.status-pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;padding:4px 10px;border-radius:999px;border:1px solid transparent;white-space:nowrap}
.status-pill.ok  {background:var(--sage-tint);  color:var(--sage-deep);  border-color:#bccdc1}
.status-pill.warn{background:var(--butter-tint);color:var(--butter-deep);border-color:#d5c187}
.status-pill.down{background:var(--blush-tint); color:var(--blush-deep); border-color:#dba9b0}

.uptime-bars{display:flex;gap:2px;align-items:flex-end;height:26px;margin-top:18px}
.uptime-bars .ub{width:4px;height:100%;border-radius:2px;background:var(--sage)}
.uptime-bars .ub.warn{background:var(--butter);height:60%}
.uptime-bars .ub.down{background:var(--blush);height:30%}
.uptime-legend{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:11.5px;color:var(--muted);letter-spacing:.04em}

.incident{padding:22px 0;border-bottom:1px solid var(--line)}
.incident:last-child{border-bottom:none}
.incident .when{font-family:'JetBrains Mono','SF Mono',Menlo,monospace;font-size:12px;color:var(--muted);letter-spacing:.04em;margin-bottom:6px}
.incident h4{font-family:'Fraunces',serif;font-weight:400;font-size:20px;color:var(--ink);margin:2px 0 8px;font-variation-settings:"opsz" 30,"SOFT" 50}
.incident p{font-size:14.5px;color:var(--ink-2);line-height:1.6;margin:0 0 6px;max-width:720px}

/* =====================================================
   BLOG ARTICLE page — single post template
   ===================================================== */

.article-page{padding:32px 0 80px;position:relative}
.article-hero{padding:14px 0 32px;border-bottom:1px solid var(--line);margin-bottom:42px}
.article-hero .crumb{font-size:13px;color:var(--muted);margin-bottom:12px;letter-spacing:.04em}
.article-hero .tag-row{display:flex;gap:8px;align-items:center;margin:8px 0 12px;flex-wrap:wrap}
.article-hero .a-tag{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:4px 10px;border-radius:999px;background:var(--clay-tint);color:var(--clay-deep)}
.article-hero .a-tag.sage  {background:var(--sage-tint);  color:var(--sage-deep)}
.article-hero .a-tag.dusk  {background:var(--dusk-tint);  color:var(--dusk-deep)}
.article-hero .a-tag.butter{background:var(--butter-tint);color:var(--butter-deep)}
.article-hero .a-tag.blush {background:var(--blush-tint); color:var(--blush-deep)}
.article-hero .read-time{font-size:13px;color:var(--muted)}
.article-hero h1{font-family:'Fraunces',serif;font-weight:400;font-size:48px;line-height:1.05;letter-spacing:-.018em;margin:6px 0 16px;color:var(--ink);font-variation-settings:"opsz" 96,"SOFT" 80;max-width:880px}
.article-hero h1 em{font-style:italic;color:var(--clay-deep)}
.article-hero p.dek{font-size:18px;line-height:1.55;color:var(--ink-2);max-width:720px;margin:0}

.article-meta-row{display:flex;align-items:center;gap:18px;margin:24px 0 0;flex-wrap:wrap}
.article-author{display:flex;align-items:center;gap:10px}
.article-author .av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--clay-tint),var(--sage-tint));display:grid;place-items:center;font-family:'Fraunces',serif;font-style:italic;color:var(--clay-deep);font-size:16px;font-variation-settings:"opsz" 24,"SOFT" 100;border:1px solid var(--line)}
.article-author .who strong{display:block;font-size:14px;color:var(--ink);font-weight:600;letter-spacing:-.005em;line-height:1.2}
.article-author .who span{display:block;font-size:12.5px;color:var(--muted);margin-top:2px}
.article-share{display:flex;gap:6px;margin-left:auto}
.article-share a{width:34px;height:34px;border-radius:10px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-2);transition:.18s}
.article-share a:hover{background:var(--clay-tint);color:var(--clay-deep);border-color:transparent;transform:translateY(-1px)}

.article-thumb{aspect-ratio:21/9;background:linear-gradient(135deg,var(--clay-tint),var(--sand));border-radius:22px;margin-bottom:48px;display:grid;place-items:center;border:1px solid var(--line);position:relative;overflow:hidden}
.article-thumb::before{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(closest-side,rgba(255,255,255,.6),transparent 70%);top:-100px;right:-100px;filter:blur(20px)}
.article-thumb .glyph{font-family:'Fraunces',serif;font-style:italic;font-size:140px;line-height:1;color:var(--clay);opacity:.5;font-variation-settings:"opsz" 144,"SOFT" 100;position:relative;z-index:1}

.article-layout{display:grid;grid-template-columns:200px 1fr;gap:56px;align-items:start}
.article-toc{position:sticky;top:84px;font-size:13.5px;max-height:calc(100vh - 100px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.article-toc h6{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 10px}
.article-toc nav{display:flex;flex-direction:column;gap:1px}
.article-toc nav a{padding:7px 12px;border-radius:8px;color:var(--ink-2);transition:.15s}
.article-toc nav a:hover{background:var(--cream-2);color:var(--ink)}
.article-toc nav a.active{background:var(--clay-tint);color:var(--clay-deep);font-weight:500}

.article-body{max-width:720px;min-width:0}
.article-body h2{font-family:'Fraunces',serif;font-weight:400;font-size:32px;letter-spacing:-.014em;margin:40px 0 14px;color:var(--ink);font-variation-settings:"opsz" 48,"SOFT" 70;scroll-margin-top:84px}
.article-body h2:first-child{margin-top:0}
.article-body h3{font-family:'Fraunces',serif;font-weight:400;font-size:22px;margin:24px 0 8px;color:var(--ink)}
.article-body p{font-size:17px;line-height:1.78;color:var(--ink-2);margin:0 0 18px}
.article-body p strong{color:var(--ink)}
.article-body a{color:var(--clay-deep);font-weight:500;border-bottom:1px solid currentColor}
.article-body a:hover{color:var(--clay)}
.article-body blockquote{border-left:3px solid var(--clay);padding:14px 24px;margin:28px 0;font-family:'Fraunces',serif;font-style:italic;font-size:22px;line-height:1.4;color:var(--ink);background:linear-gradient(90deg,var(--clay-tint),var(--cream-2));border-radius:0 14px 14px 0;font-variation-settings:"opsz" 36,"SOFT" 80}
.article-body ul,.article-body ol{padding-left:24px;font-size:16.5px;line-height:1.78;color:var(--ink-2);margin:14px 0 20px}
.article-body li{margin-bottom:6px}
.article-body figure{margin:30px 0}
.article-body figure img{border-radius:18px;width:100%;display:block}
.article-body figcaption{font-size:13px;color:var(--muted);text-align:center;margin-top:8px;font-style:italic}
.article-body hr{border:none;border-top:1px solid var(--line);margin:40px 0}
.article-body code{font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;font-size:.92em;background:var(--cream-2);padding:1px 6px;border-radius:5px;color:var(--clay-deep);border:1px solid var(--line)}

.article-related{margin-top:80px;padding-top:48px;border-top:1px solid var(--line)}
.article-related h6{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 18px;font-weight:600}

@media (max-width:980px){
  .article-layout{grid-template-columns:1fr;gap:24px}
  .article-toc{display:none}
  .article-hero h1{font-size:34px}
  .article-thumb{aspect-ratio:16/10}
  .article-thumb .glyph{font-size:96px}
}

/* =====================================================
   FREE TIER landing page
   ===================================================== */

.free-hero{padding:60px 0 40px;position:relative;overflow:hidden;text-align:center}
.free-hero .blob{position:absolute;width:560px;height:560px;border-radius:50%;filter:blur(70px);opacity:.5;pointer-events:none}
.free-hero .blob.b1{background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);top:-220px;right:-100px}
.free-hero .blob.b2{background:radial-gradient(closest-side,var(--sage-tint),transparent 70%);bottom:-260px;left:-100px}
.free-hero .crumb{font-size:13px;color:var(--muted);margin-bottom:14px;letter-spacing:.04em}
.free-hero h1{font-family:'Fraunces',serif;font-weight:400;font-size:60px;line-height:1.02;letter-spacing:-.02em;margin:8px auto 18px;color:var(--ink);font-variation-settings:"opsz" 144,"SOFT" 100;max-width:760px}
.free-hero h1 em{font-style:italic;color:var(--clay-deep)}
.free-hero p.lede{font-size:18.5px;line-height:1.55;color:var(--ink-2);max-width:620px;margin:0 auto 28px}

.free-numbers{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin:48px 0;padding:32px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.free-numbers .stat{padding:0 22px;border-right:1px solid var(--line);text-align:left}
.free-numbers .stat:last-child{border-right:none}
.free-numbers .stat .num{font-family:'Fraunces',serif;font-weight:400;font-size:40px;line-height:1;letter-spacing:-.012em;color:var(--ink);font-variation-settings:"opsz" 60,"SOFT" 70}
.free-numbers .stat .num em{font-style:italic;color:var(--clay-deep)}
.free-numbers .stat:nth-child(2) .num em{color:var(--sage-deep)}
.free-numbers .stat:nth-child(3) .num em{color:var(--dusk-deep)}
.free-numbers .stat:nth-child(4) .num em{color:var(--butter-deep)}
.free-numbers .stat .label{margin-top:6px;font-size:13px;color:var(--muted);line-height:1.4}

.free-compare{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;margin-top:40px}
.free-compare-head{padding:24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.free-compare-head:last-child{border-right:none}
.free-compare-head h3{font-family:'Fraunces',serif;font-weight:400;font-size:24px;margin:0;color:var(--ink);font-variation-settings:"opsz" 36,"SOFT" 60}
.free-compare-head .price{font-size:18px;color:var(--clay-deep);font-weight:500;margin-top:4px}
.free-compare-row{display:contents}
.free-compare-cell{padding:16px 24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);font-size:14.5px;color:var(--ink-2);display:flex;align-items:center;gap:8px}
.free-compare-cell:last-of-type{border-right:none}
.free-compare-cell.label{font-weight:500;color:var(--ink);background:var(--cream-2)}
.free-compare-cell .ck{width:18px;height:18px;border-radius:50%;background:var(--sage-tint);color:var(--sage-deep);display:grid;place-items:center;font-size:11px;flex-shrink:0}
.free-compare-cell .x{width:18px;height:18px;border-radius:50%;background:var(--cream-2);color:var(--muted);display:grid;place-items:center;font-size:11px;flex-shrink:0}

@media (max-width:820px){
  .free-numbers{grid-template-columns:1fr 1fr}
  .free-numbers .stat{border-right:none;border-bottom:1px solid var(--line);padding:14px 16px}
  .free-numbers .stat:nth-child(2){border-right:none}
  .free-compare{grid-template-columns:1fr}
  .free-compare-head,.free-compare-cell{border-right:none}
  .free-hero h1{font-size:38px}
}

/* =====================================================
   AUTH pages — login / register / forgot
   ===================================================== */

.auth-page{min-height:calc(100vh - 78px);padding:60px 0 80px;display:flex;align-items:center;position:relative;overflow:hidden}
.auth-page .blob{position:absolute;width:560px;height:560px;border-radius:50%;filter:blur(70px);opacity:.45;pointer-events:none}
.auth-page .blob.b1{background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);top:-220px;right:-160px}
.auth-page .blob.b2{background:radial-gradient(closest-side,var(--sage-tint),transparent 70%);bottom:-260px;left:-180px}

.auth-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;width:100%;position:relative;z-index:1}
.auth-pitch{padding-right:24px}
.auth-pitch .eyebrow{margin-bottom:14px}
.auth-pitch h1{font-family:'Fraunces',serif;font-weight:400;font-size:48px;line-height:1.04;letter-spacing:-.018em;margin:6px 0 16px;color:var(--ink);font-variation-settings:"opsz" 96,"SOFT" 90}
.auth-pitch h1 em{font-style:italic;color:var(--clay-deep)}
.auth-pitch p{color:var(--ink-2);font-size:16.5px;line-height:1.6;margin:0 0 20px;max-width:460px}
.auth-pitch ul.points{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.auth-pitch ul.points li{display:flex;gap:12px;align-items:flex-start;font-size:14.5px;color:var(--ink-2)}
.auth-pitch ul.points li .ck{width:22px;height:22px;border-radius:50%;background:var(--sage-tint);color:var(--sage-deep);display:grid;place-items:center;flex:0 0 22px;font-size:12px}

.auth-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:36px;box-shadow:var(--shadow);max-width:440px;width:100%;margin-left:auto}
.auth-card h2{font-family:'Fraunces',serif;font-weight:400;font-size:30px;line-height:1.1;letter-spacing:-.014em;margin:0 0 6px;color:var(--ink);font-variation-settings:"opsz" 36,"SOFT" 70}
.auth-card .sub{font-size:14.5px;color:var(--ink-2);margin:0 0 22px}
.auth-card .form-grid{margin:0}
.auth-card .full-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--muted);margin:-2px 0 6px}
.auth-card .full-row a{color:var(--clay-deep);font-weight:500}
.auth-card .full-row a:hover{text-decoration:underline}
.auth-card .footnote{font-size:13.5px;color:var(--muted);text-align:center;margin-top:18px}
.auth-card .footnote a{color:var(--clay-deep);font-weight:500}

.divider-or{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.divider-or::before,.divider-or::after{content:"";flex:1;height:1px;background:var(--line)}

.btn-social{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 14px;border-radius:12px;background:#fff;border:1px solid var(--line);font-family:inherit;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer;transition:.18s}
.btn-social:hover{background:var(--cream-2);border-color:var(--line-strong)}
.btn-social svg{width:18px;height:18px;flex:0 0 18px}
.social-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

@media (max-width:980px){
  .auth-grid{grid-template-columns:1fr;gap:36px}
  .auth-pitch{padding-right:0;text-align:center}
  .auth-pitch ul.points li{justify-content:flex-start;text-align:left}
  .auth-card{margin:0 auto}
  .auth-pitch h1{font-size:36px}
}

/* =====================================================
   LEGAL pages — terms / privacy / cookies / GDPR
   ===================================================== */

.legal-page{padding:48px 0 100px;position:relative}
.legal-hero{padding:32px 0 24px;border-bottom:1px solid var(--line);margin-bottom:36px}
.legal-hero .crumb{font-size:13px;color:var(--muted);margin-bottom:10px;letter-spacing:.04em}
.legal-hero h1{font-family:'Fraunces',serif;font-weight:400;font-size:48px;line-height:1.04;letter-spacing:-.018em;margin:8px 0 8px;color:var(--ink);font-variation-settings:"opsz" 72,"SOFT" 80}
.legal-hero h1 em{font-style:italic;color:var(--clay-deep)}
.legal-hero .meta{font-size:13.5px;color:var(--muted)}

.legal-layout{display:grid;grid-template-columns:220px 1fr;gap:48px;align-items:start}
.legal-toc{position:sticky;top:84px;font-size:13.5px;max-height:calc(100vh - 100px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.legal-toc h6{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 10px}
.legal-toc nav{display:flex;flex-direction:column;gap:1px}
.legal-toc nav a{padding:7px 12px;border-radius:8px;color:var(--ink-2);transition:.15s}
.legal-toc nav a:hover{background:var(--cream-2);color:var(--ink)}
.legal-toc nav a.active{background:var(--clay-tint);color:var(--clay-deep);font-weight:500}

.legal-body{max-width:740px}
.legal-body h2{font-family:'Fraunces',serif;font-weight:400;font-size:28px;letter-spacing:-.012em;margin:36px 0 12px;color:var(--ink);font-variation-settings:"opsz" 36,"SOFT" 60;scroll-margin-top:84px}
.legal-body h2:first-child{margin-top:0}
.legal-body h3{font-size:18px;font-weight:600;color:var(--ink);margin:22px 0 8px}
.legal-body p{font-size:15.5px;line-height:1.7;color:var(--ink-2);margin:0 0 14px}
.legal-body ul{padding-left:22px;margin:10px 0 16px;font-size:15px;color:var(--ink-2);line-height:1.7}
.legal-body li{margin-bottom:6px}
.legal-body strong{color:var(--ink)}
.legal-body a{color:var(--clay-deep);font-weight:500}
.legal-body a:hover{text-decoration:underline}

@media (max-width:980px){
  .legal-layout{grid-template-columns:1fr;gap:24px}
  .legal-toc{position:static;max-height:none;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
  .legal-hero h1{font-size:34px}
}

/* =====================================================
   ABOUT page — story + values + team
   ===================================================== */

.about-story{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:40px}
.about-story p{font-size:16px;line-height:1.65;color:var(--ink-2);margin:0 0 14px;max-width:520px}
.about-visual{background:linear-gradient(135deg,var(--clay-tint),var(--sand));border-radius:24px;aspect-ratio:1/1;position:relative;overflow:hidden;display:grid;place-items:center;border:1px solid var(--line)}
.about-visual::before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(closest-side,rgba(255,255,255,.6),transparent 70%);top:-100px;right:-80px;filter:blur(20px)}
.about-visual .glyph{font-family:'Fraunces',serif;font-style:italic;font-size:200px;line-height:1;color:var(--clay);opacity:.55;font-variation-settings:"opsz" 144,"SOFT" 100;position:relative;z-index:1}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.value{padding:28px;background:#fff;border:1px solid var(--line);border-radius:20px;display:flex;flex-direction:column;gap:8px}
.value .num{font-family:'Fraunces',serif;font-style:italic;font-size:28px;color:var(--clay-deep);line-height:1;font-variation-settings:"opsz" 36,"SOFT" 90}
.value:nth-child(2) .num{color:var(--sage-deep)}
.value:nth-child(3) .num{color:var(--dusk-deep)}
.value h4{font-family:'Fraunces',serif;font-weight:400;font-size:22px;letter-spacing:-.012em;color:var(--ink);margin:6px 0;font-variation-settings:"opsz" 30,"SOFT" 60}
.value p{font-size:14.5px;color:var(--ink-2);line-height:1.6;margin:0}

.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:50px}
.member{text-align:left;display:flex;flex-direction:column;gap:6px}
.member .av{aspect-ratio:1/1;border-radius:16px;background:linear-gradient(135deg,var(--clay-tint),var(--sand));margin-bottom:12px;display:grid;place-items:center;border:1px solid var(--line);position:relative;overflow:hidden}
.member:nth-child(2) .av{background:linear-gradient(135deg,var(--sage-tint),var(--cream))}
.member:nth-child(3) .av{background:linear-gradient(135deg,var(--dusk-tint),var(--cream))}
.member:nth-child(4) .av{background:linear-gradient(135deg,var(--butter-tint),var(--cream))}
.member:nth-child(5) .av{background:linear-gradient(135deg,var(--blush-tint),var(--cream))}
.member:nth-child(6) .av{background:linear-gradient(135deg,var(--sage-tint),var(--clay-tint))}
.member .av .glyph{font-family:'Fraunces',serif;font-style:italic;font-size:64px;line-height:1;color:var(--clay-deep);opacity:.7;font-variation-settings:"opsz" 96,"SOFT" 100}
.member:nth-child(2) .av .glyph{color:var(--sage-deep)}
.member:nth-child(3) .av .glyph{color:var(--dusk-deep)}
.member:nth-child(4) .av .glyph{color:var(--butter-deep)}
.member:nth-child(5) .av .glyph{color:var(--blush-deep)}
.member h5{font-size:15px;font-weight:600;letter-spacing:-.005em;color:var(--ink);margin:4px 0 0}
.member span.role{font-size:13.5px;color:var(--muted)}

@media (max-width:980px){
  .about-story{grid-template-columns:1fr;gap:32px}
  .values-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
}

/* =====================================================
   CHANGELOG page — timeline of releases
   ===================================================== */

.changelog{display:flex;flex-direction:column;gap:0;margin-top:40px;position:relative}
.changelog::before{content:"";position:absolute;top:8px;bottom:8px;left:120px;width:1px;background:var(--line)}
.cl-entry{display:grid;grid-template-columns:120px 1fr;gap:36px;padding:30px 0;border-bottom:1px solid var(--line);position:relative}
.cl-entry:last-child{border-bottom:none}
.cl-entry .when{font-family:'JetBrains Mono','SF Mono',Menlo,monospace;font-size:12px;color:var(--muted);letter-spacing:.04em;padding-top:4px}
.cl-entry::before{content:"";position:absolute;left:114px;top:36px;width:13px;height:13px;border-radius:50%;background:var(--clay);border:3px solid var(--cream);box-shadow:0 0 0 1px var(--line)}
.cl-entry:nth-child(2)::before{background:var(--sage)}
.cl-entry:nth-child(3)::before{background:var(--dusk)}
.cl-entry:nth-child(4)::before{background:var(--butter)}
.cl-entry:nth-child(5)::before{background:var(--blush)}
.cl-entry:nth-child(6)::before{background:var(--clay-deep)}
.cl-tag{display:inline-block;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--clay-tint);color:var(--clay-deep);margin-bottom:8px}
.cl-tag.fix{background:var(--sage-tint);color:var(--sage-deep)}
.cl-tag.improve{background:var(--dusk-tint);color:var(--dusk-deep)}
.cl-tag.new{background:var(--butter-tint);color:var(--butter-deep)}
.cl-entry h3{font-family:'Fraunces',serif;font-weight:400;font-size:24px;line-height:1.15;letter-spacing:-.012em;margin:4px 0 8px;color:var(--ink);font-variation-settings:"opsz" 30,"SOFT" 60}
.cl-entry p{font-size:15px;color:var(--ink-2);line-height:1.65;margin:0 0 8px}
.cl-entry ul{padding-left:18px;font-size:14.5px;color:var(--ink-2);line-height:1.65}
.cl-entry ul li{margin-bottom:3px}

@media (max-width:980px){
  .changelog::before{left:6px}
  .cl-entry{grid-template-columns:1fr;gap:6px;padding-left:24px}
  .cl-entry::before{left:0;top:34px}
}

/* =====================================================
   404 / error page
   ===================================================== */

.error-page{min-height:calc(100vh - 78px);padding:60px 0;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden}
.error-page .blob{position:absolute;width:600px;height:600px;border-radius:50%;filter:blur(70px);opacity:.5;pointer-events:none;background:radial-gradient(closest-side,var(--clay-tint),transparent 70%);top:-180px;left:50%;transform:translateX(-50%)}
.error-card{position:relative;z-index:1;max-width:520px;padding:30px}
.error-num{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:200px;line-height:1;color:var(--clay-deep);font-variation-settings:"opsz" 144,"SOFT" 100;letter-spacing:-.04em;margin:0;background:linear-gradient(180deg,var(--clay) 0%,var(--clay-deep) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.error-page h1{font-family:'Fraunces',serif;font-weight:400;font-size:42px;line-height:1.05;letter-spacing:-.014em;margin:8px 0 14px;color:var(--ink);font-variation-settings:"opsz" 72,"SOFT" 80}
.error-page h1 em{font-style:italic;color:var(--clay-deep)}
.error-page p{font-size:16px;color:var(--ink-2);line-height:1.6;margin:0 0 24px}
.error-page .hero-cta{justify-content:center}

/* =====================================================
   API DOCUMENTATION page
   ===================================================== */

.api-hero{padding:60px 0 32px;position:relative;overflow:hidden}
.api-hero .crumb{font-size:13px;color:var(--muted);margin-bottom:14px;letter-spacing:.04em}
.api-hero h1{font-family:'Fraunces',serif;font-weight:400;font-size:54px;line-height:1.04;letter-spacing:-.018em;margin:6px 0 16px;font-variation-settings:"opsz" 96,"SOFT" 90;color:var(--ink)}
.api-hero h1 em{font-style:italic;color:var(--clay-deep)}
.api-hero p.lede{font-size:18px;line-height:1.6;color:var(--ink-2);max-width:660px;margin:0 0 24px}

.api-layout{display:grid;grid-template-columns:240px 1fr;gap:56px;align-items:start;padding:32px 0 100px;border-top:1px solid var(--line);position:relative}

/* Sidebar */
.api-sidebar{position:sticky;top:84px;font-size:14px;max-height:calc(100vh - 100px);overflow-y:auto;padding-right:8px;-webkit-overflow-scrolling:touch}
.api-sidebar h6{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:18px 12px 10px}
.api-sidebar h6:first-child{margin-top:0}
.api-sidebar nav{display:flex;flex-direction:column;gap:1px}
.api-sidebar nav a{padding:8px 12px;border-radius:9px;color:var(--ink-2);transition:.18s;display:block;font-size:13.5px;line-height:1.4}
.api-sidebar nav a:hover{background:var(--cream-2);color:var(--ink)}
.api-sidebar nav a.active{background:var(--clay-tint);color:var(--clay-deep);font-weight:500}
.api-sidebar nav a.sub{padding-left:24px;font-size:13px;color:var(--muted)}

/* Main */
.api-main{min-width:0}
.api-section{margin-bottom:64px;scroll-margin-top:90px}
.api-main h2{font-family:'Fraunces',serif;font-weight:400;font-size:36px;letter-spacing:-.014em;margin:0 0 16px;color:var(--ink);font-variation-settings:"opsz" 60,"SOFT" 70}
.api-main h2 em{font-style:italic;color:var(--clay-deep)}
.api-main h3{font-family:'Fraunces',serif;font-weight:400;font-size:22px;margin:28px 0 10px;color:var(--ink);font-variation-settings:"opsz" 30,"SOFT" 50}
.api-main p{font-size:15.5px;line-height:1.65;color:var(--ink-2);margin:0 0 14px;max-width:720px}
.api-main strong{color:var(--ink);font-weight:600}
.api-main ul.bullets{list-style:none;padding:0;margin:14px 0;max-width:720px}
.api-main ul.bullets li{padding:8px 0 8px 24px;position:relative;font-size:15px;color:var(--ink-2);line-height:1.6}
.api-main ul.bullets li::before{content:"";position:absolute;left:6px;top:14px;width:6px;height:6px;border-radius:50%;background:var(--clay)}

/* Endpoint card */
.endpoint{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;margin:16px 0 24px}
.endpoint .ep-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.method-tag{display:inline-block;padding:4px 10px;border-radius:8px;font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;font-size:11.5px;font-weight:600;letter-spacing:.05em}
.method-tag.get   {background:var(--sage-tint);  color:var(--sage-deep)}
.method-tag.post  {background:var(--clay-tint);  color:var(--clay-deep)}
.method-tag.put   {background:var(--butter-tint);color:var(--butter-deep)}
.method-tag.delete{background:var(--blush-tint); color:var(--blush-deep)}
.endpoint .path{font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;font-size:14.5px;color:var(--ink);font-weight:500;word-break:break-all}
.endpoint .cost{margin-left:auto;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;background:var(--sand);padding:4px 10px;border-radius:999px;border:1px solid var(--line)}
.endpoint p:first-of-type{margin-top:14px;color:var(--ink-2)}

/* Parameter table */
.param-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:14px;background:#fff;margin:12px 0 18px}
.param-table{width:100%;border-collapse:collapse;font-size:14px}
.param-table th,.param-table td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.param-table tr:last-child td{border-bottom:none}
.param-table th{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--cream)}
.param-table td.name{font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;color:var(--ink);font-size:13.5px;font-weight:500}
.param-table .req{font-size:10px;background:var(--clay-tint);color:var(--clay-deep);padding:2px 7px;border-radius:6px;margin-left:6px;font-weight:600;letter-spacing:.06em}
.param-table .opt{font-size:10px;background:var(--cream-2);color:var(--muted);padding:2px 7px;border-radius:6px;margin-left:6px;letter-spacing:.06em;border:1px solid var(--line)}
.param-table td.type{color:var(--dusk-deep);font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;font-size:12.5px;white-space:nowrap}
.param-table td.desc{font-size:13.5px;color:var(--ink-2);line-height:1.5}

/* Code tabs (JS-driven) */
.code-tabs{margin:18px 0 22px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#1f1a13}
.tab-row{display:flex;gap:0;padding:0 8px;background:#2a241a;border-bottom:1px solid #3a3328}
.tab-btn{padding:10px 16px;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;color:#bbae93;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:.2s}
.tab-btn:hover{color:#f3eadc}
.tab-btn.active{color:#f3eadc;border-bottom-color:var(--clay)}
.tab-pane{display:none}
.tab-pane.active{display:block}
.code-block{background:#1f1a13;color:#f3eadc;padding:18px 20px;font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;font-size:13px;line-height:1.65;overflow-x:auto;white-space:pre;-webkit-overflow-scrolling:touch;margin:0}
.code-block .k{color:#e3a98a}    /* method/keyword */
.code-block .s{color:#cfb37a}    /* string */
.code-block .c{color:#9a9385;font-style:italic}    /* comment */
.code-block .v{color:#8ea99a}    /* var/type */
.code-block .n{color:#c69097}    /* number */
.code-block .p{color:#8694b1}    /* punctuation/property */

/* Inline <code> */
code{font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;font-size:.9em;background:var(--cream-2);padding:1px 6px;border-radius:5px;color:var(--clay-deep);border:1px solid var(--line);white-space:nowrap}

/* SDK card grid */
.sdk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:18px 0}
.sdk-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:8px;transition:.2s}
.sdk-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow);transform:translateY(-2px)}
.sdk-card .lang{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--clay-deep);font-weight:600;letter-spacing:.04em}
.sdk-card h4{font-family:'Fraunces',serif;font-weight:400;font-size:20px;margin:0;color:var(--ink)}
.sdk-card p{font-size:13.5px;color:var(--muted);margin:0 0 8px;line-height:1.5}
.sdk-card .install{font-family:'JetBrains Mono',monospace;font-size:12px;background:var(--cream);border:1px solid var(--line);border-radius:8px;padding:8px 12px;color:var(--ink-2);overflow-x:auto;white-space:nowrap}

/* Error / status callout */
.callout{display:flex;gap:14px;padding:18px 20px;background:var(--cream-2);border-left:3px solid var(--clay);border-radius:8px;margin:14px 0;font-size:14.5px;line-height:1.55;color:var(--ink-2)}
.callout.warn{background:var(--butter-tint);border-color:var(--butter-deep)}
.callout.info{background:var(--dusk-tint);border-color:var(--dusk-deep)}
.callout strong{color:var(--ink)}

/* Responsive for API doc */
@media (max-width:980px){
  .api-layout{grid-template-columns:1fr;gap:24px;padding:24px 0 80px}
  .api-sidebar{position:static;max-height:none;padding-right:0;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
  .api-hero h1{font-size:38px}
}

/* =====================================================
   DECORATIVE ORNAMENTS — sparkles, underlines, patterns
   Adds the "human / hand-made" texture across the page.
   ===================================================== */

.deco{position:absolute;pointer-events:none;z-index:0;line-height:0}
section,.hero,.cta-card,.split,.gdpr,.tools,.quote,.cases-grid,.tools-grid{position:relative}

/* Sparkle (4-point star) */
.deco-sparkle{display:inline-block;color:var(--clay);opacity:.8;animation:dec-twinkle 4s ease-in-out infinite;line-height:0}
.deco-sparkle.sage  {color:var(--sage)}
.deco-sparkle.dusk  {color:var(--dusk)}
.deco-sparkle.butter{color:var(--butter)}
.deco-sparkle.blush {color:var(--blush)}
.deco-sparkle svg{width:100%;height:100%;display:block;fill:currentColor}
@keyframes dec-twinkle{0%,100%{opacity:.85;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}
@media (prefers-reduced-motion:reduce){.deco-sparkle{animation:none}}

/* Hand-drawn squiggle underline (under emphasis word) */
.deco-underline{position:absolute;bottom:-2px;left:8%;right:8%;height:14px;color:var(--clay);opacity:.6;pointer-events:none}
.deco-underline svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:3;stroke-linecap:round}

/* Dotted texture background */
.deco-dots{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(currentColor 1px,transparent 1px);
  background-size:28px 28px;
  color:var(--line-strong);opacity:.45;
  -webkit-mask-image:radial-gradient(ellipse 75% 65% at 50% 50%, #000 50%, transparent 100%);
          mask-image:radial-gradient(ellipse 75% 65% at 50% 50%, #000 50%, transparent 100%);
}

/* Floating orbs / dot clusters */
.deco-orb{width:14px;height:14px;border-radius:50%;background:currentColor;opacity:.55}

/* Curved dotted arrows between How-it-works steps */
.steps{position:relative}
.deco-arrow{position:absolute;top:38px;width:90px;height:30px;opacity:.55;pointer-events:none}
.deco-arrow svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-dasharray:3 5}
.steps .step:nth-child(1) .deco-arrow{right:-58px;color:var(--sage-deep)}
.steps .step:nth-child(2) .deco-arrow{right:-58px;color:var(--dusk-deep)}
@media (max-width:980px){.deco-arrow{display:none}}

/* Big stylized open-quote glyph */
.quote .deco-quote{
  display:block;font-family:'Fraunces',serif;font-style:italic;
  font-variation-settings:"opsz" 144,"SOFT" 100;
  font-size:160px;line-height:.55;
  color:var(--clay);opacity:.45;
  margin:0 auto 8px;letter-spacing:-.05em;
  user-select:none
}

/* Soft halo behind the hero canvas */
.canvas-wrap{position:relative}
.canvas-halo{position:absolute;inset:-30px;border-radius:36px;background:radial-gradient(closest-side,var(--blush-tint),transparent 70%);filter:blur(24px);opacity:.55;z-index:-1;pointer-events:none}

/* "Made by humans" pill */
.deco-tag{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:11.5px;font-weight:500;letter-spacing:.06em;color:var(--ink-2);text-transform:uppercase;box-shadow:0 4px 14px -8px rgba(29,42,60,.18)}
.deco-tag .heart{width:11px;height:11px;color:var(--blush);display:inline-flex}
.deco-tag .heart svg{width:100%;height:100%;fill:currentColor}

/* =====================================================
   Responsive — mobile-first overrides for medium ↓
   Breakpoints: 1180 (large), 1024 (tablet landscape),
                820 (tablet portrait), 640 (phone), 420 (small phone)
   ===================================================== */

/* Large desktop tweaks (≤1180) */
@media (max-width:1180px){
  .container{padding:0 24px}
  nav.links{gap:18px;font-size:14px}
  h1.display{font-size:72px}
}

/* Tablet landscape (≤1024) */
@media (max-width:1024px){
  nav.links{gap:14px;font-size:13.5px}
  .nav-cta .btn-soft{display:none}             /* keep only primary CTA */
  h1.display{font-size:60px}
  h2.section-title{font-size:46px}
  .hero{padding:60px 0 80px}
  .hero-grid{gap:40px}
  .tools-head{flex-direction:column;align-items:flex-start}
  .split{padding:48px}
  .gdpr{padding:44px}
  .cta-card{padding:60px 36px}
  .foot-grid{grid-template-columns:1.4fr repeat(4,1fr);gap:28px}
  .foot-grid .foot-col:nth-child(6){grid-column:1/-1;display:flex;flex-direction:row;flex-wrap:wrap;gap:24px;padding-top:18px;border-top:1px solid var(--line)}
  .foot-grid .foot-col:nth-child(6) h6{flex:1 0 100%}
}

/* Tablet portrait → mobile (≤820) */
@media (max-width:820px){
  .container{padding:0 20px}
  /* ── Mobile nav: hide desktop links, show hamburger ── */
  nav.links{display:none}
  .mob-toggle{display:inline-flex}
  .nav-row{padding:18px 0;gap:12px}
  .nav-cta{gap:8px}
  .nav-cta .btn{padding:10px 14px;font-size:13.5px}

  /* ── Headlines ── */
  h1.display{font-size:48px;line-height:1.02}
  .page-hero h1{font-size:40px}
  h2.section-title{font-size:38px}
  .gdpr h2{font-size:32px}
  .cta-card h2{font-size:34px}
  .split h2{font-size:34px}
  .quote blockquote{font-size:24px}

  /* ── Hero ── */
  .hero{padding:32px 0 56px}
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .canvas{padding:18px}
  .row-result{grid-template-columns:1.4fr .8fr 1fr 24px;font-size:13px;padding:9px 12px}

  /* ── Section spacing ── */
  section{padding:64px 0}
  section.cta{padding:64px 0}

  /* ── Multi-col grids collapse ── */
  .tools-grid{grid-template-columns:1fr;gap:14px}
  .tool{grid-column:span 12;min-height:auto;padding:24px}
  .steps,.cases-grid,.blog-grid,.feature-grid,.plan-grid{grid-template-columns:1fr;gap:14px}
  .split,.gdpr,.price-wrap,.duo,.contact-grid{grid-template-columns:1fr;padding:32px;gap:28px}
  .split{padding:32px}
  .duo.reverse > div:first-child{order:0}
  .stats-grid{grid-template-columns:1fr 1fr;gap:0;padding:22px 0}
  .stat{border-right:none;border-bottom:1px solid var(--line);padding:18px 16px}
  .stat:nth-child(2){border-right:1px solid var(--line)}
  .stat:nth-child(2n){border-right:none}
  .stat:nth-last-child(-n+2){border-bottom:none}

  /* ── Footer ── */
  .foot-cta{padding:44px 0}
  .foot-cta-inner{flex-direction:column;align-items:flex-start;gap:22px}
  .foot-cta h3{font-size:30px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px;padding:48px 0 24px}
  .foot-brand{grid-column:1/-1}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:14px}

  /* ── GDPR badges single-col ── */
  .gdpr .badges{grid-template-columns:1fr}

  /* ── Forms ── */
  .form-grid{grid-template-columns:1fr}
  .contact-card{padding:24px}
}

/* Phone (≤640) */
@media (max-width:640px){
  .container{padding:0 16px}
  h1.display{font-size:40px}
  .page-hero h1{font-size:32px}
  h2.section-title{font-size:30px}
  .gdpr h2,.split h2,.cta-card h2{font-size:28px}
  p.section-lede,.lede{font-size:16px}
  .stats-grid{grid-template-columns:1fr}
  .stat{border-right:none !important;border-bottom:1px solid var(--line);padding:16px 0}
  .stat:last-child{border-bottom:none}
  .foot-grid{grid-template-columns:1fr;gap:28px}
  .foot-brand{grid-column:auto}
  .hero-cta{flex-direction:column;align-items:stretch;width:100%}
  .hero-cta .btn{width:100%;justify-content:center}
  .pill{font-size:12px;padding:6px 10px}
  .canvas{padding:16px}
  .chip{font-size:11.5px;padding:5px 9px}
  .row-result{grid-template-columns:1fr 60px 24px;font-size:12.5px;padding:9px 10px;gap:8px}
  .row-result .num{display:none}
  .foot-news-input{flex-direction:column;align-items:stretch}
  .foot-news-input .input{max-width:none}
  .foot-news-input .btn{width:100%;justify-content:center}
}

/* Small phone (≤420) */
@media (max-width:420px){
  .container{padding:0 14px}
  h1.display{font-size:34px}
  .page-hero h1{font-size:28px}
  h2.section-title{font-size:26px}
  .brand-mark{width:30px;height:30px}
  .nav-cta .btn{padding:9px 12px;font-size:13px}
  .nav-cta .btn .arr{display:none}
  .mega,.mega.two-col{min-width:auto;padding:16px}
}

/* ── Mobile drawer (collapsed nav links) ── */
.mob-toggle{display:none;background:transparent;border:none;cursor:pointer;color:var(--ink);padding:8px;border-radius:10px;transition:background .2s}
.mob-toggle:hover{background:var(--cream-2)}
.mob-toggle svg{width:22px;height:22px;display:block}

/* When drawer is open, show the menu pinned below the header */
@media (max-width:820px){
  body.nav-open{overflow:hidden}
  body.nav-open nav.links{
    display:flex;flex-direction:column;align-items:stretch;
    position:fixed;top:60px;left:0;right:0;bottom:0;
    background:var(--cream);padding:24px 22px;gap:6px;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    border-top:1px solid var(--line);z-index:55
  }
  body.nav-open nav.links > a,
  body.nav-open nav.links .has-menu{
    width:100%;padding:14px 4px;font-size:16px;border-bottom:1px solid var(--line)
  }
  body.nav-open nav.links .has-menu > a::before{display:none}
  /* On mobile, the "mega" panel sits inline below its trigger (no positioning) */
  body.nav-open .mega{
    position:static;transform:none;opacity:1;visibility:visible;
    box-shadow:none;border:none;padding:8px 0 16px;background:transparent;
    grid-template-columns:1fr;min-width:0;border-radius:0
  }
  body.nav-open .mega-featured{display:none}
  body.nav-open .has-menu::after{display:none}
}

/* =====================================================
   Cross-browser polish
   ===================================================== */

/* Safari: details/summary cursor */
.faq-item summary{-webkit-appearance:none;appearance:none}

/* Safari/Firefox: scroll-snap not used, but smooth scroll */
@supports not (scroll-behavior: smooth){
  html{scroll-behavior:auto}
}

/* iOS form inputs reset */
.input,.textarea,select.input{
  -webkit-appearance:none;appearance:none;
  -webkit-tap-highlight-color:transparent
}

/* Prevent horizontal scroll on small screens caused by absolute blobs */
body{overflow-x:hidden}
.hero,.page-hero,.cta-card,.foot-cta{position:relative}

/* Older Safari: backdrop-filter fallback */
@supports not ((backdrop-filter:blur(12px)) or (-webkit-backdrop-filter:blur(12px))){
  header.nav{background:rgba(245,248,252,.95)}
}
@supports ((backdrop-filter:blur(12px)) or (-webkit-backdrop-filter:blur(12px))){
  header.nav{-webkit-backdrop-filter:saturate(140%) blur(12px)}
}

/* Older browsers: gap on flex */
@supports not (gap:10px){
  .hero-cta > * + *{margin-left:10px}
}

/* Reduce motion respect (covers parallax + transforms).
   Brand-mark wave is exempt — it's a small, slow heartbeat indicator. */
@media (prefers-reduced-motion:reduce){
  *:not(.brand-mark):not(.brand-mark::before),*::before:not(.brand-mark::before),*::after{
    animation-duration:.001s !important;
    animation-iteration-count:1 !important;
    transition-duration:.001s !important;
    scroll-behavior:auto !important
  }
  .brand-mark::before{
    animation:brand-wave 1.8s cubic-bezier(.4,0,.2,1) infinite !important
  }
}

/* High-DPI smoothing */
@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){
  html,body{-webkit-font-smoothing:antialiased}
}
