/* ════════════════════════════════════════════════════════════════════
   AI ROADMAP — landing page
   Decidr Design System · purple #8E57FB · orange #F36744 · warm grey
   Structure mirrors the Sugarwork LP; visuals are pure Decidr.
   ════════════════════════════════════════════════════════════════════ */

:root{
  /* accent is tweakable — defaults to Decidr orange */
  --accent:#F36744;
  --accent-600:#EF4120;
  --accent-700:#BA1A14;
  --accent-soft:#FDE3D7;
  --accent-ink:#FFFFFF;

  /* page tints derived from Decidr neutrals */
  --ink:#0A0A0A;
  --ink-2:#394141;       /* default body */
  --ink-3:#5C6C6D;
  --ink-4:#90A0A0;
  --line:#EEF0F0;
  --line-2:#D9DEDE;
  --paper:#FFFFFF;
  --soft:#F7F8F8;
  --soft-2:#EEF0F0;

  /* corners — tweakable between rounded + sharp */
  --r-card:20px;
  --r-frame:40px;
  --r-cta:999px;

  --r-xs:8px; --r-sm:12px; --r-md:16px;

  --sh-sm:0 1px 2px rgba(10,10,10,.06),0 1px 1px rgba(10,10,10,.04);
  --sh-md:0 6px 16px rgba(10,10,10,.08);
  --sh-lg:0 16px 48px rgba(10,10,10,.12);
  --sh-accent:0 18px 48px -20px color-mix(in srgb,var(--accent) 60%,transparent);

  --maxw:1200px;
  --ease:cubic-bezier(.2,.8,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  color:var(--ink-2);
  background:var(--paper);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:color-mix(in srgb,var(--accent) 22%,white);color:var(--ink)}

.container{max-width:var(--maxw);margin-inline:auto;padding-inline:32px}
@media(max-width:640px){.container{padding-inline:20px}}

/* ── type scale ─────────────────────────────────────────────── */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:13px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;
  color:var(--ink);
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.eyebrow.on-dark{color:#fff}
.eyebrow.on-dark .dot{background:var(--orange-400)}

h1,h2,h3{font-family:var(--font-display);color:var(--ink);font-weight:500}
.h1{font-size:clamp(44px,5.6vw,78px);line-height:1.04;letter-spacing:-.03em;font-weight:500}
.h2{font-size:clamp(30px,4.1vw,48px);line-height:1.06;letter-spacing:-.028em;font-weight:500}
.h3{font-size:clamp(22px,2.4vw,30px);line-height:1.12;letter-spacing:-.02em;font-weight:500}
.lead{font-size:clamp(17px,1.45vw,20px);color:var(--ink-3);line-height:1.55;font-weight:400;max-width:60ch}
em.hi{font-style:normal;color:var(--ink)}
.h1 em.hi{color:var(--accent)}
.h1 em.hi-ink{color:var(--ink);font-weight:600}

/* ── buttons ────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:0;
  font-family:var(--font-sans);font-weight:600;font-size:16px;letter-spacing:-.01em;
  padding:15px 26px;border-radius:var(--r-cta);transition:.18s var(--ease);
  white-space:nowrap;line-height:1;
}
.btn i{font-size:18px;transition:transform .2s var(--ease)}
.btn-primary{background:var(--ink);color:#fff;box-shadow:var(--sh-md)}
.btn-primary:hover{background:#26292a;transform:translateY(-2px)}
.btn-primary:hover i{transform:translateX(3px)}
.btn-primary:active{transform:translateY(1px);background:#000}
.btn-ghost{background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line-2)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--ink);transform:translateY(-2px)}
.btn-sm{padding:11px 18px;font-size:14.5px}
.btn-lg{padding:18px 32px;font-size:17px}
.btn-on-dark{background:#fff;color:var(--ink)}
.btn-on-dark:hover{background:var(--purple-100);transform:translateY(-2px)}

/* ── signature Decidr gradient (cover) ──────────────────────── */
.cover-gradient{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(60% 70% at 72% 28%,color-mix(in srgb,var(--orange-400) 90%,transparent) 0%,transparent 60%),
    radial-gradient(60% 70% at 20% 82%,var(--purple-300) 0%,transparent 60%),
    var(--accent);
}
/* soft aurora for light surfaces */
.aurora{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.aurora::before,.aurora::after{content:"";position:absolute;border-radius:50%;filter:blur(90px)}
.aurora::before{width:52vw;height:52vw;max-width:680px;max-height:680px;left:-12%;top:-30%;
  background:radial-gradient(circle at 40% 40%,var(--purple-300),transparent 68%);opacity:.5}
.aurora::after{width:44vw;height:44vw;max-width:560px;max-height:560px;right:-8%;top:-12%;
  background:radial-gradient(circle at 60% 40%,var(--orange-300),transparent 68%);opacity:.32}
@media(prefers-reduced-motion:no-preference){
  .aurora::before{animation:drift1 24s var(--ease) infinite alternate}
  .aurora::after{animation:drift2 28s var(--ease) infinite alternate}
}
@keyframes drift1{to{transform:translate(50px,40px) scale(1.08)}}
@keyframes drift2{to{transform:translate(-44px,28px) scale(1.1)}}

/* ════════ HEADER ════════ */
.hdr{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.8);
  backdrop-filter:saturate(160%) blur(16px);-webkit-backdrop-filter:saturate(160%) blur(16px);
  border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px}
.brand-logo{width:auto;display:block}
.brand-mark{height:24px;width:auto;flex:none;color:var(--accent)}
.brand-word{font-family:var(--font-display);font-size:23px;font-weight:500;letter-spacing:-.04em;color:var(--ink)}
.hdr-nav{display:flex;gap:26px;margin-left:auto;margin-right:24px}
.hdr-nav a{font-size:15px;font-weight:400;color:var(--ink-3);transition:color .15s;white-space:nowrap}
.hdr-nav a:hover{color:var(--ink)}
@media(max-width:980px){.hdr-nav{display:none}}

/* ════════ HERO ════════ */
.hero{position:relative;overflow:hidden;background:var(--paper);
  padding:clamp(60px,8vw,108px) 0 clamp(52px,7vw,84px)}
.hero .container{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:10px;background:#fff;
  border:1px solid var(--line-2);border-radius:var(--r-cta);
  padding:7px 14px 7px 8px;font-size:13.5px;font-weight:400;color:var(--ink-3);
  box-shadow:var(--sh-sm);margin-bottom:26px}
.hero-badge .chip{background:var(--accent-soft);color:var(--accent-700);font-weight:500;
  font-size:12px;padding:3px 10px;border-radius:var(--r-cta);white-space:nowrap}
.hero-badge b{color:var(--ink);font-weight:500}
.hero h1{max-width:17ch;margin-bottom:22px;text-wrap:balance;letter-spacing:-1.3px}
@media(max-width:640px){.hero h1{font-size:clamp(40px,11.5vw,56px)}}
.hero .lead{max-width:54ch;margin-bottom:32px;text-align:center}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;align-items:center}
.hero-meta{display:flex;align-items:center;gap:9px;color:var(--ink-4);font-size:14px;font-weight:400;margin-top:18px}
.hero-meta i{color:var(--orange-400);font-size:9px}

.hero-shot{position:relative;z-index:1;width:100%;max-width:1060px;margin:clamp(42px,6vw,68px) auto 0}

/* trust strip */
.trust{padding:0 0 40px}
.trust-label{text-align:center;font-size:12.5px;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-4);margin-bottom:24px}
.trust-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:clamp(28px,4vw,56px);row-gap:clamp(20px,2.4vw,30px)}
.trust-logo{display:inline-flex;align-items:center}
.trust-logo img{display:block;width:auto}

