/* ============================================================
   GLP Finder — design system
   Palette: violet gradients (#6d28d9 → #5b21b6), app-like cards
   on soft grey; deep-space dark mode.
   Fonts: Plus Jakarta Sans (display/UI) + Gelasio (body).
   ============================================================ */

:root{
  --bg:#f4f3f8;
  --bg-raise:#eceaf4;
  --card:#ffffff;
  --card-2:#faf9fd;
  --ink:#221a3a;
  --ink-soft:#4e4668;
  --ink-faint:#847d9c;
  --line:#e4e1ee;
  --line-strong:#d4cfe4;
  --accent:#6d28d9;
  --accent-2:#5b21b6;
  --accent-ink:#5b21b6;
  --accent-soft:#f0eafc;
  --accent-softer:#f7f4fe;
  --on-accent:#ffffff;
  --grad:linear-gradient(135deg,#6d28d9 0%,#5b21b6 100%);
  --grad-soft:linear-gradient(135deg,#f4effe 0%,#ece4fb 100%);
  --good:#0e7a5f;
  --good-soft:#e5f5ef;
  --warn:#9a5b00;
  --warn-soft:#fdf3e2;
  --star:#d97706;
  --rec-bg:#f6f1ff;
  --rec-line:#c8b1f2;
  --shadow-sm:0 1px 2px rgba(34,26,58,.06),0 2px 8px rgba(34,26,58,.05);
  --shadow-md:0 2px 6px rgba(34,26,58,.07),0 10px 28px rgba(34,26,58,.09);
  --shadow-lg:0 4px 12px rgba(45,20,90,.10),0 22px 48px rgba(45,20,90,.14);
  --radius:18px;
  --radius-sm:12px;
  --radius-pill:999px;
  --font-display:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-body:Gelasio,Georgia,'Times New Roman',serif;
  --wrap:1120px;
  color-scheme:light;
}

/* Deep-space dark mode: system preference… */
@media (prefers-color-scheme:dark){
  :root:not([data-theme="light"]){
    --bg:#0a0618;
    --bg-raise:#110b24;
    --card:#161028;
    --card-2:#1c1533;
    --ink:#ede9fb;
    --ink-soft:#bdb3dc;
    --ink-faint:#8b81ad;
    --line:#292045;
    --line-strong:#382c5c;
    --accent:#8b5cf6;
    --accent-2:#7c3aed;
    --accent-ink:#c4b0f7;
    --accent-soft:#251a48;
    --accent-softer:#1d1538;
    --on-accent:#ffffff;
    --grad:linear-gradient(135deg,#6d28d9 0%,#4c1d95 100%);
    --grad-soft:linear-gradient(135deg,#1f1740 0%,#170f30 100%);
    --good:#4fd1a5;
    --good-soft:#12302a;
    --warn:#f3b95e;
    --warn-soft:#332510;
    --star:#fbbf24;
    --rec-bg:#221643;
    --rec-line:#5b3fa8;
    --shadow-sm:0 1px 2px rgba(0,0,0,.4),0 2px 8px rgba(0,0,0,.35);
    --shadow-md:0 2px 6px rgba(0,0,0,.45),0 12px 30px rgba(0,0,0,.5);
    --shadow-lg:0 4px 14px rgba(0,0,0,.5),0 26px 56px rgba(0,0,0,.55);
    color-scheme:dark;
  }
}
/* …and explicit toggle override */
:root[data-theme="dark"]{
  --bg:#0a0618;
  --bg-raise:#110b24;
  --card:#161028;
  --card-2:#1c1533;
  --ink:#ede9fb;
  --ink-soft:#bdb3dc;
  --ink-faint:#8b81ad;
  --line:#292045;
  --line-strong:#382c5c;
  --accent:#8b5cf6;
  --accent-2:#7c3aed;
  --accent-ink:#c4b0f7;
  --accent-soft:#251a48;
  --accent-softer:#1d1538;
  --on-accent:#ffffff;
  --grad:linear-gradient(135deg,#6d28d9 0%,#4c1d95 100%);
  --grad-soft:linear-gradient(135deg,#1f1740 0%,#170f30 100%);
  --good:#4fd1a5;
  --good-soft:#12302a;
  --warn:#f3b95e;
  --warn-soft:#332510;
  --star:#fbbf24;
  --rec-bg:#221643;
  --rec-line:#5b3fa8;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4),0 2px 8px rgba(0,0,0,.35);
  --shadow-md:0 2px 6px rgba(0,0,0,.45),0 12px 30px rgba(0,0,0,.5);
  --shadow-lg:0 4px 14px rgba(0,0,0,.5),0 26px 56px rgba(0,0,0,.55);
  color-scheme:dark;
}

/* ---------- base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:1.0625rem;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.q-card,.btn,.badge,.nav,.brand,.code-chip,.step-num{font-family:var(--font-display)}
h1{font-size:clamp(1.9rem,4.5vw,3rem);line-height:1.12;letter-spacing:-.02em;font-weight:800;margin:.2em 0 .45em}
h2{font-size:clamp(1.4rem,3vw,1.9rem);line-height:1.2;letter-spacing:-.01em;font-weight:800;margin:0 0 .5em}
h3{font-size:1.15rem;font-weight:700;margin:1.2em 0 .4em}
p{margin:.75em 0}
a{color:var(--accent-ink);text-decoration-thickness:1px;text-underline-offset:2px}
a:hover{color:var(--accent)}
img,svg{max-width:100%}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}
main.wrap{padding-top:1.5rem;padding-bottom:3rem}
section{margin:3.25rem 0}
:target{scroll-margin-top:90px}
.eyebrow{
  display:inline-block;font-family:var(--font-display);font-weight:700;
  font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-ink);background:var(--accent-soft);
  padding:.3rem .8rem;border-radius:var(--radius-pill);margin-bottom:.9rem;
}
.lede{font-size:1.17rem;color:var(--ink-soft)}
.muted{color:var(--ink-faint);font-size:.92rem}

/* ---------- header ---------- */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.65rem clamp(16px,3vw,32px);
  background:color-mix(in srgb,var(--card) 88%,transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--ink);font-weight:800;font-size:1.12rem;letter-spacing:-.01em}
.brand-mark{flex:0 0 auto;display:block}
.brand em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.topbar-right{display:flex;align-items:center;gap:.5rem}
.nav{display:flex;align-items:center;gap:.25rem}
.nav-link{
  font-weight:600;font-size:.94rem;text-decoration:none;color:var(--ink-soft);
  padding:.45rem .75rem;border-radius:var(--radius-pill);
}
.nav-link:hover{color:var(--accent-ink);background:var(--accent-soft)}
.nav-link.nav-cta{background:var(--grad);color:var(--on-accent);box-shadow:var(--shadow-sm)}
.nav-link.nav-cta:hover{color:var(--on-accent);filter:brightness(1.08)}
.icon-btn{
  border:1px solid var(--line);background:var(--card);color:var(--ink);
  width:38px;height:38px;border-radius:12px;cursor:pointer;font-size:1rem;
  display:inline-flex;align-items:center;justify-content:center;
}
.icon-btn:hover{border-color:var(--accent);color:var(--accent-ink)}
.nav-toggle{display:none}
@media (max-width:860px){
  .nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:.15rem;
    background:var(--card);border-bottom:1px solid var(--line);
    padding:.8rem 1rem 1rem;box-shadow:var(--shadow-md);
  }
  .nav.open{display:flex}
  .nav-link{padding:.7rem .9rem;border-radius:var(--radius-sm)}
  .nav-toggle{display:inline-flex}
}

/* ---------- hero ---------- */
.hero{
  background:var(--grad);
  color:#fff;
  padding:clamp(2.4rem,6vw,4.2rem) 0 clamp(4rem,7vw,5.2rem);
  position:relative;overflow:hidden;
}
.hero::after{ /* soft glow */
  content:"";position:absolute;inset:auto -15% -60% -15%;height:120%;
  background:radial-gradient(closest-side,rgba(255,255,255,.14),transparent 70%);
  pointer-events:none;
}
.hero .eyebrow{background:rgba(255,255,255,.16);color:#fff}
.hero h1{color:#fff;max-width:16em}
.hero .hero-sub{max-width:44em;font-size:1.15rem;color:rgba(255,255,255,.88)}
.hero-stats{display:flex;flex-wrap:wrap;gap:1.8rem;margin:1.6rem 0 1.4rem}
.hero-stat b{display:block;font-family:var(--font-display);font-size:1.7rem;font-weight:800;line-height:1.1}
.hero-stat span{font-size:.85rem;color:rgba(255,255,255,.75)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}
.hero-shortcut{
  margin-top:1.1rem;font-size:.95rem;color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  border-radius:var(--radius-sm);padding:.6rem .9rem;display:inline-block;max-width:46em;
}
.hero-shortcut a{color:#fff;font-weight:700}

/* ---------- self-check band (static anchors, no JS needed) ---------- */
.check-band{
  margin-top:-3rem;position:relative;z-index:2;
}
.check-band-inner{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:1.4rem clamp(1rem,3vw,1.8rem) 1.5rem;
}
.check-band-head{display:flex;align-items:baseline;gap:.7rem;flex-wrap:wrap;margin-bottom:1rem}
.check-band-head h2{margin:0;font-size:1.25rem}
.q-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media (max-width:860px){.q-grid{grid-template-columns:1fr}}
.q-card{
  background:var(--card-2);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.6rem;
}
.q-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;background:var(--grad);color:#fff;
  font-size:.8rem;font-weight:800;flex:0 0 auto;
}
.q-card p{margin:0;font-weight:700;font-size:.98rem;line-height:1.4}
.q-answers{display:flex;flex-direction:column;gap:.4rem;margin-top:auto}
.q-answers a{
  display:flex;justify-content:space-between;gap:.6rem;align-items:center;
  text-decoration:none;font-size:.88rem;font-weight:600;color:var(--accent-ink);
  background:var(--accent-softer);border:1px solid var(--line);
  border-radius:10px;padding:.45rem .7rem;
}
.q-answers a:hover{border-color:var(--accent);background:var(--accent-soft)}
.q-answers .qa-arrow{opacity:.7}

/* ---------- path cards ---------- */
.path-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
@media (max-width:960px){.path-grid{grid-template-columns:1fr}}
.path-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:1.5rem 1.4rem;display:flex;flex-direction:column;
  border-top:4px solid var(--accent);
}
.path-card h3{margin:0 0 .2rem;font-size:1.22rem}
.path-kicker{font-family:var(--font-display);font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-ink)}
.path-drug{color:var(--ink-faint);font-size:.92rem;margin:0 0 .6rem}
.path-facts{list-style:none;margin:.8rem 0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.path-facts li{
  font-size:.93rem;line-height:1.5;padding-left:1.5rem;position:relative;color:var(--ink-soft);
}
.path-facts li::before{content:"→";position:absolute;left:0;color:var(--accent);font-family:var(--font-display);font-weight:700}
.path-price{
  margin:.4rem 0 1rem;background:var(--accent-softer);border:1px dashed var(--line-strong);
  border-radius:var(--radius-sm);padding:.6rem .8rem;font-size:.92rem;
}
.path-price b{font-family:var(--font-display);font-size:1.15rem;color:var(--accent-ink)}
.path-card .btn{margin-top:auto}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  font-weight:700;font-size:.97rem;text-decoration:none;cursor:pointer;
  border-radius:var(--radius-pill);padding:.72rem 1.4rem;border:1px solid transparent;
  transition:filter .15s,transform .15s;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--grad);color:var(--on-accent);box-shadow:var(--shadow-sm)}
.btn-primary:hover{color:var(--on-accent);filter:brightness(1.08)}
.btn-ghost{background:transparent;color:var(--accent-ink);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--accent);background:var(--accent-softer)}
.hero .btn-ghost{color:#fff;border-color:rgba(255,255,255,.45)}
.hero .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-visit{
  display:inline-block;white-space:nowrap;text-decoration:none;
  font-family:var(--font-display);font-weight:700;font-size:.86rem;
  background:var(--accent-soft);color:var(--accent-ink);
  border:1px solid var(--line-strong);border-radius:var(--radius-pill);
  padding:.42rem .95rem;
}
.btn-visit:hover{background:var(--grad);color:var(--on-accent);border-color:transparent}

/* ---------- comparison table ---------- */
.table-meta{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;margin:.9rem 0 .7rem;font-size:.9rem;color:var(--ink-faint);font-family:var(--font-display)}
.table-scroll{
  overflow-x:auto;border-radius:var(--radius);border:1px solid var(--line);
  background:var(--card);box-shadow:var(--shadow-md);
}
table.cmp{width:100%;border-collapse:collapse;min-width:880px;font-size:.93rem}
table.cmp thead th{
  font-family:var(--font-display);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-faint);text-align:left;padding:.85rem .9rem;
  border-bottom:2px solid var(--line-strong);background:var(--card-2);
  position:sticky;top:0;
}
table.cmp td{padding:.85rem .9rem;border-bottom:1px solid var(--line);vertical-align:top}
table.cmp tbody tr:last-child td{border-bottom:none}
table.cmp tbody tr:hover td{background:var(--accent-softer)}
th.sortable{cursor:pointer;user-select:none}
th.sortable:hover{color:var(--accent-ink)}
th.sortable .arrow{opacity:.55;font-size:.9em}
.prov-name{font-family:var(--font-display);font-weight:700;font-size:1rem;display:block}
.prov-reg{display:block;font-size:.8rem;color:var(--ink-faint);font-family:var(--font-display)}
.price{font-family:var(--font-display);font-weight:800;font-size:1.05rem;white-space:nowrap}
.price-promo{color:var(--good)}
.price-note{display:block;font-size:.78rem;color:var(--ink-faint);font-family:var(--font-display)}
.code-chip{
  display:inline-block;background:var(--good-soft);color:var(--good);
  font-weight:700;font-size:.8rem;letter-spacing:.04em;
  border-radius:6px;padding:.15rem .5rem;
}
tr.rec td{background:var(--rec-bg);border-top:2px solid var(--rec-line);border-bottom:2px solid var(--rec-line)}
tr.rec:hover td{background:var(--rec-bg)}
.badge-rec{
  display:inline-block;background:var(--grad);color:#fff;font-size:.72rem;font-weight:800;
  letter-spacing:.05em;border-radius:var(--radius-pill);padding:.18rem .6rem;
  margin-left:.4rem;vertical-align:middle;white-space:nowrap;
}
.rec-note{display:block;font-size:.8rem;color:var(--accent-ink);font-family:var(--font-display);margin-top:.15rem}
.honesty{font-size:.88rem;color:var(--ink-faint);margin-top:.9rem;max-width:62em}

/* table → stacked cards under 720px */
@media (max-width:720px){
  .table-scroll{overflow:visible;border:none;background:transparent;box-shadow:none}
  table.cmp{min-width:0;display:block}
  table.cmp thead{display:none}
  table.cmp tbody{display:grid;gap:.9rem}
  table.cmp tr{
    display:block;background:var(--card);border:1px solid var(--line);
    border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:.5rem .9rem;
  }
  table.cmp tr.rec{border:2px solid var(--rec-line);background:var(--rec-bg)}
  table.cmp tr.rec td{background:transparent;border-top:none}
  table.cmp td{
    display:flex;justify-content:space-between;gap:1rem;align-items:baseline;
    border-bottom:1px dashed var(--line);padding:.5rem 0;text-align:right;
  }
  table.cmp td:last-child{border-bottom:none;justify-content:flex-end}
  table.cmp td::before{
    content:attr(data-label);font-family:var(--font-display);font-weight:600;
    font-size:.78rem;color:var(--ink-faint);text-align:left;flex:0 0 auto;
  }
  table.cmp tbody tr:hover td{background:transparent}
}

/* ---------- TWC pick panel ---------- */
.pick-panel{
  background:var(--grad);color:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:clamp(1.6rem,4vw,2.6rem);
  display:grid;grid-template-columns:1.6fr 1fr;gap:2rem;align-items:center;
}
@media (max-width:860px){.pick-panel{grid-template-columns:1fr}}
.pick-panel h2{color:#fff;margin-top:0}
.pick-panel p{color:rgba(255,255,255,.88)}
.pick-points{list-style:none;padding:0;margin:1rem 0;display:grid;gap:.55rem}
.pick-points li{padding-left:1.7rem;position:relative;font-size:.98rem}
.pick-points li::before{
  content:"✓";position:absolute;left:0;top:0;
  font-family:var(--font-display);font-weight:800;color:#c9b2f5;
}
.pick-aside{
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);
  border-radius:var(--radius-sm);padding:1.3rem;text-align:center;
}
.pick-aside .big{font-family:var(--font-display);font-weight:800;font-size:2rem;line-height:1}
.pick-aside .code-chip{background:rgba(255,255,255,.92);color:var(--accent-2);font-size:.95rem;padding:.3rem .8rem}
.pick-aside .btn-primary{background:#fff;color:var(--accent-2);margin-top:1rem;width:100%}
.pick-aside .btn-primary:hover{filter:none;background:#f3edff}
.pick-small{font-size:.8rem;color:rgba(255,255,255,.7);margin-top:.7rem}

/* ---------- FAQ ---------- */
.faq{max-width:820px}
.faq-item{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);
  margin-bottom:.8rem;box-shadow:var(--shadow-sm);overflow:hidden;
}
.faq-item summary{
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;
  padding:1rem 1.2rem;font-family:var(--font-display);font-weight:700;font-size:1rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-weight:800;color:var(--accent);font-size:1.2rem;line-height:1}
.faq-item[open] summary::after{content:"–"}
.faq-item[open] summary{color:var(--accent-ink)}
.faq-a{padding:0 1.2rem 1.1rem;color:var(--ink-soft);font-size:.98rem}
.faq-a p{margin:.4em 0}

/* ---------- blog teasers / cards ---------- */
.teaser-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.2rem}
.teaser-card{
  display:flex;flex-direction:column;gap:.5rem;text-decoration:none;color:var(--ink);
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:1.3rem 1.3rem 1.2rem;
  transition:transform .15s,box-shadow .15s;
}
.teaser-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);color:var(--ink)}
.teaser-card h3{margin:0;font-size:1.08rem;line-height:1.35}
.teaser-card:hover h3{color:var(--accent-ink)}
.teaser-meta{font-family:var(--font-display);font-size:.8rem;color:var(--ink-faint)}
.teaser-desc{font-size:.93rem;color:var(--ink-soft);margin:0}
.teaser-more{margin-top:auto;font-family:var(--font-display);font-weight:700;font-size:.88rem;color:var(--accent-ink)}

