/* ==========================================================================
   Slick Popup — Main stylesheet
   Base + .sp-* component primitives + page sections.
   Fonts are self-hosted; see assets/css/fonts.css.
   ========================================================================== */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:88px}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;transition-duration:.001ms!important}}

body{
  margin:0;
  font-family:var(--sp-font-body);
  font-size:var(--sp-fs-body);
  line-height:1.65;
  color:var(--sp-text);
  background:var(--sp-paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
:focus-visible{outline:2.5px solid var(--sp-accent);outline-offset:3px;border-radius:4px}
::selection{background:var(--sp-accent);color:#fff}

h1,h2,h3,h4{
  font-family:var(--sp-font-display);
  font-weight:600;
  line-height:1.04;
  letter-spacing:-.02em;
  margin:0 0 .5em;
  color:var(--sp-ink);
}
h1{font-size:var(--sp-fs-h1)}
h2{font-size:var(--sp-fs-h2)}
h3{font-size:var(--sp-fs-h3)}
h4{font-size:var(--sp-fs-h4);letter-spacing:-.01em}
p{margin:0 0 1.1em}

/* ---- Layout helpers ---- */
.sp-wrap{max-width:var(--sp-maxw);margin-inline:auto;padding-inline:var(--sp-gutter)}
.sp-narrow{max-width:var(--sp-maxw-text)}
.sp-section{padding-block:var(--sp-section)}
.sp-section--tight{padding-block:clamp(3rem,2rem+4vw,5.5rem)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--sp-ink);color:#fff;padding:.7rem 1.2rem;z-index:200;border-radius:0 0 var(--sp-r-sm) 0}
.skip-link:focus{left:0}

.sp-ink-panel{background:var(--sp-ink);color:var(--sp-text-inv)}
.sp-ink-panel h1,.sp-ink-panel h2,.sp-ink-panel h3,.sp-ink-panel h4{color:#fff}

/* ---- Eyebrow / kicker ---- */
.sp-eyebrow{
  font-family:var(--sp-font-mono);
  font-size:var(--sp-fs-eyebrow);
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--sp-accent);
  display:inline-flex;align-items:center;gap:.55rem;
  margin-bottom:1.1rem;font-weight:600;
}
.sp-eyebrow::before{content:"";width:26px;height:1.5px;background:var(--sp-accent);display:inline-block}
.sp-ink-panel .sp-eyebrow{color:var(--sp-orange)}
.sp-ink-panel .sp-eyebrow::before{background:var(--sp-orange)}

.sp-lead{font-size:var(--sp-fs-lead);color:var(--sp-text-soft);line-height:1.55;max-width:62ch}
.sp-ink-panel .sp-lead{color:var(--sp-text-inv-soft)}

/* ---- Buttons ---- */
.sp-btn{
  --bg:var(--sp-ink);--fg:#fff;
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--bg);color:var(--fg);
  font-family:var(--sp-font-body);font-weight:600;font-size:var(--sp-fs-sm);
  padding:.92rem 1.5rem;border-radius:var(--sp-r-pill);
  border:1.5px solid var(--bg);
  transition:transform .25s var(--sp-ease),box-shadow .25s var(--sp-ease),background .25s,color .25s;
  white-space:nowrap;letter-spacing:.01em;
}
.sp-btn:hover{transform:translateY(-2px);box-shadow:var(--sp-shadow)}
.sp-btn .lucide{width:17px;height:17px}
.sp-btn--accent{--bg:var(--sp-accent);--fg:#fff;border-color:var(--sp-accent)}
.sp-btn--accent:hover{--bg:var(--sp-accent-deep);border-color:var(--sp-accent-deep)}
.sp-btn--ghost{--bg:transparent;--fg:var(--sp-ink);border-color:var(--sp-line)}
.sp-btn--ghost:hover{--bg:var(--sp-ink);--fg:#fff}
.sp-ink-panel .sp-btn--ghost{--fg:#fff;border-color:var(--sp-line-ink)}
.sp-ink-panel .sp-btn--ghost:hover{--bg:#fff;--fg:var(--sp-ink)}
.sp-btn--lg{padding:1.1rem 1.9rem;font-size:var(--sp-fs-body)}

/* ---- Badge / pill ---- */
.sp-badge{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  padding:.34rem .7rem;border-radius:var(--sp-r-pill);
  background:var(--sp-paper-2);color:var(--sp-text-soft);
  border:1px solid var(--sp-line);
}
.sp-badge--accent{background:color-mix(in srgb,var(--sp-accent) 12%,transparent);color:var(--sp-accent-deep);border-color:color-mix(in srgb,var(--sp-accent) 28%,transparent)}
.sp-badge--pro{background:var(--sp-ink);color:#fff;border-color:var(--sp-ink)}

/* ---- Card primitive ---- */
.sp-card{
  background:var(--sp-card);
  border:1px solid var(--sp-line);
  border-radius:var(--sp-r-lg);
  padding:var(--sp-6);
  box-shadow:var(--sp-shadow-sm);
  transition:transform .35s var(--sp-ease),box-shadow .35s var(--sp-ease),border-color .35s;
  position:relative;
}
.sp-card--hover:hover{transform:translateY(-5px);box-shadow:var(--sp-shadow);border-color:color-mix(in srgb,var(--sp-accent) 40%,var(--sp-line))}

/* ============================ HEADER ============================ */
.sp-header{
  position:sticky;top:0;z-index:120;
  background:color-mix(in srgb,var(--sp-paper) 86%,transparent);
  backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s,box-shadow .3s;
}
.sp-header.is-stuck{border-bottom-color:var(--sp-line);box-shadow:0 6px 24px -18px rgba(22,19,18,.5)}
.sp-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:74px}
.sp-logo{display:flex;align-items:center;gap:.6rem;font-family:var(--sp-font-display);font-weight:600;font-size:1.18rem;letter-spacing:-.02em;color:var(--sp-ink)}
.sp-logo__mark{width:34px;height:34px;border-radius:10px;background:var(--sp-ink);display:grid;place-items:center;color:#fff;position:relative;overflow:hidden}
.sp-logo__mark::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 25%,var(--sp-red),transparent 60%)}
.sp-logo__mark svg{width:18px;height:18px;position:relative;z-index:1}
.sp-logo b{color:var(--sp-accent)}
.sp-nav{display:flex;align-items:center;gap:.3rem}
.sp-nav a{font-size:var(--sp-fs-sm);font-weight:500;color:var(--sp-text-soft);padding:.5rem .8rem;border-radius:var(--sp-r-pill);transition:color .2s,background .2s}
.sp-nav a:hover,.sp-nav .current-menu-item>a,.sp-nav a[aria-current]{color:var(--sp-ink);background:var(--sp-paper-2)}
.sp-header__cta{display:flex;align-items:center;gap:.7rem}
.sp-burger{display:none;width:44px;height:44px;border:1px solid var(--sp-line);border-radius:12px;background:var(--sp-card);place-items:center}
.sp-burger svg{width:20px;height:20px}

@media(max-width:960px){
  .sp-nav,.sp-header__cta .sp-btn--ghost{display:none}
  .sp-burger{display:grid}
  .sp-mobile{position:fixed;inset:74px 0 auto;background:var(--sp-paper);border-bottom:1px solid var(--sp-line);padding:1.25rem var(--sp-gutter) 2rem;transform:translateY(-120%);transition:transform .4s var(--sp-ease-out);z-index:110;box-shadow:var(--sp-shadow)}
  .sp-mobile.is-open{transform:translateY(0)}
  .sp-mobile a{display:block;padding:.85rem .25rem;font-size:1.15rem;font-family:var(--sp-font-display);border-bottom:1px solid var(--sp-line);color:var(--sp-ink)}
  .sp-mobile .sp-btn{width:100%;justify-content:center;margin-top:1.1rem}
}
@media(min-width:961px){.sp-mobile{display:none}}

/* ============================ HERO ============================ */
.sp-hero{position:relative;padding-block:clamp(4rem,3rem+6vw,8rem) clamp(3rem,2rem+5vw,6rem);overflow:hidden}
.sp-hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(60% 50% at 80% 8%,color-mix(in srgb,var(--orange-500) 18%,transparent),transparent 70%),
    radial-gradient(50% 45% at 10% 90%,color-mix(in srgb,var(--orange-400) 14%,transparent),transparent 70%);
}
.sp-hero__grid{position:absolute;inset:0;z-index:-1;opacity:.5;
  background-image:linear-gradient(var(--sp-line) 1px,transparent 1px),linear-gradient(90deg,var(--sp-line) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(70% 60% at 50% 35%,#000,transparent 80%);
  mask-image:radial-gradient(70% 60% at 50% 35%,#000,transparent 80%);
}
.sp-hero__inner{max-width:980px}
.sp-hero h1{font-size:var(--sp-fs-mega);margin-bottom:.35em}
.sp-hero h1 em{font-style:normal;color:var(--sp-accent);position:relative}
.sp-hero h1 .sp-underline{display:inline-block;position:relative}
.sp-hero h1 .sp-underline::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.16em;background:var(--sp-orange);border-radius:4px;z-index:-1;opacity:.55}
.sp-hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem;align-items:center}
.sp-hero__meta{display:flex;flex-wrap:wrap;gap:1.4rem 2.4rem;margin-top:2.6rem;padding-top:1.8rem;border-top:1px solid var(--sp-line)}
.sp-hero__meta div{display:flex;flex-direction:column}
.sp-hero__meta b{font-family:var(--sp-font-display);font-size:1.6rem;color:var(--sp-ink);line-height:1}
.sp-hero__meta span{font-size:var(--sp-fs-xs);color:var(--sp-text-mute);text-transform:uppercase;letter-spacing:.1em;font-family:var(--sp-font-mono);margin-top:.35rem}

/* Reveal on load */
.sp-reveal{opacity:0;transform:translateY(22px);animation:sp-rise .8s var(--sp-ease-out) forwards}
@keyframes sp-rise{to{opacity:1;transform:none}}
.sp-reveal[data-d="1"]{animation-delay:.06s}.sp-reveal[data-d="2"]{animation-delay:.14s}
.sp-reveal[data-d="3"]{animation-delay:.22s}.sp-reveal[data-d="4"]{animation-delay:.3s}
.sp-reveal[data-d="5"]{animation-delay:.38s}

/* Scroll-in */
.sp-in{opacity:0;transform:translateY(28px);transition:opacity .7s var(--sp-ease-out),transform .7s var(--sp-ease-out)}
.sp-in.is-vis{opacity:1;transform:none}

/* ============================ SECTION HEAD ============================ */
.sp-shead{max-width:680px;margin-bottom:clamp(2.2rem,1.5rem+2vw,3.5rem)}
.sp-shead--center{margin-inline:auto;text-align:center}
.sp-shead--center .sp-eyebrow{justify-content:center}

/* ============================ DEMO GALLERY ============================ */
.sp-demogrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:1.1rem}
.sp-demo{
  display:flex;flex-direction:column;gap:.9rem;text-align:left;
  background:var(--sp-card);border:1px solid var(--sp-line);border-radius:var(--sp-r-lg);
  padding:1.6rem;min-height:172px;position:relative;overflow:hidden;
  transition:transform .35s var(--sp-ease),box-shadow .35s var(--sp-ease),border-color .35s;
}
.sp-demo::after{content:"";position:absolute;right:-30%;top:-30%;width:60%;height:60%;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--demo-c,var(--orange-500)) 26%,transparent),transparent 70%);
  opacity:0;transition:opacity .4s}
.sp-demo:hover{transform:translateY(-5px);box-shadow:var(--sp-shadow);border-color:color-mix(in srgb,var(--demo-c,var(--orange-500)) 45%,var(--sp-line))}
.sp-demo:hover::after{opacity:1}
.sp-demo__ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;background:var(--demo-c,var(--orange-500));box-shadow:0 8px 18px -8px var(--demo-c,var(--orange-500))}
.sp-demo__ico svg{width:22px;height:22px}
.sp-demo h4{margin:0;font-size:1.12rem}
.sp-demo__tag{margin-top:auto;display:inline-flex;align-items:center;gap:.35rem;font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);color:var(--sp-text-mute);font-weight:600;letter-spacing:.04em}
.sp-demo:hover .sp-demo__tag{color:var(--demo-c,var(--orange-500))}
.sp-demo__tag svg{width:14px;height:14px;transition:transform .3s}
.sp-demo:hover .sp-demo__tag svg{transform:translateX(4px)}

