/* ============================================================================
   LOKAL — "Midnight Terminal" art direction.
   Near-black canvas · volt signal (#CBF74A) · forged Bricolage display · mono numbers.
   A real-estate market-intelligence product, not a Canva template.
   Motion is bulletproof: every reveal has a visible final state without JS, and
   all motion is gated behind prefers-reduced-motion.
   ========================================================================== */

:root{
  /* surfaces */
  --ink:#0B0E12;
  --ink-2:#12161C;
  --ink-3:#191F27;
  --ink-4:#232B35;
  /* light / text */
  --bone:#ECEAE0;
  --bone-2:#C9C6BA;
  --bone-dim:rgba(236,234,224,.60);
  --bone-mute:rgba(236,234,224,.60); /* WCAG AA: info-bearing muted text (.result__meta, .crumbs, thead th, footer) */
  --bone-deco:rgba(236,234,224,.40); /* decorative only — never load-bearing text */
  --bone-faint:rgba(236,234,224,.10);
  /* signal + market */
  --volt:#CBF74A;
  --volt-d:#B6E635;
  --up:#CBF74A;
  --down:#FF6B5C;
  --flat:rgba(236,234,224,.5);
  /* lines */
  --line:rgba(236,234,224,.12);
  --line-2:rgba(236,234,224,.06);
  /* type */
  --fd:"Lokal Display","Familjen Grotesk",system-ui,sans-serif;
  --fdl:"Lokal Display Light","Familjen Grotesk",system-ui,sans-serif;
  --ft:"Lokal Text","Spline Sans",system-ui,sans-serif;
  --ftm:"Lokal Text Medium","Spline Sans",system-ui,sans-serif;
  --fm:"Lokal Mono","Spline Sans Mono",ui-monospace,monospace;
  /* layout */
  --wrap:1280px;
  --gutter:clamp(20px,5vw,72px);
  --r:6px;
  --r-lg:18px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  background:var(--ink);
  color:var(--bone);
  font-family:var(--ft);
  font-size:17px;
  line-height:1.62;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--volt);color:#0A0C10}

/* grain — fixed, very subtle, lets the dark breathe */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  opacity:.04;mix-blend-mode:overlay;
}

a{color:inherit;text-decoration:none}
img,canvas,svg{display:block;max-width:100%}
button{font:inherit;cursor:pointer;color:inherit;background:none;border:none}
input,textarea{font:inherit}
h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.02em;line-height:1.02;text-wrap:balance}
.tnum{font-family:var(--fm);font-variant-numeric:tabular-nums;letter-spacing:0}
.wrap{width:min(100% - calc(var(--gutter) * 2),var(--wrap));margin-inline:auto;position:relative;z-index:2}

