/* sp.css — Shared service-page styles
 * Each page overrides: --accent, --accent2, --accent-rgb, --accent2-rgb, --accent-fg
 */

/* ── DEFAULT TOKENS (pages override accents) ───────────────────── */
:root {
  --card:#0a0a0a;--border:#27272a;--muted:#18181b;--radius:0.625rem;
  --background:#0a0a0a;--foreground:#fafafa;--muted-foreground:#a1a1aa;
  --primary:#fafafa;--primary-foreground:#18181b;
  --font-sans:'Geist',ui-sans-serif,system-ui,-apple-system,sans-serif;
  --font-mono:'Geist Mono','Fira Code',ui-monospace,monospace;
  --accent:#2BC8B7;--accent2:#3b82f6;
  --accent-rgb:43,200,183;--accent2-rgb:59,130,246;
  --accent-fg:var(--accent);
}

/* ── BASE ───────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-sans);background:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}img{display:block;max-width:100%}ul{list-style:none}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
:focus-visible{outline:2px solid #2BC8B7;outline-offset:3px;border-radius:3px}
:focus:not(:focus-visible){outline:none}
.container{width:100%;max-width:68rem;margin-inline:auto;padding-inline:1.5rem}

/* ── ANIMATIONS ─────────────────────────────────────────────────── */
@keyframes blur-in-up{from{opacity:0;filter:blur(8px);transform:translateY(18px)}to{opacity:1;filter:blur(0);transform:translateY(0)}}
.anim{animation:blur-in-up .65s cubic-bezier(.22,1,.36,1) both}
.anim-1{animation-delay:.05s}.anim-2{animation-delay:.18s}.anim-3{animation-delay:.32s}.anim-4{animation-delay:.46s}.anim-5{animation-delay:.6s}