/* ============================ COLORS & ANIMATIONS ============================ */
.sp-ca{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,1rem+3vw,3.5rem);align-items:start}
@media(max-width:860px){.sp-ca{grid-template-columns:1fr}}
.sp-swatches{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.4rem}
.sp-swatch{display:flex;align-items:center;gap:.6rem;padding:.55rem .9rem .55rem .6rem;border-radius:var(--sp-r-pill);background:var(--sp-card);border:1px solid var(--sp-line);font-size:var(--sp-fs-sm);font-weight:600}
.sp-swatch i{width:22px;height:22px;border-radius:50%;display:block;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
.sp-swatch--custom i{background:conic-gradient(var(--sp-red),var(--sp-orange),var(--sp-green),var(--sp-blue),var(--sp-red))}
.sp-anims{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.4rem}
.sp-chip{font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);font-weight:600;letter-spacing:.03em;
  padding:.5rem .85rem;border-radius:var(--sp-r-sm);background:var(--sp-paper-2);border:1px solid var(--sp-line);color:var(--sp-text-soft);
  transition:transform .2s var(--sp-ease),background .2s,color .2s,border-color .2s}
.sp-chip:hover{transform:translateY(-2px) rotate(-1.5deg);background:var(--sp-ink);color:#fff;border-color:var(--sp-ink)}

/* ============================ STATS ============================ */
.sp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--sp-line-ink);border-radius:var(--sp-r-lg);overflow:hidden;border:1px solid var(--sp-line-ink)}
@media(max-width:680px){.sp-stats{grid-template-columns:1fr}}
.sp-stat{background:var(--sp-ink-soft);padding:clamp(2rem,1.5rem+2vw,3.2rem);text-align:center}
.sp-stat b{display:block;font-family:var(--sp-font-display);font-weight:600;font-size:clamp(2.6rem,1.8rem+3vw,4rem);color:#fff;line-height:1;letter-spacing:-.03em}
.sp-stat b sup{color:var(--orange-400);font-size:.5em;vertical-align:super}
.sp-stat span{display:block;margin-top:.7rem;font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--sp-text-inv-soft)}

