/* ============================================================
   ZORYN AI — design system v2 · "premium dispatch software"
   Palette: ink (base) · bone (text) · flare (safety orange) · signal (live green)
   Type: Bricolage Grotesque (display) · Inter (body) · IBM Plex Mono (telemetry)
   ============================================================ */

/* ---------- tokens ---------- */
:root{
  --ink-900:#0B1120;
  --ink-800:#0E1628;
  --ink-700:#131C33;
  --ink-500:#243352;
  --bone-100:#F2EFE8;
  --bone-400:#A9A698;
  --flare-500:#FF5A1F;
  --flare-600:#E64A12;
  --signal-400:#3DDC97;

  --font-display:"Bricolage Grotesque",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
  --font-mono:"IBM Plex Mono",ui-monospace,"SF Mono",monospace;

  --wrap:1200px;
  --gutter:24px;
  --radius:12px;
  --section-y:clamp(64px,9vw,120px);

  --t-fast:120ms;
  --t-med:350ms;
}

/* ---------- fonts (self-hosted) ---------- */
@font-face{font-family:"Bricolage Grotesque";font-style:normal;font-weight:700;font-display:swap;src:url(fonts/bricolage-grotesque-latin-700-normal.woff2) format("woff2")}
@font-face{font-family:"Bricolage Grotesque";font-style:normal;font-weight:800;font-display:swap;src:url(fonts/bricolage-grotesque-latin-800-normal.woff2) format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:400;font-display:swap;src:url(fonts/inter-latin-400-normal.woff2) format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:500;font-display:swap;src:url(fonts/inter-latin-500-normal.woff2) format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:600;font-display:swap;src:url(fonts/inter-latin-600-normal.woff2) format("woff2")}
@font-face{font-family:"IBM Plex Mono";font-style:normal;font-weight:400;font-display:swap;src:url(fonts/ibm-plex-mono-latin-400-normal.woff2) format("woff2")}
@font-face{font-family:"IBM Plex Mono";font-style:normal;font-weight:500;font-display:swap;src:url(fonts/ibm-plex-mono-latin-500-normal.woff2) format("woff2")}

/* ---------- base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--ink-900);color:var(--bone-100);
  font-family:var(--font-body);font-size:1.0625rem;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:inherit}
::selection{background:var(--flare-500);color:var(--ink-900)}

h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.08;margin:0}
h1{font-size:clamp(2.4rem,6vw,4.5rem);font-weight:800}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem)}
h3{font-size:1.15rem;line-height:1.3}
p{margin:0}

.mono,.stat b,.price,[data-count]{font-family:var(--font-mono)}
.mono{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.02em}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}

/* focus — flare ring everywhere */
:focus-visible{outline:2px solid var(--flare-500);outline-offset:2px;border-radius:4px}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;background:var(--flare-500);color:var(--ink-900);padding:.6rem 1rem;z-index:200;font-weight:600}
.skip:focus{left:8px;top:8px}

/* ---------- section rhythm + work-order rules ---------- */
.section{padding-block:var(--section-y);position:relative}
.rule{
  display:flex;align-items:center;gap:.8rem;
  max-width:var(--wrap);margin:0 auto;padding-inline:var(--gutter);
}
.rule::after{content:"";flex:1;height:1px;background:var(--ink-500)}
.rule span{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;color:var(--bone-400);text-transform:lowercase;white-space:nowrap}

