/* ═══════════════════════════════════════════════════════
   DictDrop — Design System
   Dark premium · Developer-first · Animated
   ═══════════════════════════════════════════════════════ */

/* ── Tokens ──────────────────────────────────────────── */
:root {
  --bg:          #060610;
  --bg-2:        #0c0c1d;
  --bg-3:        #111128;
  --bg-card:     rgba(255,255,255,.035);
  --bg-card-h:   rgba(255,255,255,.06);
  --border:      rgba(255,255,255,.07);
  --border-2:    rgba(255,255,255,.13);
  --border-acc:  rgba(99,102,241,.4);

  --text-1:  #f0f2ff;
  --text-2:  #8b92b8;
  --text-3:  #484f74;

  --indigo:  #6366f1;
  --purple:  #a855f7;
  --cyan:    #22d3ee;
  --green:   #4ade80;

  --grad-btn:  linear-gradient(135deg,#6366f1 0%,#a855f7 100%);
  --grad-text: linear-gradient(135deg,#c7d2fe 0%,#a5b4fc 35%,#c084fc 65%,#67e8f9 100%);
  --grad-hero: radial-gradient(ellipse at 50% 0%,rgba(99,102,241,.18) 0%,transparent 65%);

  --shadow-card: 0 4px 24px rgba(0,0,0,.5);
  --shadow-btn:  0 0 28px rgba(99,102,241,.5);
  --shadow-btn-h:0 0 48px rgba(168,85,247,.65);

  --radius:    10px;
  --radius-lg: 16px;
  --radius-xl: 24px;

  --nav-h: 68px;
  --font: 'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --mono: 'SFMono-Regular',Consolas,Menlo,monospace;
  --max-w: 1140px;
  --max-w-md: 800px;
  --max-w-sm: 640px;
}

[data-theme="light"] {
  --bg:       #fafafa;
  --bg-2:     #f3f4f6;
  --bg-3:     #e9eaf0;
  --bg-card:  #ffffff;
  --bg-card-h:#f5f5ff;
  --border:   #e5e7eb;
  --border-2: #d1d5db;
  --border-acc:rgba(99,102,241,.3);
  --text-1:  #111827;
  --text-2:  #374151;
  --text-3:  #6b7280;
  --grad-text: linear-gradient(135deg,#4338ca 0%,#7c3aed 50%,#0891b2 100%);
  --grad-hero: radial-gradient(ellipse at 50% 0%,rgba(99,102,241,.1) 0%,transparent 60%);
  --shadow-card: 0 4px 24px rgba(0,0,0,.08);
}

/* ── Reset ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--text-1);
  font-family:var(--font);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .25s,color .25s;
}
img,video{max-width:100%;display:block}
a{color:var(--indigo);text-decoration:none}
a:hover{color:var(--text-1)}
ul,ol{list-style:none}
button{cursor:pointer;font-family:var(--font)}
strong{font-weight:600;color:var(--text-1)}

/* ── Layout ──────────────────────────────────────────── */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px}
.container--md{max-width:var(--max-w-md)}
.container--sm{max-width:var(--max-w-sm)}
.container--center{text-align:center}
.section{padding:100px 0}
.section--alt{background:var(--bg-2)}
.section--dark{background:var(--bg-3)}

/* ── Typography helpers ──────────────────────────────── */
.gradient-text{
  background:var(--grad-text);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--indigo);
  margin-bottom:20px;
}
.eyebrow__dot{
  width:6px;height:6px;
  border-radius:50%;
  background:var(--indigo);
  animation:pulse-dot 2s ease infinite;
}
.section__label{
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--text-3);
  text-align:center;
  margin-bottom:14px;
}
.section__title{
  font-size:clamp(1.75rem,3.2vw,2.4rem);
  font-weight:800;
  letter-spacing:-.03em;
  color:var(--text-1);
  text-align:center;
  line-height:1.15;
  margin-bottom:14px;
}
.section__sub{
  text-align:center;
  color:var(--text-2);
  font-size:1.05rem;
  max-width:560px;
  margin:0 auto 56px;
  line-height:1.7;
}

/* ── Keyframes ───────────────────────────────────────── */
@keyframes orb-a{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(50px,-40px) scale(1.06)}
  66%{transform:translate(-30px,50px) scale(.94)}
}
@keyframes orb-b{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(-60px,30px) scale(1.08)}
  66%{transform:translate(40px,-60px) scale(.93)}
}
@keyframes orb-c{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(30px,30px) scale(1.1)}
}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
@keyframes pulse-dot{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(.7)}
}
@keyframes shimmer{
  0%{background-position:200% center}
  100%{background-position:-200% center}
}
@keyframes cursor-blink{
  0%,100%{opacity:1}50%{opacity:0}
}
@keyframes badge-in{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes spin{
  to{transform:rotate(360deg)}
}
@keyframes count-up{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

/* ── Scroll reveal ───────────────────────────────────── */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);
  transition-delay:var(--d,0s);
}
.reveal.in-view{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);transition-delay:var(--d,0s)}
.reveal-left.in-view{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);transition-delay:var(--d,0s)}
.reveal-right.in-view{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .55s cubic-bezier(.22,1,.36,1),transform .55s cubic-bezier(.22,1,.36,1);transition-delay:var(--d,0s)}
.reveal-scale.in-view{opacity:1;transform:scale(1)}

