/* ============================================================================
   Exhibit Domain - design system
   "Engineered industrial": teal + charcoal + steel, blueprint accents.
   GPU-friendly motion only (transform/opacity). No external CSS deps.
   ========================================================================== */

/* ---- Fonts (self-hosted, swap to avoid FOIT) ---------------------------- */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500 700;
  font-display:swap;src:url('../fonts/space-grotesk.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:400 600;
  font-display:swap;src:url('../fonts/inter.woff2') format('woff2');}

/* ---- Tokens ------------------------------------------------------------- */
:root{
  --teal:#018897; --teal-600:#017584; --teal-700:#0b5563; --teal-050:#e6f4f5;
  --ink:#1d1f22; --ink-700:#33373c; --slate:#5b636c; --mute:#7c858f;
  --line:#e2e0d8; --line-2:#d3d0c6;
  --paper:#ffffff; --sand:#f6f5f1; --sand-2:#ece9e1; --warm:#e8e6de;
  --steel-900:#11161b; --steel-800:#161d24; --steel-700:#1d2630;
  --accent:#f0a429;            /* signal amber for highlights/badges */
  --good:#0e7a4e;
  --ring:rgba(1,136,151,.35);

  --maxw:1180px; --gut:clamp(1.1rem,4vw,2.5rem);
  --r-sm:8px; --r:14px; --r-lg:22px; --r-pill:999px;
  --sh-1:0 1px 2px rgba(20,25,30,.06),0 2px 8px rgba(20,25,30,.05);
  --sh-2:0 8px 24px rgba(20,25,30,.10),0 2px 6px rgba(20,25,30,.06);
  --sh-3:0 24px 60px rgba(17,22,27,.20);
  --ff-head:'Space Grotesk',ui-sans-serif,system-ui,'Segoe UI',Roboto,sans-serif;
  --ff-body:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --t-fast:.18s cubic-bezier(.4,0,.2,1); --t:.32s cubic-bezier(.4,0,.2,1);
}