/* ════════ generic section ════════ */
.section{padding:clamp(68px,8.5vw,116px) 0;position:relative}
.section.soft{background:var(--soft)}
#proof{padding-top:50px}
#roadmap{padding-top:50px}
.section.lilac{background:var(--accent-soft)}
.sec-head{max-width:760px;margin-bottom:clamp(38px,5vw,58px)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head h2{margin-bottom:18px}
.sec-head.center .lead{margin-inline:auto}

/* ════════ PROBLEM ════════ */
.prob-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:clamp(40px,5vw,62px)}
@media(max-width:760px){.prob-stats{grid-template-columns:1fr;gap:16px}}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);padding:32px 30px;
  box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}
.stat-num{font-family:var(--font-display);font-size:clamp(42px,5vw,58px);font-weight:500;
  letter-spacing:-.04em;line-height:1;color:var(--ink)}
.stat-num .u{color:var(--ink);font-size:.6em;vertical-align:baseline;margin-left:1px}
.stat-label{margin-top:14px;font-size:16px;color:var(--ink-2);line-height:1.45;font-weight:500}
.stat-sub{margin-top:6px;font-size:14px;color:var(--ink-4);line-height:1.45}

.prob-two{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,4vw,56px);align-items:center}
@media(max-width:880px){.prob-two{grid-template-columns:1fr;gap:32px}}
.prob-copy p{color:var(--ink-3);font-size:17.5px;line-height:1.62;margin-bottom:18px;max-width:50ch}
.prob-copy p strong{color:var(--ink);font-weight:600}
.prob-copy .first{font-family:var(--font-display);font-size:clamp(22px,2.4vw,29px);line-height:1.24;
  color:var(--ink);font-weight:500;letter-spacing:-.02em;margin-bottom:20px}