/* ============================ FEATURES ============================ */
.sp-fgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.1rem}
.sp-feature{padding:1.7rem;border-radius:var(--sp-r-lg);background:var(--sp-card);border:1px solid var(--sp-line);transition:border-color .3s,transform .3s var(--sp-ease)}
.sp-feature:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--sp-accent) 35%,var(--sp-line))}
.sp-feature__ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;margin-bottom:1.1rem;background:color-mix(in srgb,var(--sp-accent) 12%,transparent);color:var(--sp-accent-deep)}
.sp-feature__ico svg{width:21px;height:21px}
.sp-feature h4{margin:0 0 .4rem;font-size:1.12rem}
.sp-feature p{margin:0;color:var(--sp-text-soft);font-size:var(--sp-fs-sm);line-height:1.55}

/* ============================ MORE OPTIONS ============================ */
.sp-more{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media(max-width:780px){.sp-more{grid-template-columns:1fr}}
.sp-morecard{display:flex;flex-direction:column;gap:1rem;padding:clamp(1.8rem,1.4rem+1.5vw,2.6rem);border-radius:var(--sp-r-lg);background:var(--sp-card);border:1px solid var(--sp-line);position:relative;overflow:hidden;transition:transform .35s var(--sp-ease),box-shadow .35s}
.sp-morecard:hover{transform:translateY(-4px);box-shadow:var(--sp-shadow)}
.sp-morecard__num{font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);color:var(--sp-text-mute);letter-spacing:.1em}
.sp-morecard h3{margin:0;font-size:var(--sp-fs-h3)}
.sp-morecard p{margin:0;color:var(--sp-text-soft)}
.sp-morecard__link{margin-top:auto;display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--sp-accent-deep);font-size:var(--sp-fs-sm)}
.sp-morecard__link svg{width:16px;height:16px;transition:transform .3s}
.sp-morecard:hover .sp-morecard__link svg{transform:translateX(4px)}