.section-head{max-width:760px;margin-bottom:clamp(2rem,4vw,3.2rem)}
.section-head h2{margin-top:.9rem}
.section-head p{margin-top:1rem;color:var(--bone-400)}
.eyebrow{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--flare-500)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-body);font-weight:600;font-size:.95rem;line-height:1;
  padding:.85rem 1.4rem;border-radius:10px;border:1px solid transparent;
  text-decoration:none;cursor:pointer;
  transition:transform var(--t-fast) ease,box-shadow var(--t-fast) ease,border-color var(--t-fast) ease,background var(--t-fast) ease;
  will-change:transform;
}
.btn--lg{padding:1.05rem 1.7rem;font-size:1.02rem}
.btn--primary{background:var(--flare-500);color:var(--ink-900)}
.btn--primary:hover{transform:translateY(-2px);background:var(--flare-600);color:var(--bone-100)}
.btn--ghost{background:transparent;color:var(--bone-100);border-color:var(--ink-500)}
.btn--ghost:hover{transform:translateY(-2px);border-color:var(--flare-500)}
.btn .arrow{width:1em;height:1em;stroke-width:2}
.link-arrow{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--bone-100);text-decoration:none;border-bottom:1px solid var(--ink-500);padding-bottom:2px}
.link-arrow:hover{border-color:var(--flare-500)}
.link-arrow .arrow{width:1em;height:1em}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:100;transition:background var(--t-med) ease,border-color var(--t-med) ease;border-bottom:1px solid transparent}
.nav.is-scrolled{background:rgba(11,17,32,.82);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom-color:var(--ink-500)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;min-height:64px}
.brand{font-family:var(--font-display);font-weight:800;font-size:1.25rem;text-decoration:none;letter-spacing:-.02em}
.brand .ai{color:var(--flare-500)}
.nav__links{display:flex;gap:1.4rem}
.nav__links a{font-size:.92rem;font-weight:500;color:var(--bone-400);text-decoration:none}
.nav__links a:hover,.nav__links a.is-active{color:var(--bone-100)}
.nav__right{display:flex;align-items:center;gap:.9rem}

/* segmented language control */
.lang{display:inline-flex;border:1px solid var(--ink-500);border-radius:8px;overflow:hidden;font-family:var(--font-mono);font-size:.74rem}
.lang a{padding:.42rem .65rem;text-decoration:none;color:var(--bone-400)}
.lang a.is-active{background:var(--ink-700);color:var(--bone-100)}
.lang a + a{border-left:1px solid var(--ink-500)}

@media (max-width:880px){.nav__links{display:none}}