/* ---------- article & static pages ---------- */
.page-head{padding:2.6rem 0 .4rem}
.crumbs{font-family:var(--font-display);font-size:.85rem;color:var(--ink-faint);margin:1.4rem 0 0}
.crumbs a{color:var(--ink-faint);text-decoration:none}
.crumbs a:hover{color:var(--accent-ink)}
.article-shell{max-width:780px;margin:0 auto}
.article-byline{
  display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;align-items:center;
  font-family:var(--font-display);font-size:.87rem;color:var(--ink-faint);
  border-bottom:1px solid var(--line);padding-bottom:1.1rem;margin-bottom:1.6rem;
}
.article-body h2{margin-top:2.2rem}
.article-body h3{margin-top:1.8rem}
.article-body ul,.article-body ol{padding-left:1.4rem}
.article-body li{margin:.35em 0}
.article-body table{width:100%;border-collapse:collapse;font-size:.92rem;font-family:var(--font-display)}
.article-body .table-scroll{margin:1.4rem 0}
.article-body th{
  text-align:left;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink-faint);background:var(--card-2);padding:.7rem .8rem;border-bottom:2px solid var(--line-strong);
}
.article-body td{padding:.7rem .8rem;border-bottom:1px solid var(--line)}
.article-body tr:last-child td{border-bottom:none}