/* ============================ LITE VS PRO ============================ */
.sp-compare{overflow:hidden;border:1px solid var(--sp-line);border-radius:var(--sp-r-lg);background:var(--sp-card)}
.sp-compare table{width:100%;border-collapse:collapse;font-size:var(--sp-fs-sm)}
.sp-compare th,.sp-compare td{padding:1rem 1.2rem;text-align:left;border-bottom:1px solid var(--sp-line)}
.sp-compare thead th{font-family:var(--sp-font-display);font-size:1.05rem;color:var(--sp-ink);background:var(--sp-paper-2)}
.sp-compare thead th:last-child{background:var(--sp-ink);color:#fff;position:relative}
.sp-compare tbody tr:last-child td{border-bottom:0}
.sp-compare td:first-child{font-weight:600;color:var(--sp-text)}
.sp-compare td.cell{text-align:center;width:130px}
.sp-compare .yes{color:var(--sp-green)}
.sp-compare .no{color:var(--sp-text-mute)}
.sp-compare td.cell svg{width:18px;height:18px;display:inline-block}
.sp-compare .col-pro{background:color-mix(in srgb,var(--sp-ink) 4%,transparent)}
@media(max-width:620px){.sp-compare{overflow-x:auto}.sp-compare table{min-width:520px}}

/* ============================ TESTIMONIALS ============================ */
.sp-tgrid{columns:3 300px;column-gap:1.1rem}
.sp-tcard{break-inside:avoid;margin-bottom:1.1rem;padding:1.6rem;border-radius:var(--sp-r-lg);background:var(--sp-card);border:1px solid var(--sp-line)}
.sp-tcard__stars{display:flex;gap:2px;color:var(--gold-400);margin-bottom:.8rem}
.sp-tcard__stars svg{width:16px;height:16px;fill:currentColor}
.sp-tcard p{font-size:var(--sp-fs-sm);color:var(--sp-text);line-height:1.6;margin:0 0 1rem}
.sp-tcard__who{display:flex;align-items:center;gap:.7rem}
.sp-tcard__av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-family:var(--sp-font-display);font-weight:600;color:#fff;background:var(--sp-ink);font-size:.95rem}
.sp-tcard__who b{display:block;font-size:var(--sp-fs-sm)}
.sp-tcard__who span{font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);color:var(--sp-text-mute)}

