/* =========================================================================
   Brand tokens. Accent = the one colour that themes the whole site.
   Change --accent here (and BRAND in app.js) to rebrand the entire page.
   ========================================================================= */
:root {
  --accent: #7c5cff;          /* primary violet */
  --accent-2: #a78bff;        /* lighter violet */
  --accent-3: #2bd4c0;        /* teal sweep (in the gradient ring) */
  --accent-glow: rgba(124, 92, 255, 0.55);

  --bg: #07070b;
  --bg-2: #0c0c12;
  --ink: #f4f3fb;
  --ink-soft: #b9b8c9;
  --ink-mute: #76758c;
  --line: rgba(255, 255, 255, 0.09);
  --line-2: rgba(255, 255, 255, 0.06);
  --card: rgba(255, 255, 255, 0.035);
  --card-2: rgba(255, 255, 255, 0.05);
  --radius: 18px;
  --radius-lg: 26px;
  --maxw: 1140px;
  --grad: linear-gradient(100deg, var(--accent), var(--accent-2) 55%, var(--accent-3));
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

/* ============================ ambient background ======================== */
.bg { position: fixed; inset: 0; z-index: -1; overflow: hidden; background:
    radial-gradient(1200px 800px at 70% -10%, rgba(124,92,255,0.10), transparent 60%),
    radial-gradient(900px 700px at 10% 10%, rgba(43,212,192,0.06), transparent 55%),
    var(--bg); }
.glow { position: absolute; border-radius: 50%; filter: blur(120px); opacity: 0.6; }
.glow-1 { width: 620px; height: 620px; top: -160px; right: -120px; background: radial-gradient(circle, var(--accent-glow), transparent 70%); animation: float1 18s ease-in-out infinite; }
.glow-2 { width: 540px; height: 540px; top: 480px; left: -180px; background: radial-gradient(circle, rgba(43,212,192,0.35), transparent 70%); animation: float2 22s ease-in-out infinite; }
@keyframes float1 { 50% { transform: translate(-40px, 60px); } }
@keyframes float2 { 50% { transform: translate(50px, -40px); } }
.grid-lines { position: absolute; inset: 0; background-image:
    linear-gradient(var(--line-2) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-2) 1px, transparent 1px);
  background-size: 64px 64px; mask-image: radial-gradient(circle at 50% 0%, #000 0%, transparent 70%); opacity: 0.5; }
.grain { position: absolute; inset: 0; opacity: 0.025; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
@media (prefers-reduced-motion: reduce) { .glow { animation: none; } }

/* ================================ nav =================================== */
.nav { position: sticky; top: 0; z-index: 50; transition: background .3s, border-color .3s, backdrop-filter .3s; border-bottom: 1px solid transparent; }
.nav.scrolled { background: rgba(8,8,13,0.72); backdrop-filter: saturate(160%) blur(18px); border-bottom-color: var(--line); }
.nav-in { display: flex; align-items: center; gap: 28px; height: 68px; }
.brand { display: flex; align-items: center; gap: 11px; font-weight: 700; font-size: 18px; letter-spacing: -0.02em; }
.brand-mark { width: 26px; height: 26px; border-radius: 9px; background: var(--grad); box-shadow: 0 0 22px var(--accent-glow); position: relative; }
.brand-mark::after { content: ""; position: absolute; inset: 6px; border-radius: 4px; background: var(--bg); }
.brand-name { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
/* the stylised dot in the wordmark — logo reads "siftlr." (only on the logo, not in body text) */
.brand-name::after { content: "."; }
.nav-links { display: flex; align-items: center; gap: 26px; margin-left: 8px; font-size: 14.5px; color: var(--ink-soft); }
.nav-links a { transition: color .2s; }
.nav-links a:hover { color: var(--ink); }
/* nav dropdowns (desktop = hover, mobile = inline groups) */
.nav-item { position: relative; display: inline-flex; align-items: center; }
.nav-top { display: inline-flex; align-items: center; gap: 4px; background: none; border: 0; padding: 0; margin: 0; font: inherit; font-size: 14.5px; color: var(--ink-soft); cursor: pointer; transition: color .2s; }
.nav-item:hover .nav-top, .nav-item.open .nav-top { color: var(--ink); }
.nav-chev { width: 15px; height: 15px; opacity: .65; transition: transform .2s; }
.nav-item:hover .nav-chev, .nav-item.open .nav-chev { transform: rotate(180deg); }
.nav-drop { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(6px); min-width: 188px; display: flex; flex-direction: column; gap: 2px; margin-top: 12px; padding: 8px; border-radius: 14px; background: rgba(12,12,18,0.98); border: 1px solid var(--line); box-shadow: 0 22px 54px -22px rgba(0,0,0,0.75); opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .16s, transform .16s, visibility .16s; z-index: 60; }
.nav-drop::before { content: ""; position: absolute; left: 0; right: 0; top: -14px; height: 16px; } /* hover bridge across the gap */
.nav-item:hover .nav-drop, .nav-item.open .nav-drop { opacity: 1; visibility: visible; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.nav-drop a { padding: 9px 12px; border-radius: 9px; font-size: 14px; color: var(--ink-soft); white-space: nowrap; }
.nav-drop a:hover { background: var(--card-2); color: var(--ink); }
.nav-cta { margin-left: auto; display: flex; gap: 10px; align-items: center; }
/* mobile hamburger — hidden on desktop, shown < 900px */
.nav-burger { display: none; width: 42px; height: 42px; flex-direction: column; align-items: center; justify-content: center; gap: 5px; border: 1px solid var(--line); border-radius: 11px; background: var(--card-2); cursor: pointer; flex: 0 0 auto; }
.nav-burger span { width: 18px; height: 2px; border-radius: 2px; background: var(--ink); transition: transform .22s ease, opacity .18s ease; }
.nav.open .nav-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav.open .nav-burger span:nth-child(2) { opacity: 0; }
.nav.open .nav-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
/* Higher specificity than .btn so it stays hidden on desktop (only the dropdown shows it on mobile). */
.nav-links a.nav-menu-cta { display: none; } /* only appears inside the mobile dropdown */

/* ================================ buttons =============================== */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-weight: 600; font-size: 14.5px; padding: 10px 18px; border-radius: 999px; border: 1px solid transparent; cursor: pointer; transition: transform .15s ease, box-shadow .25s, background .2s, border-color .2s; white-space: nowrap; }
.btn:active { transform: translateY(1px) scale(0.99); }
.btn-primary { background: linear-gradient(110deg, var(--accent) 0%, var(--accent-2) 42%, var(--accent-3) 66%, var(--accent-2) 88%, var(--accent) 100%); background-size: 210% 100%; color: #fff; box-shadow: 0 8px 30px rgba(124,92,255,0.35); animation: btnFlow 10s ease-in-out infinite; }
@keyframes btnFlow { 0%, 100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
@media (prefers-reduced-motion: reduce) { .btn-primary { animation: none; background: linear-gradient(120deg, var(--accent), var(--accent-2)); } }
.btn-primary:hover { box-shadow: 0 10px 40px rgba(124,92,255,0.5); transform: translateY(-1px); }
.btn-ghost { background: var(--card-2); color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { background: rgba(255,255,255,0.09); border-color: rgba(255,255,255,0.18); }
.btn-lg { padding: 14px 26px; font-size: 15.5px; }
.btn.full { width: 100%; }

/* language switcher (flag dropdown) */
.lang-toggle { display: none; } /* the bare button is replaced by the dropdown via i18n.js */
.lang-select { position: relative; }
.lang-trigger { display: inline-flex; align-items: center; gap: 7px; background: var(--card-2); border: 1px solid var(--line); color: var(--ink-soft); font: inherit; font-size: 13px; font-weight: 700; letter-spacing: .03em; padding: 7px 11px; border-radius: 999px; cursor: pointer; transition: background .2s, color .2s, border-color .2s; }
.lang-trigger:hover { color: var(--ink); border-color: rgba(255,255,255,.2); background: rgba(255,255,255,.09); }
.lang-flag { display: inline-flex; }
.lang-flag svg { width: 20px; height: 13px; border-radius: 3px; display: block; box-shadow: inset 0 0 0 1px rgba(255,255,255,.14); }
.lang-chev { width: 14px; height: 14px; opacity: .6; transition: transform .2s; }
.lang-select.open .lang-chev { transform: rotate(180deg); }
.lang-menu { position: absolute; right: 0; top: calc(100% + 8px); min-width: 172px; padding: 6px; border: 1px solid var(--line); border-radius: 13px; background: rgba(14,14,20,.97); backdrop-filter: blur(14px); box-shadow: 0 22px 55px rgba(0,0,0,.55); opacity: 0; transform: translateY(-6px); pointer-events: none; transition: opacity .18s ease, transform .18s ease; z-index: 60; }
.lang-select.open .lang-menu { opacity: 1; transform: none; pointer-events: auto; }
.lang-opt { display: flex; align-items: center; gap: 10px; width: 100%; background: transparent; border: 0; color: var(--ink-soft); font: inherit; font-size: 14px; font-weight: 600; padding: 9px 10px; border-radius: 9px; cursor: pointer; text-align: left; transition: background .15s, color .15s; }
.lang-opt:hover { background: rgba(255,255,255,.07); color: var(--ink); }
.lang-opt.active { color: var(--ink); }
.lang-opt.active::after { content: ""; margin-left: auto; width: 15px; height: 15px; background: var(--accent-2); -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat; }

/* ================================ hero ================================== */
.hero { padding: 86px 0 40px; text-align: center; position: relative; overflow: hidden; }
.hero-in { display: flex; flex-direction: column; align-items: center; position: relative; z-index: 1; }
/* Lightweight code-based "aurora" behind the hero — replaces the video: ~0 weight, perfectly
   smooth, no loop seam. Two slow-drifting blurred colour fields in the brand palette. */
.hero-aurora { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none;
  -webkit-mask-image: radial-gradient(125% 95% at 50% 30%, #000 30%, transparent 82%);
  mask-image: radial-gradient(125% 95% at 50% 30%, #000 30%, transparent 82%); }
.hero-aurora::before, .hero-aurora::after { content: ""; position: absolute; border-radius: 50%; filter: blur(72px); will-change: transform; }
.hero-aurora::before { width: 62vw; height: 62vw; left: 6%; top: -16%; opacity: .5;
  background: radial-gradient(circle, rgba(124,92,255,.6), rgba(167,139,255,.18) 45%, transparent 66%);
  animation: heroAurora1 30s ease-in-out infinite; }
.hero-aurora::after { width: 54vw; height: 54vw; right: 4%; top: -4%; opacity: .42;
  background: radial-gradient(circle, rgba(43,212,192,.5), transparent 62%);
  animation: heroAurora2 38s ease-in-out infinite; }
@keyframes heroAurora1 { 0%,100% { transform: translate3d(0,0,0) scale(1); } 50% { transform: translate3d(10%,7%,0) scale(1.14); } }
@keyframes heroAurora2 { 0%,100% { transform: translate3d(0,0,0) scale(1.06); } 50% { transform: translate3d(-9%,5%,0) scale(.9); } }
@media (prefers-reduced-motion: reduce) { .hero-aurora::before, .hero-aurora::after { animation: none; } }
.pill { display: inline-flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 600; color: var(--ink-soft); padding: 7px 15px; border: 1px solid var(--line); border-radius: 999px; background: var(--card); backdrop-filter: blur(8px); }
.pulse { width: 7px; height: 7px; border-radius: 50%; background: var(--accent-3); box-shadow: 0 0 0 0 rgba(43,212,192,0.6); animation: pulse 2s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(43,212,192,0.6);} 70% { box-shadow: 0 0 0 8px rgba(43,212,192,0);} 100% { box-shadow: 0 0 0 0 rgba(43,212,192,0);} }
.hero h1 { font-size: clamp(42px, 7vw, 86px); line-height: 0.98; letter-spacing: -0.04em; font-weight: 800; margin: 26px 0 0; }
.grad { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.lede { max-width: 620px; margin: 24px 0 0; font-size: clamp(16px, 2vw, 19px); color: var(--ink-soft); }
.hero-cta { display: flex; gap: 13px; margin-top: 34px; flex-wrap: wrap; justify-content: center; }

/* live demo stage */
.demo-stage { width: 100%; max-width: 760px; margin: 60px auto 0; }
.searchbar { position: relative; display: flex; align-items: center; gap: 12px; padding: 16px 16px 16px 22px; border-radius: 16px; background: rgba(16,16,24,0.85); border: 1.5px solid transparent; backdrop-filter: blur(10px); box-shadow: 0 20px 60px rgba(0,0,0,0.45); text-align: left; }
.searchbar::before { content: ""; position: absolute; inset: 0; border-radius: 16px; padding: 1.6px; pointer-events: none;
  background: linear-gradient(90deg, var(--accent), var(--accent-2), var(--accent-3), var(--accent)); background-size: 300% 100%;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude;
  animation: laser 5s linear infinite; }
@keyframes laser { to { background-position: 300% 0; } }
.search-ic { color: var(--accent-2); display: grid; place-items: center; flex-shrink: 0; }
.search-text { flex: 1; font-size: 17px; color: var(--ink); min-height: 22px; }
.caret { width: 2px; height: 20px; background: var(--accent-2); margin-left: -10px; animation: blink 1s step-end infinite; }
@keyframes blink { 50% { opacity: 0; } }
.ai-toggle { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--accent-2); flex-shrink: 0; }
.ai-dot { width: 34px; height: 20px; border-radius: 999px; background: var(--accent); position: relative; box-shadow: 0 0 14px var(--accent-glow); }
.ai-dot::after { content: ""; position: absolute; top: 2px; right: 2px; width: 16px; height: 16px; border-radius: 50%; background: #fff; }

.answer { position: relative; margin-top: 16px; text-align: left; border: 1px solid var(--line); border-radius: 18px; background: var(--card); backdrop-filter: blur(12px); padding: 22px; opacity: 0; transform: translateY(12px); transition: opacity .5s, transform .5s; }
.answer.show { opacity: 1; transform: none; }
.answer-head { display: flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 600; color: var(--ink-mute); margin-bottom: 12px; }
.spark { width: 16px; height: 16px; background: var(--grad); border-radius: 5px; box-shadow: 0 0 14px var(--accent-glow); flex: 0 0 auto; }
.answer-cart { margin-left: auto; display: inline-flex; align-items: center; gap: 7px; color: var(--ink-soft); }
.cart-badge { min-width: 18px; height: 18px; padding: 0 5px; border-radius: 999px; background: var(--accent); color: #fff; font-size: 11px; font-weight: 700; display: inline-grid; place-items: center; transition: transform .2s; }
.cart-badge.bump { transform: scale(1.45); }
.answer-body { font-size: 15.5px; color: var(--ink-soft); min-height: 44px; }

.answer-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 18px; }
.acard { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: 14px; padding: 10px; background: var(--card-2); opacity: 0; transform: translateY(10px); transition: opacity .4s, transform .4s; }
.acard.show { opacity: 1; transform: none; }
.acard-photo { height: 70px; border-radius: 9px; display: grid; place-items: center; color: #fff; margin-bottom: 9px; background: linear-gradient(135deg, var(--p1, rgba(124,92,255,.5)), var(--p2, rgba(43,212,192,.4))); }
.acard-photo svg { width: 30px; height: 30px; }
.acard-cat { font-size: 9.5px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--accent-2); margin-bottom: 3px; }
.acard .nm { font-size: 12.5px; font-weight: 600; line-height: 1.25; }
.acard .pr { font-size: 13px; color: var(--ink); font-weight: 700; margin-top: 4px; }
.acard-add { margin-top: 9px; border: 1px solid var(--line); background: rgba(255,255,255,.05); color: var(--ink); font: inherit; font-size: 11px; font-weight: 600; padding: 7px 6px; border-radius: 9px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 5px; transition: background .2s, border-color .2s, color .2s; }
.acard-add svg { width: 13px; height: 13px; flex: 0 0 auto; }
.acard-add.added { background: var(--accent); border-color: transparent; color: #fff; }

.answer-total { margin-top: 16px; display: flex; align-items: center; justify-content: space-between; font-size: 14px; color: var(--ink-soft); opacity: 0; transition: opacity .4s; }
.answer-total.show { opacity: 1; }
.answer-total b { font-size: 18px; font-weight: 800; background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.answer-total .ok { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--accent-3); font-weight: 600; }
.answer-total .ok svg { width: 14px; height: 14px; }
/* "Add the whole set at once" button in the demo (mirrors the widget's routine button). */
.answer-addall { margin-top: 12px; width: 100%; display: inline-flex; align-items: center; justify-content: center; gap: 8px; border: 0; border-radius: 12px; background: var(--grad); color: #fff; font: inherit; font-weight: 700; font-size: 13.5px; padding: 12px; cursor: pointer; opacity: 0; transform: translateY(8px); transition: opacity .4s, transform .4s, filter .15s; }
.answer-addall.show { opacity: 1; transform: none; }
.answer-addall:hover { filter: brightness(1.08); }
.answer-addall svg { width: 16px; height: 16px; flex: 0 0 auto; }
.answer-addall.done { background: rgba(43,212,192,.16); color: var(--accent-3); }

.demo-cursor { position: absolute; left: 24px; top: 65%; width: 26px; height: 26px; pointer-events: none; opacity: 0; z-index: 6; filter: drop-shadow(0 4px 9px rgba(0,0,0,.55)); transition: left .85s cubic-bezier(.45,.5,.2,1), top .85s cubic-bezier(.45,.5,.2,1), opacity .3s ease, transform .12s ease; }
.demo-cursor.show { opacity: 1; }
.demo-cursor.click { transform: scale(.78); }

.logos { display: flex; align-items: center; gap: 12px; margin-top: 54px; font-size: 13.5px; color: var(--ink-mute); flex-wrap: wrap; justify-content: center; }
.logos b { color: var(--ink-soft); font-weight: 600; }
.logos i { opacity: 0.4; font-style: normal; }

/* ============================== sections =============================== */
.section { padding: 96px 0; position: relative; }
.sec-head { max-width: 660px; margin: 0 0 52px; }
.sec-head.center, .center { text-align: center; margin-left: auto; margin-right: auto; }
.eyebrow { display: inline-block; font-size: 13px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent-2); margin-bottom: 14px; }
.eyebrow.center { display: block; }
h2 { font-size: clamp(28px, 4.4vw, 46px); line-height: 1.05; letter-spacing: -0.03em; font-weight: 800; }
h3 { font-size: 19px; letter-spacing: -0.02em; font-weight: 700; }

/* steps */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.step { border: 1px solid var(--line); border-radius: var(--radius); padding: 30px; background: var(--card); position: relative; overflow: hidden; }
.step::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: 0; transition: opacity .3s; }
.step:hover::before { opacity: 0.8; }
.step-n { font-size: 13px; font-weight: 700; color: var(--accent-2); letter-spacing: 0.1em; margin-bottom: 16px; }
.step h3 { margin-bottom: 9px; }
.step p { color: var(--ink-soft); font-size: 15px; }

/* bento */
.bento { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.tile { border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 28px; background: var(--card); transition: transform .3s, border-color .3s, background .3s; position: relative; overflow: hidden; }
.tile:hover { transform: translateY(-4px); border-color: rgba(255,255,255,0.16); background: var(--card-2); }
.tile-lg { grid-column: span 2; }
.tile-tag { font-size: 12.5px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--accent-2); margin-bottom: 14px; }
.tile h3 { margin-bottom: 9px; font-size: 21px; }
.tile p { color: var(--ink-soft); font-size: 15px; max-width: 460px; }
.tile-visual { margin-top: 22px; }
.combo { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.chip { padding: 9px 15px; border-radius: 11px; background: var(--card-2); border: 1px solid var(--line); font-size: 13.5px; font-weight: 600; }
.plus { color: var(--accent-2); font-weight: 700; }
.total { margin-left: auto; font-weight: 800; font-size: 20px; background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.stats { display: flex; gap: 28px; }
.ministat b { display: block; font-size: 26px; font-weight: 800; letter-spacing: -0.02em; }
.ministat span { font-size: 13px; color: var(--ink-mute); }

/* results */
.results-card { border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 64px 40px; background:
    radial-gradient(600px 300px at 50% 0%, rgba(124,92,255,0.12), transparent 70%), var(--card); text-align: center; }
.results-card h2 { max-width: 640px; margin: 0 auto; }
.big-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin: 52px 0 24px; }
.bs-num { font-size: clamp(40px, 6vw, 64px); font-weight: 800; letter-spacing: -0.04em; line-height: 1; }
.bs-lab { color: var(--ink-soft); font-size: 14.5px; margin-top: 12px; max-width: 220px; margin-left: auto; margin-right: auto; }
.disclaimer { font-size: 13px; color: var(--ink-mute); margin-top: 16px; }

/* pricing */
.sec-sub { color: var(--ink-soft); font-size: 16px; margin-top: 14px; }
.billing-toggle { display: inline-flex; gap: 4px; margin-top: 26px; padding: 5px; border: 1px solid var(--line); border-radius: 999px; background: var(--card); backdrop-filter: blur(8px); }
.bt-opt { background: transparent; border: 0; color: var(--ink-soft); font: inherit; font-size: 14px; font-weight: 600; padding: 9px 18px; border-radius: 999px; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; transition: background .25s, color .2s; }
.bt-opt.on { background: var(--grad); color: #fff; }
.save { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 999px; background: rgba(43,212,192,0.18); color: var(--accent-3); }
.bt-opt.on .save { background: rgba(255,255,255,0.22); color: #fff; }
.roi-note { text-align: center; margin: 36px auto 0; color: var(--ink-soft); font-size: 15px; max-width: 580px; }
.plans { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: stretch; }
.plan { border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 32px; background: var(--card); position: relative; transition: transform .3s, border-color .3s; display: flex; flex-direction: column; }
.plan a.btn { margin-top: auto; }
.plan:hover { transform: translateY(-4px); }
.plan-feat { border-color: rgba(124,92,255,0.5); background:
    radial-gradient(400px 240px at 50% 0%, rgba(124,92,255,0.16), transparent 70%), var(--card-2); box-shadow: 0 24px 70px rgba(124,92,255,0.18); }
.plan-badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--grad); color: #fff; font-size: 12px; font-weight: 700; padding: 5px 14px; border-radius: 999px; }
.plan-name { font-weight: 700; font-size: 17px; color: var(--ink-soft); }
.plan-price { font-size: 42px; font-weight: 800; letter-spacing: -0.03em; margin: 10px 0 2px; }
.plan-price b { font-weight: 800; }
.plan-price .cur { font-size: 24px; font-weight: 700; vertical-align: top; margin-right: 1px; }
.plan-price span:not(.cur) { font-size: 16px; font-weight: 500; color: var(--ink-mute); }
.plan-sub { color: var(--ink-mute); font-size: 14px; margin-bottom: 22px; }
.plan ul { list-style: none; margin-bottom: 26px; display: flex; flex-direction: column; gap: 11px; }
.plan li { font-size: 14.5px; color: var(--ink-soft); padding-left: 26px; position: relative; }
/* "Not included in this plan" — a muted grey cross instead of the gradient check. */
.plan li.no { color: var(--ink-mute); }
.plan li.no::before { background: var(--ink-mute); border-radius: 0;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='%23000' stroke-width='2.6' stroke-linecap='round' d='M7 7l10 10M17 7 7 17'/%3E%3C/svg%3E") center/contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='%23000' stroke-width='2.6' stroke-linecap='round' d='M7 7l10 10M17 7 7 17'/%3E%3C/svg%3E") center/contain no-repeat; }
.plan li::before { content: ""; position: absolute; left: 0; top: 6px; width: 15px; height: 15px; border-radius: 50%; background: var(--grad); -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat; }

/* cta */
.cta-section { padding: 60px 0 110px; }
.cta-card { position: relative; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 72px 40px; text-align: center; overflow: hidden; background:
    radial-gradient(700px 360px at 50% 120%, rgba(124,92,255,0.18), transparent 70%), var(--card-2); }
.glow-cta { position: absolute; width: 500px; height: 500px; bottom: -300px; left: 50%; transform: translateX(-50%); background: radial-gradient(circle, var(--accent-glow), transparent 70%); filter: blur(90px); opacity: 0.6; }
.cta-card h2 { max-width: 620px; margin: 0 auto; position: relative; }
.cta-card p { color: var(--ink-soft); margin: 16px auto 32px; max-width: 480px; position: relative; }
.cta-form { display: flex; gap: 11px; max-width: 480px; margin: 0 auto; position: relative; }
.cta-form input { flex: 1; padding: 14px 18px; border-radius: 999px; border: 1px solid var(--line); background: rgba(0,0,0,0.3); color: var(--ink); font-size: 15px; font-family: inherit; }
.cta-form input:focus { outline: none; border-color: var(--accent); }
.cta-form input::placeholder { color: var(--ink-mute); }
.cta-note { margin-top: 16px; font-size: 14px; color: var(--accent-3); min-height: 20px; }

/* footer */
.footer { position: relative; border-top: 0; padding: 44px 0; }
/* soft, edge-fading divider instead of a hard full-width hairline */
.footer::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.14), transparent); }
.footer-in { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.footer-links { display: flex; gap: 22px; font-size: 14px; color: var(--ink-soft); }
.footer-links a:hover { color: var(--ink); }
.footer-copy { margin-left: auto; font-size: 13px; color: var(--ink-mute); }

/* ============================ scroll reveal ============================= */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ============================ research proof =========================== */
.proofgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.proof { display: flex; flex-direction: column; gap: 12px; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 26px; background: var(--card); transition: transform .3s, border-color .3s, background .3s; }
.proof:hover { transform: translateY(-4px); border-color: rgba(255,255,255,0.18); background: var(--card-2); }
.proof-num { font-size: 40px; font-weight: 800; letter-spacing: -0.03em; line-height: 1; }
.proof-txt { font-size: 14.5px; color: var(--ink-soft); flex: 1; }
.proof-txt b { color: var(--ink); }
.proof-src { font-size: 12px; color: var(--accent-2); font-weight: 600; }
.proof-foot { text-align: center; max-width: 640px; margin: 36px auto 0; font-size: 16px; color: var(--ink-soft); }
.proof-foot b { color: var(--ink); }

/* ====================== in-store / not-a-bot =========================== */
.notbot { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; max-width: 880px; margin: 8px auto 0; }
.notbot-item { border: 1px solid var(--line); border-radius: var(--radius); padding: 24px 20px; background: var(--card); text-align: center; transition: transform .3s, border-color .3s; }
.notbot-item:hover { transform: translateY(-3px); border-color: rgba(255,255,255,0.16); }
.notbot-no { font-size: 13.5px; color: var(--ink-mute); text-decoration: line-through; text-decoration-color: rgba(255,107,139,.6); margin-bottom: 9px; }
.notbot-yes { font-size: 16.5px; font-weight: 700; letter-spacing: -0.01em; color: var(--ink); }

/* ============================ integrations ============================= */
.intgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.intcard { border: 1px solid var(--line); border-radius: var(--radius); padding: 28px 22px; background: var(--card); text-align: center; transition: transform .3s, border-color .3s; }
.intcard:hover { transform: translateY(-4px); border-color: rgba(255,255,255,0.18); }
.intcard b { display: block; font-size: 19px; letter-spacing: -0.02em; margin-bottom: 6px; }
.intcard span { font-size: 13px; color: var(--ink-mute); }
/* embeddable code snippet (integrations page) */
.embedblock { max-width: 760px; margin: 0 auto; }
.embedblock pre { background: rgba(0,0,0,0.42); border: 1px solid var(--line); border-radius: 14px; padding: 18px 20px; overflow-x: auto; margin: 0; }
.embedblock code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 13px; line-height: 1.6; color: var(--ink-soft); white-space: pre; }

/* ============================ trust / security ========================= */
.trustgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.trust { border: 1px solid var(--line); border-radius: var(--radius); padding: 26px; background: var(--card); }
.trust-ic { margin-bottom: 14px; color: var(--accent-2); }
.trust-ic svg { width: 30px; height: 30px; }
.trust h3 { font-size: 16px; margin-bottom: 7px; }
.trust p { font-size: 14px; color: var(--ink-soft); }

/* ============================ resources / posts ======================== */
.postgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.post { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 26px; background: var(--card); transition: transform .3s, border-color .3s, background .3s; }
.post:hover { transform: translateY(-4px); border-color: rgba(124,92,255,0.45); background: var(--card-2); }
.post-tag { font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--accent-2); margin-bottom: 14px; }
.post h3 { font-size: 19px; letter-spacing: -0.02em; margin-bottom: 10px; line-height: 1.2; }
.post p { font-size: 14px; color: var(--ink-soft); flex: 1; }
/* blog cover images */
.post-cover { margin: -26px -26px 18px; border-radius: var(--radius-lg) var(--radius-lg) 0 0; overflow: hidden; }
.post-cover img { width: 100%; aspect-ratio: 3/2; object-fit: cover; display: block; }
.article-cover { margin: 22px 0 6px; border-radius: 16px; overflow: hidden; border: 1px solid var(--line); }
.article-cover img { width: 100%; aspect-ratio: 3/2; object-fit: cover; display: block; }
.post-link { margin-top: 16px; font-size: 14px; font-weight: 600; color: var(--accent-2); }

/* ================================ FAQ ================================== */
.faq { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.faq details { border: 1px solid var(--line); border-radius: var(--radius); background: var(--card); padding: 4px 22px; transition: border-color .25s; }
.faq details[open] { border-color: rgba(124,92,255,0.4); background: var(--card-2); }
.faq summary { list-style: none; cursor: pointer; font-weight: 600; font-size: 16px; padding: 18px 0; display: flex; justify-content: space-between; align-items: center; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: 22px; color: var(--accent-2); font-weight: 400; transition: transform .25s; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details p { font-size: 14.5px; color: var(--ink-soft); padding: 0 0 20px; line-height: 1.6; }

/* ============================ richer footer ============================ */
.footer-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; padding: 8px 0 40px; }
.footer-brand p { color: var(--ink-mute); font-size: 14px; margin-top: 14px; max-width: 30ch; }
.footer-col h4 { font-size: 13px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 14px; }
.footer-col a { display: block; font-size: 14px; color: var(--ink-mute); margin-bottom: 10px; transition: color .2s; }
.footer-col a:hover { color: var(--ink); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap; padding-top: 26px; border-top: 1px solid var(--line); }
.footer-copy { font-size: 13px; color: var(--ink-mute); }
.footer-legal { display: flex; align-items: center; gap: 10px; font-size: 12.5px; color: var(--ink-mute); flex-wrap: wrap; }
.footer-legal a { color: var(--ink-mute); }
.footer-legal a:hover { color: var(--ink); }
.footer-legal i { opacity: .4; font-style: normal; }

/* ============================ article / blog =========================== */
.subpage { padding-top: 60px; }
.article { max-width: 720px; margin: 0 auto; padding: 0 24px; }
.article-meta { font-size: 13px; font-weight: 600; color: var(--accent-2); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 16px; }
.article h1 { font-size: clamp(32px, 5vw, 52px); line-height: 1.04; letter-spacing: -0.03em; font-weight: 800; margin-bottom: 18px; }
.article-lede { font-size: 19px; color: var(--ink-soft); margin-bottom: 14px; }
.prose { font-size: 16.5px; line-height: 1.75; color: var(--ink-soft); }
.prose h2 { font-size: 26px; letter-spacing: -0.02em; color: var(--ink); margin: 40px 0 14px; font-weight: 800; }
.prose h3 { font-size: 19px; color: var(--ink); margin: 28px 0 10px; }
.prose p { margin-bottom: 18px; }
.prose ul { margin: 0 0 18px 22px; display: flex; flex-direction: column; gap: 8px; }
.prose a { color: var(--accent-2); text-decoration: underline; text-underline-offset: 3px; }
.prose b, .prose strong { color: var(--ink); }
.prose blockquote { border-left: 3px solid var(--accent); padding: 6px 0 6px 22px; margin: 24px 0; font-size: 20px; color: var(--ink); font-weight: 500; }
.callout { border: 1px solid rgba(124,92,255,0.4); border-radius: var(--radius); background: radial-gradient(500px 200px at 80% -20%, var(--accent-soft), transparent 70%), var(--card-2); padding: 22px 24px; margin: 28px 0; font-size: 15.5px; }
.callout b { color: var(--ink); }
.sources { border-top: 1px solid var(--line); margin-top: 40px; padding-top: 22px; font-size: 13.5px; color: var(--ink-mute); }
.sources h3 { font-size: 13px; text-transform: uppercase; letter-spacing: .05em; color: var(--ink-soft); margin-bottom: 12px; }
.sources ol { margin-left: 18px; display: flex; flex-direction: column; gap: 8px; }
.sources a { color: var(--accent-2); }
.article-cta { text-align: center; margin: 56px auto 0; max-width: 720px; padding: 36px 24px; border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--card-2); }
.article-cta h3 { font-size: 22px; margin-bottom: 10px; letter-spacing: -0.02em; }
.article-cta p { color: var(--ink-soft); margin-bottom: 20px; }
.backlink { display: inline-block; margin-bottom: 24px; font-size: 14px; color: var(--accent-2); font-weight: 600; }

/* contact page */
.contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 32px; align-items: start; max-width: 960px; margin: 0 auto; }
.cform { display: flex; flex-direction: column; gap: 16px; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 28px; background: var(--card); }
.cform-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cform label { display: flex; flex-direction: column; gap: 7px; font-size: 13.5px; font-weight: 600; color: var(--ink-soft); }
.cform input, .cform textarea, .cform select { font: inherit; font-size: 15px; padding: 12px 14px; border-radius: 12px; border: 1px solid var(--line); background: rgba(0,0,0,.3); color: var(--ink); resize: vertical; }
.cform input:focus, .cform textarea:focus, .cform select:focus { outline: none; border-color: var(--accent); }
.cform select { appearance: none; -webkit-appearance: none; cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%239aa0aa' d='M1 1l5 5 5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
.cform select option { background: #14161c; color: var(--ink); }
.cta-cform { max-width: 520px; margin: 28px auto 0; text-align: left; }
.cinfo h3 { font-size: 14px; letter-spacing: .02em; margin-bottom: 8px; }
.cinfo p { font-size: 15px; color: var(--ink-soft); }
.cinfo a { color: var(--accent-2); }
.cinfo .muted2 { color: var(--ink-mute); font-size: 14px; line-height: 1.7; }

.blog-hero { text-align: center; padding: 40px 0 10px; }
.blog-hero .eyebrow { display: block; margin-bottom: 14px; }
.blog-hero h1 { font-size: clamp(36px, 6vw, 64px); letter-spacing: -0.04em; font-weight: 800; }
.blog-hero .lede { max-width: 560px; margin: 18px auto 0; color: var(--ink-soft); font-size: 18px; }

/* ============================== responsive ============================= */
@media (max-width: 900px) {
  .nav-burger { display: flex; }
  .nav-demo { display: none; } /* the demo CTA lives inside the dropdown on mobile */
  /* nav links become a full-width dropdown under the bar */
  .nav-links { position: absolute; top: 67px; left: 0; right: 0; flex-direction: column; gap: 0;
    background: #0a0a11; border-bottom: 1px solid var(--line-strong, var(--line)); padding: 6px 24px 16px;
    box-shadow: 0 24px 50px -16px rgba(0,0,0,0.8);
    opacity: 0; transform: translateY(-10px); pointer-events: none; transition: opacity .2s ease, transform .2s ease; }
  .nav.open .nav-links { opacity: 1; transform: none; pointer-events: auto; }
  .nav-links a { padding: 14px 2px; border-bottom: 1px solid var(--line-2); font-size: 16px; }
  .nav-links a.nav-menu-cta { display: flex; margin-top: 12px; padding: 13px; border-bottom: 0; justify-content: center; }
  /* dropdowns become tap-to-expand accordions on mobile (collapsed by default = clean) */
  .nav-links { align-items: stretch; } /* override desktop center → full-width left-aligned rows */
  .nav-links > a:not(.nav-menu-cta) { display: block; width: 100%; text-align: left; }
  .nav-item { display: block; width: 100%; }
  .nav-top { width: 100%; justify-content: space-between; padding: 14px 2px; border-bottom: 1px solid var(--line-2); font-size: 16px; color: var(--ink); }
  .nav-chev { display: inline-block; width: 18px; height: 18px; opacity: .8; }
  /* override ALL desktop dropdown positioning (incl. the hover transform that sticks on touch) */
  .nav-drop, .nav-item:hover .nav-drop, .nav-item.open .nav-drop { position: static; transform: none; opacity: 1; visibility: visible; pointer-events: auto; }
  .nav-drop { min-width: 0; left: auto; margin: 0; padding: 0 0 0 14px; background: none; border: 0; box-shadow: none; gap: 0; max-height: 0; overflow: hidden; transition: max-height .26s ease; }
  .nav-item.open .nav-drop { max-height: 260px; }
  .nav-drop::before { display: none; }
  .nav-drop a { padding: 12px 2px; font-size: 15px; color: var(--ink-2); border-bottom: 1px solid var(--line-2); }
  .steps, .bento, .big-stats, .plans { grid-template-columns: 1fr; }
  .tile-lg { grid-column: span 1; }
  .answer-cards { grid-template-columns: 1fr 1fr; }
  .proofgrid, .intgrid, .trustgrid, .notbot { grid-template-columns: 1fr 1fr; }
  .postgrid { grid-template-columns: 1fr; }
  .contact-grid, .cform-row { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 28px; }
  .section { padding: 64px 0; }
  .sec-head { margin: 0 0 34px; }
  .hero { padding: 64px 0 28px; }
  .demo-stage { margin-top: 44px; }
}
@media (max-width: 560px) {
  .wrap { padding: 0 18px; }
  .nav-cta .btn-ghost, .nav-demo { display: none; }
  .ai-toggle span:not(.ai-dot) { display: none; }
  .cta-form { flex-direction: column; }
  .stats { flex-wrap: wrap; gap: 18px; }
  .proofgrid, .intgrid, .trustgrid, .notbot, .footer-top { grid-template-columns: 1fr; }
  .section { padding: 52px 0; }
  .hero { padding: 48px 0 22px; }
  .hero-cta { width: 100%; }
  .hero-cta .btn { flex: 1 1 auto; }
  .answer-cards { grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 14px; }
  .acard { padding: 8px; }
  .acard-photo { height: 54px; margin-bottom: 7px; }
  .acard .nm { font-size: 12px; }
  .acard .pr { font-size: 12.5px; }
  .acard-add { font-size: 10.5px; padding: 6px 5px; }
  .answer-total { font-size: 13px; }
  .answer-total b { font-size: 16px; }
  .searchbar { padding: 12px 12px 12px 16px; gap: 8px; }
  .search-text { font-size: 15.5px; }
  .answer { padding: 16px; }
  .cta-card { padding: 48px 22px; }
  /* the simulated click-cursor can misalign on a narrow stacked layout — hide it on phones
     (the typing + answer reveal + cart bump still communicate the demo) */
  .demo-cursor { display: none !important; }
  .answer-head { flex-wrap: wrap; gap: 6px; }
  .answer-head #answerHeadLabel { font-size: 12px; line-height: 1.35; }
  .demo-stage { margin-top: 32px; }
}

/* ---- mobile performance: kill scroll jank ----------------------------- */
/* On phones, animated glows on a fixed bg + multiple backdrop-filters cause
   stuttery scrolling. Freeze the glows and drop the blur for smooth scroll. */
@media (max-width: 820px) {
  .glow { animation: none !important; filter: blur(70px); opacity: 0.32; }
  .glow-2 { display: none; }
  .nav.scrolled { backdrop-filter: none; background: rgba(8,8,13,0.94); }
  .searchbar { backdrop-filter: none; background: rgba(16,16,24,0.97); }
  .answer, .pill, .lang-menu { backdrop-filter: none; }
  .answer { background: rgba(16,16,24,0.98); }
  .pill { background: rgba(18,18,26,0.95); }
  /* Freeze the continuous decorative animations so they don't repaint during scroll (smooth scroll). */
  .hero-aurora::before, .hero-aurora::after { animation: none !important; }
  .searchbar::before { animation: none !important; }
  /* The simulated cursor animates left/top (layout) — hide it on touch to keep scroll smooth. */
  .demo-cursor { display: none !important; }
}
@media (hover: none) {
  /* touch devices: neutralise hover-lift transforms that can feel laggy */
  .tile:hover, .btn-primary:hover, .step:hover { transform: none; }
}

/* ---- pricing add-ons (features decoupled from volume) ------------------ */
.addons { margin-top: 30px; border-top: 1px solid var(--line); padding-top: 30px; }
.addons-head { text-align: center; margin-bottom: 22px; }
.addons-head .sec-sub { margin: 8px auto 0; max-width: 52ch; }
.addon-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; max-width: 760px; margin: 0 auto; }
.addon { border: 1px solid var(--line); border-radius: var(--radius-lg, 18px); padding: 22px 24px; background: var(--card);
  background-image: radial-gradient(420px 160px at 90% -30%, rgba(124,92,255,0.10), transparent 70%); }
.addon-top { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.addon-name { font-weight: 700; font-size: 17px; letter-spacing: -0.01em; }
.addon-price { font-variant-numeric: tabular-nums; color: var(--ink); white-space: nowrap; }
.addon-price .cur { color: var(--ink-soft); font-size: 14px; margin-right: 1px; }
.addon-price b { font-size: 22px; font-weight: 700; }
.addon-price span:last-child { color: var(--ink-mute); font-size: 13px; }
.addon p { color: var(--ink-soft); font-size: 14px; line-height: 1.55; margin: 0; }
@media (max-width: 640px) { .addon-grid { grid-template-columns: 1fr; } }

/* ===== shared building blocks for content pages (features/security/roadmap/cases) ===== */
.page-hero{padding:64px 0 6px;text-align:center}
.page-hero .eyebrow{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-2);
  border:1px solid var(--line);border-radius:999px;padding:5px 13px}
.page-hero h1{font-size:clamp(32px,5vw,54px);font-weight:800;letter-spacing:-.03em;margin:16px 0 0;line-height:1.05}
.page-hero .lede{max-width:600px;margin:16px auto 0;color:var(--ink-soft);font-size:clamp(16px,2vw,18px)}
.psec{padding:30px 0}
.psec h2{font-size:22px;font-weight:800;letter-spacing:-.02em;margin:0 0 4px}
.psec .sub{color:var(--ink-soft);font-size:14px;margin:0 0 20px;max-width:62ch}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pgrid.two{grid-template-columns:repeat(2,1fr)}
@media(max-width:820px){.pgrid,.pgrid.two{grid-template-columns:1fr}}
.pcard{border:1px solid var(--line);border-radius:var(--radius);padding:22px;background:var(--card);display:flex;flex-direction:column;gap:9px}
.pcard h3{font-size:17px;font-weight:700;margin:0;letter-spacing:-.01em;line-height:1.3}
.pcard p{color:var(--ink-soft);font-size:13.5px;line-height:1.55;margin:0}
.pic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-3))}
.pic svg{width:19px;height:19px}

/* alternating feature rows */
.featrow{display:grid;grid-template-columns:1fr 1fr;gap:38px;align-items:center;padding:34px 0;border-top:1px solid var(--line)}
.featrow:nth-child(even) .featrow-vis{order:-1}
@media(max-width:820px){.featrow{grid-template-columns:1fr;gap:18px}.featrow:nth-child(even) .featrow-vis{order:0}}
.featrow .eyebrow{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-2)}
.featrow h3{font-size:25px;font-weight:800;letter-spacing:-.02em;margin:8px 0 10px}
.featrow>div>p{color:var(--ink-soft);font-size:15px;line-height:1.6;margin:0 0 14px;max-width:46ch}
.featrow ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px}
.featrow li{font-size:14px;color:var(--ink);padding-left:24px;position:relative;line-height:1.45}
.featrow li::before{content:"";position:absolute;left:0;top:5px;width:13px;height:13px;border-radius:4px;background:var(--grad)}
.featrow-vis{border:1px solid var(--line);border-radius:20px;background:radial-gradient(360px 160px at 100% -20%,rgba(124,92,255,.14),transparent 70%),var(--card-2);
  min-height:210px;padding:22px;display:flex;flex-direction:column;justify-content:center;gap:12px}

/* roadmap */
.road{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.road{grid-template-columns:1fr}}
.roadcol{border:1px solid var(--line);border-radius:16px;background:var(--card);padding:6px 18px 14px}
.roadcol h3{font-size:14.5px;font-weight:800;margin:16px 0 4px;display:flex;align-items:center;gap:9px}
.rpill{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 9px;border-radius:999px}
.rpill.now{background:rgba(43,212,192,.16);color:var(--accent-3)}
.rpill.soon{background:rgba(124,92,255,.16);color:var(--accent-2)}
.rpill.later{background:rgba(255,255,255,.08);color:var(--ink-mute)}
.roaditem{font-size:13.5px;color:var(--ink-soft);padding:11px 0;border-top:1px solid var(--line);line-height:1.5}
.roaditem b{color:var(--ink);font-weight:650}

/* checklist (security/trust) */
.checklist{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:820px){.checklist{grid-template-columns:1fr}}
.check{display:flex;gap:12px;align-items:flex-start}
.check .ck{width:24px;height:24px;border-radius:50%;background:rgba(43,212,192,.16);color:var(--accent-3);display:grid;place-items:center;flex:0 0 auto;font-size:13px;font-weight:800}
.check b{font-size:14.5px}
.check span{display:block;color:var(--ink-soft);font-size:13px;margin-top:3px;line-height:1.5}
.callout{border:1px solid var(--line);border-radius:14px;background:var(--card-2);padding:18px 20px;margin-top:8px;font-size:14px;color:var(--ink-soft);line-height:1.6}
.callout b{color:var(--ink)}

/* case study */
.case{border:1px solid var(--line);border-radius:var(--radius-lg);background:radial-gradient(500px 200px at 90% -20%,rgba(124,92,255,.12),transparent 70%),var(--card-2);padding:30px;display:grid;grid-template-columns:1.3fr 1fr;gap:28px;align-items:center}
@media(max-width:820px){.case{grid-template-columns:1fr;gap:20px}}
.case .tag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--accent-3);background:rgba(43,212,192,.14);border-radius:999px;padding:4px 11px}
.case h3{font-size:24px;font-weight:800;letter-spacing:-.02em;margin:12px 0 8px}
.case p{color:var(--ink-soft);font-size:14.5px;line-height:1.6;margin:0}
.case-empty{border:1px dashed var(--line-2);border-radius:var(--radius);padding:26px;text-align:center;color:var(--ink-mute);background:rgba(255,255,255,.015)}
.case-empty b{color:var(--ink-soft);display:block;font-size:15px;margin-bottom:6px}

