/* Landing styles — mirrors the app's dark theme (web/app/css/tokens.css):
   #181A1B surfaces, the logo blue #1696DB as the brand accent (used boldly, not
   just as a hint), translucent hairlines, 6/10/16 radii. PulsarCast Ultra uses
   its gold (#F5C518) so it stands apart as the premium tier. CSP forbids inline
   styles, so everything lives here. */
:root{
  --bg:#181A1B; --surface:#1E2022; --elevated:#24262A;
  --text:#F4F4F0; --text-2:#A8A8AD; --text-3:#5A5A60;
  --blue:#1696DB; --blue-2:#1176B6; --blue-bright:#3CA9E4;
  --blue-soft:color-mix(in srgb, var(--blue) 18%, transparent);
  --gold:#F5C518; --gold-2:#E0B000; --gold-ink:#1A1404;
  --gold-soft:color-mix(in srgb, var(--gold) 18%, transparent);
  --line:rgba(255,255,255,.08);
  --r-sm:6px; --r-md:10px; --r-lg:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font:16px/1.6 -apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
::selection{background:var(--blue-soft)}
.wrap{max-width:780px;margin:0 auto;padding:0 22px}

/* Top bar */
header.site{position:sticky;top:0;background:color-mix(in srgb,var(--bg) 82%,transparent);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line);z-index:20}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:56px;gap:14px}
.brand{font-weight:700;font-size:18px;letter-spacing:-.01em;color:var(--text)}
.brand:hover{text-decoration:none}
.brand .c{color:var(--blue)}
.subnav{display:flex;align-items:center;gap:18px}
.subnav a{color:var(--text-2);font-size:15px;font-weight:600}
.subnav a:hover{color:var(--blue);text-decoration:none}

/* Hero — blue glow behind the logo gives the page the app's accent presence */
.hero{position:relative;text-align:center;padding:84px 0 60px;overflow:hidden}
.hero::before{content:"";position:absolute;top:-40px;left:50%;width:680px;height:520px;transform:translateX(-50%);background:radial-gradient(ellipse at center, color-mix(in srgb,var(--blue) 32%,transparent), transparent 62%);filter:blur(26px);z-index:0;pointer-events:none}
.hero .wrap{position:relative;z-index:1}
.logo{width:92px;height:92px;border-radius:21px;display:inline-block;margin-bottom:26px;box-shadow:0 18px 56px color-mix(in srgb,var(--blue) 50%,transparent);overflow:hidden}
.logo img{width:100%;height:100%;display:block}
.hero h1{font-size:44px;line-height:1.07;letter-spacing:-.025em;margin-bottom:16px}
.hero .lead{font-size:18px;color:var(--text-2);max-width:540px;margin:0 auto 32px}
.platforms{color:var(--text-3);font-size:14px;letter-spacing:.01em}
.platforms b{color:var(--blue);font-weight:600}