/* ---- Reset -------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--ff-body);color:var(--ink);background:var(--paper);
  font-size:clamp(1rem,.97rem + .15vw,1.075rem);line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg,video{display:block;max-width:100%;height:auto}
h1,h2,h3,h4{font-family:var(--ff-head);line-height:1.1;font-weight:600;
  letter-spacing:-.02em;color:var(--ink);margin:0 0 .5em}
h1{font-size:clamp(2.1rem,1.5rem + 3vw,3.6rem);letter-spacing:-.03em}
h2{font-size:clamp(1.7rem,1.25rem + 2vw,2.6rem)}
h3{font-size:clamp(1.25rem,1.05rem + 1vw,1.6rem)}
h4{font-size:1.075rem;letter-spacing:-.01em}
p{margin:0 0 1rem}
a{color:var(--teal-600);text-decoration:none}
a:hover{color:var(--teal-700)}
ul,ol{margin:0 0 1rem;padding-left:1.15rem}
strong{font-weight:600;color:var(--ink)}
hr{border:0;border-top:1px solid var(--line);margin:2.5rem 0}
:focus-visible{outline:3px solid var(--ring);outline-offset:2px;border-radius:4px}
::selection{background:var(--teal);color:#fff}

/* ---- Layout primitives -------------------------------------------------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.wrap-narrow{max-width:760px;margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(3.5rem,2.5rem + 5vw,6.5rem)}
.section-sm{padding-block:clamp(2.5rem,2rem + 3vw,4rem)}
.grid{display:grid;gap:clamp(1.1rem,.8rem + 1.5vw,2rem)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:860px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}
.center{text-align:center}
.lead{font-size:clamp(1.1rem,1rem + .5vw,1.32rem);color:var(--ink-700);line-height:1.55}
.eyebrow{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.16em;
  font-size:.78rem;font-weight:600;color:var(--teal-600);margin:0 0 .9rem;
  display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:1.6rem;height:2px;background:currentColor;opacity:.55;flex:none}
.muted{color:var(--slate)}
.maxch{max-width:62ch}

/* ---- Surfaces ----------------------------------------------------------- */
.bg-sand{background:var(--sand)}
.bg-warm{background:var(--warm)}
.bg-dark{background:var(--steel-800);color:#cfd6dd}
.bg-dark h1,.bg-dark h2,.bg-dark h3,.bg-dark h4{color:#fff}
.bg-dark .eyebrow{color:#5ed0db}
.bg-dark .lead{color:#aeb8c2}
.bg-dark a:not(.btn){color:#5ed0db}
.blueprint{background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:32px 32px}

/* ---- Buttons ------------------------------------------------------------ */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--ff-head);
  font-weight:600;font-size:1rem;line-height:1;padding:.85em 1.4em;border-radius:var(--r-pill);
  border:1px solid transparent;cursor:pointer;transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);
  text-align:center;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--teal-600);color:#fff;box-shadow:var(--sh-1)}
.btn-primary:hover{background:#015561;color:#fff;box-shadow:var(--sh-2);transform:translateY(-2px)}
.btn-amber{background:var(--accent);color:#241a00}
.btn-amber:hover{filter:brightness(1.05);transform:translateY(-2px);color:#241a00}
.btn-ghost{background:transparent;border-color:var(--line-2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal-700);background:var(--teal-050)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:#fff;color:var(--teal-700);transform:translateY(-2px);box-shadow:var(--sh-2)}
.btn-lg{font-size:1.08rem;padding:1.02em 1.7em}
.btn svg{width:18px;height:18px}
.btn-arrow svg{transition:transform var(--t-fast)}
.site-footer p svg{width:18px;height:18px;flex:none;color:#5ed0db}
.btn:hover .btn-arrow svg{transform:translateX(3px)}

/* ---- Header / nav ------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line);
  transition:box-shadow var(--t-fast)}
.site-header.scrolled{background:#fff;box-shadow:var(--sh-1)}
.nav{display:flex;align-items:center;gap:1.5rem;height:68px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--ff-head);
  font-weight:700;font-size:1.22rem;letter-spacing:-.02em;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand svg,.brand img{width:34px;height:34px}
.brand b{color:var(--teal)}
.nav-list{display:flex;align-items:center;gap:.35rem;list-style:none;margin:0;padding:0;flex:1}
.nav-list>li{position:relative}
.nav-link{display:inline-flex;align-items:center;gap:.3rem;padding:.5rem .7rem;border-radius:var(--r-sm);
  font-weight:500;color:var(--ink-700);font-size:.97rem;cursor:pointer}
.nav-link:hover,.nav-link[aria-current=page]{color:var(--teal-700);background:var(--teal-050)}
.nav-link svg{width:13px;height:13px;opacity:.6;transition:transform var(--t-fast)}
.has-menu:hover .nav-link svg,.has-menu:focus-within .nav-link svg{transform:rotate(180deg)}
.submenu{position:absolute;top:calc(100% + 8px);left:0;min-width:280px;background:#fff;
  border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-2);padding:.5rem;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:all var(--t-fast);list-style:none;margin:0}
.has-menu:hover .submenu,.has-menu:focus-within .submenu{opacity:1;visibility:visible;transform:none}
.submenu a{display:block;padding:.6rem .75rem;border-radius:var(--r-sm);color:var(--ink-700);font-weight:500;font-size:.95rem}
.submenu a:hover{background:var(--sand);color:var(--teal-700)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem;color:var(--ink)}
.nav-toggle svg{width:26px;height:26px}
@media (max-width:1080px){
  .nav-toggle{display:inline-flex}
  .nav-list{position:fixed;inset:68px 0 auto 0;flex-direction:column;align-items:stretch;
    background:#fff;border-bottom:1px solid var(--line);padding:1rem var(--gut);gap:.2rem;
    transform:translateY(-12px);opacity:0;visibility:hidden;transition:all var(--t);max-height:calc(100vh - 68px);overflow:auto}
  .nav[data-open=true] .nav-list{transform:none;opacity:1;visibility:visible}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;
    border:0;border-left:2px solid var(--teal-050);border-radius:0;padding:0 0 0 .75rem;margin:.2rem 0 .5rem}
  .nav-cta .btn-ghost{display:none}
}

/* ---- Hero --------------------------------------------------------------- */
.hero{position:relative;overflow:hidden;background:var(--steel-900);color:#fff;isolation:isolate}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media img,.hero-media video{width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(105deg,rgba(10,14,18,.92) 0%,rgba(12,20,26,.78) 42%,rgba(1,60,68,.45) 100%)}
.hero .wrap{padding-block:clamp(4rem,3rem + 9vw,8.5rem)}
.hero h1{color:#fff;max-width:16ch}
.hero .lead{color:#cfd9e0;max-width:54ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem}
.hero-trust{margin-top:2.2rem;display:flex;flex-wrap:wrap;gap:1.4rem 2rem;align-items:center;color:#9fb0bd;font-size:.92rem}
.hero-trust b{color:#fff}

/* ---- Cards -------------------------------------------------------------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;
  box-shadow:var(--sh-1);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.card-hover:hover{transform:translateY(-4px);box-shadow:var(--sh-2);border-color:var(--line-2)}
.card .ico{width:48px;height:48px;display:grid;place-items:center;border-radius:12px;
  background:var(--teal-050);color:var(--teal-700);margin-bottom:1rem}
.card .ico svg{width:26px;height:26px}
.kpi{font-family:var(--ff-head);font-weight:700;font-size:clamp(2.2rem, 1.5rem + 2.5vw, 3.2rem);
  color:var(--teal);line-height:1;letter-spacing:-.03em}
.kpi-label{color:var(--slate);font-size:.95rem;margin-top:.35rem}

/* ---- Badges / chips ----------------------------------------------------- */
.badge{display:inline-flex;align-items:center;gap:.4em;font-family:var(--ff-head);font-weight:600;
  font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:.3em .7em;border-radius:var(--r-pill)}
.badge-teal{background:var(--teal-050);color:var(--teal-700)}
.badge-amber{background:#fdecc8;color:#7a5200}
.badge-good{background:#e3f5ec;color:#0d6b45}
.tag{display:inline-block;font-size:.8rem;color:var(--slate);background:var(--sand-2);
  padding:.25em .65em;border-radius:var(--r-pill)}

/* ---- Pricing ------------------------------------------------------------ */
.toggle{display:inline-flex;align-items:center;gap:.9rem;background:#fff;border:1px solid var(--line);
  padding:.4rem;border-radius:var(--r-pill);box-shadow:var(--sh-1)}
.toggle button{border:0;background:none;font-family:var(--ff-head);font-weight:600;cursor:pointer;
  padding:.55rem 1.1rem;border-radius:var(--r-pill);color:var(--slate);transition:all var(--t-fast)}
.toggle button[aria-pressed=true]{background:var(--ink);color:#fff}
.toggle .save{font-size:.7rem;font-weight:700;background:#d9f2e4;color:#0b6b43;padding:.12em .45em;border-radius:5px;margin-left:.1em}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;align-items:start}
@media (max-width:920px){.price-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}
.plan{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.7rem;
  display:flex;flex-direction:column;box-shadow:var(--sh-1);position:relative}
.plan.featured{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal),var(--sh-2);transform:translateY(-6px)}
@media(max-width:920px){.plan.featured{transform:none}}
.plan .pop{position:absolute;top:-12px;left:50%;transform:translateX(-50%)}
.plan h3{margin-bottom:.15rem}
.plan .tl{color:var(--slate);font-size:.95rem;margin-bottom:1rem}
.plan .price{font-family:var(--ff-head);font-weight:700;font-size:2.6rem;color:var(--ink);letter-spacing:-.03em;line-height:1}
.plan .price .per{font-size:1rem;color:var(--slate);font-weight:500}
.plan .billed{font-size:.9rem;color:var(--slate);margin:.35rem 0 1.2rem}
.plan ul{list-style:none;padding:0;margin:0 0 1.4rem;display:grid;gap:.6rem}
.plan li{display:flex;gap:.6rem;align-items:flex-start;font-size:.96rem;color:var(--ink-700)}
.plan li svg{flex:none;width:18px;height:18px;color:var(--teal);margin-top:.15rem}
.plan .btn{margin-top:auto}

/* ---- Feature matrix / tables ------------------------------------------- */
.matrix{width:100%;border-collapse:collapse;font-size:.95rem}
.matrix th,.matrix td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--line)}
.matrix thead th{font-family:var(--ff-head);background:var(--sand)}
.matrix tbody th{font-weight:500;color:var(--ink-700)}
.matrix td{text-align:center}
.matrix .yes{color:var(--good)}
.matrix .no{color:var(--line-2)}

/* ---- Logo marquee (social proof) --------------------------------------- */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;align-items:center;gap:clamp(2.5rem, 1.5rem + 3vw, 4.5rem);width:max-content;animation:marquee 36s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-logo{height:34px;width:auto;filter:grayscale(1);opacity:.55;transition:filter var(--t),opacity var(--t)}
.marquee-logo:hover{filter:grayscale(0);opacity:1}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;flex-wrap:wrap;justify-content:center}}

/* ---- Accordion (FAQ) ---------------------------------------------------- */
.acc{border:1px solid var(--line);border-radius:var(--r);background:#fff;overflow:hidden}
.acc+.acc{margin-top:.7rem}
.acc summary{list-style:none;cursor:pointer;padding:1.1rem 1.3rem;font-family:var(--ff-head);
  font-weight:600;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.acc summary::-webkit-details-marker{display:none}
.acc summary .pm{flex:none;width:22px;height:22px;position:relative;transition:transform var(--t)}
.acc summary .pm::before,.acc summary .pm::after{content:"";position:absolute;background:var(--teal);
  inset:50% 2px auto 2px;height:2px;transform:translateY(-50%)}
.acc summary .pm::after{transform:translateY(-50%) rotate(90deg);transition:transform var(--t)}
.acc[open] summary .pm::after{transform:translateY(-50%) rotate(0)}
.acc .acc-body{padding:0 1.3rem 1.2rem;color:var(--ink-700)}

/* ---- Steps / process ---------------------------------------------------- */
.steps{counter-reset:s;display:grid;gap:1.2rem}
.step{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:start}
.step .n{counter-increment:s;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:var(--ink);color:#fff;font-family:var(--ff-head);font-weight:700}
.step .n::before{content:counter(s)}
.step-h{font-size:1.075rem;letter-spacing:-.01em;margin:0}

/* ---- Testimonials ------------------------------------------------------- */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--sh-1)}
.quote .qmark{width:34px;height:34px;margin-bottom:.4rem}
.quote p{font-size:1.05rem;color:var(--ink);line-height:1.55}
.quote .who{display:flex;align-items:center;gap:.8rem;margin-top:1.1rem}
.quote .who img{width:46px;height:46px;border-radius:50%;object-fit:cover}
.quote .who b{display:block;font-size:.95rem}
.quote .who span{font-size:.85rem;color:var(--slate)}

/* ---- CTA band ----------------------------------------------------------- */
.cta-band{background:linear-gradient(120deg,var(--teal-700),var(--teal));color:#fff;border-radius:var(--r-lg);
  padding:clamp(2rem,1.5rem + 3vw,3.5rem);text-align:center;position:relative;overflow:hidden}
.cta-band h2{color:#fff}
.cta-band p{color:#dff1f3;max-width:54ch;margin-inline:auto}

/* ---- Footer ------------------------------------------------------------- */
.site-footer{background:var(--steel-900);color:#9fb0bd;padding-block:3.5rem 2rem;font-size:.95rem}
.site-footer h3{color:#fff;font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem}
.site-footer a{color:#aeb8c2;display:block;padding:.28rem 0}
.site-footer a:hover{color:#5ed0db}
.footer-grid{display:grid;grid-template-columns:1.6fr repeat(3,1fr);gap:2rem}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);color:#7c858f;font-size:.86rem}
.footer-brand{display:flex;align-items:center;gap:.6rem;font-family:var(--ff-head);font-weight:700;color:#fff;font-size:1.2rem;margin-bottom:.8rem}
.footer-brand{font-size:1.35rem}
.footer-brand img{width:46px;height:46px}

/* ---- Breadcrumb --------------------------------------------------------- */
.crumb{font-size:.85rem;color:var(--slate);padding-block:1rem .25rem}
.crumb a{color:var(--slate)}.crumb a:hover{color:var(--teal-700)}

/* ---- Reveal-on-scroll --------------------------------------------------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---- Forms -------------------------------------------------------------- */
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:600;font-size:.92rem;margin-bottom:.35rem;font-family:var(--ff-head)}
.field input,.field select,.field textarea{width:100%;font:inherit;color:var(--ink);background:#fff;
  border:1px solid var(--line-2);border-radius:var(--r-sm);padding:.75rem .9rem;transition:border var(--t-fast),box-shadow var(--t-fast)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--ring)}
.field textarea{min-height:130px;resize:vertical}
.field .hint{font-size:.82rem;color:var(--mute);margin-top:.3rem}
.field .err{font-size:.82rem;color:#c0392b;margin-top:.3rem;display:none}
.field.invalid input,.field.invalid textarea,.field.invalid select{border-color:#c0392b}
.field.invalid .err{display:block}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.85rem;color:var(--mute)}
.form-ok,.form-bad{padding:1rem 1.2rem;border-radius:var(--r);margin-bottom:1rem;display:none}
.form-ok{background:#e3f5ec;color:#0d6b45;border:1px solid #b7e3cb}
.form-bad{background:#fdecec;color:#a3271c;border:1px solid #f3c4bf}

/* ---- Modal (in-system, not library-looking) ---------------------------- */
.modal-root{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:1.2rem;
  background:rgba(12,18,22,.55);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity var(--t)}
.modal-root[data-open=true]{opacity:1;visibility:visible}
.modal{background:#fff;border-radius:var(--r-lg);max-width:560px;width:100%;box-shadow:var(--sh-3);
  padding:clamp(1.4rem,1rem + 2vw,2.2rem);transform:translateY(18px) scale(.98);transition:transform var(--t);max-height:90vh;overflow:auto}
.modal-root[data-open=true] .modal{transform:none}
.modal h3{margin-top:0}
.modal .x{position:absolute;top:0;right:0}
@media (prefers-reduced-motion:reduce){.modal,.modal-root{transition:none}.modal{transform:none}}

/* ---- Tools (estimator / scorecard / slider) ----------------------------- */
.tool{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-2);overflow:hidden;color:var(--ink)}
.tool-head{padding:1.4rem 1.6rem;border-bottom:1px solid var(--line);background:var(--sand)}
.tool-body{padding:1.6rem}
.opt-row{display:flex;flex-wrap:wrap;gap:.6rem;margin:.5rem 0 1.4rem}
.chip{border:1px solid var(--line-2);background:#fff;border-radius:var(--r-pill);padding:.55rem 1rem;
  font-weight:500;cursor:pointer;font-size:.95rem;transition:all var(--t-fast);user-select:none}
.chip[aria-pressed=true]{background:var(--teal-600);color:#fff;border-color:var(--teal-600)}
.chip:hover{border-color:var(--teal)}
.range{width:100%;accent-color:var(--teal)}
.result{background:var(--sand);border-radius:var(--r);padding:1.3rem;margin-top:1rem}
.bars{display:grid;gap:.7rem;margin:1rem 0}
.bar{height:38px;border-radius:8px;display:flex;align-items:center;padding:0 .8rem;color:#fff;
  font-weight:600;font-family:var(--ff-head);white-space:nowrap;transition:width .5s cubic-bezier(.2,.7,.2,1)}
.bar.them{background:var(--ink-700)}.bar.us{background:var(--teal-600)}

/* ---- Utility ------------------------------------------------------------ */
.stack-sm>*+*{margin-top:.6rem}.stack>*+*{margin-top:1.2rem}
.flex{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.between{justify-content:space-between}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.pill-list{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}
.skip{position:absolute;left:-999px;top:0;background:#fff;padding:.6rem 1rem;z-index:200}
.skip:focus{left:8px;top:8px}
.icon-list{list-style:none;padding:0;display:grid;gap:.7rem}
.icon-list li{display:flex;gap:.65rem;align-items:flex-start}
.icon-list svg{flex:none;width:20px;height:20px;color:var(--teal);margin-top:.2rem}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem, 1.5rem + 4vw, 5rem);align-items:center}
.split>*{min-width:0}
@media(max-width:840px){.split{grid-template-columns:1fr}}
.ratio{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-2)}
.ratio img{width:100%;height:100%;object-fit:cover}
.prose h2{margin-top:2.2rem}.prose h3{margin-top:1.6rem}
.prose ul li,.prose ol li{margin-bottom:.4rem}
.prose img{border-radius:var(--r);margin:1.5rem 0}
.article-meta{color:var(--slate);font-size:.9rem;display:flex;gap:1rem;flex-wrap:wrap;align-items:center}

/* ---- A11y helpers ---- */
.vh{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.prose a,p a:not(.btn):not(.nav-link){text-decoration:underline;text-underline-offset:.15em}
.crumb a,.article-meta a{text-decoration:none}

/* ---- Invisible Turnstile: collapse when nothing is shown ---- */
.field:has(> .cf-turnstile){margin-bottom:0}
.cf-turnstile:empty{display:none}
.cf-turnstile:not(:empty){margin-bottom:1.1rem;display:block}

/* ---- Monogram avatar (initials) for testimonials ---- */
.mono{flex:none;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  color:#fff;font-family:var(--ff-head);font-weight:700;font-size:1rem;letter-spacing:.02em}
