/* Cofounder — landing page styles. Palette mirrors the in-game UiTheme. */
:root{
  --blue:#3D5AF1; --green:#12B981; --purple:#7C5CFC; --gold:#F4B400;
  --ink:#1A2230; --muted:#6B7686; --bg:#EEF0F4; --surface:#FFFFFF; --line:#E4E7EC; --chip:#F1F3F7;
  --radius:18px; --shadow:0 18px 50px rgba(26,34,48,.12); --shadow-sm:0 6px 18px rgba(26,34,48,.08);
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  line-height:1.55; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
h1,h2,h3{line-height:1.1;letter-spacing:-.02em;margin:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.grad{background:linear-gradient(100deg,#9db4ff,#c9b6ff);-webkit-background-clip:text;background-clip:text;color:transparent}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;font-weight:700;border-radius:999px;
  padding:.7em 1.25em;background:var(--blue);color:#fff;border:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(61,90,241,.35)}
.btn-lg{font-size:1.08rem;padding:.95em 1.7em}
.btn-sm{font-size:.92rem;padding:.55em 1.05em}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.2);box-shadow:none}

/* nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;padding:14px 22px}
.nav::before{content:"";position:fixed;inset:0 0 auto 0;height:70px;background:rgba(238,240,244,.92);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);z-index:-1}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.25rem;letter-spacing:-.02em}
.brand-mark{width:30px;height:30px}
.brand.small{font-size:1.05rem}
.nav-links{display:flex;align-items:center;gap:26px;font-weight:600;color:var(--muted)}
.nav-links a:not(.btn):hover{color:var(--ink)}

/* hero */
.hero{position:relative;color:#fff;overflow:hidden;
  background:radial-gradient(120% 130% at 80% 0%,#5b6cff 0%,#3D5AF1 38%,#2a2f8f 78%,#20235f 100%)}
.hero-glow{position:absolute;width:680px;height:680px;right:-160px;top:-220px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,92,252,.55),transparent 62%);filter:blur(10px);pointer-events:none}
.hero-inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:74px 22px 110px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.eyebrow{display:inline-block;font-size:.82rem;font-weight:800;letter-spacing:.18em;
  color:#bcd0ff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:.4em .9em;border-radius:999px}
.hero h1{font-size:clamp(2.5rem,5.4vw,4rem);font-weight:850;margin:18px 0 0}
.lede{font-size:clamp(1.05rem,1.6vw,1.25rem);color:#dfe6ff;max-width:34ch;margin:20px 0 0}
.lede strong{color:#fff}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin:30px 0 0}
.cta-note{margin:16px 0 0;color:#bcc8f5;font-size:.92rem}

/* hero art */
.hero-art{position:relative;height:420px}
.card{position:absolute;background:#fff;color:var(--ink);border-radius:16px;box-shadow:var(--shadow);padding:16px 18px}
.card-head{display:flex;gap:6px;margin-bottom:12px}
.dot{width:9px;height:9px;border-radius:50%;background:#e4e7ec}
.card-chart{left:0;top:40px;width:300px}
.metric{display:flex;justify-content:space-between;align-items:baseline}
.metric-label{color:var(--muted);font-weight:600;font-size:.85rem}
.metric-val{font-weight:800;font-size:1.5rem}.metric-val small{color:var(--muted);font-size:.9rem;font-weight:600}
.metric-val.big{font-size:2rem;display:block}
.spark{width:100%;height:90px;margin-top:8px;display:block}
.card-users{right:6px;top:0;width:150px;text-align:left;animation:float 6s ease-in-out infinite}
.pill{display:inline-block;margin-top:8px;font-size:.78rem;font-weight:800;padding:.25em .7em;border-radius:999px}
.pill.up{background:#dcfaee;color:#0f9d6b}
.card-coop{right:24px;bottom:8px;width:260px;display:flex;align-items:center;gap:6px;animation:float 7s ease-in-out infinite .6s}
.avatar{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;font-size:1.2rem;flex:0 0 auto}
.a1{background:var(--blue)}.a2{background:var(--purple)}
.link-line{flex:1;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--blue),var(--purple));position:relative}
.link-line::after{content:"";position:absolute;inset:-3px auto -3px 50%;width:9px;height:9px;border-radius:50%;background:var(--green);transform:translateX(-50%);box-shadow:0 0 0 4px rgba(18,185,129,.18)}
.coop-tag{position:absolute;bottom:-26px;left:0;color:var(--muted);font-size:.8rem;font-weight:600;white-space:nowrap}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* bands & sections */
.band{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section{padding:84px 0}.band .wrap{padding-top:84px;padding-bottom:84px}
.kicker{display:inline-block;font-size:.8rem;font-weight:800;letter-spacing:.16em;color:var(--blue)}
.section-head{text-align:center;max-width:640px;margin:0 auto 46px}
.section-head h2,.band h2{font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:850;margin:10px 0 0}
.section-head p{color:var(--muted);font-size:1.1rem;margin:12px 0 0}
.band-lede{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--muted);max-width:60ch;margin:16px 0 0}
.band-lede strong{color:var(--ink)}

/* co-op points */
.coop-points{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:38px}
.cp{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:22px;font-size:.98rem;color:var(--muted)}
.cp b{color:var(--ink)}
.cp-ic{font-size:1.6rem;display:block;margin-bottom:8px}

/* steps */
.steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow-sm)}
.step-n{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--purple));color:#fff;font-weight:800;font-size:1.2rem;margin-bottom:16px}
.step h3{font-size:1.2rem;margin-bottom:8px}
.step p{color:var(--muted);font-size:.97rem;margin:0}
.step b{color:var(--ink)}

/* features grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease}
.feat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feat-ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;color:#fff;margin-bottom:16px;font-weight:800}
.ic-blue{background:var(--blue)}.ic-green{background:var(--green)}.ic-purple{background:var(--purple)}.ic-gold{background:var(--gold)}
.feat h3{font-size:1.2rem;margin-bottom:8px}
.feat p{color:var(--muted);font-size:.97rem;margin:0}

/* screenshots */
.shots{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.shot{margin:0;background:var(--bg);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease}
.shot.feature{grid-column:1 / -1}
.shot:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.shot-bar{display:flex;gap:6px;padding:11px 14px;background:#fff;border-bottom:1px solid var(--line)}
.shot-bar span{width:9px;height:9px;border-radius:50%;background:#dfe3ea}
.shot img{display:block;width:100%;height:auto;background:var(--bg)}
.shot.feature img{max-height:520px;object-fit:contain}
.shot figcaption{padding:14px 16px;color:var(--muted);font-size:.95rem;font-weight:600;background:#fff;border-top:1px solid var(--line);text-align:center}
@media (max-width:760px){.shots{grid-template-columns:1fr;max-width:520px;margin:0 auto}}

/* roadmap */
.road{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.road-col{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;box-shadow:var(--shadow-sm)}
.road-col.is-now{border-color:rgba(18,185,129,.5);box-shadow:0 12px 32px rgba(18,185,129,.14)}
.road-tag{display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:.1em;color:var(--muted);background:var(--bg);border:1px solid var(--line);padding:.45em .85em;border-radius:999px;margin-bottom:18px}
.road-col.is-now .road-tag{color:#0f9d6b;background:#dcfaee;border-color:rgba(18,185,129,.4)}
.road-col ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:13px}
.road-col li{position:relative;padding-left:26px;color:var(--muted);font-size:1rem}
.road-col li::before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;border-radius:50%;background:#cfd5df}
.road-col.is-now li::before{background:var(--green)}
.road-col li strong{color:var(--ink)}

/* co-op in 3 steps */
.steps3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step3{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow-sm);text-align:center}
.step3 .s3-n{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--purple));color:#fff;font-weight:800;font-size:1.3rem;margin-bottom:16px}
.step3.is-code{border-color:rgba(18,185,129,.45)}
.step3 .s3-code{display:inline-block;font-family:ui-monospace,"Cascadia Code",Consolas,monospace;font-weight:800;font-size:1.3rem;letter-spacing:2px;color:#0f9d6b;background:#dcfaee;border:1.5px dashed rgba(18,185,129,.55);padding:.45em 1em;border-radius:12px;margin-bottom:16px}
.step3 h3{font-size:1.18rem;margin-bottom:8px}
.step3 p{color:var(--muted);font-size:.98rem;margin:0}
.step3 b{color:var(--ink)}
.steps3-cta{text-align:center;margin-top:36px}
@media (max-width:760px){.road{grid-template-columns:1fr;max-width:460px;margin:0 auto}.steps3{grid-template-columns:1fr;max-width:460px;margin:0 auto}}

/* faq */
.faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:20px 22px;font-weight:700;font-size:1.08rem;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--blue);font-size:1.6rem;font-weight:700;line-height:1;transition:transform .2s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:0;padding:0 22px 22px;color:var(--muted);font-size:1rem;line-height:1.6}
.faq em{color:var(--ink);font-style:normal;font-weight:700}

/* hero note link */
.cta-note a{color:#fff;font-weight:700;text-decoration:underline;text-underline-offset:2px}
.cta-note a:hover{color:#dfe6ff}

/* soft button (secondary, on light bg) */
.btn-soft{background:var(--chip,#f1f3f7);color:var(--blue);border:1.5px solid var(--line)}
.btn-soft:hover{background:#e9ecf5;box-shadow:0 10px 24px rgba(61,90,241,.16)}

/* pricing */
.price{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;max-width:840px;margin:0 auto}
.price-col{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.price-col.is-free{border-color:rgba(18,185,129,.5);box-shadow:0 14px 36px rgba(18,185,129,.14)}
.price-tag{display:inline-block;align-self:flex-start;font-size:.74rem;font-weight:800;letter-spacing:.1em;color:var(--muted);background:var(--bg);border:1px solid var(--line);padding:.45em .85em;border-radius:999px}
.price-col.is-free .price-tag{color:#0f9d6b;background:#dcfaee;border-color:rgba(18,185,129,.4)}
.price-amt{font-size:2.4rem;font-weight:850;letter-spacing:-.02em;margin:18px 0 4px}
.price-amt span{display:inline-block;font-size:.9rem;font-weight:700;color:var(--muted);margin-left:8px;letter-spacing:0}
.price-col ul{margin:14px 0 24px;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px}
.price-col li{position:relative;padding-left:28px;color:var(--muted);font-size:1rem}
.price-col li::before{content:"✓";position:absolute;left:0;top:0;color:#cfd5df;font-weight:800}
.price-col.is-free li::before{color:var(--green)}
.price-col li strong{color:var(--ink)}
.price-col .btn{margin-top:auto;align-self:flex-start}
.price-fine{text-align:center;color:var(--muted);font-size:.95rem;max-width:620px;margin:28px auto 0}
@media (max-width:760px){.price{grid-template-columns:1fr;max-width:440px}}

/* waitlist */
.wl-wrap{max-width:720px;margin:0 auto;text-align:center}
.wl-form{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:6px auto 0;max-width:520px}
.wl-email{flex:1 1 260px;min-width:0;font:inherit;font-size:1.02rem;padding:.85em 1.1em;border-radius:999px;border:1.5px solid var(--line);background:var(--bg);color:var(--ink);outline:none;transition:border-color .15s ease,box-shadow .15s ease}
.wl-email:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(61,90,241,.14);background:#fff}
.wl-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.wl-msg{margin:18px 0 0;font-weight:700;color:#0f9d6b;font-size:1.05rem}
.wl-fine{margin:14px 0 0;color:var(--muted);font-size:.88rem}

/* final cta */
.cta-final{text-align:center;padding:96px 0;
  background:radial-gradient(120% 140% at 50% 0%,#4a5cf5,#3D5AF1 55%,#2a2f8f);color:#fff}
.cta-final h2{font-size:clamp(2rem,4vw,2.8rem);font-weight:850}
.cta-final p{color:#dfe6ff;font-size:1.15rem;margin:14px 0 28px}
.platforms{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:30px}
.plat{font-size:.9rem;font-weight:600;color:#cdd6ff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);padding:.5em 1em;border-radius:999px}
.plat.on{color:#fff;background:rgba(18,185,129,.25);border-color:rgba(18,185,129,.5)}
.plat-note{margin-top:16px;color:#c2cdf2;font-size:.86rem}.plat-note strong{color:#fff}

/* footer */
.foot{background:#161c28;color:#aeb6c4;padding:42px 0 26px}
.foot-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot .brand{color:#fff}
.foot-tag{margin:10px 0 0;color:#8b95a6;font-size:.95rem}
.foot-links{display:flex;flex-wrap:wrap;gap:22px;font-weight:600;padding-top:4px}
.foot-links a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:22px;font-size:.88rem;color:#8b95a6}
.foot-bottom strong{color:#cdd3dd}
@media (max-width:600px){.foot-inner{flex-direction:column;gap:18px}}

/* reveal — content is visible by DEFAULT; .anim is added by JS only as an enhancement, so a JS/Safari hiccup
   can never leave the page blank. */
.anim{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.anim.in{opacity:1;transform:none}

/* responsive */
@media (max-width:880px){
  .nav-links a:not(.btn){display:none}
  .hero-inner{grid-template-columns:1fr;gap:24px;padding-bottom:60px}
  .hero-art{height:300px;margin-top:6px}
  .card-users{display:none}                 /* avoid card overlap on narrow screens */
  .card-chart{width:88%;left:0;top:6px}
  .card-coop{right:0;bottom:4px;width:92%}
  .coop-points{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  .steps{grid-template-columns:1fr}
  .hero-art{height:320px}
  .cta-row .btn{flex:1 1 auto}
}
@media (prefers-reduced-motion:reduce){.anim,.card-users,.card-coop{transition:none;animation:none;opacity:1;transform:none}}