.eyebrow{
  font-family:var(--fm);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--volt);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--volt);box-shadow:0 0 0 4px rgba(203,247,74,.16)}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--volt);--fg:#0A0C10;
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--ftm);font-size:.96rem;letter-spacing:.01em;
  padding:15px 26px;border-radius:var(--r);background:var(--bg);color:var(--fg);
  border:1px solid transparent;white-space:nowrap;
  transition:transform .35s var(--ease),background .25s,box-shadow .35s var(--ease),color .25s;
  will-change:transform;
}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover{background:var(--volt-d);box-shadow:0 14px 40px -14px rgba(203,247,74,.55)}
.btn:hover .arr{transform:translateX(5px)}
.btn--ink{--bg:var(--ink-3);--fg:var(--bone);border-color:var(--line)}
.btn--ink:hover{--bg:var(--ink-4);box-shadow:none}
.btn--ghost{--bg:transparent;--fg:var(--bone);border-color:var(--line)}
.btn--ghost:hover{--bg:var(--ink-2);border-color:var(--bone-mute);box-shadow:none}
.btn--lg{padding:18px 32px;font-size:1.04rem}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--ink) 78%,transparent);backdrop-filter:blur(14px) saturate(1.1);border-bottom:1px solid var(--line-2)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:inline-flex;align-items:center;gap:11px}
.brand__mark{width:30px;height:30px;flex:none}
.brand__name{font-family:var(--fd);font-size:1.4rem;letter-spacing:-.01em;line-height:1}
.nav{display:flex;align-items:center;gap:8px}
.nav__links{display:flex;align-items:center;gap:4px;margin-right:14px}
.nav__link{font-family:var(--ftm);font-size:.92rem;color:var(--bone-dim);padding:9px 14px;border-radius:var(--r);transition:color .2s,background .2s}
.nav__link:hover{color:var(--bone);background:var(--ink-2)}
.nav__cta{font-family:var(--ftm);font-size:.92rem;color:#0A0C10;background:var(--volt);padding:10px 18px;border-radius:var(--r);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.nav__cta:hover{transform:translateY(-1px);box-shadow:0 10px 30px -12px rgba(203,247,74,.6)}
.nav__mobtoggle{display:none;color:var(--bone);padding:8px}

/* ---------- hero ---------- */
.hero{padding:clamp(48px,8vw,104px) 0 clamp(40px,6vw,72px);position:relative}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.hero__kicker{margin-bottom:26px}
.hero__title{
  font-family:var(--fd);
  font-size:clamp(3.1rem,8.4vw,6.6rem);
  line-height:.94;letter-spacing:-.035em;margin:0 0 .5em;
}
.hero__title .l2{color:var(--volt)}
.hero__title .l3{color:var(--bone-2)}
.hero__lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--bone-dim);max-width:46ch;margin:0 0 34px}
.hero__cta-row{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.hero__cta-sub{font-family:var(--fm);font-size:.78rem;letter-spacing:.06em;color:var(--bone-mute)}

/* live sample card (product-as-hero) */
.hero__visual{position:relative;perspective:1400px}
.sample-card{
  position:relative;background:linear-gradient(160deg,var(--ink-2),var(--ink));
  border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 34px 26px;
  box-shadow:0 50px 90px -50px rgba(0,0,0,.9),0 0 0 1px rgba(203,247,74,.04);
  transform:rotateY(-9deg) rotateX(3deg);transition:transform .8s var(--ease);
  transform-style:preserve-3d;overflow:hidden;
}
.hero__visual:hover .sample-card{transform:rotateY(-3deg) rotateX(1deg)}
.sample-card::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 70% at 80% 0%,rgba(203,247,74,.10),transparent 60%);pointer-events:none}
.sample-card__sticker{position:absolute;top:18px;right:-44px;transform:rotate(34deg);background:var(--volt);color:#0A0C10;font-family:var(--fm);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;padding:7px 52px;z-index:3}
.sample-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}
.sample-card__brand{display:flex;align-items:center;gap:9px;font-family:var(--fd);font-size:1.05rem;letter-spacing:-.01em}
.sample-card__brand svg{width:22px;height:22px}
.sample-card__period{font-family:var(--fm);font-size:.66rem;letter-spacing:.16em;color:var(--bone-mute)}
.sample-card__city{font-family:var(--fd);font-size:3.1rem;line-height:1;margin:0}
.sample-card__sub{font-family:var(--fm);font-size:.7rem;letter-spacing:.2em;color:var(--volt);margin-top:8px}
.sample-card__hero-metric{margin:26px 0 22px}
.sample-card__hl{font-family:var(--fm);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-mute);margin-bottom:8px}
.sample-card__hv{font-family:var(--fm);font-size:3.3rem;line-height:1;letter-spacing:-.02em}
.sample-card__chg{font-family:var(--ftm);font-size:.95rem;margin-top:10px}
.sample-card__chg.is-down{color:var(--down)}
.sample-card__chg.is-up{color:var(--up)}
.sample-card__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden;margin-bottom:18px}
.sample-card__cell{background:var(--ink-2);padding:14px 14px 16px}
.sample-card__cell .l{font-family:var(--fm);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-mute);margin-bottom:6px}
.sample-card__cell .v{font-family:var(--fm);font-size:1.35rem;letter-spacing:-.01em}
.sample-card__credit{font-family:var(--fm);font-size:.64rem;letter-spacing:.1em;color:var(--bone-mute);text-align:right}

/* hero stats */
.hero__stats{display:grid;grid-template-columns:repeat(3,auto);gap:clamp(28px,6vw,80px);justify-content:start;margin-top:clamp(40px,6vw,64px);padding-top:34px;border-top:1px solid var(--line)}
.stat__num{font-family:var(--fd);font-size:clamp(2.4rem,4vw,3.4rem);line-height:1;letter-spacing:-.02em}
.stat__label{font-family:var(--fm);font-size:.74rem;letter-spacing:.06em;color:var(--bone-dim);margin-top:8px}