/* ============================ BUY CTA (ink) ============================ */
.sp-buy{position:relative;overflow:hidden;text-align:center}
.sp-buy::before{content:"";position:absolute;inset:0;z-index:0;opacity:.5;
  background:radial-gradient(50% 60% at 50% 0%,color-mix(in srgb,var(--orange-500) 40%,transparent),transparent 70%)}
.sp-buy__inner{position:relative;z-index:1;max-width:740px;margin-inline:auto}
.sp-buy h2{font-size:clamp(2.2rem,1.6rem+3vw,3.8rem)}
.sp-buy__actions{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;margin-top:2rem}
.sp-buy__fine{margin-top:1.6rem;font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);color:var(--sp-text-inv-soft);letter-spacing:.04em}

/* ============================ SUPPORT (3 paths) ============================ */
.sp-support{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:820px){.sp-support{grid-template-columns:1fr}}
.sp-spath{padding:1.9rem;border-radius:var(--sp-r-lg);background:var(--sp-card);border:1px solid var(--sp-line);display:flex;flex-direction:column;gap:.7rem;transition:transform .3s var(--sp-ease),border-color .3s}
.sp-spath:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--sp-accent) 35%,var(--sp-line))}
.sp-spath__ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;background:var(--sp-ink);margin-bottom:.3rem}
.sp-spath__ico svg{width:22px;height:22px}
.sp-spath h3{margin:0;font-size:1.2rem}
.sp-spath p{margin:0;color:var(--sp-text-soft);font-size:var(--sp-fs-sm);flex:1}
.sp-spath a{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--sp-accent-deep);font-size:var(--sp-fs-sm);margin-top:.4rem}
.sp-spath a svg{width:16px;height:16px;transition:transform .3s}
.sp-spath:hover a svg{transform:translateX(4px)}

/* ============================ COMPANION PLUGINS ============================ */
.sp-companion{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.sp-comp{display:flex;align-items:center;gap:.9rem;padding:1.2rem 1.3rem;border-radius:var(--sp-r);background:var(--sp-card);border:1px solid var(--sp-line);transition:transform .3s var(--sp-ease),border-color .3s}
.sp-comp:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--sp-accent) 35%,var(--sp-line))}
.sp-comp__ico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:var(--sp-paper-2);color:var(--sp-accent-deep);flex:none}
.sp-comp__ico svg{width:20px;height:20px}
.sp-comp b{display:block;font-size:var(--sp-fs-sm);font-weight:600;line-height:1.2}
.sp-comp span{font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);color:var(--sp-text-mute)}

