
:root{
  --bg:#06140d;--panel:#0c2317;--panel-2:#103020;--line:#1c4530;
  --green:#1fd47a;--green-2:#12a35c;--yellow:#ffd23f;--yellow-2:#f0b400;
  --sky:#27b7e6;--text:#e7f6ee;--muted:#9dc6b1;--white:#ffffff;
  --radius:14px;--maxw:1150px;--shadow:0 12px 34px rgba(0,0,0,.4);
  --font:'Segoe UI',Roboto,-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{width:100%;overflow-x:hidden;margin:0;padding:0}
body{
  font-family:var(--font);background:var(--bg);color:var(--text);
  line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none}
a:hover{text-decoration:underline}
main{display:block}
h1,h2,h3,h4{line-height:1.22;color:var(--white);margin:1.4em 0 .55em;font-weight:700}
h1{font-size:2.05rem;margin-top:.2em}
h2{font-size:1.5rem;border-bottom:2px solid var(--green-2);padding-bottom:.25rem}
h3{font-size:1.18rem;color:var(--yellow)}
p{margin:0 0 1.05em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}

/* ---- header ---- */
.topbar{background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.topbar .row{display:flex;align-items:center;gap:14px;max-width:var(--maxw);margin:0 auto;padding:11px 18px}
.brand{display:flex;align-items:baseline;gap:9px;font-weight:800;color:var(--white)}
.brand b{font-size:1.2rem;letter-spacing:.01em}
.brand small{font-size:.6rem;letter-spacing:.3em;color:var(--yellow);text-transform:uppercase;font-weight:700}
.menu{display:flex;align-items:center;gap:1px;margin-left:auto;flex-wrap:nowrap}
.menu a.lnk{color:var(--muted);padding:8px 10px;border-radius:8px;font-size:.9rem;white-space:nowrap}
.menu a.lnk:hover{color:var(--white);background:var(--panel-2);text-decoration:none}
.menu a.lnk[aria-current="page"]{color:var(--green)}
.go{background:linear-gradient(135deg,var(--yellow),var(--yellow-2));color:#1c1400!important;
  font-weight:800;padding:9px 15px;border-radius:10px;margin-left:8px;white-space:nowrap}
.go:hover{text-decoration:none;filter:brightness(1.06)}
.burger{display:none;margin-left:auto;width:44px;height:40px;background:var(--panel-2);
  border:1px solid var(--line);border-radius:10px;cursor:pointer;flex-direction:column;
  justify-content:center;align-items:center;gap:5px;padding:0}
.burger span{display:block;width:21px;height:2px;background:var(--green);border-radius:2px;transition:.2s}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---- carousel ---- */
.promo{background:var(--panel-2);border-bottom:1px solid var(--line);padding:12px 0}
.rail{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 18px}
.rail-view{overflow:hidden;border-radius:var(--radius)}
.rail-track{display:flex;transition:transform .45s ease}
.banner{position:relative;min-width:100%;display:block}
.banner img{width:100%;height:auto;object-fit:contain;background:#04110a;border-radius:var(--radius)}
.banner .ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;
  gap:6px;padding:5% 7%;background:linear-gradient(90deg,rgba(3,16,10,.8),rgba(3,16,10,.04))}
.banner .ov b{font-size:clamp(1rem,3.4vw,1.7rem);color:var(--white);max-width:62%}
.banner .ov span{color:var(--muted);font-size:clamp(.7rem,2.4vw,1rem);max-width:56%}
.banner .ov em{display:inline-block;margin-top:6px;background:var(--green);color:#04150c;font-style:normal;
  font-weight:800;padding:7px 14px;border-radius:9px;width:max-content;font-size:.85rem}
.rail-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:38px;height:38px;
  border-radius:50%;border:none;background:rgba(3,16,10,.72);color:var(--green);font-size:1.3rem;cursor:pointer}
.rail-btn.p{left:26px}.rail-btn.n{right:26px}
.rail-dots{display:flex;gap:7px;justify-content:center;margin-top:10px}
.rail-dots button{width:9px;height:9px;border-radius:50%;border:none;background:var(--line);cursor:pointer;padding:0}
.rail-dots button.on{background:var(--green);width:22px;border-radius:5px}

/* ---- hero ---- */
.aurora{position:relative;background:
  radial-gradient(900px 320px at 10% -10%,rgba(31,212,122,.2),transparent),
  radial-gradient(760px 300px at 94% 0%,rgba(255,210,63,.13),transparent),var(--bg);
  border-bottom:1px solid var(--line)}
.aurora .wrap{padding:34px 18px 26px}
.lede{font-size:1.12rem;color:var(--muted);max-width:64ch}
.updated{font-size:.83rem;color:var(--muted);margin:.2em 0 1em}
.updated b{color:var(--green)}
.snippet{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--yellow);
  border-radius:12px;padding:14px 18px;font-size:1.03rem;color:var(--text);margin:0 0 1.3em}

/* ---- breadcrumbs ---- */
.crumbs{font-size:.82rem;color:var(--muted);padding:14px 0 2px}
.crumbs a{color:var(--muted)}.crumbs a:hover{color:var(--green)}
.crumbs .s{margin:0 7px;color:var(--line)}
.crumbs b{color:var(--text)}