/* ---------- ticker ---------- */
.ticker{border-block:1px solid var(--line);background:var(--ink-2);overflow:hidden;white-space:nowrap;position:relative;z-index:2}
.ticker__track{display:inline-flex;gap:0;will-change:transform;animation:ticker 48s linear infinite}
.ticker__item{display:inline-flex;align-items:center;gap:12px;padding:15px 26px;font-family:var(--fm);font-size:.82rem;letter-spacing:.02em;color:var(--bone-dim);border-right:1px solid var(--line-2)}
.ticker__item b{color:var(--bone);font-weight:400}
.ticker__item .u{color:var(--up)}
.ticker__item .d{color:var(--down)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker:hover .ticker__track{animation-play-state:paused}

/* ---------- section heads ---------- */
section{position:relative;z-index:2}
.sec-head__title{font-family:var(--fd);font-size:clamp(2rem,4.4vw,3.5rem);line-height:1.02;letter-spacing:-.025em;margin:18px 0 0;max-width:18ch}
.sec-head__lead{color:var(--bone-dim);max-width:54ch;margin:18px 0 0;font-size:1.06rem}

/* ---------- compare (signature: blank -> filled) ---------- */
.compare{padding:clamp(64px,9vw,120px) 0}
.compare__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,40px);margin-top:clamp(40px,5vw,64px);align-items:stretch}
.cmp{border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;position:relative;overflow:hidden}
.cmp--them{background:var(--ink-2)}
.cmp--us{background:linear-gradient(165deg,var(--ink-2),var(--ink));border-color:rgba(203,247,74,.22)}
.cmp__tag{font-family:var(--fm);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-mute)}
.cmp__label{font-family:var(--fd);font-size:1.5rem;margin:8px 0 26px}
.cmp--us .cmp__label{color:var(--volt)}
.cmp__blank{display:flex;flex-direction:column;gap:16px}
.cmp__skeleton{display:flex;align-items:center;gap:14px;color:var(--bone-mute);font-size:.96rem}
.cmp__skeleton .box{width:30px;height:30px;border:1px dashed var(--bone-faint);border-radius:6px;flex:none;position:relative}
.cmp__skeleton .box::after{content:"";position:absolute;inset:9px;border-radius:2px;background:repeating-linear-gradient(45deg,var(--bone-faint),var(--bone-faint) 3px,transparent 3px,transparent 6px)}
.cmp__canvas-wrap{border-radius:12px;overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 60px -40px #000}
.cmp__canvas-wrap canvas{width:100%;height:auto}
.cmp__caption{font-family:var(--fm);font-size:.74rem;letter-spacing:.04em;color:var(--bone-mute);margin:16px 0 0}

/* ---------- generator ---------- */
.generator{padding:clamp(64px,9vw,120px) 0;border-top:1px solid var(--line-2)}
.search{margin-top:clamp(28px,4vw,44px);max-width:560px;position:relative}
.search__label{font-family:var(--fm);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-mute);display:block;margin-bottom:10px}
.search__field{display:flex;align-items:center;gap:12px;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);padding:0 16px;transition:border-color .2s,box-shadow .2s}
.search__field:focus-within{border-color:var(--volt);box-shadow:0 0 0 4px rgba(203,247,74,.12)}
.search__icon{width:20px;height:20px;color:var(--bone-mute);flex:none}
.search__input{flex:1;background:none;border:none;outline:none;color:var(--bone);padding:16px 0;font-size:1.05rem}
.search__input::placeholder{color:var(--bone-mute)}
.search__results{list-style:none;margin:8px 0 0;padding:6px;position:absolute;left:0;right:0;z-index:30;background:var(--ink-3);border:1px solid var(--line);border-radius:var(--r);box-shadow:0 30px 60px -30px #000}
.result{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:var(--r);cursor:pointer}
.result:hover,.result.is-active{background:var(--ink-4)}
.result__name{font-family:var(--ftm)}
.result__meta{font-family:var(--fm);font-size:.74rem;color:var(--bone-mute)}
.result__zip{font-family:var(--fm);font-size:.7rem;letter-spacing:.08em;color:var(--volt);background:color-mix(in srgb,var(--volt) 14%,transparent);border:1px solid color-mix(in srgb,var(--volt) 32%,transparent);border-radius:5px;padding:1px 6px;margin-left:8px;vertical-align:middle}
.result--empty{color:var(--bone-mute);cursor:default}

.stage{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:clamp(24px,4vw,52px);margin-top:clamp(32px,4vw,52px);align-items:start;opacity:.32;filter:saturate(.4);transition:opacity .5s var(--ease),filter .5s var(--ease)}
.stage[data-active="1"]{opacity:1;filter:none}
.preview{position:sticky;top:96px}
.preview__stage{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(14px,2vw,26px);display:flex;justify-content:center}
.preview__stage canvas{width:auto;max-width:100%;max-height:62vh;border-radius:8px;box-shadow:0 30px 60px -40px #000}
.preview__controls{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:16px;flex-wrap:wrap}
.formtabs{display:inline-flex;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);padding:4px}
.formtab{font-family:var(--ftm);font-size:.86rem;color:var(--bone-dim);padding:9px 16px;border-radius:4px;transition:color .2s,background .2s}
.formtab[aria-selected="true"]{background:var(--volt);color:#0A0C10}
.slide-nav{display:inline-flex;align-items:center;gap:12px;font-family:var(--fm);font-size:.84rem;color:var(--bone-dim)}
.slide-nav button{width:38px;height:38px;display:grid;place-items:center;border:1px solid var(--line);border-radius:var(--r);color:var(--bone);transition:border-color .2s,background .2s}
.slide-nav button:hover{background:var(--ink-3);border-color:var(--bone-mute)}

.editor{display:flex;flex-direction:column;gap:24px}
.editor__title{display:flex;align-items:baseline;justify-content:space-between;gap:16px;font-family:var(--fd);font-size:1.3rem}
.editor__hint{color:var(--bone-dim);font-size:.92rem;margin:8px 0 18px}
.linkbtn{font-family:var(--fm);font-size:.74rem;letter-spacing:.04em;color:var(--volt);text-transform:uppercase}
.linkbtn:hover{text-decoration:underline}
.metrics-panel{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.metric{background:var(--ink-2);padding:16px 18px;position:relative}
.metric__label{font-family:var(--fm);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-mute);margin-bottom:8px}
.metric__value{font-family:var(--fm);font-size:1.5rem;letter-spacing:-.01em;outline:none;border-bottom:1px dashed transparent;display:inline-block;min-width:2ch}
.metric__value:focus{border-bottom-color:var(--volt)}
.metric__changes{margin-top:8px}
.chg{font-family:var(--ftm);font-size:.82rem}
.chg em{font-style:normal;color:var(--bone-mute);font-family:var(--fm);font-size:.72rem}
.chg--up{color:var(--up)}.chg--down{color:var(--down)}.chg--flat{color:var(--flat)}
.metric--edited::after{content:"MLS";position:absolute;top:14px;right:14px;font-family:var(--fm);font-size:.56rem;letter-spacing:.1em;color:#0A0C10;background:var(--volt);padding:3px 6px;border-radius:3px}
.disclaimer{display:flex;align-items:flex-start;gap:10px;font-size:.84rem;color:var(--bone-mute);margin:16px 0 0}
.disclaimer svg{width:18px;height:18px;flex:none;color:var(--bone-mute);margin-top:2px}

.caption-box{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.caption-box__head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.caption-box__title{font-family:var(--ftm);font-size:.92rem}
.copybtn{display:inline-flex;align-items:center;gap:7px;font-family:var(--fm);font-size:.74rem;letter-spacing:.04em;color:var(--volt);text-transform:uppercase}
.copybtn svg{width:15px;height:15px}
.copybtn.is-copied{color:var(--up)}
.caption-box textarea{width:100%;min-height:150px;background:none;border:none;outline:none;resize:vertical;color:var(--bone);padding:16px 18px;font-size:.92rem;line-height:1.6;font-family:var(--ft)}

.export-panel{background:linear-gradient(165deg,var(--ink-3),var(--ink-2));border:1px solid var(--line);border-radius:var(--r-lg);padding:22px}
.export-panel__head{display:flex;align-items:center;justify-content:space-between}
.export-panel__title{font-family:var(--fd);font-size:1.2rem}
.hd-badge{font-family:var(--fm);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:#0A0C10;background:var(--volt);padding:5px 9px;border-radius:4px}
.export-panel__note{color:var(--bone-dim);font-size:.86rem;margin:8px 0 18px}
.export-actions{display:flex;gap:12px;flex-wrap:wrap}
.unlock-btn{margin-top:14px;width:100%;justify-content:center}

/* ---------- pricing ---------- */
.pricing{padding:clamp(64px,9vw,120px) 0;border-top:1px solid var(--line-2)}
.plans{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.5vw,28px);margin-top:clamp(36px,5vw,56px);align-items:start}
.plan{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px}
.plan--feat{background:linear-gradient(170deg,var(--ink-3),var(--ink-2));border-color:rgba(203,247,74,.28);position:relative}
.plan__badge{position:absolute;top:-12px;left:34px;background:var(--volt);color:#0A0C10;font-family:var(--fm);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:4px}
.plan__name{font-family:var(--fm);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-dim)}
.plan__price{font-family:var(--fd);font-size:clamp(2.6rem,4vw,3.4rem);line-height:1;margin:14px 0 6px}
.plan__price span{font-family:var(--ft);font-size:1rem;color:var(--bone-dim);letter-spacing:0}
.plan__desc{color:var(--bone-dim);font-size:.95rem;margin:0 0 22px}
.plan__list{list-style:none;margin:0 0 4px;padding:0;display:flex;flex-direction:column;gap:13px}
.plan__list li{display:flex;align-items:flex-start;gap:11px;font-size:.96rem}
.plan__list svg{width:19px;height:19px;color:var(--volt);flex:none;margin-top:2px}
.waitlist{margin-top:26px;padding-top:24px;border-top:1px solid var(--line)}
.waitlist__form{display:flex;gap:10px;flex-wrap:wrap}
.waitlist__form input{flex:1;min-width:180px;background:var(--ink);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;color:var(--bone);outline:none;transition:border-color .2s}
.waitlist__form input:focus{border-color:var(--volt)}
.waitlist__msg{display:flex;align-items:center;gap:9px;color:var(--up);font-size:.9rem;margin:14px 0 0}
.waitlist__msg svg{color:var(--up)}
.pricing__note{font-family:var(--fm);font-size:.78rem;letter-spacing:.04em;color:var(--bone-mute);margin-top:26px;text-align:center}

/* ---------- cities ---------- */
.cities{padding:clamp(64px,9vw,120px) 0;border-top:1px solid var(--line-2)}
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-top:clamp(36px,5vw,52px)}
.citycard{display:flex;align-items:baseline;justify-content:space-between;gap:10px;background:var(--ink-2);padding:18px 20px;transition:background .2s,color .2s}
.citycard:hover{background:var(--ink-4)}
.citycard__name{font-family:var(--ftm);font-size:1rem}
.citycard:hover .citycard__name{color:var(--volt)}
.citycard__state{font-family:var(--fm);font-size:.72rem;color:var(--bone-mute)}

/* ---------- about ---------- */
.about{padding:clamp(64px,9vw,120px) 0;border-top:1px solid var(--line-2)}
.about__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);margin-top:clamp(36px,5vw,52px)}
.about__col h3{font-family:var(--fd);font-size:1.2rem;margin-bottom:12px}
.about__col p{color:var(--bone-dim);font-size:.96rem;margin:0}
.about__col a{color:var(--volt)}
.about__col a:hover{text-decoration:underline}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--line);padding:48px 0;margin-top:clamp(40px,6vw,80px)}
.site-footer__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.site-footer .brand__mark{width:26px;height:26px}
.site-footer__meta{display:flex;flex-direction:column;gap:4px;text-align:right;font-family:var(--fm);font-size:.78rem;color:var(--bone-mute)}
.site-footer__meta a{color:var(--bone-dim)}
.site-footer__meta a:hover{color:var(--volt)}

/* ---------- focus / a11y ---------- */
:focus-visible{outline:2px solid var(--volt);outline-offset:2px;border-radius:3px}

/* ---------- reveal / motion ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  [data-reveal]{opacity:1;transform:none}
  .sample-card{transform:none}
  .ticker__track{animation:none}
}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .hero__grid{grid-template-columns:1fr;gap:48px}
  .hero__visual{max-width:460px}
  .compare__grid,.stage,.plans,.about__grid{grid-template-columns:1fr}
  .preview{position:static}
  .preview__stage canvas{max-height:none}
}
@media (max-width:640px){
  body{font-size:16px}
  .nav__links,.nav__cta{display:none}
  .nav__mobtoggle{display:block}
  .nav.is-open{position:absolute;top:72px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--ink-2);border-bottom:1px solid var(--line);padding:8px}
  .nav.is-open .nav__links{display:flex;flex-direction:column;margin:0}
  .nav.is-open .nav__cta{display:block;text-align:center;margin:8px}
  .hero__stats{grid-template-columns:1fr;gap:20px}
  .metrics-panel{grid-template-columns:1fr}
  .about__grid{gap:28px}
  .site-footer__inner{flex-direction:column;align-items:flex-start}
  .site-footer__meta{text-align:left}
}