/* ── Buttons ─────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font);font-weight:600;
  text-decoration:none;border:none;
  border-radius:var(--radius);
  cursor:pointer;
  transition:transform .18s ease,box-shadow .22s ease,background .2s ease;
  line-height:1.3;white-space:nowrap;
}
.btn--glow{
  background:var(--grad-btn);
  color:#fff;
  box-shadow:var(--shadow-btn);
  padding:15px 32px;font-size:1rem;
}
.btn--glow:hover{
  box-shadow:var(--shadow-btn-h);
  transform:translateY(-2px);
  color:#fff;
}
.btn--glow:active{transform:translateY(0)}
.btn--sm{padding:10px 20px;font-size:.875rem}
.btn--lg{padding:17px 38px;font-size:1.05rem}
.btn--xl{padding:20px 48px;font-size:1.15rem;border-radius:var(--radius-lg)}
.btn--ghost{
  background:transparent;
  border:1px solid var(--border-2);
  color:var(--text-2);
  padding:10px 20px;font-size:.875rem;
}
.btn--ghost:hover{border-color:var(--indigo);color:var(--indigo)}
.btn--full{width:100%;display:flex}

/* ── Navigation ──────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:200;
  height:var(--nav-h);
  background:rgba(6,6,16,.8);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:box-shadow .2s,border-color .2s;
}
[data-theme="light"] .nav{background:rgba(250,250,250,.85)}
.nav--scrolled{box-shadow:0 1px 0 var(--border),0 8px 32px rgba(0,0,0,.2)}
.nav__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px;
  gap:20px;
}
.nav__logo{
  display:flex;align-items:center;gap:10px;
  font-size:1.15rem;font-weight:800;letter-spacing:-.03em;
  color:var(--text-1);text-decoration:none;flex-shrink:0;
}
.nav__logo:hover{color:var(--text-1)}
.nav__logo-icon{
  width:32px;height:32px;
  background:var(--grad-btn);
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1rem;
  box-shadow:0 0 16px rgba(99,102,241,.4);
  flex-shrink:0;
}
.nav__links{
  display:flex;align-items:center;gap:4px;
}
.nav__link{
  padding:7px 14px;
  font-size:.9rem;font-weight:500;
  color:var(--text-2);
  border-radius:var(--radius);
  transition:color .15s,background .15s;
  text-decoration:none;
}
.nav__link:hover{color:var(--text-1);background:rgba(255,255,255,.05)}
.nav__link--active{color:var(--text-1);background:rgba(99,102,241,.12)}
[data-theme="light"] .nav__link:hover{background:rgba(0,0,0,.05)}
[data-theme="light"] .nav__link--active{background:rgba(99,102,241,.1)}
.nav__right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav__theme{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;
  background:transparent;border:1px solid var(--border);
  border-radius:var(--radius);color:var(--text-2);
  transition:background .15s,border-color .15s,color .15s;
}
.nav__theme:hover{background:var(--bg-card-h);border-color:var(--border-2);color:var(--text-1)}
.nav__theme svg{width:17px;height:17px}
.icon-sun{display:none}.icon-moon{display:block}
[data-theme="light"] .icon-sun{display:block}[data-theme="light"] .icon-moon{display:none}

/* Mobile nav */
.nav__burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:38px;height:38px;background:transparent;border:1px solid var(--border);
  border-radius:var(--radius);padding:8px;
}
.nav__burger span{
  display:block;width:100%;height:1.5px;background:var(--text-2);
  border-radius:2px;transition:transform .25s ease,opacity .2s ease;
}
.nav--open .nav__burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav--open .nav__burger span:nth-child(2){opacity:0}
.nav--open .nav__burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav__mobile{
  display:none;
  position:fixed;inset:0;top:var(--nav-h);
  background:var(--bg);
  flex-direction:column;padding:24px;gap:4px;z-index:190;
  border-top:1px solid var(--border);
  animation:fade-in .2s ease;
}
@keyframes fade-in{from{opacity:0}to{opacity:1}}
.nav--open .nav__mobile{display:flex}
.nav__mobile .nav__link{font-size:1.1rem;padding:14px 16px}
.nav__mobile .btn--glow{margin-top:12px;justify-content:center}

@media(max-width:660px){
  .nav__links{display:none}
  .nav__right .btn--glow{display:none}
  .nav__burger{display:flex}
}