/* callout — key takeaway */
.callout{
  background:var(--accent-softer);border-left:4px solid var(--accent);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  padding:1rem 1.3rem;margin:1.6rem 0;
}
.callout-title{
  display:block;font-family:var(--font-display);font-weight:800;font-size:.8rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--accent-ink);margin-bottom:.3rem;
}
.callout p{margin:.3em 0}
.callout--warn{background:var(--warn-soft);border-left-color:var(--warn)}
.callout--warn .callout-title{color:var(--warn)}

/* CTA box — The Weight Clinic (mid-article + end-of-article) */
.cta-box{
  background:var(--grad);color:#fff;border-radius:var(--radius);
  padding:1.5rem 1.6rem;margin:2rem 0;box-shadow:var(--shadow-md);
}
.cta-box h3,.cta-box .cta-title{color:#fff;margin:0 0 .35rem;font-family:var(--font-display);font-weight:800;font-size:1.15rem}
.cta-box p{color:rgba(255,255,255,.88);margin:.35em 0 .9em;font-size:.97rem}
.cta-box .btn-primary{background:#fff;color:var(--accent-2)}
.cta-box .btn-primary:hover{filter:none;background:#f3edff}
.cta-box .code-chip{background:rgba(255,255,255,.92);color:var(--accent-2)}

/* inline "decision step" list for guides */
.step-list{list-style:none;counter-reset:step;padding:0;margin:1.4rem 0;display:grid;gap:.9rem}
.step-list>li{
  counter-increment:step;position:relative;padding:1rem 1.2rem 1rem 3.4rem;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);
}
.step-list>li::before{
  content:counter(step);position:absolute;left:1rem;top:1rem;
  width:28px;height:28px;border-radius:50%;background:var(--grad);color:#fff;
  font-family:var(--font-display);font-weight:800;font-size:.85rem;
  display:flex;align-items:center;justify-content:center;
}

/* ---------- contact / info cards ---------- */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;margin:1.6rem 0}
.info-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:1.4rem;
}
.info-card h3{margin-top:0}