/* ---------- hero + dispatch board ---------- */
.hero{padding-block:clamp(3rem,7vw,6.5rem) clamp(3.4rem,6vw,5.5rem);overflow:hidden}
.hero__grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:clamp(2rem,4vw,4rem);align-items:center}
@media (max-width:960px){.hero__grid{grid-template-columns:1fr}}
.hero__eyebrow{display:inline-block;margin-bottom:1.2rem}
.hero h1 .accent{color:var(--flare-500)}
.hero__sub{margin-top:1.3rem;color:var(--bone-400);font-size:1.1rem;max-width:34rem}
.hero__cta{margin-top:1.9rem;display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero__meta{display:flex;gap:2rem;margin-top:2.2rem;flex-wrap:wrap}
.hero__meta b{display:block;font-family:var(--font-mono);font-weight:500;font-size:1.15rem;color:var(--bone-100)}
.hero__meta span{font-size:.82rem;color:var(--bone-400)}

/* load choreography */
@media (prefers-reduced-motion:no-preference){
  .rise{opacity:0;transform:translateY(14px);animation:rise .55s cubic-bezier(.2,.7,.3,1) forwards}
  .rise[data-d="1"]{animation-delay:.06s}.rise[data-d="2"]{animation-delay:.12s}
  .rise[data-d="3"]{animation-delay:.18s}.rise[data-d="4"]{animation-delay:.24s}
  .rise[data-d="5"]{animation-delay:.3s}
  @keyframes rise{to{opacity:1;transform:none}}
}

/* dispatch board panel */
.board{
  background:var(--ink-700);border:1px solid var(--ink-500);border-radius:var(--radius);
  overflow:hidden;font-size:.9rem;
}
.board__bar{
  display:flex;align-items:center;gap:.8rem;
  padding:.7rem 1rem;border-bottom:1px solid var(--ink-500);
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;
}
.board__live{display:inline-flex;align-items:center;gap:.45rem;color:var(--signal-400)}
.board__live i{width:7px;height:7px;border-radius:50%;background:var(--signal-400);display:inline-block}
@media (prefers-reduced-motion:no-preference){.board__live i{animation:pulse 1.6s ease-in-out infinite}@keyframes pulse{50%{opacity:.35}}}
.board__clock{margin-left:auto;color:var(--bone-400)}
.board__langs{display:inline-flex;border:1px solid var(--ink-500);border-radius:6px;overflow:hidden}
.board__langs button{font-family:var(--font-mono);font-size:.7rem;background:none;border:0;color:var(--bone-400);padding:.3rem .55rem;cursor:pointer}
.board__langs button.is-active{background:var(--ink-500);color:var(--bone-100)}
.board__feed{padding:1rem 1.1rem;min-height:262px;display:flex;flex-direction:column;gap:.65rem}
.board__line{display:flex;gap:.7rem;opacity:0;transform:translateY(6px);transition:opacity .3s ease,transform .3s ease}
.board__line.is-in{opacity:1;transform:none}
.board__line .who{font-family:var(--font-mono);font-size:.68rem;color:var(--bone-400);min-width:54px;padding-top:.2rem;text-transform:uppercase}
.board__line.is-ai .who{color:var(--flare-500)}
.board__line .txt{color:var(--bone-100);font-size:.88rem;line-height:1.5}
.board__card{
  margin-top:.4rem;border:1px solid var(--signal-400);border-radius:8px;padding:.7rem .9rem;
  font-family:var(--font-mono);font-size:.74rem;color:var(--signal-400);letter-spacing:.04em;
  opacity:0;transform:translateY(8px);transition:opacity .35s ease,transform .35s ease;
}
.board__card.is-in{opacity:1;transform:none}
.board__foot{padding:.8rem 1.1rem;border-top:1px solid var(--ink-500);font-size:.82rem;color:var(--bone-400)}
.board__foot a{color:var(--bone-100);font-weight:600}

/* demo number CTA under board */
.demo-cta{margin-top:1rem;display:flex;flex-direction:column;gap:.35rem}
.demo-cta .mono{color:var(--bone-400)}
.tel-btn{
  display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-weight:500;
  font-size:1.05rem;color:var(--ink-900);background:var(--flare-500);border-radius:10px;
  padding:.9rem 1.3rem;text-decoration:none;transition:transform var(--t-fast) ease;
}
.tel-btn:hover{transform:translateY(-2px)}

/* ---------- ticker (trades marquee → mono tags) ---------- */
.ticker{border-block:1px solid var(--ink-500);padding-block:.9rem;overflow:hidden}
.ticker__track{display:flex;gap:0;width:max-content;font-family:var(--font-mono);font-size:.78rem;color:var(--bone-400);letter-spacing:.04em}
.ticker__track span{white-space:nowrap}
.ticker__track span::after{content:"//";margin-inline:1.1rem;color:var(--ink-500)}
@media (prefers-reduced-motion:no-preference){
  .ticker__track{animation:tick 36s linear infinite}
  .ticker:hover .ticker__track{animation-play-state:paused}
  @keyframes tick{to{transform:translateX(-50%)}}
}
@media (prefers-reduced-motion:reduce){.ticker__track{flex-wrap:wrap;width:auto;row-gap:.4rem}}

/* ---------- stats / telemetry ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ink-500);border:1px solid var(--ink-500);border-radius:var(--radius);overflow:hidden}
@media (max-width:880px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--ink-700);padding:1.5rem 1.3rem}
.stat b{display:block;font-weight:500;font-size:clamp(1.7rem,3.4vw,2.4rem);color:var(--bone-100)}
.stat b.is-flashed{color:var(--flare-500);transition:color .5s ease}
.stat span{display:block;margin-top:.5rem;font-size:.82rem;color:var(--bone-400);line-height:1.5}
.stats-note{margin-top:1.1rem;font-family:var(--font-mono);font-size:.74rem;color:var(--bone-400)}

/* receipts strip */
.receipts{margin-top:2.2rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media (max-width:880px){.receipts{grid-template-columns:1fr}}
.receipt{border:1px solid var(--ink-500);border-radius:var(--radius);background:var(--ink-800);padding:1.2rem 1.3rem}
.receipt .k{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;color:var(--flare-500);text-transform:uppercase}
.receipt h3{margin-top:.6rem;font-size:1rem}
.receipt p{margin-top:.45rem;font-size:.85rem;color:var(--bone-400)}
.receipt .score{font-family:var(--font-mono);font-size:2rem;color:var(--signal-400);font-weight:500}

/* ---------- cards (services) ---------- */
.cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media (max-width:980px){.cardgrid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.cardgrid{grid-template-columns:1fr}}
.scard{
  background:var(--ink-700);border:1px solid var(--ink-500);border-radius:var(--radius);
  padding:1.5rem 1.4rem;display:flex;flex-direction:column;gap:.8rem;
  transition:border-color var(--t-fast) ease,transform var(--t-fast) ease;
  will-change:transform;
}
.scard:hover{border-color:var(--flare-500)}
.scard__ic{width:38px;height:38px;color:var(--flare-500)}
.scard__ic svg{width:100%;height:100%}
.scard p{color:var(--bone-400);font-size:.92rem;flex:1}
.scard__price{font-family:var(--font-mono);font-size:.9rem;color:var(--bone-100)}
.scard__spec{
  margin-top:.4rem;padding-top:.8rem;border-top:1px solid var(--ink-500);
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.09em;color:var(--bone-400);text-transform:uppercase;
}

/* ---------- pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media (max-width:880px){.pillars{grid-template-columns:1fr}}
.pillar{border:1px solid var(--ink-500);border-radius:var(--radius);padding:1.6rem 1.4rem;background:var(--ink-800)}
.pillar__ic{width:34px;height:34px;color:var(--flare-500);margin-bottom:1rem}
.pillar__ic svg{width:100%;height:100%}
.pillar p{margin-top:.6rem;color:var(--bone-400);font-size:.92rem}

/* ---------- bundles ---------- */
.bundles{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;align-items:stretch}
@media (max-width:980px){.bundles{grid-template-columns:1fr}}
.bundle{
  position:relative;background:var(--ink-700);border:1px solid var(--ink-500);border-radius:var(--radius);
  padding:1.7rem 1.5rem;display:flex;flex-direction:column;gap:.85rem;
}
.bundle.is-feature{border-color:var(--flare-500);border-top:3px solid var(--flare-500)}
.bundle__badge{
  position:absolute;top:-11px;left:1.4rem;background:var(--ink-900);
  font-family:var(--font-mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--flare-500);border:1px solid var(--flare-500);border-radius:6px;padding:.22rem .55rem;
}
.bundle__badge--muted{color:var(--bone-400);border-color:var(--ink-500)}
.bundle__emoji{font-size:1.5rem}
.bundle__desc{color:var(--bone-400);font-size:.9rem;flex:0}
.bundle__price{font-family:var(--font-mono)}
.bundle__price .setup{font-size:1.5rem;font-weight:500}
.bundle__price .mo{font-size:.85rem;color:var(--bone-400)}
.bundle__ltv{font-family:var(--font-mono);font-size:.74rem;color:var(--bone-400)}
.bundle__bar{display:flex;height:8px;border-radius:4px;overflow:hidden;border:1px solid var(--ink-500)}
.bundle__bar i{display:block;height:100%}
.bundle__bar .b-setup{background:var(--flare-500)}
.bundle__bar .b-mo{background:var(--ink-500)}
.bundle__legend{display:flex;gap:1rem;font-family:var(--font-mono);font-size:.62rem;color:var(--bone-400);letter-spacing:.05em}
.bundle__legend .sw{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:.3rem}
.bundle ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;flex:1}
.bundle li{display:flex;gap:.55rem;align-items:flex-start;font-size:.9rem;color:var(--bone-100)}
.bundle li svg{width:15px;height:15px;color:var(--signal-400);flex:none;margin-top:.25rem}
.bundle .btn{justify-content:center}

/* ---------- process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}
@media (max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.steps{grid-template-columns:1fr}}
.step{border:1px solid var(--ink-500);border-radius:var(--radius);padding:1.3rem 1.2rem;background:var(--ink-800)}
.step__n{font-family:var(--font-mono);color:var(--flare-500);font-size:.85rem;margin-bottom:.7rem}
.step h3{font-size:1rem}
.step p{margin-top:.5rem;font-size:.85rem;color:var(--bone-400)}

/* ---------- bilingual flip card ---------- */
.biling{max-width:760px;margin-inline:auto;perspective:1200px}
.biling__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.biling__card{position:relative;transform-style:preserve-3d;transition:transform .4s cubic-bezier(.2,.7,.3,1)}
.biling__card.is-flipped{transform:rotateY(180deg)}
.biling__face{
  border:1px solid var(--ink-500);border-radius:var(--radius);background:var(--ink-700);
  padding:2rem 1.8rem;backface-visibility:hidden;-webkit-backface-visibility:hidden;
}
.biling__face--es{position:absolute;inset:0;transform:rotateY(180deg);display:flex;flex-direction:column;justify-content:center}
.biling__face .flag{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;color:var(--flare-500)}
.biling__face h3{margin-top:.7rem;font-size:1.4rem}
.biling__face p{margin-top:.8rem;color:var(--bone-400)}
@media (prefers-reduced-motion:reduce){
  .biling__card.is-flipped{transform:none}
  .biling__face--es{position:relative;transform:none;margin-top:1rem}
}

/* ---------- calculator ---------- */
.calc{border:1px solid var(--ink-500);border-radius:var(--radius);background:var(--ink-700);overflow:hidden}
.calc__bar{display:flex;align-items:center;gap:.7rem;padding:.7rem 1.1rem;border-bottom:1px solid var(--ink-500);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;color:var(--bone-400)}
.calc__bar b{color:var(--flare-500);font-weight:500}
.calc__grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
@media (max-width:820px){.calc__grid{grid-template-columns:1fr}}
.calc__inputs{padding:1.5rem 1.4rem;display:flex;flex-direction:column;gap:1.4rem}
.calc__field label{display:flex;justify-content:space-between;font-size:.85rem;color:var(--bone-400);margin-bottom:.55rem}
.calc__field output{font-family:var(--font-mono);color:var(--bone-100)}
.calc input[type=range]{width:100%;accent-color:var(--flare-500);height:22px}
.calc__result{
  padding:1.5rem 1.4rem;border-left:1px solid var(--ink-500);
  display:flex;flex-direction:column;justify-content:center;gap:.8rem;background:var(--ink-800);
}
@media (max-width:820px){.calc__result{border-left:none;border-top:1px solid var(--ink-500)}}
.calc__result .lede{font-size:.9rem;color:var(--bone-400)}
.calc__num{font-family:var(--font-mono);font-weight:500;font-size:clamp(2rem,5vw,2.9rem);color:var(--flare-500)}
.calc__compare{font-size:.85rem;color:var(--bone-400);line-height:1.6}
.calc__compare b{color:var(--signal-400);font-family:var(--font-mono);font-weight:500}
.calc__cta{margin-top:.4rem}

/* ---------- pricing tiers ---------- */
.ptiers{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media (max-width:880px){.ptiers{grid-template-columns:1fr}}
.ptier{border:1px solid var(--ink-500);border-radius:var(--radius);background:var(--ink-700);padding:1.5rem 1.4rem}
.ptier.is-feature{border-color:var(--flare-500);transform:scale(1.02)}
@media (max-width:880px){.ptier.is-feature{transform:none}}
.ptier h3{font-size:.95rem;font-family:var(--font-mono);font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--bone-400);position:sticky;top:64px;background:inherit;padding-block:.2rem}
.ptier .amt{font-family:var(--font-mono);font-size:1.6rem;font-weight:500;margin-top:.8rem}
.ptier .amt small{display:block;font-size:.78rem;color:var(--bone-400);margin-top:.25rem}
.ptier .amt .day{display:block;font-size:.66rem;color:var(--bone-400);margin-top:.3rem;letter-spacing:.04em}
@media (hover:hover) and (pointer:fine){.ptier .day{opacity:0;transition:opacity var(--t-fast) ease}.ptier:hover .day{opacity:1}}
.ptier ul{list-style:none;margin:1.1rem 0 0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.ptier li{display:flex;gap:.55rem;font-size:.88rem;color:var(--bone-100)}
.ptier li svg{width:15px;height:15px;color:var(--signal-400);flex:none;margin-top:.25rem}

/* ---------- FAQ ---------- */
.faq{max-width:820px}
.faq details{border-bottom:1px solid var(--ink-500);padding:1.15rem 0}
.faq summary{font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--font-mono);color:var(--flare-500)}
.faq details[open] summary::after{content:"–"}
.faq details p{margin-top:.8rem;color:var(--bone-400);font-size:.95rem}

/* ---------- final CTA / book ---------- */
.finalcta{text-align:center;max-width:720px;margin-inline:auto}
.finalcta h2{margin-top:1rem}
.finalcta p{margin-top:1rem;color:var(--bone-400)}
.finalcta .btn{margin-top:1.8rem}
.finalcta .alt{margin-top:1.4rem;font-size:.9rem}
.finalcta .alt a{color:var(--bone-100)}

/* fallback lead form */
.miniform{margin:1.6rem auto 0;max-width:430px;text-align:left;border:1px solid var(--ink-500);border-radius:var(--radius);padding:1.2rem;background:var(--ink-800)}
.miniform .k{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;color:var(--bone-400);text-transform:uppercase}
.miniform .row{display:flex;gap:.6rem;margin-top:.8rem}
@media (max-width:480px){.miniform .row{flex-direction:column}}
.miniform input{
  flex:1;background:var(--ink-900);border:1px solid var(--ink-500);border-radius:8px;
  color:var(--bone-100);font-family:var(--font-body);font-size:.92rem;padding:.7rem .8rem;min-width:0;
}
.miniform input:focus-visible{outline:2px solid var(--flare-500);outline-offset:1px}
.miniform button{margin-top:.8rem;width:100%;justify-content:center}
.miniform .ok{margin-top:.8rem;color:var(--signal-400);font-family:var(--font-mono);font-size:.8rem}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--ink-500);padding-block:3.2rem 2rem;font-size:.9rem}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem}
@media (max-width:880px){.footer__grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer__grid{grid-template-columns:1fr}}
.footer__brand p{margin-top:.9rem;color:var(--bone-400);font-size:.88rem;max-width:30rem}
.footer__social{display:flex;gap:.9rem;margin-top:1.1rem}
.footer__social a{color:var(--bone-400)}
.footer__social a:hover{color:var(--bone-100)}
.footer__social svg{width:18px;height:18px}
.footer h4{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-400);margin:0 0 .9rem}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.footer ul a{color:var(--bone-100);text-decoration:none;font-size:.88rem}
.footer ul a:hover{color:var(--flare-500)}
.footer__status{font-family:var(--font-mono);font-size:.74rem;color:var(--signal-400)}
.footer__status i{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--signal-400);margin-right:.4rem}
@media (prefers-reduced-motion:no-preference){.footer__status i{animation:pulse 1.6s ease-in-out infinite}}
.footer__bottom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;border-top:1px solid var(--ink-500);margin-top:2.4rem;padding-top:1.6rem;font-family:var(--font-mono);font-size:.72rem;color:var(--bone-400)}