/* ============================ FOOTER ============================ */
.sp-footer{background:var(--sp-ink);color:var(--sp-text-inv-soft);padding-block:clamp(3.5rem,2.5rem+3vw,5rem) 2rem}
.sp-footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem}
@media(max-width:820px){.sp-footer__top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.sp-footer__top{grid-template-columns:1fr}}
.sp-footer h5{font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);letter-spacing:.16em;text-transform:uppercase;color:var(--sp-text-inv-soft);margin:0 0 1.1rem;font-weight:600}
.sp-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}
.sp-footer a{color:rgba(246,241,234,.8);font-size:var(--sp-fs-sm);transition:color .2s}
.sp-footer a:hover{color:#fff}
.sp-footer__brand p{max-width:34ch;font-size:var(--sp-fs-sm);line-height:1.6;margin-top:1rem}
.sp-footer__logo{display:inline-flex;align-items:center;gap:.6rem}
.sp-footer__logo-img{display:block;height:44px;width:auto}
.sp-footer__bottom{margin-top:clamp(2.5rem,2rem+2vw,3.5rem);padding-top:1.8rem;border-top:1px solid var(--sp-line-ink);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;font-size:var(--sp-fs-xs);color:var(--sp-text-inv-soft);font-family:var(--sp-font-mono);letter-spacing:.02em}

/* ============================ INNER PAGE HERO ============================ */
.sp-phero{padding-block:clamp(3.5rem,2.5rem+5vw,7rem) clamp(2rem,1.5rem+3vw,4rem);position:relative;overflow:hidden}
.sp-phero::before{content:"";position:absolute;inset:0;z-index:-1;opacity:.6;
  background:radial-gradient(55% 60% at 85% 0%,color-mix(in srgb,var(--sp-orange) 16%,transparent),transparent 70%)}
.sp-phero h1{font-size:var(--sp-fs-h1)}
.sp-crumbs{display:flex;gap:.5rem;align-items:center;font-family:var(--sp-font-mono);font-size:var(--sp-fs-xs);color:var(--sp-text-mute);margin-bottom:1.4rem;letter-spacing:.04em}
.sp-crumbs a:hover{color:var(--sp-accent)}
.sp-crumbs svg{width:13px;height:13px}

/* ============================ FAQ / ACCORDION ============================ */
.sp-acc{max-width:880px;margin-inline:auto;display:flex;flex-direction:column;gap:.7rem}
.sp-acc details{background:var(--sp-card);border:1px solid var(--sp-line);border-radius:var(--sp-r);overflow:hidden;transition:border-color .3s,box-shadow .3s}
.sp-acc details[open]{border-color:color-mix(in srgb,var(--sp-accent) 35%,var(--sp-line));box-shadow:var(--sp-shadow-sm)}
.sp-acc summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;font-family:var(--sp-font-display);font-weight:600;font-size:1.12rem;color:var(--sp-ink)}
.sp-acc summary::-webkit-details-marker{display:none}
.sp-acc summary .sp-acc__icon{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--sp-paper-2);transition:transform .3s,background .3s,color .3s}
.sp-acc summary .sp-acc__icon svg{width:16px;height:16px}
.sp-acc details[open] summary .sp-acc__icon{transform:rotate(45deg);background:var(--sp-accent);color:#fff}
.sp-acc__body{padding:0 1.5rem 1.4rem;color:var(--sp-text-soft);font-size:var(--sp-fs-sm);line-height:1.65}
.sp-acc__body p:last-child{margin-bottom:0}
.sp-acc__body code,.sp-code{font-family:var(--sp-font-mono);font-size:.85em;background:var(--sp-ink);color:var(--cream);padding:.18em .45em;border-radius:5px}
.sp-acc__body pre,pre.sp-code{display:block;background:var(--sp-ink);color:var(--cream);padding:1rem 1.2rem;border-radius:var(--sp-r-sm);overflow-x:auto;font-family:var(--sp-font-mono);font-size:.85rem;line-height:1.55;margin:.6rem 0}
pre.sp-code{white-space:pre-wrap;word-break:break-word}

/* ============================ FEATURE PAGE GRID (side buttons / activation) ============================ */
.sp-optgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.1rem}
.sp-opt{padding:1.7rem;border-radius:var(--sp-r-lg);background:var(--sp-card);border:1px solid var(--sp-line);transition:transform .3s var(--sp-ease),border-color .3s}
.sp-opt:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--sp-accent) 35%,var(--sp-line))}
.sp-opt__ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;background:var(--sp-accent);margin-bottom:1rem}
.sp-opt__ico svg{width:22px;height:22px}
.sp-opt h3{margin:0 0 .4rem;font-size:1.18rem}
.sp-opt p{margin:0;color:var(--sp-text-soft);font-size:var(--sp-fs-sm)}