/* ---------- footer ---------- */
.footer{background:var(--bg-raise);border-top:1px solid var(--line);margin-top:3rem;font-size:.92rem}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;
  padding:2.6rem 0 1.6rem;
}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr}}
.footer h4{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 .7rem;font-family:var(--font-display)}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}
.footer-links a{text-decoration:none;color:var(--ink-soft);font-family:var(--font-display);font-size:.92rem}
.footer-links a:hover{color:var(--accent-ink)}
.footer-brand p{color:var(--ink-soft);font-size:.93rem;max-width:34em}
.compliance{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:1.3rem 1.4rem;margin-bottom:1.6rem;
}
.compliance h4{margin-top:0}
.compliance p{font-size:.86rem;color:var(--ink-soft);margin:.5em 0;line-height:1.6}
.compliance strong{font-family:var(--font-display);font-size:.95em}
.footer-bottom{
  display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;justify-content:space-between;
  border-top:1px solid var(--line);padding:1.1rem 0 1.6rem;
  color:var(--ink-faint);font-size:.85rem;font-family:var(--font-display);
}
.footer-bottom a{color:var(--ink-faint)}
.footer-bottom a:hover{color:var(--accent-ink)}

/* ---------- utilities ---------- */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;
}
.center{text-align:center}
.mt-0{margin-top:0}
.section-head{max-width:46em;margin-bottom:1.6rem}
.skip-link{
  position:absolute;left:-999px;top:0;background:var(--accent);color:#fff;
  padding:.6rem 1rem;z-index:100;border-radius:0 0 8px 0;
}
.skip-link:focus{left:0}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .btn:hover,.teaser-card:hover{transform:none}
}