/* ---------- sticky mobile bar ---------- */
.stickybar{
  position:fixed;left:0;right:0;bottom:0;z-index:120;
  display:none;gap:.6rem;align-items:center;
  background:rgba(11,17,32,.94);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border-top:1px solid var(--ink-500);padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom));
}
.stickybar.is-on{display:flex}
.stickybar .btn{flex:1;justify-content:center;padding:.8rem .6rem;font-size:.88rem}
.stickybar__x{background:none;border:0;color:var(--bone-400);font-size:1.1rem;padding:.4rem;cursor:pointer;line-height:1}
@media (min-width:881px){.stickybar.is-on{display:none}}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity var(--t-med) ease-out,transform var(--t-med) ease-out}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.07s}.reveal[data-d="2"]{transition-delay:.14s}
.reveal[data-d="3"]{transition-delay:.21s}.reveal[data-d="4"]{transition-delay:.28s}
@media (prefers-reduced-motion:reduce){
  .reveal,.rise{opacity:1!important;transform:none!important;animation:none!important;transition:none!important}
}

/* ---------- page hero (interior pages) ---------- */
.pagehero{padding-block:clamp(2.6rem,6vw,4.5rem) clamp(1rem,3vw,2rem);max-width:880px}
.pagehero .breadcrumb{font-family:var(--font-mono);font-size:.74rem;color:var(--bone-400);margin-bottom:1.2rem}
.pagehero .breadcrumb a{color:var(--bone-400);text-decoration:none}
.pagehero .breadcrumb a:hover{color:var(--bone-100)}
.pagehero h1{font-size:clamp(2rem,5vw,3.4rem)}
.pagehero p{margin-top:1.2rem;color:var(--bone-400);font-size:1.08rem;max-width:42rem}