/* ===== interactivity polish for content pages ===== */
.pcard{transition:transform .25s ease,border-color .25s ease,background .25s ease}
.pcard:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.18);background:var(--card-2)}
.pic{transition:transform .25s ease}
.pcard:hover .pic{transform:scale(1.08) rotate(-3deg)}
.roadcol{transition:border-color .25s ease}
.roadcol:hover{border-color:rgba(255,255,255,.16)}
/* staggered cascade when a grid scrolls into view */
.pgrid > .reveal:nth-child(2){transition-delay:.07s}
.pgrid > .reveal:nth-child(3){transition-delay:.14s}
.pgrid > .reveal:nth-child(4){transition-delay:.21s}
.pgrid > .reveal:nth-child(5){transition-delay:.28s}
.pgrid > .reveal:nth-child(6){transition-delay:.35s}
.road > .reveal:nth-child(2){transition-delay:.09s}
.road > .reveal:nth-child(3){transition-delay:.18s}
/* roadmap items get a themed icon-bullet per column (no extra markup) */
.roaditem{padding-left:26px;position:relative}
.road > .roadcol:nth-child(1) .roaditem::before{content:"✓";position:absolute;left:2px;color:var(--accent-3);font-weight:800;font-size:12px}
.road > .roadcol:nth-child(2) .roaditem::before{content:"→";position:absolute;left:2px;color:var(--accent-2);font-weight:800}
.road > .roadcol:nth-child(3) .roaditem::before{content:"○";position:absolute;left:3px;top:11px;color:var(--ink-mute);font-size:10px}