/* ---- content ---- */
.body{padding:8px 0 40px}
.body figure{margin:1.3em 0}
.body figure img{border-radius:var(--radius);border:1px solid var(--line)}
.body figcaption{font-size:.82rem;color:var(--muted);margin-top:.4em;text-align:center}
.fact{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;margin:1.3em 0}
.fact h3{margin-top:0}
.fact ul{margin:.4em 0 0;padding-left:1.1em}
.fact li{margin:.3em 0}

/* hub board (home) */
.board{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin:1.6em 0}
.tile{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;transition:.18s;display:flex;flex-direction:column;border-top:3px solid var(--green-2)}
.tile:hover{border-color:var(--green);transform:translateY(-3px)}
.tile h3{margin:0 0 .35em;color:var(--white)}
.tile p{font-size:.95rem;color:var(--muted);flex:1}
.tile a.more{margin-top:.6em;color:var(--green);font-weight:700}

/* tables */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);
  border-radius:var(--radius);margin:1.3em 0}
table{border-collapse:collapse;width:100%;min-width:460px}
caption{caption-side:top;text-align:left;color:var(--yellow);font-weight:700;padding:10px 14px}
th,td{padding:10px 14px;border-bottom:1px solid var(--line);text-align:left;font-size:.95rem}
th{background:var(--panel-2);color:var(--white)}
tbody tr:last-child td{border-bottom:none}

/* CTA */
.cta{margin:1.6em 0;text-align:center}
.cta .btn,.btn{display:inline-block;background:linear-gradient(135deg,var(--green),var(--green-2));
  color:#04150c;font-weight:800;padding:13px 30px;border-radius:11px;font-size:1.02rem;border:none;cursor:pointer}
.btn:hover{text-decoration:none;filter:brightness(1.07)}

/* safer-play aside */
.safer{background:var(--panel-2);border:1px dashed var(--green-2);border-radius:var(--radius);
  padding:16px 18px;margin:1.8em 0}
.safer h3{margin-top:0;color:var(--green)}
.safer ul{margin:.3em 0 0;padding-left:1.1em}

/* FAQ */
.faq{margin:2em 0}
.qa{background:var(--panel);border:1px solid var(--line);border-radius:11px;margin:.55em 0;overflow:hidden}
.qa summary{cursor:pointer;padding:14px 16px;font-weight:700;color:var(--white);list-style:none}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";float:right;color:var(--green);font-size:1.2rem}
.qa[open] summary::after{content:"\2212"}
.qa .a{padding:0 16px 14px;color:var(--muted)}

/* tabs (interactive format explainer) */
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin:1.4em 0 .4em}
.tabs button{background:var(--panel-2);border:1px solid var(--line);color:var(--muted);
  padding:8px 15px;border-radius:9px;cursor:pointer;font-weight:600}
.tabs button.on{background:var(--green);color:#04150c;border-color:var(--green)}
.tab-panel{display:none}.tab-panel.on{display:block}

/* footer */
.foot{background:var(--panel);border-top:1px solid var(--line);margin-top:30px}
.foot .grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:24px;max-width:var(--maxw);
  margin:0 auto;padding:30px 18px}
.foot h4{color:var(--green);font-size:.92rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 .6em}
.foot ul{list-style:none;margin:0;padding:0}
.foot li{margin:.32em 0}
.foot a{color:var(--muted)}.foot a:hover{color:var(--white)}
.foot .blurb{color:var(--muted);font-size:.92rem}
.legal{border-top:1px solid var(--line);text-align:center;padding:16px;color:var(--muted);font-size:.82rem}
.legal .dis{display:block;max-width:74ch;margin:0 auto .6em;font-size:.78rem}

/* back to top */
.totop{position:fixed;right:18px;bottom:18px;width:46px;height:46px;border-radius:50%;
  border:1px solid var(--green-2);background:var(--panel);color:var(--green);font-size:1.3rem;
  cursor:pointer;z-index:30;opacity:0;pointer-events:none;transition:.2s}
.totop.show{opacity:1;pointer-events:auto}

/* lightbox (hard-hidden when closed so it never eats taps) */
.lightbox{position:fixed;inset:0;background:rgba(2,10,6,.93);display:flex;align-items:center;
  justify-content:center;z-index:60;padding:24px}
.lightbox[hidden]{display:none}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:10px}
.lightbox .x{position:absolute;top:16px;right:20px;font-size:2rem;color:var(--white);
  background:none;border:none;cursor:pointer}

@media(max-width:860px){
  .foot .grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  body{font-size:16px}
  h1{font-size:1.7rem}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--panel);
    flex-direction:column;align-items:stretch;gap:0;border-bottom:1px solid var(--line);padding:8px}
  .menu.is-open{display:flex}
  .menu a.lnk{padding:12px 14px;border-radius:8px}
  .go{margin:8px 6px 4px;text-align:center}
  .burger{display:flex}
  .topbar .row{position:relative}
  .rail-btn.p{left:10px}.rail-btn.n{right:10px}
  /* Keep heading+CTA overlaid; drop the middle subtext on mobile so the short
     (uncropped) banner has room for the button without clipping */
  .banner img{min-height:118px}  /* contain -> letterbox (no crop), room for overlay */
  .banner .ov{padding:8px 12px;gap:4px;justify-content:center}
  .banner .ov b{max-width:64%;font-size:clamp(.9rem,4vw,1.1rem);line-height:1.15}
  .banner .ov span{display:none}
  .banner .ov em{margin-top:4px;font-size:.82rem;padding:6px 12px}
  .foot .grid{grid-template-columns:1fr}
  .board{grid-template-columns:1fr}
}