/* ── HERO ───────────────────────────────────────────────────────── */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:5rem;overflow:hidden;background:var(--background)}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse 85% 70% at 50% 30%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 85% 70% at 50% 30%,black 20%,transparent 100%)}
.hero-bg::after{content:'';position:absolute;top:-10%;left:50%;transform:translateX(-50%);width:60%;height:50%;background:radial-gradient(ellipse,rgba(var(--accent-rgb),.07) 0%,transparent 70%)}
.hero__inner{position:relative;z-index:1;width:100%;max-width:68rem;margin-inline:auto;padding-inline:1.5rem;padding-block:5rem 4rem;display:flex;flex-direction:column;align-items:flex-start;gap:3rem}
@media(min-width:1024px){.hero__inner{flex-direction:row;align-items:center;gap:4rem}}
.hero__content{display:flex;flex-direction:column;align-items:flex-start;flex:1;min-width:0}
.hero__visual{flex:0 0 auto;width:240px;margin-inline:auto;animation:hv-float 3s ease-in-out infinite;display:none}
@media(min-width:768px){.hero__visual{display:block}}
@media(min-width:1024px){.hero__visual{width:280px}}
@media(prefers-reduced-motion:reduce){.hero__visual{animation:none}}
@keyframes hv-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hv-svg{width:100%;height:auto;display:block;overflow:visible}
.hero__breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--muted-foreground);margin-bottom:1.75rem}
.hero__breadcrumb a:hover{color:var(--foreground)}
.hero__breadcrumb svg{width:.75rem;height:.75rem;flex-shrink:0}
.hero__badge{display:inline-flex;align-items:center;gap:.5rem;padding:.3125rem .875rem;border:1px solid rgba(var(--accent-rgb),.3);border-radius:9999px;font-size:.8125rem;font-weight:500;color:var(--accent-fg);background:rgba(var(--accent-rgb),.06);margin-bottom:1.75rem}
.hero__badge-dot{width:.4375rem;height:.4375rem;border-radius:9999px;background:var(--accent);animation:pulse-accent 2s ease-in-out infinite}
@keyframes pulse-accent{0%,100%{box-shadow:0 0 0 0 rgba(var(--accent-rgb),.5)}50%{box-shadow:0 0 0 5px rgba(var(--accent-rgb),0)}}
.hero__h1{font-size:clamp(2.5rem,6vw,4.25rem);font-weight:700;line-height:1.06;letter-spacing:-.04em;color:var(--foreground);max-width:32rem;margin-bottom:1.5rem;text-wrap:balance}
.hero__h1 mark{background:none;color:transparent;background-image:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);-webkit-background-clip:text;background-clip:text}
.hero__desc{font-size:clamp(1rem,2vw,1.125rem);color:var(--muted-foreground);line-height:1.75;max-width:30rem;margin-bottom:2.5rem}
.hero__ctas{display:flex;flex-wrap:wrap;gap:.875rem;margin-bottom:3rem}
@property --hbg-a{syntax:'<angle>';initial-value:0deg;inherits:false}
.hbg-btn{position:relative;display:inline-flex;border-radius:9999px;padding:1px;cursor:pointer;text-decoration:none;background:conic-gradient(from var(--hbg-a),transparent 0%,rgba(var(--accent-rgb),.6) 20%,transparent 40%);animation:hbg-spin 2.5s linear infinite;--hbg-a:0deg}
.hbg-btn::after{content:'';position:absolute;inset:1px;border-radius:9999px;background:#080808;z-index:0}
.hbg-btn:hover{background:conic-gradient(from var(--hbg-a),transparent 0%,rgba(var(--accent2-rgb),.8) 20%,transparent 40%)}
@keyframes hbg-spin{to{--hbg-a:360deg}}
.hbg-inner{position:relative;z-index:10;display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:9999px;color:var(--foreground);font-family:var(--font-sans);font-size:.9375rem;font-weight:600;white-space:nowrap}
.hbg-inner svg{width:1rem;height:1rem;flex-shrink:0}
.btn-ghost{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:1px solid var(--border);border-radius:9999px;font-size:.9375rem;font-weight:500;color:var(--muted-foreground);background:transparent;transition:background .15s,color .15s,border-color .15s}
.btn-ghost:hover{background:var(--muted);color:var(--foreground);border-color:#3f3f46}
.btn-ghost svg{width:.9375rem;height:.9375rem;flex-shrink:0}
.hero__trust{display:flex;flex-wrap:wrap;gap:1.25rem}
.hero__trust-item{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--muted-foreground)}
.hero__trust-item svg{width:.875rem;height:.875rem;flex-shrink:0}

/* ── PARTNERS ───────────────────────────────────────────────────── */
.partners{padding-block:4rem 5rem}
.partners__label{text-align:center;font-size:.8125rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-foreground);margin-bottom:2rem}
.partners__grid{display:flex;flex-wrap:wrap;justify-content:center;gap:0;border-top:1px solid var(--border);border-left:1px solid var(--border)}
.partners__item{flex:1 1 auto;min-width:8rem;max-width:12rem;display:flex;align-items:center;justify-content:center;padding:1.5rem 1.25rem;border-right:1px solid var(--border);border-bottom:1px solid var(--border);transition:background .2s}
.partners__item:hover{background:rgba(255,255,255,.02)}
.partners__grid:has(.partners__item:hover) .partners__item:not(:hover){opacity:.35;filter:blur(1px);transition:opacity .25s,filter .25s}
.partners__grid:has(.partners__item:hover) .partners__item:hover{opacity:1;filter:blur(0)}
.partners__logo{font-family:var(--font-mono);font-size:.75rem;font-weight:600;letter-spacing:.05em;color:#52525b;text-transform:uppercase;white-space:nowrap;transition:color .2s}
.partners__item:hover .partners__logo{color:var(--muted-foreground)}

/* ── SECTION TYPOGRAPHY ─────────────────────────────────────────── */
.section-tag{display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.section-h2{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700;letter-spacing:-.03em;line-height:1.12;color:var(--foreground);margin-bottom:1rem;text-wrap:balance}
.section-desc{font-size:1.0625rem;color:var(--muted-foreground);line-height:1.7;max-width:42rem;margin-bottom:3.5rem}
.section-link-cta{display:inline-flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:500;color:var(--accent-fg);text-decoration:none;transition:gap .2s}
.section-link-cta:hover{gap:.75rem}
.sec-divider{position:relative;padding-block:5rem 6rem}
.sec-divider::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--border) 30%,var(--border) 70%,transparent)}