/* Generic pill buttons */
.cta-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:20px}
.cta{display:inline-block;background:var(--surface);border:1px solid var(--line);color:var(--text);padding:13px 22px;border-radius:999px;font-weight:600;font-size:15px}
.cta:hover{text-decoration:none;background:var(--elevated)}
.cta.live{background:var(--blue);border-color:var(--blue);color:#fff}
.cta.live:hover{background:var(--blue-2);border-color:var(--blue-2)}

/* Official store badges */
.cta-row.badges{gap:16px;align-items:center}
.badge{display:inline-flex;border-radius:var(--r-md)}
.badge:hover{text-decoration:none;opacity:.88}
.badge img{display:block;height:50px;width:auto}   /* both badges trimmed to content → equal height = equal size */

/* Feature grid — the brand blue on every tile, like the app's icon tiles */
.features{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:14px 0 24px}
.feature{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;text-align:left}
.feature .dot{width:38px;height:38px;border-radius:var(--r-md);background:var(--blue-soft);color:var(--blue-bright);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:13px}
.feature .dot svg{display:block}
.feature h3{font-size:16px;margin-bottom:6px;color:var(--text)}
.feature p{font-size:14px;color:var(--text-2)}
.feature.wide{grid-column:1 / -1}
.feature.wide p b{color:var(--text);font-weight:600}

/* Section headers */
.sec-title{text-align:center;padding:18px 0 4px}
.sec-title h2{font-size:27px;letter-spacing:-.02em;margin-bottom:8px}
.sec-title p{color:var(--text-2);font-size:16px;max-width:540px;margin:0 auto}

/* Ultra band — the premium tier, in gold so it stands out */
.ultra-band{position:relative;margin:18px 0 56px;background:linear-gradient(150deg,var(--gold-soft),color-mix(in srgb,var(--gold) 4%,transparent) 60%);border:1px solid color-mix(in srgb,var(--gold) 34%,transparent);border-radius:var(--r-lg);padding:34px 30px;box-shadow:0 24px 60px color-mix(in srgb,var(--gold) 10%,transparent)}
.ultra-band .eyebrow{display:inline-flex;align-items:center;gap:7px;color:var(--gold);font-weight:800;font-size:13px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:12px}
.ultra-band h2{font-size:28px;letter-spacing:-.02em;margin-bottom:10px}
.ultra-band>p{color:var(--text-2);font-size:16px;max-width:560px;margin-bottom:24px}
.ultra-list{display:grid;grid-template-columns:1fr 1fr;gap:16px 26px;margin-bottom:28px}
.ultra-list>div{display:flex;gap:11px;align-items:flex-start}
.ultra-list>div>div{flex:1;min-width:0}
.ultra-list .g{flex:0 0 auto;width:28px;height:28px;border-radius:8px;background:var(--gold-soft);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:15px;margin-top:1px}
.ultra-list strong{display:block;font-size:15px;color:var(--text)}
.ultra-list strong em{display:inline-block;margin-left:7px;padding:1px 8px;border-radius:999px;background:var(--gold);color:var(--gold-ink);font-style:normal;font-weight:800;font-size:11px;letter-spacing:.03em;text-transform:uppercase;vertical-align:middle}
.ultra-list span{font-size:14px;color:var(--text-2)}

/* Purchase buttons — gold, high-contrast, built to convert */
.plan-lead{color:var(--text);font-size:16px;font-weight:700;margin-bottom:14px}
.buybtns{display:flex;flex-wrap:wrap;gap:14px;align-items:stretch;margin-bottom:16px}
.buy{display:flex;flex-direction:column;justify-content:center;gap:3px;min-width:220px;padding:16px 28px;border-radius:14px;font-weight:700;text-align:center;border:2px solid var(--gold)}
.buy:hover{text-decoration:none}
.buy.primary{background:var(--gold);color:var(--gold-ink);box-shadow:0 12px 32px color-mix(in srgb,var(--gold) 32%,transparent)}
.buy.primary:hover{background:var(--gold-2);border-color:var(--gold-2)}
.buy.primary b{font-size:18px;letter-spacing:-.01em}
.buy.primary small{font-size:12.5px;font-weight:700;opacity:.78}
.buy.alt{background:transparent;color:var(--gold)}
.buy.alt:hover{background:var(--gold-soft)}
.buy.alt b{font-size:17px}
.buy.alt small{font-size:12px;font-weight:600;color:var(--text-2)}
.band-note{color:var(--text-3);font-size:13px;margin-top:4px}
.band-note a{color:var(--gold);font-weight:600}

/* Footer */
footer.site{border-top:1px solid var(--line);padding:30px 0 48px;color:var(--text-3);font-size:14px}
footer.site .wrap{display:flex;flex-wrap:wrap;gap:14px 22px;justify-content:space-between;align-items:center}
footer.site nav a{color:var(--text-2);margin-right:18px}
footer.site nav a:hover{color:var(--blue);text-decoration:none}

@media(max-width:640px){.ultra-list{grid-template-columns:1fr}.ultra-band{padding:26px 20px}.buy{flex:1 1 100%;min-width:0}}
@media(max-width:600px){.hero{padding:60px 0 44px}.hero h1{font-size:33px}.features{grid-template-columns:1fr}.sec-title h2,.ultra-band h2{font-size:23px}}