.prob-quote{position:relative;overflow:hidden;border-radius:var(--r-frame);
  padding:clamp(34px,4vw,48px);color:#fff;box-shadow:var(--sh-lg);background:#0A0A0A}
.prob-quote .cover-gradient{display:none}
.prob-quote .label{position:relative;z-index:1;font-size:12.5px;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:#fff;margin-bottom:20px}
.prob-quote blockquote{position:relative;z-index:1;font-family:var(--font-display);
  font-size:clamp(24px,3vw,36px);line-height:1.18;font-weight:500;letter-spacing:-.025em;color:#fff}
.prob-quote cite{position:relative;z-index:1;display:block;margin-top:24px;font-style:normal;
  font-size:14.5px;color:#fff;font-weight:400}

/* ════════ HOW IT WORKS ════════ */
.steps{display:flex;flex-direction:column;gap:clamp(40px,5vw,72px)}
.step{display:grid;grid-template-columns:1fr 1.12fr;gap:clamp(36px,5vw,68px);align-items:center}
.step:nth-child(even){grid-template-columns:1.12fr 1fr}
.step:nth-child(even) .step-copy{order:2}
.step:nth-child(even) .step-media{order:1}
@media(max-width:880px){
  .step,.step:nth-child(even){grid-template-columns:1fr;gap:26px}
  .step:nth-child(even) .step-copy{order:0}
  .step:nth-child(even) .step-media{order:0}
}
.step-n{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;
  border-radius:13px;background:var(--accent-soft);color:var(--accent-700);
  font-family:var(--font-display);font-weight:500;font-size:19px;margin-bottom:22px}
.step-copy h3{margin-bottom:14px}
.step-copy p{color:var(--ink-3);font-size:17px;line-height:1.6;margin-bottom:20px;max-width:46ch}
.step-tags{display:flex;flex-wrap:wrap;gap:8px}
.tag{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:400;color:var(--ink-2);
  background:#fff;border:1px solid var(--line-2);border-radius:var(--r-cta);padding:7px 13px}
.tag i{font-size:14px;color:var(--accent)}
.step-media{border-radius:var(--r-card);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--sh-md);background:var(--soft)}

.how-band{margin-top:clamp(44px,5vw,68px);border-radius:var(--r-frame);
  padding:clamp(32px,4vw,46px) clamp(30px,4vw,54px);display:flex;flex-direction:column;
  gap:clamp(28px,3.4vw,40px);position:relative;overflow:hidden;color:#fff;background:#0A0A0A}
.how-band .cover-gradient{display:none}
.how-band-copy{position:relative;z-index:1;max-width:62ch}
.how-band-copy .k{font-size:12.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--purple-200);margin-bottom:13px}
.how-band-copy p{font-family:var(--font-display);font-size:clamp(19px,2.1vw,25px);font-weight:500;
  line-height:1.3;letter-spacing:-.02em;color:#fff}
.how-band-stats{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;border-top:1px solid var(--white-a15)}
@media(max-width:600px){.how-band-stats{grid-template-columns:1fr}}
.how-band-stat{padding:clamp(24px,2.8vw,32px) clamp(20px,2.4vw,34px) 0}
.how-band-stat:not(:first-child){border-left:1px solid var(--white-a15)}
@media(max-width:600px){.how-band-stat{padding:24px 0 0}
  .how-band-stat:not(:first-child){border-left:0;border-top:1px solid var(--white-a15)}}
.how-band-stat .n{font-family:var(--font-display);font-size:clamp(38px,4.4vw,58px);font-weight:500;
  letter-spacing:-.03em;line-height:1}
.how-band-stat .n .u{color:var(--orange-300);font-size:.6em;margin-left:1px}
.how-band-stat .l{font-size:19px;color:var(--white-a75);margin-top:12px;max-width:18ch;line-height:1.4}

/* ════════ PROOF — objection slider ════════ */
.obj-slider{display:flex;align-items:center;gap:clamp(12px,2vw,22px);max-width:760px;margin-inline:auto}
.obj-arrow{flex:none;width:48px;height:48px;border-radius:50%;border:1.5px solid var(--line-2);
  background:#fff;cursor:pointer;color:var(--ink-2);display:flex;align-items:center;justify-content:center;
  font-size:19px;transition:.18s var(--ease)}
.obj-arrow:hover{border-color:var(--accent);color:var(--accent-700);transform:translateY(-2px)}
.obj-arrow:active{transform:translateY(0)}
@media(max-width:560px){.obj-arrow{width:42px;height:42px;font-size:17px}}
.obj-viewport{flex:1;min-width:0;overflow:hidden;border-radius:16px}
.obj-track{display:flex;transition:transform .42s var(--ease)}
.obj-card{flex:0 0 100%;box-sizing:border-box;background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--sh-sm);padding:clamp(30px,4vw,48px)}
.obj-label{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.09em;text-transform:uppercase}
.obj-label-q{color:var(--ink-4)}
.obj-q{font-family:var(--font-display);font-size:clamp(22px,2.8vw,32px);font-weight:500;
  letter-spacing:-.02em;line-height:1.15;color:var(--ink);text-wrap:balance}
.obj-divider{display:flex;align-items:center;gap:14px;margin:clamp(22px,2.6vw,30px) 0 clamp(16px,2vw,22px)}
.obj-divider::before,.obj-divider::after{content:"";height:1px;flex:1;background:var(--line)}
.obj-label-a{color:var(--ink)}
.obj-a{font-size:clamp(16px,1.5vw,18px);line-height:1.6;color:var(--ink-3);font-weight:400}
.obj-a strong{color:var(--ink-2);font-weight:600}
.obj-dots{display:flex;justify-content:center;gap:10px;margin-top:24px}
.obj-dot{width:9px;height:9px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:var(--line-2);transition:.18s var(--ease)}
.obj-dot:hover{background:var(--ink-4)}
.obj-dot.is-active{background:var(--accent);width:26px;border-radius:999px}

.case{margin-top:clamp(32px,4vw,50px);display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--r-card);overflow:hidden}
@media(max-width:760px){.case{grid-template-columns:repeat(2,1fr)}}
.case-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:760px){.case-3{grid-template-columns:1fr}}
.case-cell{background:#fff;padding:30px 24px;text-align:center}
.case-cell .n{font-family:var(--font-display);font-size:clamp(30px,3vw,40px);font-weight:500;
  letter-spacing:-.03em;color:var(--ink);line-height:1}
.case-cell .n .u{color:var(--ink);font-size:.55em;margin-left:1px}
.case-cell .l{margin-top:10px;font-size:13.5px;color:var(--ink-3);line-height:1.4}
.case-note{text-align:center;margin-top:18px;font-size:13.5px;color:var(--ink-4)}
.case-note a{color:var(--accent);font-weight:500}
.case-cta{margin-top:clamp(40px,5vw,64px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px}
.case-cta-note{font-size:13px;color:var(--ink-4)}
.how-cta{margin-top:clamp(40px,5vw,64px);display:flex;justify-content:center}

/* ════════ CASE STUDY (Mercha) ════════ */
.cs-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(20px,2.6vw,34px);align-items:start;
  margin-top:clamp(32px,4vw,50px)}
@media(max-width:880px){.cs-grid{grid-template-columns:1fr}}
.cs-story{padding:0}
.cs-meta{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:24px}
@media(max-width:480px){.cs-meta{grid-template-columns:1fr}}
.cs-meta-row{background:#fff;padding:13px 16px}
.cs-meta-row dt{font-size:11px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-4)}
.cs-meta-row dd{margin-top:4px;font-size:14.5px;font-weight:500;color:var(--ink);line-height:1.35}
.cs-story p{font-size:15.5px;line-height:1.62;color:var(--ink-3);margin-bottom:14px}
.cs-story p strong{color:var(--ink-2);font-weight:600}
.cs-quote{margin:24px 0 0;padding:22px 24px;background:#fff;border:1px solid var(--line);border-radius:5px;
  border-left:3px solid var(--accent)}
#case{padding-bottom:50px}
.cs-quote p{font-family:var(--font-display);font-size:clamp(18px,2vw,21px);font-weight:500;
  letter-spacing:-.015em;line-height:1.32;color:var(--ink);margin:0 0 14px}
.cs-quote footer{display:flex;align-items:center;gap:12px}
.cs-quote-photo{width:44px;height:44px;border-radius:999px;object-fit:cover;flex:0 0 auto;
  background:var(--bg-soft,#f1f3f3)}
.cs-quote-id{display:flex;flex-direction:column;gap:1px}
.cs-quote-name{font-size:14.5px;font-weight:600;color:var(--ink)}
.cs-quote-role{font-size:13px;color:var(--ink-4)}

.cs-flow{position:relative;overflow:hidden;border-radius:var(--r-card);padding:clamp(26px,3vw,34px);
  color:#fff;background:var(--ink)}
.cs-flow-k{font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;margin-bottom:9px}
.cs-flow-h{font-family:var(--font-display);font-size:clamp(22px,2.4vw,27px);font-weight:500;
  letter-spacing:-.02em;line-height:1.15;margin:0 0 22px;color:#fff}
.cs-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:18px}
.cs-steps li{display:flex;gap:15px;align-items:flex-start}
.cs-step-n{flex:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:14px;font-weight:600;background:var(--white-a10);
  color:#fff;border:1px solid var(--white-a20)}
.cs-steps strong{display:block;font-size:15px;font-weight:600;color:#fff;margin-bottom:3px}
.cs-steps p{font-size:13.5px;line-height:1.5;color:var(--white-a60);margin:0}

/* ════════ ASSURANCES ════════ */
.assure{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:980px){.assure{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.assure{grid-template-columns:1fr}}
.assure-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-card);
  padding:30px 26px;box-shadow:var(--sh-sm)}
.assure-ic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);color:var(--accent-700);font-size:23px;margin-bottom:20px}
.assure-card h3{font-size:19px;margin-bottom:10px;letter-spacing:-.02em;font-weight:500}
.assure-card p{font-size:15px;color:var(--ink-3);line-height:1.52}

/* ════════ FINAL CTA + BOOKING ════════ */
.book-sec{position:relative;overflow:hidden;color:#fff;padding:clamp(68px,8.5vw,112px) 0;background:#0A0A0A}
/* dark base with a purple gradient bloom (overrides the cover-gradient default) */
.book-sec .cover-gradient{
  background:
    radial-gradient(58% 70% at 78% 18%,color-mix(in srgb,var(--accent) 62%,transparent) 0%,transparent 58%),
    radial-gradient(60% 68% at 12% 92%,var(--purple-800) 0%,transparent 62%),
    linear-gradient(160deg,#16111F 0%,#0A0A0A 60%);
}
.book-grid{position:relative;z-index:1;display:grid;grid-template-columns:.92fr 1.08fr;
  gap:clamp(40px,5vw,72px);align-items:center}
@media(max-width:980px){.book-grid{grid-template-columns:1fr;gap:40px}}
.book-pitch h2{color:#fff;margin:18px 0 18px;max-width:15ch}
.book-pitch em.hi{color:#fff}
.book-pitch .lead{color:var(--white-a75);max-width:44ch;font-family:var(--font-display);font-size:18px}
.book-badges{list-style:none;margin-top:30px;display:flex;flex-direction:column;gap:14px}
.book-badges li{display:flex;align-items:center;gap:12px;font-size:15.5px;color:var(--white-a90)}
.book-badges i{color:#fff;background:var(--white-a15);
  width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex:none}
.book-mail{margin-top:30px;font-size:14.5px;color:var(--white-a60)}
.book-mail a{color:#fff;font-weight:500;border-bottom:1px solid var(--white-a35)}

/* ════════ FOOTER ════════ */
.footer{background:#0A0A0A;color:#fff;padding:clamp(80px,9vw,120px) 0 48px}
.footer-top{display:grid;grid-template-columns:1fr;gap:clamp(40px,5vw,64px)}
@media(max-width:780px){.footer-top{grid-template-columns:1fr 1fr;gap:40px}}
.footer .brand-word{color:#fff}
.footer .brand-mark{color:#fff}
.footer .brand-logo{-webkit-filter:brightness(0) invert(1);filter:brightness(0) invert(1)}
.footer-lockup{display:flex;align-items:center;gap:16px;flex-wrap:nowrap}
@media(max-width:780px){
  .footer-top{grid-template-columns:1fr}
  .footer-lockup{flex-wrap:wrap;gap:12px 16px}
  .footer-tagline{padding-left:0;border-left:0}
}
/* keep the footer mark white on every viewport */
.footer .brand-logo{-webkit-filter:brightness(0) invert(1)!important;filter:brightness(0) invert(1)!important}
.footer-tagline{font-family:var(--font-display);font-size:clamp(18px,2vw,22px);font-weight:500;
  letter-spacing:-.02em;color:#fff;padding-left:16px;border-left:1px solid var(--white-a20);white-space:nowrap}
.footer-brand p{margin-top:22px;color:var(--white-a60);font-size:16px;max-width:40ch;line-height:1.6}
.footer-brand .merge{margin-top:20px;display:inline-flex;align-items:center;gap:8px;font-size:12.5px;
  font-weight:500;color:#fff;background:var(--white-a15);
  padding:7px 14px;border-radius:var(--r-cta)}
.footer h6{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--white-a40);margin-bottom:20px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.footer ul a{font-size:16px;color:var(--white-a75);transition:color .15s}
.footer ul a:hover{color:#fff}
.footer-bot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
  margin-top:clamp(56px,6vw,72px);padding-top:32px;border-top:1px solid var(--white-a15);
  font-size:14px;color:var(--white-a40)}
.footer-bot .soc{display:flex;gap:18px}
.footer-bot .soc a{color:var(--white-a60);transition:color .15s}
.footer-bot .soc a:hover{color:#fff}

/* ════════ ROADMAP (interactive 3-phase map) ════════ */
.rm-track{position:relative;display:grid;grid-template-columns:repeat(3,1fr);
  margin-bottom:clamp(28px,3.5vw,44px)}
.rm-rail{position:absolute;top:23px;left:16.66%;right:16.66%;height:2px;
  background:var(--line-2);z-index:0}
.rm-rail-fill{right:auto;background:var(--accent);transition:width .4s var(--ease);max-width:66.66%}
.rm-node{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:5px;border:0;background:transparent;cursor:pointer;padding:0 8px;
  font-family:var(--font-sans)}
.rm-dot{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:#fff;border:2px solid var(--line-2);color:var(--ink-4);
  font-family:var(--font-display);font-size:19px;font-weight:500;margin-bottom:6px;
  transition:.22s var(--ease)}
.rm-node:hover .rm-dot{border-color:var(--accent);color:var(--accent-700)}
.rm-node.is-done .rm-dot{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-700)}
.rm-node.is-active .rm-dot{background:var(--accent);border-color:var(--accent);color:#fff;
  box-shadow:0 0 0 6px color-mix(in srgb,var(--accent) 16%,transparent)}
.rm-tag{font-size:12px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-4)}
.rm-node.is-active .rm-tag,.rm-node.is-done .rm-tag{color:var(--accent-700)}
.rm-ttl{font-family:var(--font-display);font-size:17px;font-weight:500;letter-spacing:-.01em;color:var(--ink)}
.rm-when{font-size:13px;color:var(--ink-4)}
@media(max-width:560px){
  .rm-ttl{font-size:14px}.rm-tag{font-size:10.5px}.rm-when{font-size:11.5px}
  .rm-dot{width:42px;height:42px;font-size:17px}.rm-rail,.rm-rail-fill{top:20px}
}

.rm-detail{background:#fff;border:1px solid var(--line);border-radius:var(--r-frame);
  box-shadow:var(--sh-md);padding:clamp(28px,3.4vw,42px);animation:rmIn .4s var(--ease) both}
@keyframes rmIn{from{transform:translateY(10px)}to{transform:none}}
.rm-detail-head{display:block;padding-bottom:clamp(22px,2.6vw,30px);margin-bottom:clamp(24px,2.8vw,32px);
  border-bottom:1px solid var(--line)}
@media(max-width:780px){.rm-detail-head{grid-template-columns:1fr;gap:20px}}
.rm-detail-tag{font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);margin-bottom:12px}
.rm-strap{font-family:var(--font-display);font-size:clamp(24px,3vw,34px);font-weight:500;
  letter-spacing:-.025em;line-height:1.1;color:var(--ink);margin-bottom:14px;text-wrap:balance}
.rm-sum{font-size:16.5px;line-height:1.55;color:var(--ink-3);max-width:60ch}
.rm-powered{display:flex;flex-direction:column;gap:11px}
.rm-powered-l{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4)}
.rm-powered-row{display:flex;flex-wrap:wrap;gap:8px}
.rm-powered-pill{display:inline-flex;align-items:center;font-size:13px;font-weight:500;color:var(--ink-2);
  background:var(--soft);border:1px solid var(--line);border-radius:var(--r-cta);padding:7px 14px}
.rm-builds{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:720px){.rm-builds{grid-template-columns:1fr;gap:14px}}
.rm-build{background:var(--soft);border:1px solid var(--line);border-radius:var(--r-card);
  padding:22px 20px;animation:rmIn .45s var(--ease) both}
.rm-build-ic{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);color:var(--accent-700);font-size:21px;margin-bottom:15px}
.rm-build-t{font-family:var(--font-display);font-size:17px;font-weight:500;letter-spacing:-.01em;
  color:var(--ink);margin-bottom:7px}
.rm-build-d{font-size:14px;line-height:1.5;color:var(--ink-3)}

/* reveal-on-scroll */
.reveal-up{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-up.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal-up{opacity:1;transform:none;transition:none}}