/* ── FEATURE CARDS ──────────────────────────────────────────────── */
.features__grid{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:640px){.features__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.features__grid{grid-template-columns:repeat(3,1fr)}}
.acard{position:relative;border:1px solid var(--border);border-radius:1rem;background:#0d0d10;overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s}
.acard:hover{border-color:rgba(var(--accent-rgb),.25);box-shadow:0 0 0 1px rgba(var(--accent-rgb),.08),0 8px 32px rgba(0,0,0,.4)}
.acard__canvas{width:100%;aspect-ratio:280/200;position:relative;overflow:hidden;background:#090910;border-bottom:1px solid var(--border)}
.acard__scene{width:100%;height:100%;display:block}
.acard__fade{position:absolute;bottom:0;left:0;right:0;height:4rem;background:linear-gradient(to bottom,transparent,#090910);pointer-events:none}
.acard__text{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}
.acard__tag{font-family:var(--font-mono);font-size:.6875rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-fg)}
.acard__title{font-size:1.0625rem;font-weight:600;color:var(--foreground);line-height:1.3}
.acard__desc{font-size:.9375rem;color:var(--muted-foreground);line-height:1.65}

/* ── PROCESS (rm-* roadmap — used by most pages) ────────────────── */
.rm-card{border:1px solid var(--border);border-radius:1.5rem;background:#0d0d10;overflow:hidden}
.rm-content{padding:2rem 1.5rem;display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:768px){.rm-content{grid-template-columns:1fr 1fr;gap:3rem;padding:2.5rem}}
.rm-left{display:flex;flex-direction:column;justify-content:center;gap:1.25rem}
.rm-left-tag{font-family:var(--font-mono);font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.rm-h3{font-size:clamp(1.5rem,3vw,2.25rem);font-weight:700;letter-spacing:-.03em;line-height:1.15;color:var(--foreground)}
.rm-desc{font-size:1rem;color:var(--muted-foreground);line-height:1.7}
.rm-timeline{position:relative}
.rm-timeline-line{position:absolute;top:.875rem;left:0;right:0;height:2px;background:var(--border);border-radius:9999px}
.rm-timeline-progress{position:absolute;top:.875rem;left:0;height:2px;width:0%;background:linear-gradient(to right,var(--accent),var(--accent2));border-radius:9999px;transition:width .65s cubic-bezier(.4,0,.2,1)}
.rm-items{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding-top:.25rem}
.rm-item{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center;padding-top:.25rem}
.rm-dot{width:1.75rem;height:1.75rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;transition:background .3s,border-color .3s,box-shadow .3s;flex-shrink:0}
.rm-dot--muted{background:var(--muted);border:2px solid var(--border)}
.rm-dot--active{background:rgba(var(--accent-rgb),.12);border:2px solid var(--accent);box-shadow:0 0 0 4px rgba(var(--accent-rgb),.1)}
.rm-dot-inner{width:.5rem;height:.5rem;border-radius:9999px;background:#52525b;transition:background .3s}
.rm-dot--active .rm-dot-inner{background:var(--accent)}
@keyframes rm-pop{0%{transform:scale(1)}40%{transform:scale(1.35)}70%{transform:scale(.92)}100%{transform:scale(1)}}
.rm-dot--pop{animation:rm-pop .52s cubic-bezier(.22,1,.36,1)}
.rm-badge{font-family:var(--font-mono);font-size:.625rem;font-weight:600;letter-spacing:.05em;padding:.2rem .45rem;border-radius:.375rem;transition:background .3s,color .3s,border-color .3s}
.rm-badge--outline{border:1px solid var(--border);color:#52525b;background:transparent}
.rm-badge--active{border:1px solid rgba(var(--accent-rgb),.4);color:var(--accent-fg);background:rgba(var(--accent-rgb),.08)}
.rm-step-title{font-size:.8125rem;font-weight:600;color:var(--muted-foreground);line-height:1.3;transition:color .3s}
.rm-item:has(.rm-dot--active) .rm-step-title{color:var(--foreground)}
.rm-step-desc{font-size:.75rem;color:#3f3f46;line-height:1.5;transition:color .3s}
.rm-item:has(.rm-dot--active) .rm-step-desc{color:var(--muted-foreground)}

/* ── TYPES ──────────────────────────────────────────────────────── */
.types-list{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:768px){.types-list{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.types-list{grid-template-columns:repeat(4,1fr)}}
.type-card{border:1px solid var(--border);border-radius:1rem;background:#0d0d10;padding:1.5rem;display:flex;flex-direction:column;gap:.875rem;transition:border-color .2s,box-shadow .2s}
.type-card:hover{border-color:rgba(var(--accent-rgb),.25);box-shadow:0 0 0 1px rgba(var(--accent-rgb),.06)}
.type-tag{font-family:var(--font-mono);font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-fg);background:rgba(var(--accent-rgb),.08);border:1px solid rgba(var(--accent-rgb),.2);padding:.2rem .625rem;border-radius:9999px;width:fit-content}
.type-title{font-size:1.0625rem;font-weight:600;color:var(--foreground);line-height:1.3}
.type-body{font-size:.9375rem;color:var(--muted-foreground);line-height:1.65;flex:1}
.type-items{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem}
.type-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--muted-foreground)}
.type-item svg{width:.875rem;height:.875rem;flex-shrink:0;color:#22c55e}

/* ── FAQ ────────────────────────────────────────────────────────── */
.faq__grid{display:grid;grid-template-columns:1fr;gap:3rem}
@media(min-width:1024px){.faq__grid{grid-template-columns:1fr 1.75fr;gap:5rem;align-items:start}}
.faq__heading-block{display:flex;flex-direction:column;gap:1rem}
.faq__h2{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.03em;line-height:1.15;color:var(--foreground)}
.faq__subtitle{font-size:1rem;color:var(--muted-foreground);line-height:1.7}
.faq__list{display:flex;flex-direction:column}
.faq__item{border-bottom:1px solid var(--border)}
.faq__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:1.25rem;background:none;border:none;color:var(--foreground);font-family:var(--font-sans);font-size:1rem;font-weight:500;text-align:left;cursor:pointer;transition:color .15s}
.faq__trigger:hover{color:var(--accent-fg)}
.faq__chevron{width:1.125rem;height:1.125rem;flex-shrink:0;color:var(--muted-foreground);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.faq__item[data-open="true"] .faq__chevron{transform:rotate(180deg)}
.faq__content-wrap{overflow:hidden;height:0;transition:height .3s cubic-bezier(.4,0,.2,1)}
.faq__content{padding-bottom:1.25rem;font-size:.9375rem;color:var(--muted-foreground);line-height:1.75;display:flex;flex-direction:column;gap:.75rem}
.faq__content ol,.faq__content ul{padding-left:1.25rem;display:flex;flex-direction:column;gap:.375rem}
.faq__content ol{list-style:decimal}.faq__content ul{list-style:disc}

/* ── CTA SPOTLIGHT ──────────────────────────────────────────────── */
.spot{padding-block:5rem 7rem;position:relative}
.spot::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--border) 30%,var(--border) 70%,transparent)}
.spot__inner{border:1px solid var(--border);border-radius:1.5rem;padding:3rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem;position:relative;overflow:hidden;background:#0d0d10}
.spot__inner::before{content:'';position:absolute;top:-40%;left:50%;transform:translateX(-50%);width:60%;height:60%;background:radial-gradient(ellipse,rgba(var(--accent-rgb),.07) 0%,transparent 70%);pointer-events:none}
.spot__badge{display:inline-flex;align-items:center;gap:.5rem;padding:.3125rem .875rem;border:1px solid var(--border);border-radius:9999px;font-size:.8125rem;font-weight:500;color:var(--muted-foreground)}
.spot__badge-dot{width:.4375rem;height:.4375rem;border-radius:9999px;background:#22c55e;animation:pulse-green 2s ease-in-out infinite}
@keyframes pulse-green{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}50%{box-shadow:0 0 0 5px rgba(34,197,94,0)}}
.spot__h2{font-size:clamp(1.75rem,4vw,3rem);font-weight:700;letter-spacing:-.03em;line-height:1.12;color:var(--foreground);max-width:28rem;text-wrap:balance}
.spot__desc{font-size:1.0625rem;color:var(--muted-foreground);line-height:1.7;max-width:30rem}
.spot__actions{display:flex;flex-wrap:wrap;gap:.875rem;justify-content:center;margin-top:.5rem}

/* ── RELATED CARDS ──────────────────────────────────────────────── */
.related-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.related-grid{grid-template-columns:repeat(3,1fr)}}
.related-card{border:1px solid var(--border);border-radius:1rem;background:#0d0d10;padding:1.5rem;display:flex;flex-direction:column;gap:.625rem;transition:border-color .2s,background .2s}
.related-card:hover{border-color:#3f3f46;background:#111116}
.related-card__label{font-family:var(--font-mono);font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#52525b}
.related-card__title{font-size:1rem;font-weight:600;color:var(--foreground);line-height:1.3}
.related-card__arrow{margin-top:auto;padding-top:.5rem;color:var(--muted-foreground);font-size:.875rem;display:flex;align-items:center;gap:.375rem;transition:gap .2s,color .2s}
.related-card:hover .related-card__arrow{gap:.625rem;color:var(--foreground)}
.related-card__arrow svg{width:.875rem;height:.875rem;flex-shrink:0}

/* ── CROSS-LINKS ────────────────────────────────────────────────── */
.crosslinks{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.crosslinks{grid-template-columns:repeat(3,1fr)}}
.crosslink-card{border:1px solid var(--border);border-radius:1rem;background:#0d0d10;padding:1.5rem;display:flex;flex-direction:column;gap:.625rem;transition:border-color .2s,box-shadow .2s}
.crosslink-card:hover{border-color:rgba(var(--accent-rgb),.2);box-shadow:0 0 0 1px rgba(var(--accent-rgb),.06)}
.crosslink-tag{font-family:var(--font-mono);font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-fg)}
.crosslink-title{font-size:1rem;font-weight:600;color:var(--foreground);line-height:1.3}
.crosslink-arrow{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--muted-foreground);margin-top:auto}
.crosslink-arrow svg{width:.875rem;height:.875rem;flex-shrink:0;transition:transform .2s}
.crosslink-card:hover .crosslink-arrow svg{transform:translateX(3px)}

/* ── SCROLL REVEAL ───────────────────────────────────────────── */
.rv{opacity:0;transform:translateY(22px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.rv.vis{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none}}

/* staggered grid children */
.rv-g>*{opacity:0;transform:translateY(18px);transition:opacity .55s cubic-bezier(.22,1,.36,1),transform .55s cubic-bezier(.22,1,.36,1)}
.rv-g.vis>*{opacity:1;transform:none}
.rv-g.vis>*:nth-child(1){transition-delay:.05s}
.rv-g.vis>*:nth-child(2){transition-delay:.13s}
.rv-g.vis>*:nth-child(3){transition-delay:.21s}
.rv-g.vis>*:nth-child(4){transition-delay:.29s}
.rv-g.vis>*:nth-child(5){transition-delay:.37s}
.rv-g.vis>*:nth-child(6){transition-delay:.45s}
@media(prefers-reduced-motion:reduce){.rv-g>*,.rv-g.vis>*{opacity:1;transform:none;transition-delay:0s!important}}