/* position diagram for side buttons */
.sp-posbox{position:relative;aspect-ratio:16/11;border:2px dashed var(--sp-line);border-radius:var(--sp-r-lg);background:var(--sp-paper-2);max-width:560px;margin-top:1.5rem}
.sp-posbox span{position:absolute;background:var(--sp-accent);color:#fff;font-family:var(--sp-font-mono);font-size:10px;font-weight:600;padding:.3rem .55rem;border-radius:6px;white-space:nowrap;box-shadow:var(--sp-shadow-sm)}
.sp-posbox .tl{top:8%;left:0;transform:translateX(-30%) rotate(-90deg);transform-origin:left}
.sp-posbox .ml{top:50%;left:0;transform:translate(-30%,-50%) rotate(-90deg)}
.sp-posbox .bl{bottom:8%;left:0;transform:translate(-30%,0) rotate(-90deg);transform-origin:left}
.sp-posbox .tr{top:8%;right:0;transform:translateX(30%) rotate(90deg);transform-origin:right}
.sp-posbox .mr{top:50%;right:0;transform:translate(30%,-50%) rotate(90deg)}
.sp-posbox .br{bottom:8%;right:0;transform:translate(30%,0) rotate(90deg);transform-origin:right}
.sp-posbox .tc{top:0;left:50%;transform:translate(-50%,-50%)}
.sp-posbox .bc{bottom:0;left:50%;transform:translate(-50%,50%)}

/* doc layout */
.sp-doc{display:grid;grid-template-columns:240px 1fr;gap:clamp(1.5rem,1rem+3vw,3.5rem);align-items:start}
@media(max-width:900px){.sp-doc{grid-template-columns:1fr}.sp-doc__nav{position:static!important}}
.sp-doc__nav{position:sticky;top:96px;display:flex;flex-direction:column;gap:.2rem;padding:1.2rem;background:var(--sp-card);border:1px solid var(--sp-line);border-radius:var(--sp-r-lg)}
.sp-doc__nav a{font-size:var(--sp-fs-sm);color:var(--sp-text-soft);padding:.5rem .7rem;border-radius:var(--sp-r-sm);transition:background .2s,color .2s}
.sp-doc__nav a:hover{background:var(--sp-paper-2);color:var(--sp-ink)}
.sp-doc__body{max-width:760px}
.sp-doc__body h2{scroll-margin-top:100px;margin-top:2.4rem;padding-top:1.2rem;border-top:1px solid var(--sp-line)}
.sp-doc__body h2:first-child{border-top:0;margin-top:0;padding-top:0}
.sp-doc__body ol,.sp-doc__body ul{padding-left:1.3rem;color:var(--sp-text-soft)}
.sp-doc__body li{margin-bottom:.5rem}
.sp-doc__body li strong{color:var(--sp-ink)}

.sp-mono{font-family:var(--sp-font-mono)}
.sp-divider{height:1px;background:var(--sp-line);border:0;margin-block:var(--sp-section)}

/* Self-hosted brand logo fallback (used when no custom-logo is set). */
.sp-logo__img{display:block;height:34px;width:auto}

/* Demo tile screenshots (self-hosted staging media). Full-bleed thumbnail at
   the top of the card. Reconcile with the locked tile design if/when
   shared/styles.css from the handoff is available. */
.sp-demo--shot{padding-top:0}
.sp-demo__shot{display:block;margin:0 -1.6rem .9rem;aspect-ratio:16 / 10;overflow:hidden;background:var(--sp-line)}
.sp-demo__shot img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--sp-ease)}
.sp-demo:hover .sp-demo__shot img{transform:scale(1.05)}