/* ---------- vertical landing pages ---------- */
.vhero{padding-block:clamp(3rem,6vw,5rem) clamp(2rem,4vw,3rem)}
.vhero .wrap{max-width:880px}
.vhero h1{font-size:clamp(2.1rem,5.4vw,3.6rem)}
.vhero .sub{margin-top:1.2rem;color:var(--bone-400);font-size:1.1rem;max-width:38rem}
.vhero .sub b{color:var(--bone-100);font-family:var(--font-mono);font-weight:500}
.vhero .cta{margin-top:1.8rem;display:flex;flex-wrap:wrap;gap:.9rem}
.howsteps{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media (max-width:820px){.howsteps{grid-template-columns:1fr}}
.demo-block{border:1px solid var(--flare-500);border-radius:var(--radius);background:var(--ink-700);padding:2rem 1.7rem;text-align:center}
.demo-block h2{font-size:clamp(1.4rem,3vw,2rem)}
.demo-block p{margin-top:.8rem;color:var(--bone-400)}
.demo-block .tel-btn{margin-top:1.3rem}
.localproof{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;justify-content:space-between;border:1px solid var(--ink-500);border-radius:var(--radius);background:var(--ink-800);padding:1.2rem 1.4rem}
.localproof .mono{color:var(--bone-400)}

/* prose (articles, long copy) */
.prose{max-width:760px;margin-inline:auto}
.prose h2{margin-top:2.6rem;font-size:clamp(1.4rem,3vw,1.9rem)}
.prose h3{margin-top:1.8rem}
.prose p{margin-top:1.1rem;color:var(--bone-100)}
.prose p.muted,.prose li{color:var(--bone-400)}
.prose ul,.prose ol{margin-top:1rem;padding-left:1.3rem;display:flex;flex-direction:column;gap:.5rem}
.prose table{width:100%;border-collapse:collapse;margin-top:1.4rem;font-size:.9rem}
.prose th{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--bone-400);text-align:left;padding:.6rem .7rem;border-bottom:1px solid var(--ink-500)}
.prose td{padding:.65rem .7rem;border-bottom:1px solid var(--ink-500)}
.prose td:first-child{color:var(--bone-100)}
.prose td{color:var(--bone-400)}
.prose .num,.prose td.num{font-family:var(--font-mono);color:var(--bone-100)}
.prose blockquote{margin:1.6rem 0 0;border-left:3px solid var(--flare-500);padding:.4rem 0 .4rem 1.2rem;color:var(--bone-400)}
.article-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.2rem;font-family:var(--font-mono);font-size:.74rem;color:var(--bone-400)}

/* insights cards */
.postgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media (max-width:880px){.postgrid{grid-template-columns:1fr}}
.post{border:1px solid var(--ink-500);border-radius:var(--radius);background:var(--ink-700);padding:1.5rem 1.4rem;display:flex;flex-direction:column;gap:.7rem;text-decoration:none;transition:border-color var(--t-fast) ease,transform var(--t-fast) ease}
.post:hover{border-color:var(--flare-500);transform:translateY(-2px)}
.post .k{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;color:var(--flare-500);text-transform:uppercase}
.post h3{font-size:1.05rem;line-height:1.35}
.post p{color:var(--bone-400);font-size:.88rem;flex:1}
.post .meta{font-family:var(--font-mono);font-size:.7rem;color:var(--bone-400)}

/* utility */
.center{text-align:center}
.mt-2{margin-top:2rem}
.muted{color:var(--bone-400)}
