:root{ --maxw: 1120px; }
[data-theme="light"]{
  --bg:#f0f4f7; --bg-soft:#e8eef3; --surface:#ffffff; --surface-2:#f7fafc;
  --text:#4c5564; --muted:#69788a; --heading:#22384a;
  --border:#dfe7ee; --border-strong:#c9d6e0;
  --accent:#0e87e6; --accent-hover:#0b76cc; --accent-soft:#e1f1fd;
  --steel:#39698e; --dash:#9fb3c4;
  --good:#1f9d61; --good-soft:#e2f5ec;
  --band:#243a50; --band-2:#1e3144; --band-text:#ffffff; --band-muted:#b9c9d6;
  --shadow:0 12px 40px rgba(36,58,80,.10);
  --header-bg:rgba(255,255,255,.82);
}
[data-theme="dark"]{
  --bg:#1c1d27; --bg-soft:#1f202b; --surface:#252631; --surface-2:#2a2b38;
  --text:#aab8c5; --muted:#8391a2; --heading:#e7ecf1;
  --border:#37394d; --border-strong:#454861;
  --accent:#36a3f2; --accent-hover:#5cb5f5; --accent-soft:#1c3a55;
  --steel:#7ba6c9; --dash:#4e5a70;
  --good:#34b97c; --good-soft:#173a2b;
  --band:#13141c; --band-2:#181924; --band-text:#e7ecf1; --band-muted:#9fb0bf;
  --shadow:0 12px 40px rgba(0,0,0,.35);
  --header-bg:rgba(28,29,39,.82);
}
*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth; scroll-padding-top:84px}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg); color:var(--text); line-height:1.65; font-size:16px;
  -webkit-font-smoothing:antialiased;
}
.container{max-width:var(--maxw); margin:0 auto; padding:0 24px}
h1,h2,h3{color:var(--heading); line-height:1.15; letter-spacing:-0.02em}
a{color:var(--accent); text-decoration:none}
section{padding:88px 0}
.eyebrow{color:var(--accent); font-weight:700; font-size:13px; letter-spacing:.14em; text-transform:uppercase; margin-bottom:14px}
.section-title{font-size:clamp(1.7rem,3.4vw,2.4rem); font-weight:800; margin-bottom:16px}
.lead{font-size:18px; color:var(--muted); max-width:680px}
.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px; padding:13px 24px; border-radius:10px; font-weight:600; font-size:15.5px; cursor:pointer; border:none; transition:all .18s ease; white-space:nowrap}
.btn svg{flex:none}
.btn-primary{background:var(--accent); color:#fff !important}
.btn-primary:hover{background:var(--accent-hover); transform:translateY(-1px); box-shadow:0 6px 18px rgba(14,135,230,.35)}
.btn-ghost{background:var(--surface); color:var(--heading) !important; border:1px solid var(--border-strong)}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent) !important}
.btn-band{background:transparent; color:#fff !important; border:1px solid rgba(255,255,255,.4)}
.btn-band:hover{border-color:#fff; background:rgba(255,255,255,.08)}

/* header */
.site-header{position:sticky; top:0; z-index:100; background:var(--header-bg); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--border)}
.site-header .container{display:flex; align-items:center; justify-content:space-between; height:68px; gap:18px}
.brand{display:flex; align-items:center; gap:10px}
.brand img{height:40px; width:auto}
.wm{font-size:21px; font-weight:800; letter-spacing:-0.02em; color:var(--heading)}
.wm b{color:var(--accent); font-weight:800}
.byline{font-size:11.5px; font-weight:600; color:var(--muted); letter-spacing:.06em; margin-top:-3px; text-transform:uppercase}
.brand-text{display:flex; flex-direction:column; line-height:1.2}
.nav-links{display:flex; gap:26px; align-items:center}
.nav-links a{color:var(--muted); font-weight:500; font-size:15px}
.nav-links a:hover{color:var(--heading)}
.header-actions{display:flex; align-items:center; gap:12px}
.theme-btn{display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:10px; border:1px solid var(--border-strong); background:var(--surface); color:var(--muted); cursor:pointer; transition:all .18s}
.theme-btn:hover{color:var(--accent); border-color:var(--accent)}
[data-theme="light"] .sun{display:none}
[data-theme="dark"] .moon{display:none}
[data-theme="light"] .logo-dark{display:none}
[data-theme="dark"] .logo-light{display:none}
.hamburger{display:none; width:40px; height:40px; border-radius:10px; border:1px solid var(--border-strong); background:var(--surface); color:var(--heading); cursor:pointer; align-items:center; justify-content:center}
.mobile-nav{display:none}

/* hero */
.hero{position:relative; text-align:center; padding:92px 0 80px; overflow:hidden; background:radial-gradient(1100px 480px at 50% -120px, var(--accent-soft), transparent 65%)}
.badge{display:inline-flex; align-items:center; gap:8px; padding:7px 16px; border-radius:999px; background:var(--surface); border:1px solid var(--border-strong); color:var(--steel); font-weight:600; font-size:13.5px; margin-bottom:26px}
.hero h1{font-size:clamp(2.3rem,5.4vw,3.6rem); font-weight:800; max-width:880px; margin:0 auto 20px}
.hero h1 em{font-style:normal; color:var(--accent)}
.hero .lead{margin:0 auto 14px}
.tagline{font-size:19px; font-weight:700; color:var(--steel); margin-bottom:40px}

/* dual path cards */
.path-cards{display:grid; grid-template-columns:1fr 1fr; gap:22px; max-width:920px; margin:0 auto}
.path-card{background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:32px 30px; text-align:left; box-shadow:var(--shadow); display:flex; flex-direction:column; gap:12px}
.path-card.parker{border-top:4px solid var(--accent)}
.path-card.operator{border-top:4px solid var(--steel)}
.path-card h3{font-size:20px; font-weight:800}
.path-card p{font-size:15px; color:var(--muted); flex:1}
.path-card .btn{width:100%}
.path-micro{font-size:13px; color:var(--muted); text-align:center}
.path-alt{font-size:14.5px; text-align:center; font-weight:600}

/* why cards */
.why{padding-top:72px}
.cards-3{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.vcard{background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:30px 28px; text-align:left}
.icon-tile{width:46px; height:46px; border-radius:12px; background:var(--accent-soft); color:var(--accent); display:flex; align-items:center; justify-content:center; margin-bottom:18px}
.vcard h3{font-size:18.5px; font-weight:700; margin-bottom:8px}
.vcard p{font-size:15px; color:var(--muted)}

/* feature sections */
.feature .container{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center}
.feature.rev .feat-text{order:2}
.feature.rev .feat-media{order:1}
.feature .lead{margin-bottom:24px}
.checks{list-style:none; display:flex; flex-direction:column; gap:13px}
.checks li{display:flex; gap:12px; align-items:flex-start; font-size:15.5px}
.checks li svg{flex:none; color:var(--accent); margin-top:3px}
.checks li b{color:var(--heading); font-weight:600}
.feat-media{display:flex; flex-direction:column; gap:20px}
.tinted{background:var(--bg-soft)}
.feat-cta{margin-top:26px; display:flex; gap:14px; flex-wrap:wrap; align-items:center}
.free-note{font-size:14px; color:var(--muted); font-weight:600}

/* product vignettes (illustrations, not screenshots) */
.shot{background:var(--surface); border:1px solid var(--border); border-radius:14px; box-shadow:var(--shadow); overflow:hidden}
.shot-bar{display:flex; align-items:center; gap:6px; padding:11px 16px; border-bottom:1px solid var(--border)}
.shot-bar i{width:10px; height:10px; border-radius:50%; background:var(--border-strong); display:inline-block}
.shot-bar span{margin-left:10px; font-size:12.5px; color:var(--muted)}
.vignette{padding:22px; display:flex; flex-direction:column; gap:14px}
.vg-row{display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap}
.vg-title{font-weight:700; color:var(--heading); font-size:15.5px}
.vg-sub{font-size:13.5px; color:var(--muted)}
.pill{font-size:12px; font-weight:700; padding:3px 11px; border-radius:999px; background:var(--accent-soft); color:var(--accent); letter-spacing:.03em; white-space:nowrap}
.pill.good{background:var(--good-soft); color:var(--good)}
.steps{display:flex; align-items:center; gap:0; margin:2px 0}
.step{display:flex; flex-direction:column; align-items:center; gap:6px; flex:1; position:relative; font-size:12px; color:var(--muted); font-weight:600; text-align:center}
.step .dot{width:22px; height:22px; border-radius:50%; border:2px solid var(--border-strong); background:var(--surface); display:flex; align-items:center; justify-content:center; color:#fff; z-index:1}
.step.done .dot{background:var(--accent); border-color:var(--accent)}
.step:not(:first-child)::before{content:""; position:absolute; top:11px; right:50%; width:100%; height:2px; background:var(--border-strong)}
.step.done:not(:first-child)::before{background:var(--accent)}
.chips{display:flex; gap:8px; flex-wrap:wrap}
.chip{display:inline-flex; align-items:center; gap:7px; font-size:12.5px; font-weight:600; color:var(--text); background:var(--surface-2); border:1px solid var(--border); padding:6px 12px; border-radius:8px}
.chip svg{color:var(--good)}
.note-box{background:var(--accent-soft); border-radius:10px; padding:13px 15px; font-size:13.5px; color:var(--heading)}
.note-box b{color:var(--accent)}
.conf{display:flex; align-items:center; gap:12px}
.conf-bar{flex:1; height:8px; border-radius:99px; background:var(--bg-soft); overflow:hidden}
.conf-bar i{display:block; height:100%; width:92%; border-radius:99px; background:linear-gradient(90deg, var(--accent), var(--good))}
.conf b{font-size:13.5px; color:var(--heading); white-space:nowrap}
.vg-list{list-style:none; display:flex; flex-direction:column; gap:8px}
.vg-list li{display:flex; gap:9px; align-items:flex-start; font-size:13.5px}
.vg-list li svg{flex:none; color:var(--accent); margin-top:3px}
.vg-actions{display:flex; gap:9px; flex-wrap:wrap}
.mini-btn{font-size:13px; font-weight:600; padding:8px 14px; border-radius:8px; border:1px solid var(--border-strong); background:var(--surface); color:var(--heading); cursor:default}
.mini-btn.solid{background:var(--accent); border-color:var(--accent); color:#fff}
.policy-quote{border-left:3px solid var(--accent); padding:4px 0 4px 14px; font-size:13.5px; color:var(--muted); font-style:italic}

/* how it works */
.hiw-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:48px; text-align:left}
.hiw{background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:30px 28px; position:relative}
.hiw .num{position:absolute; top:-16px; left:24px; width:32px; height:32px; border-radius:50%; background:var(--accent); color:#fff; font-weight:800; font-size:15px; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow)}
.hiw h3{font-size:17.5px; font-weight:700; margin-bottom:8px; margin-top:6px}
.hiw p{font-size:14.5px; color:var(--muted)}
.center{text-align:center}
.center .lead{margin-left:auto; margin-right:auto}

/* company band */
.band{background:var(--band); text-align:center}
.band .eyebrow{color:#7cc1f3}
.band .section-title{color:var(--band-text)}
.band .lead{color:var(--band-muted); margin:0 auto 18px; max-width:760px}
.band .cta-row{margin-top:34px}
.cta-row{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}
.xlink{display:inline-flex; align-items:center; gap:8px; color:#7cc1f3; font-weight:600; font-size:15.5px}
.xlink:hover{color:#fff}

/* faq */
.faq-list{max-width:820px; margin:44px auto 0}
.faq-group{margin-top:34px}
.faq-group h3{font-size:14px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:6px}
details{border-bottom:1px solid var(--border)}
details:first-of-type{border-top:1px solid var(--border)}
summary{cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:16px; padding:20px 6px; font-weight:600; font-size:16.5px; color:var(--heading)}
summary::-webkit-details-marker{display:none}
summary svg{flex:none; color:var(--muted); transition:transform .25s}
details[open] summary svg{transform:rotate(45deg); color:var(--accent)}
details p{padding:0 6px 22px; color:var(--muted); font-size:15.5px; max-width:740px}

/* final cta */
.get-started{background:radial-gradient(900px 420px at 50% 120%, var(--accent-soft), transparent 65%)}

/* footer */
footer{background:var(--band); color:var(--band-muted); padding:54px 0 0}
.foot-grid{display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; padding-bottom:40px}
.foot-brand img{height:46px; width:auto; margin-bottom:14px}
.foot-brand .wm{color:#fff}
.foot-brand p{font-size:14px; max-width:340px; margin-top:10px}
.foot-col h4{color:#fff; font-size:14px; font-weight:700; margin-bottom:14px; letter-spacing:.04em}
.foot-col a{display:block; color:var(--band-muted); font-size:14.5px; margin-bottom:9px}
.foot-col a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12); padding:20px 0; font-size:13.5px; display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap}

/* legal pages (privacy) */
.legal{max-width:860px; margin:0 auto; padding:56px 24px 72px}
.legal h1{font-size:2.2rem; font-weight:800; margin-bottom:8px}
.legal h2{font-size:1.45rem; font-weight:700; margin:40px 0 12px}
.legal h3{font-size:1.15rem; font-weight:700; margin:28px 0 10px}
.legal h4{font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--steel); margin:20px 0 8px}
.legal p{margin:0 0 14px}
.legal ul{margin:0 0 16px 22px}
.legal li{margin-bottom:6px}
.legal section{padding:0; margin:0}
.legal a{word-break:break-word}

/* 404 */
.notfound{min-height:60vh; display:flex; align-items:center; text-align:center; background:radial-gradient(1100px 480px at 50% -120px, var(--accent-soft), transparent 65%)}
.notfound .code{font-size:clamp(4rem,10vw,6.5rem); font-weight:800; color:var(--accent); line-height:1}
.notfound h1{font-size:clamp(1.5rem,3vw,2.1rem); margin:10px 0 14px}
.notfound .lead{margin:0 auto 30px}

/* reveal animation */
html.js .reveal{opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1)}
html.js .reveal.in{opacity:1; transform:none}

@media (max-width: 980px){
  .nav-links{display:none}
  .hamburger{display:inline-flex}
  .mobile-nav{display:none; flex-direction:column; gap:4px; padding:10px 24px 18px; border-top:1px solid var(--border); background:var(--header-bg); backdrop-filter:blur(14px)}
  .mobile-nav.open{display:flex}
  .mobile-nav a{padding:10px 0; color:var(--heading); font-weight:600; font-size:16px}
  .cards-3,.hiw-grid{grid-template-columns:1fr 1fr}
  .feature .container{grid-template-columns:1fr}
  .feature.rev .feat-text{order:1}
  .feature.rev .feat-media{order:2}
  .path-cards{grid-template-columns:1fr}
}
@media (max-width: 620px){
  .cards-3,.hiw-grid{grid-template-columns:1fr}
  section{padding:64px 0}
  .header-cta{display:none}
  .byline{display:none}
}