/* ── Hero ────────────────────────────────────────────── */
.hero{
  position:relative;overflow:hidden;
  padding:120px 0 100px;
  background:var(--bg);
  text-align:center;
}
.hero__orbs{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero__orb{position:absolute;border-radius:50%;filter:blur(80px)}
.hero__orb--1{
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(99,102,241,.28) 0%,transparent 70%);
  top:-200px;right:-100px;
  animation:orb-a 12s ease-in-out infinite;
}
.hero__orb--2{
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(168,85,247,.22) 0%,transparent 70%);
  bottom:-100px;left:-80px;
  animation:orb-b 14s ease-in-out infinite;
}
.hero__orb--3{
  width:350px;height:350px;
  background:radial-gradient(circle,rgba(34,211,238,.14) 0%,transparent 70%);
  top:40%;left:35%;
  animation:orb-c 10s ease-in-out infinite;
}
.hero__inner{position:relative;z-index:1}
.hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(99,102,241,.12);
  border:1px solid rgba(99,102,241,.3);
  color:#a5b4fc;
  font-size:.78rem;font-weight:600;letter-spacing:.06em;
  padding:6px 16px;border-radius:99px;
  margin-bottom:28px;
}
.hero__badge-dot{
  width:6px;height:6px;border-radius:50%;
  background:#6366f1;
  animation:pulse-dot 2s ease infinite;
}
.hero__h1{
  font-size:clamp(2.6rem,6vw,4.8rem);
  font-weight:900;
  letter-spacing:-.04em;
  line-height:1.08;
  color:var(--text-1);
  margin-bottom:12px;
}
.hero__h1 .gradient-text{
  display:block;
}
.hero__tagline{
  font-size:clamp(1rem,2.2vw,1.3rem);
  color:var(--text-2);
  max-width:600px;
  margin:0 auto 40px;
  line-height:1.65;
  font-weight:400;
}
.hero__cta{display:flex;flex-direction:column;align-items:center;gap:14px}
.hero__cta-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center}
.hero__note{
  font-size:.8rem;color:var(--text-3);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center;
}
.hero__note-sep{color:var(--border-2)}
.hero__trust{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;
  margin-top:10px;
}
.trust-item{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.76rem;color:var(--text-3);
}
.trust-item svg{color:var(--text-3)}

/* ── Stats strip ─────────────────────────────────────── */
.stats{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:44px 0;
}
.stats__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  max-width:700px;margin:0 auto;
  text-align:center;
}
.stat{padding:8px 24px}
.stat+.stat{border-left:1px solid var(--border)}
.stat__num{
  font-size:clamp(2rem,4vw,2.8rem);
  font-weight:900;letter-spacing:-.04em;
  background:var(--grad-text);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.1;margin-bottom:4px;
}
.stat__label{font-size:.82rem;color:var(--text-3);font-weight:500}

@media(max-width:480px){
  .stats__grid{grid-template-columns:1fr;gap:24px}
  .stat+.stat{border-left:none;border-top:1px solid var(--border)}
}

/* ── Hero terminal demo ──────────────────────────────── */
.hero__demo{
  margin:64px auto 0;
  max-width:600px;
  animation:float 5s ease-in-out infinite;
}
.demo-terminal{
  background:#080812;
  border:1px solid rgba(99,102,241,.25);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 0 0 1px rgba(79,70,229,.06),0 16px 60px rgba(0,0,0,.7),0 0 120px rgba(79,70,229,.08);
  font-family:var(--mono);font-size:.85rem;text-align:left;
}
[data-theme="light"] .demo-terminal{background:#1e1e2e;border-color:rgba(99,102,241,.4)}
.demo-terminal__bar{
  display:flex;align-items:center;gap:6px;
  padding:11px 16px;
  background:rgba(255,255,255,.025);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.demo-terminal__dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.demo-terminal__dot:nth-child(1){background:#ff5f57}
.demo-terminal__dot:nth-child(2){background:#ffbd2e}
.demo-terminal__dot:nth-child(3){background:#28ca41}
.demo-terminal__title{
  margin-left:10px;font-size:.72rem;
  color:rgba(255,255,255,.25);
  font-family:var(--font);flex:1;text-align:center;
}
.demo-terminal__body{padding:18px 22px 26px;min-height:100px}
.demo-line{line-height:1.8;color:rgba(255,255,255,.4);font-size:.82rem}
.demo-line--sys{color:rgba(255,255,255,.18);font-size:.74rem;margin-bottom:6px}
.demo-line--prompt{color:rgba(255,255,255,.88)}
.demo-prompt-sym{color:#818cf8;margin-right:7px}
.demo-cursor{
  display:inline-block;width:2px;height:.9em;
  background:#818cf8;vertical-align:text-bottom;
  margin-left:1px;animation:cursor-blink 1s step-end infinite;
}
#demo-badge-wrap{margin-top:12px}
.demo-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 13px;border-radius:99px;
  font-size:.74rem;font-family:var(--font);font-weight:600;
}
.demo-badge--ok{
  background:rgba(74,222,128,.12);
  border:1px solid rgba(74,222,128,.22);
  color:#4ade80;
  animation:badge-in .3s ease;
}

/* ── Gap grid (problem section) ──────────────────────── */
.gap-grid{margin:52px 0 32px;display:flex;flex-direction:column;gap:32px}
.gap-row{display:flex;flex-direction:column;gap:14px}
@media(min-width:680px){.gap-row{flex-direction:row;align-items:flex-start;gap:32px}}
.gap-row__label{
  flex-shrink:0;width:168px;
  font-size:.73rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding-top:8px;display:flex;align-items:center;gap:7px;line-height:1.4;
}
.gap-row__label--none{color:#f87171}
.gap-row__label--broken{color:#fbbf24}
[data-theme="light"] .gap-row__label--none{color:#dc2626}
[data-theme="light"] .gap-row__label--broken{color:#b45309}
.gap-row__icon{font-size:.95rem;flex-shrink:0}
.gap-row__tools{display:flex;flex-wrap:wrap;gap:8px;flex:1}
.tool-chip{
  display:inline-flex;align-items:center;padding:6px 15px;
  border-radius:99px;font-size:.82rem;font-weight:500;white-space:nowrap;
  transition:transform .15s ease;
}
.tool-chip:hover{transform:translateY(-2px)}
.tool-chip--none{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:#fca5a5}
.tool-chip--broken{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);color:#fcd34d}
[data-theme="light"] .tool-chip--none{background:rgba(239,68,68,.06);border-color:rgba(220,38,38,.25);color:#dc2626}
[data-theme="light"] .tool-chip--broken{background:rgba(245,158,11,.06);border-color:rgba(180,83,9,.25);color:#b45309}

.gap-solution{
  background:var(--bg-card);border:1px solid var(--border-acc);
  border-radius:var(--radius-xl);padding:3px;position:relative;overflow:hidden;
}
.gap-solution::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(99,102,241,.1) 0%,transparent 50%,rgba(74,222,128,.06) 100%);
  pointer-events:none;
}
.gap-solution__inner{
  background:var(--bg-card);border-radius:calc(var(--radius-xl) - 3px);
  padding:48px 40px;text-align:center;position:relative;
}
.gap-solution__badge{
  display:inline-block;
  background:rgba(74,222,128,.12);border:1px solid rgba(74,222,128,.25);
  color:#4ade80;font-size:.74rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  padding:5px 14px;border-radius:99px;margin-bottom:20px;
}
[data-theme="light"] .gap-solution__badge{background:rgba(21,128,61,.08);border-color:rgba(21,128,61,.2);color:#15803d}
.gap-solution__title{font-size:clamp(1.3rem,2.5vw,1.7rem);font-weight:800;letter-spacing:-.025em;color:var(--text-1);margin-bottom:14px;line-height:1.3}
.gap-solution__body{max-width:520px;margin:0 auto 28px;color:var(--text-2);font-size:.97rem;line-height:1.75}
.gap-solution__footer{display:flex;flex-direction:column;align-items:center;gap:14px}
@media(min-width:500px){.gap-solution__footer{flex-direction:row;justify-content:center;gap:24px}}
.gap-solution__price{font-size:1rem;font-weight:700;color:var(--indigo);margin:0}

/* ── App compat ──────────────────────────────────────── */
.app-compat{
  padding:60px 0;
  background:var(--bg-2);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  text-align:center;
}
.app-compat__label{font-size:.72rem;text-transform:uppercase;letter-spacing:.09em;color:var(--text-3);margin-bottom:10px}
.app-compat__sub{font-size:.95rem;color:var(--text-2);max-width:400px;margin:0 auto 36px;line-height:1.65}
.app-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:12px;max-width:580px;margin:0 auto;
}
.app-card{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:20px 10px;
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);
  transition:border-color .2s,background .2s,transform .2s;
  cursor:default;
}
.app-card:hover{border-color:var(--border-acc);background:var(--bg-card-h);transform:translateY(-3px)}
.app-icon{filter:brightness(0) invert(1);opacity:.65;transition:opacity .2s;flex-shrink:0}
[data-theme="light"] .app-icon{filter:none;opacity:1}
.app-card:hover .app-icon{opacity:1}
.app-name{font-size:.7rem;font-weight:600;color:var(--text-2);text-align:center;line-height:1.3}
.app-compat__also{margin:40px 0 12px;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3)}
.app-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:7px;max-width:640px;margin:0 auto}
.app-chip{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.8rem;color:var(--text-3);padding:5px 14px;
  background:var(--bg-card);border:1px solid var(--border);border-radius:99px;white-space:nowrap;
}
.app-chip__icon{filter:brightness(0) invert(1);opacity:.5;flex-shrink:0}
[data-theme="light"] .app-chip__icon{filter:none;opacity:.7}
.app-compat__disclaimer{margin-top:28px;font-size:.68rem;color:var(--text-3);opacity:.5}
@media(max-width:480px){.app-grid{grid-template-columns:repeat(2,1fr);max-width:300px}}

/* ── How it works ────────────────────────────────────── */
.steps{display:grid;gap:28px}
@media(min-width:700px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{
  display:flex;gap:18px;align-items:flex-start;
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:28px;transition:border-color .2s,transform .2s;
}
.step:hover{border-color:var(--border-acc);transform:translateY(-4px)}
.step__num{
  flex-shrink:0;width:38px;height:38px;border-radius:50%;
  background:var(--grad-btn);color:#fff;font-size:.95rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 14px rgba(99,102,241,.45);
}
.step__title{font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:7px;line-height:1.3}
.step p{font-size:.9rem;color:var(--text-2);line-height:1.7}

/* ── Features grid ───────────────────────────────────── */
.features{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:540px){.features{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.features{grid-template-columns:repeat(3,1fr)}}
.feature{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:28px;
  transition:border-color .2s,background .2s,transform .2s;
  cursor:default;
}
.feature:hover{border-color:var(--border-acc);background:var(--bg-card-h);transform:translateY(-4px)}
.feature__icon{
  width:44px;height:44px;border-radius:var(--radius);
  background:rgba(99,102,241,.12);border:1px solid rgba(99,102,241,.2);
  display:flex;align-items:center;justify-content:center;
  color:var(--indigo);margin-bottom:16px;font-size:1.25rem;
}
.feature__tag{font-size:.875rem;font-weight:700;color:var(--text-1);margin-bottom:8px;line-height:1.4}
.feature p{font-size:.88rem;color:var(--text-2);line-height:1.7}

/* ── Privacy flow ────────────────────────────────────── */
.flow{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:14px;margin:44px 0 36px;
}
.flow__node{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:18px 28px;text-align:center;
  display:flex;flex-direction:column;gap:4px;
  transition:border-color .2s;
}
.flow__node:hover{border-color:var(--border-2)}
.flow__node strong{font-size:1rem;font-weight:700}
.flow__node span{font-size:.8rem;color:var(--text-3)}
.flow__node--highlight{border-color:var(--indigo);background:rgba(99,102,241,.07)}
.flow__node--highlight strong{color:var(--indigo)}
.flow__arrow{font-size:1.5rem;color:var(--text-3);flex-shrink:0}
.privacy-note{
  max-width:600px;margin:0 auto 32px;text-align:center;
  color:var(--text-2);font-size:.95rem;line-height:1.75;
}
.checklist{display:flex;flex-direction:column;gap:11px;max-width:440px;margin:0 auto}
.checklist li{display:flex;align-items:center;gap:11px;font-size:.9rem;color:var(--text-2)}
.checklist li::before{
  content:'';flex-shrink:0;width:20px;height:20px;
  background:rgba(74,222,128,.1);border:1px solid rgba(74,222,128,.25);border-radius:50%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%234ade80' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}

/* ── Testimonials ────────────────────────────────────── */
.testimonial-grid{display:grid;gap:20px;grid-template-columns:1fr}
@media(min-width:620px){.testimonial-grid{grid-template-columns:repeat(2,1fr)}}
.testimonial-card{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:30px;display:flex;flex-direction:column;gap:18px;
  transition:border-color .2s,transform .2s;
}
.testimonial-card:hover{border-color:var(--border-acc);transform:translateY(-4px)}
.testimonial-stars{color:#fbbf24;font-size:1rem;letter-spacing:.06em;line-height:1}
.testimonial-quote{font-size:.93rem;color:var(--text-2);line-height:1.78;flex:1;margin:0}
.testimonial-meta{display:flex;flex-direction:column;gap:2px;padding-top:6px;border-top:1px solid var(--border)}
.testimonial-name{font-size:.875rem;font-weight:700;color:var(--text-1)}
.testimonial-role{font-size:.8rem;color:var(--text-3)}

/* ── Pricing ─────────────────────────────────────────── */
.pricing-layout{display:grid;gap:36px;align-items:start}
@media(min-width:880px){.pricing-layout{grid-template-columns:340px 1fr}}
.pricing-card{
  background:var(--bg-card);border:1px solid var(--border-acc);
  border-radius:var(--radius-xl);padding:36px;
  box-shadow:0 0 48px rgba(99,102,241,.12);
  position:relative;overflow:hidden;
}
.pricing-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(99,102,241,.06) 0%,transparent 60%);
  pointer-events:none;
}
.pricing-card__badge{
  display:inline-block;
  background:var(--grad-btn);color:#fff;
  font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 12px;border-radius:99px;margin-bottom:20px;
}
.pricing-card__name{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--indigo);margin-bottom:12px}
.pricing-card__price{font-size:3.4rem;font-weight:900;letter-spacing:-.05em;color:var(--text-1);line-height:1}
.pricing-card__period{font-size:.88rem;color:var(--text-3);margin-top:4px;margin-bottom:26px}
.pricing-card__list{margin-bottom:28px;display:flex;flex-direction:column;gap:12px}
.pricing-card__list li{display:flex;align-items:center;gap:11px;font-size:.9rem;color:var(--text-2)}
.pricing-card__list li::before{
  content:'';flex-shrink:0;width:18px;height:18px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%234ade80' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}
.pricing-card__note{margin-top:14px;font-size:.8rem;color:var(--text-3);text-align:center}

/* compare table */
.compare{align-self:center}
.compare__title{font-size:1rem;font-weight:700;color:var(--text-2);margin-bottom:18px}
.compare__wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.compare__table{width:100%;border-collapse:collapse;font-size:.88rem;min-width:420px}
.compare__table th,.compare__table td{padding:11px 15px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}
.compare__table thead th{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);padding-bottom:10px}
.compare__table tbody th{font-weight:400;color:var(--text-2)}
.compare__table tbody td{color:var(--text-2)}
.compare__savit{background:rgba(99,102,241,.07);font-weight:700;color:var(--text-1)!important}
.compare__good{color:var(--green)!important}
.compare__footnote{margin-top:10px;font-size:.75rem;color:var(--text-3);line-height:1.6}

/* ── FAQ ─────────────────────────────────────────────── */
.faq{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.faq__item{border-bottom:1px solid var(--border)}
.faq__item:last-child{border-bottom:none}
.faq__q{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:20px 24px;background:var(--bg-card);border:none;
  color:var(--text-1);font-family:var(--font);font-size:.95rem;font-weight:500;
  text-align:left;cursor:pointer;transition:background .15s;
}
.faq__q:hover{background:var(--bg-card-h)}
.faq__icon{flex-shrink:0;width:20px;height:20px;position:relative;transition:transform .25s}
.faq__icon::before,.faq__icon::after{content:'';position:absolute;background:var(--text-3);border-radius:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq__icon::before{width:12px;height:1.5px}
.faq__icon::after{width:1.5px;height:12px;transition:transform .25s ease,opacity .25s ease}
.faq__q[aria-expanded="true"] .faq__icon::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq__a{padding:0 24px;overflow:hidden;max-height:0;transition:max-height .3s ease,padding .3s ease}
.faq__a:not([hidden]){max-height:500px;padding:4px 24px 20px}
.faq__a p{font-size:.9rem;color:var(--text-2);line-height:1.78}
.faq__a a{color:var(--indigo)}
.faq__a a:hover{color:var(--text-1)}

/* ── Origin callout ──────────────────────────────────── */
.origin-callout{background:rgba(99,102,241,.06);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.origin-quote{margin:0;padding:0;text-align:center}
.origin-quote p{font-size:clamp(1.05rem,2vw,1.25rem);font-style:italic;color:var(--text-1);line-height:1.7;margin-bottom:16px}
.origin-quote footer{font-size:.9rem;color:var(--text-2);font-style:normal}

/* ── Trust badges ────────────────────────────────────── */
.trust-row{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:18px}
.trust-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.76rem;color:var(--text-3);
  background:var(--bg-card);border:1px solid var(--border);border-radius:99px;padding:5px 13px;white-space:nowrap;
}
.trust-badge svg{flex-shrink:0;color:var(--text-3)}

/* ── Email capture ───────────────────────────────────── */
.email-capture{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.email-capture__title{font-size:clamp(1.45rem,2.5vw,1.9rem);font-weight:800;letter-spacing:-.02em;color:var(--text-1);margin-bottom:10px}
.email-capture__sub{color:var(--text-2);font-size:.95rem;max-width:480px;margin:0 auto 28px;line-height:1.7}
.email-form__row{display:flex;gap:8px;max-width:420px;margin:0 auto}
.email-form__input{
  flex:1;padding:13px 17px;background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--radius);
  color:var(--text-1);font-family:var(--font);font-size:.9rem;outline:none;
  transition:border-color .15s,box-shadow .15s;min-width:0;
}
.email-form__input::placeholder{color:var(--text-3)}
.email-form__input:focus{border-color:var(--indigo);box-shadow:0 0 0 3px rgba(99,102,241,.15)}
.email-form__btn{padding:13px 22px;font-size:.9rem;white-space:nowrap;flex-shrink:0}
.email-form__msg{margin-top:12px;font-size:.85rem;text-align:center}
.email-form__msg--ok{color:var(--green)}
.email-form__msg--error{color:#f87171}
@media(max-width:420px){.email-form__row{flex-direction:column}.email-form__btn{width:100%}}

/* ── CTA section ─────────────────────────────────────── */
.cta-section{position:relative;overflow:hidden;text-align:center}
.cta-section__inner{position:relative;z-index:1}
.cta-section__title{font-size:clamp(1.7rem,3.5vw,2.6rem);font-weight:900;letter-spacing:-.03em;color:var(--text-1);margin-bottom:14px;line-height:1.15}
.cta-section__sub{color:var(--text-2);font-size:1rem;margin-bottom:36px;line-height:1.7;max-width:600px;margin-left:auto;margin-right:auto;margin-bottom:36px}
.cta-section__note{margin-top:20px;font-size:.82rem;color:var(--text-3)}

/* ── Footer ──────────────────────────────────────────── */
.footer{padding:40px 0;border-top:1px solid var(--border)}
.footer__inner{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:32px;
  max-width:var(--max-w);margin:0 auto;padding:0 24px;
}
.footer__brand{}
.footer__logo{font-size:1.1rem;font-weight:800;letter-spacing:-.03em;color:var(--text-1);display:flex;align-items:center;gap:8px;margin-bottom:8px}
.footer__logo-icon{width:26px;height:26px;background:var(--grad-btn);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem;flex-shrink:0}
.footer__tagline{font-size:.82rem;color:var(--text-3);line-height:1.6}
.footer__col-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:14px}
.footer__links{display:flex;flex-direction:column;gap:8px}
.footer__link{font-size:.88rem;color:var(--text-2);text-decoration:none;transition:color .15s}
.footer__link:hover{color:var(--text-1)}
.footer__bottom{
  margin-top:36px;padding-top:24px;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
  max-width:var(--max-w);margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px;
}
.footer__copy{font-size:.8rem;color:var(--text-3)}
.footer__bottom-links{display:flex;gap:20px}
.footer__bottom-links a{font-size:.8rem;color:var(--text-3)}
.footer__bottom-links a:hover{color:var(--text-2)}
@media(max-width:680px){
  .footer__inner{grid-template-columns:1fr;gap:28px}
  .footer__bottom{flex-direction:column;text-align:center}
}

/* ── Page hero (inner pages) ─────────────────────────── */
.page-hero{
  position:relative;overflow:hidden;
  padding:88px 0 72px;text-align:center;
  background:var(--bg);
}
.page-hero__orbs{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.page-hero__orb{position:absolute;border-radius:50%;filter:blur(70px)}
.page-hero__orb--1{width:500px;height:500px;background:radial-gradient(circle,rgba(99,102,241,.22) 0%,transparent 70%);top:-150px;right:-50px;animation:orb-a 14s ease-in-out infinite}
.page-hero__orb--2{width:400px;height:400px;background:radial-gradient(circle,rgba(168,85,247,.16) 0%,transparent 70%);bottom:-50px;left:-60px;animation:orb-b 16s ease-in-out infinite}
.page-hero__inner{position:relative;z-index:1}
.page-hero__h1{font-size:clamp(2rem,4vw,3.4rem);font-weight:900;letter-spacing:-.04em;line-height:1.1;color:var(--text-1);margin-bottom:14px}
.page-hero__sub{font-size:clamp(.95rem,2vw,1.15rem);color:var(--text-2);max-width:560px;margin:0 auto;line-height:1.65}

/* ── Feature deep-dive cards ─────────────────────────── */
.feature-row{
  display:grid;gap:60px;align-items:center;
}
@media(min-width:760px){.feature-row{grid-template-columns:1fr 1fr}}
.feature-row--flip{}
@media(min-width:760px){.feature-row--flip .feature-row__visual{order:-1}}
.feature-row__label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--indigo);margin-bottom:10px}
.feature-row__h{font-size:clamp(1.4rem,2.5vw,2rem);font-weight:800;letter-spacing:-.02em;color:var(--text-1);margin-bottom:12px;line-height:1.2}
.feature-row__p{color:var(--text-2);line-height:1.75;font-size:.97rem;margin-bottom:14px}
.feature-row__visual{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);
  padding:36px 32px;min-height:200px;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.feature-row__visual::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(99,102,241,.07) 0%,transparent 60%);
  pointer-events:none;
}
.visual-icon{font-size:4rem;line-height:1;text-align:center}
.visual-code{
  font-family:var(--mono);font-size:.82rem;color:rgba(255,255,255,.75);
  background:rgba(0,0,0,.4);border-radius:var(--radius);padding:18px 20px;
  width:100%;position:relative;z-index:1;
}
.visual-code__line{line-height:1.9}
.visual-code__k{color:#818cf8}
.visual-code__s{color:#4ade80}
.visual-code__c{color:rgba(255,255,255,.28)}

/* ── Pricing page extras ─────────────────────────────── */
.pricing-cta-note{font-size:.85rem;color:var(--text-3);margin-top:16px;text-align:center}
.faq-grid{display:grid;gap:16px;grid-template-columns:1fr}
@media(min-width:700px){.faq-grid{grid-template-columns:repeat(2,1fr)}}
.faq-item-simple{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.faq-item-simple h3{font-size:.95rem;font-weight:700;color:var(--text-1);margin-bottom:8px}
.faq-item-simple p{font-size:.88rem;color:var(--text-2);line-height:1.7}

/* ── About extras ────────────────────────────────────── */
.about-stack{display:grid;gap:16px;grid-template-columns:1fr}
@media(min-width:620px){.about-stack{grid-template-columns:repeat(2,1fr)}}
.stack-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:border-color .2s}
.stack-card:hover{border-color:var(--border-acc)}
.stack-card__label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-3);margin-bottom:6px}
.stack-card__name{font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:4px}
.stack-card p{font-size:.85rem;color:var(--text-2);line-height:1.65}

/* ── Kbd ─────────────────────────────────────────────── */
kbd{
  display:inline-block;padding:2px 7px;background:var(--bg-card);
  border:1px solid var(--border-2);border-radius:5px;
  font-family:var(--font);font-size:.85em;color:var(--text-2);
}

/* ── Responsive misc ─────────────────────────────────── */
@media(max-width:600px){
  .hero{padding:80px 0 70px}
  .section{padding:70px 0}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .btn,.faq__a,.faq__icon::after,.demo-cursor{transition:none}
  .demo-cursor,.hero__orb,.hero__demo,
  .hero__orb--1,.hero__orb--2,.hero__orb--3,
  .page-hero__orb--1,.page-hero__orb--2{animation:none}
  .reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none;transition:none}
}

/* ── Homepage additions ───────────────────────────────── */
.hero__sub-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.78rem;color:var(--text-3);
  margin-bottom:18px;
}
.hero__sub-badge span{color:var(--text-2)}

.problem-cols{display:grid;gap:18px;margin-bottom:36px}
@media(min-width:700px){.problem-cols{grid-template-columns:1fr 1fr}}
.problem-col{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.problem-col__label{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.problem-col--none .problem-col__label{color:#f87171}
.problem-col--broken .problem-col__label{color:#fbbf24}
.problem-col__tools{display:flex;flex-direction:column;gap:7px}
.ptool{display:flex;align-items:center;gap:9px;font-size:.875rem;color:var(--text-2)}
.ptool::before{content:'';flex-shrink:0;width:6px;height:6px;border-radius:50%}
.problem-col--none .ptool::before{background:#f87171}
.problem-col--broken .ptool::before{background:#fbbf24}

.tool-compat-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));margin-bottom:16px}
.tool-compat-card{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 14px;display:flex;flex-direction:column;gap:6px;
  transition:border-color .2s,transform .2s;
}
.tool-compat-card:hover{border-color:var(--border-acc);transform:translateY(-3px)}
.tool-compat-card__name{font-size:.88rem;font-weight:700;color:var(--text-1)}
.tool-compat-card__type{font-size:.72rem;color:var(--text-3)}
.also-works{display:flex;flex-wrap:wrap;gap:7px;margin-top:24px}

.install-steps{display:flex;flex-direction:column;gap:0;position:relative}
.install-steps::before{
  content:'';position:absolute;left:22px;top:44px;bottom:44px;
  width:1px;background:var(--border);
}
@media(max-width:599px){.install-steps::before{display:none}}
.install-step{display:flex;gap:22px;align-items:flex-start;padding:32px 0}
.install-step+.install-step{border-top:1px solid var(--border)}
.install-step__num{
  flex-shrink:0;width:44px;height:44px;border-radius:50%;
  background:var(--grad-btn);color:#fff;font-size:1rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-btn);z-index:1;
}
.install-step__title{font-size:1.05rem;font-weight:700;color:var(--text-1);margin-bottom:8px;line-height:1.3}
.install-step p{font-size:.92rem;color:var(--text-2);line-height:1.75}

.priv-flow{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;
  margin:44px 0 36px;
}
.priv-node{
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:20px 22px;text-align:center;min-width:140px;
}
.priv-node--accent{border-color:var(--indigo);background:rgba(99,102,241,.06)}
.priv-node strong{display:block;font-size:.95rem;font-weight:700;color:var(--text-1);margin-bottom:4px}
.priv-node span{font-size:.78rem;color:var(--text-3)}
.priv-node--accent strong{color:var(--indigo)}
.priv-arrow{padding:0 12px;font-size:1.4rem;color:var(--text-3);flex-shrink:0}

.compare-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:var(--radius-lg)}
.compare-table{width:100%;border-collapse:collapse;font-size:.88rem;min-width:580px}
.compare-table th,.compare-table td{padding:13px 18px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}
.compare-table tbody tr:last-child td,.compare-table tbody tr:last-child th{border-bottom:none}
.compare-table thead th{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);background:var(--bg-card)}
.compare-table thead th:first-child{border-radius:var(--radius-lg) 0 0 0}
.compare-table thead th:last-child{border-radius:0 var(--radius-lg) 0 0}
.compare-table tbody th{font-weight:500;color:var(--text-2);background:transparent}
.compare-table .col-us{background:rgba(99,102,241,.06);font-weight:700;color:var(--text-1)!important}
.compare-table .good{color:var(--green)}
.compare-table .bad{color:#f87171}
.compare-table .neutral{color:var(--text-3)}
.compare-footnote{margin-top:12px;font-size:.74rem;color:var(--text-3);line-height:1.65}
.compare-footnote a{color:var(--indigo)}

.faq-full .faq__q{font-size:.92rem}

.guarantee{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.2);
  border-radius:var(--radius-lg);padding:14px 22px;
  font-size:.88rem;color:var(--text-2);margin-top:16px;
}
.guarantee__icon{font-size:1.4rem;flex-shrink:0}

.origin-blockquote{
  background:var(--bg-card);border-left:3px solid var(--indigo);
  border-radius:0 var(--radius-lg) var(--radius-lg) 0;
  padding:28px 32px;margin:48px 0 0;
  max-width:680px;
}
.origin-blockquote p{font-size:1.02rem;font-style:italic;color:var(--text-1);line-height:1.75;margin-bottom:12px}
.origin-blockquote footer{font-size:.85rem;color:var(--text-3);font-style:normal}

/* ── Legal pages ─────────────────────────────────────── */
.legal-page{padding:60px 0 80px}
.legal-page h1{font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}
.legal-page .updated{font-size:.85rem;color:var(--text-3);margin-bottom:48px}
.legal-page h2{font-size:1.1rem;font-weight:600;color:var(--text-1);margin:36px 0 12px}
.legal-page p{color:var(--text-2);font-size:.95rem;line-height:1.8;margin-bottom:14px}
.legal-page ul{margin:10px 0 14px 20px;list-style:disc}
.legal-page ul li{color:var(--text-2);font-size:.95rem;line-height:1.8;margin-bottom:6px}
.legal-page .disclaimer{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin:24px 0}
.legal-page .disclaimer p{font-weight:500;color:var(--text-1);margin:0}
.legal-page .highlight-box{background:var(--green-bg,rgba(74,222,128,.08));border:1px solid rgba(74,222,128,.2);border-radius:var(--radius);padding:20px 24px;margin:24px 0}
.legal-page .highlight-box p{color:var(--text-1);font-weight:500;margin:0}
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-3);font-size:.875rem;text-decoration:none;margin-bottom:36px}
.back-link:hover{color:var(--text-2)}
hr.legal-rule{border:none;border-top:1px solid var(--border);margin:40px 0}
.flow-text{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;font-family:var(--font);font-size:.9rem;color:var(--text-2);margin:16px 0;text-align:center}
