/* ----- tokens ----- */
:root, [data-theme="brand"] { --a1:#a855f7; --a2:#3b82f6; --a3:#22d3ee; --t1:#bd6cff; --t2:#4d8dff; --t3:#21e8ff; }
[data-theme="roblox"]    { --a1:#1f6bff; --a2:#4f9cff; --a3:#cfe3ff; --t1:#2f7bff; --t2:#5cb2ff; --t3:#8fd2ff; }
[data-theme="uefn"]      { --a1:#8b5cf6; --a2:#4c51f7; --a3:#5fceea; --t1:#a578ff; --t2:#5d63ff; --t3:#4fdcff; }
[data-theme="minecraft"] { --a1:#4ade80; --a2:#2dd4bf; --a3:#22d3ee; --t1:#54f08c; --t2:#2ee8c4; --t3:#1fe1ff; }
:root {
  --bg:#070710; --surface:#13131f;
  --border:rgba(255,255,255,.08); --border2:rgba(255,255,255,.14);
  --text:#edecf7; --dim:#9b9bbd; --faint:#8b8ba8; --head:#f5f4ff;
  --success:#34d399; --danger:#f87171; --warning:#fbbf24;
  --grad:linear-gradient(120deg,var(--a1),var(--a2) 55%,var(--a3));
  --acc-glow:color-mix(in srgb,var(--a1) 42%,transparent);
  --maxw:1180px;
  --sans:"Inter",system-ui,sans-serif;
  --display:"Space Grotesk","Inter",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
* { box-sizing:border-box; margin:0; padding:0; }
html,body { height:100%; }
body { background:var(--bg); color:var(--text); font-family:var(--sans); line-height:1.6; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
h1,h2,h3,h4 { font-family:var(--display); line-height:1.06; letter-spacing:-.025em; font-weight:700; color:var(--head); }
img,svg,canvas { max-width:100%; }
.wrap { max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.m { font-family:var(--mono); font-size:.86em; }
.dim { color:var(--dim); }
.gt { background:linear-gradient(120deg,var(--t1),var(--t2) 55%,var(--t3)); -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:saturate(1.12) drop-shadow(0 0 16px color-mix(in srgb,var(--t2) 30%,transparent)); }
.kicker { display:inline-flex; align-items:center; gap:9px; font-family:var(--mono); text-transform:uppercase; letter-spacing:.22em; font-size:.72rem; font-weight:600; color:var(--t3); }
.kicker::before { content:""; width:22px; height:1px; background:var(--t3); opacity:.6; }
.lead { color:var(--dim); font-size:1.05rem; text-wrap:pretty; }

/* ----- backdrop (glow discipline: 3 orbs + plate) ----- */
.bgfx { position:fixed; inset:0; z-index:0; pointer-events:none; background:var(--bg); }
.bgfx .hex { position:absolute; inset:-2px; background:url("/assets/v7/hex-mamba.png") center/cover; opacity:.95; }
.bgfx .orb { position:absolute; border-radius:50%; filter:blur(110px); opacity:.3; mix-blend-mode:screen; transition:background 1.2s ease; }
.o1 { width:520px; height:520px; background:var(--a1); top:-160px; left:-120px; }
.o2 { width:460px; height:460px; background:var(--a2); top:30%; right:-180px; }
.o3 { width:380px; height:380px; background:var(--a3); top:78%; left:18%; }
.vig { position:fixed; inset:0; z-index:0; pointer-events:none; background:radial-gradient(120% 90% at 50% 40%, transparent 55%, rgba(0,0,0,.55) 100%); }
main { position:relative; z-index:1; } /* lift page content above fixed bgfx/vig (z-index:0) */

/* ----- nav ----- */
.nav { position:fixed; top:0; left:0; right:0; z-index:55; height:70px; display:flex; align-items:center; justify-content:space-between;
  padding:0 clamp(20px,4vw,40px); transition:background .3s, border-color .3s, backdrop-filter .3s; border-bottom:1px solid transparent; }
.nav.solid { background:rgba(7,7,16,.72); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); border-bottom:1px solid var(--border); }
.brand { display:flex; align-items:center; gap:11px; font-family:var(--display); font-weight:700; font-size:1.16rem; color:var(--head); }
.brand .mark { width:30px; height:34px; filter:drop-shadow(0 0 14px var(--acc-glow)); }
.brand .mark svg { width:100%; height:100%; display:block; }
.brand .tag { color:var(--a2); }
.nav-links { display:flex; gap:26px; align-items:center; }
.nav-links > a { color:var(--dim); font-weight:500; font-size:.93rem; transition:color .2s; white-space:nowrap; }
.nav-links > a:hover { color:var(--text); }
.nav-links > a.on { color:var(--text); }
.nav-cta { display:flex; gap:14px; align-items:center; }
.nav-signin { display:inline-flex; align-items:center; gap:8px; color:var(--dim); font-weight:500; font-size:.93rem; transition:color .2s; }
.nav-signin:hover { color:var(--text); }
.nav-acct { display:inline-flex; align-items:center; gap:9px; padding:5px 12px 5px 6px; border:1px solid var(--border); border-radius:999px;
  font-weight:500; font-size:.88rem; color:var(--text); background:rgba(255,255,255,.03); transition:border-color .2s; }
.nav-acct:hover { border-color:var(--a2); }
.nav-acct .av { width:24px; height:24px; border-radius:50%; background:var(--grad); box-shadow:0 0 8px var(--acc-glow); }
.nav-acct .h { font-family:var(--mono); font-size:.78rem; }
.nav-burger { display:none; background:none; border:0; color:var(--text); font-size:1.4rem; cursor:pointer; }
.nd { position:relative; }
.nd-btn { display:inline-flex; align-items:center; gap:7px; background:none; border:0; cursor:pointer;
  color:var(--dim); font-family:var(--sans); font-weight:500; font-size:.93rem; padding:24px 0; transition:color .2s; white-space:nowrap; }
.nd:hover .nd-btn, .nd.open .nd-btn { color:var(--text); }
.caret { width:7px; height:7px; border-right:1.6px solid currentColor; border-bottom:1.6px solid currentColor;
  transform:rotate(45deg) translateY(-2px); transition:transform .2s; }
.nd.open .caret { transform:rotate(225deg) translateY(-1px); }
.nd-panel { position:absolute; top:calc(100% - 12px); left:50%; transform:translateX(-50%) translateY(6px); min-width:300px;
  background:rgba(12,12,24,.92); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border); border-radius:14px; padding:10px;
  opacity:0; pointer-events:none; transition:opacity .18s, transform .18s; overflow:clip;
  box-shadow:0 24px 60px -18px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.05); }
.nd-panel::before { content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); opacity:.6; }
.nd.open .nd-panel { opacity:1; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.nd-grid { display:grid; grid-template-columns:repeat(var(--cols,1),minmax(220px,1fr)); gap:2px; }
.nd-item { display:flex; flex-direction:column; gap:1px; padding:10px 12px; border-radius:9px; transition:background .15s; }
.nd-item:hover { background:rgba(255,255,255,.045); }
.nd-item b { font-weight:600; font-size:.9rem; color:var(--text); }
.nd-item span { font-size:.78rem; color:var(--faint); line-height:1.4; }
.nd-all { display:flex; align-items:center; gap:7px; margin-top:8px; padding:10px 12px 6px; border-top:1px solid var(--border);
  font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--t3); }
.nd-all .arr { transition:transform .2s; }
.nd-all:hover .arr { transform:translateX(4px); }

/* ----- buttons ----- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; padding:12px 22px; border-radius:12px; font-weight:600; font-size:.95rem;
  font-family:var(--sans); cursor:pointer; border:1px solid transparent; transition:transform .15s, box-shadow .25s, border-color .2s; white-space:nowrap; }
.btn .arr { transition:transform .2s; }
.btn:hover .arr { transform:translateX(4px); }
.btn-primary { background:var(--grad); color:#fff; box-shadow:0 8px 30px -8px var(--acc-glow); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 14px 40px -10px var(--acc-glow); }
.btn-ghost { border-color:var(--border2); color:var(--text); background:rgba(255,255,255,.02); }
.btn-ghost:hover { border-color:var(--a1); color:#fff; }
.btn-nav { padding:10px 18px; font-size:.9rem; }
.btn-sm { padding:8px 14px; font-size:.84rem; border-radius:10px; }

/* ----- glass card ----- */
.glass { background:rgba(255,255,255,.034); border:1px solid var(--border); border-radius:16px;
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px); position:relative; overflow:clip;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05); }
.glass::before { content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); opacity:.55; }
.glass.danger { border-color:rgba(248,113,113,.3); }
.glass.danger::before { background:linear-gradient(120deg,var(--danger),color-mix(in srgb,var(--danger) 50%,var(--a1))); opacity:.7; }
.glass.plain::before { display:none; }

/* ----- footer ----- */
.foot { position:relative; z-index:2; border-top:1px solid var(--border); background:rgba(7,7,16,.55);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); padding:56px 0 26px; color:var(--faint); font-size:.9rem; }
.foot-grid { display:flex; gap:clamp(32px,5vw,80px); align-items:flex-start; flex-wrap:wrap; }
.ff-brand { max-width:280px; flex:0 0 auto; }
.ff-brand p { font-size:.88rem; color:var(--dim); margin-top:12px; text-wrap:pretty; }
.ff-verts { display:flex; gap:6px; flex-wrap:wrap; margin-top:14px; }
.vchip { font-family:var(--mono); font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--faint);
  border:1px solid var(--border); border-radius:999px; padding:3px 9px; }
.ff-cols { display:grid; grid-template-columns:repeat(4,minmax(140px,1fr)); gap:clamp(20px,3vw,48px); flex:1; min-width:0; }
.foot-col h5 { color:var(--text); font-family:var(--display); font-size:.92rem; margin-bottom:14px; }
.foot-col a { display:flex; align-items:center; gap:7px; color:var(--dim); margin-bottom:9px; transition:color .2s; font-size:.88rem; }
.foot-col a:hover { color:var(--text); }
.fb { font-style:normal; font-family:var(--mono); font-size:.56rem; letter-spacing:.1em; text-transform:uppercase; border-radius:999px; padding:1px 7px; }
.fb.restored { color:var(--t3); border:1px solid color-mix(in srgb,var(--a3) 35%,transparent); }
.fb.soon { color:var(--faint); border:1px solid var(--border); }
.foot-bottom { display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; margin-top:44px; padding-top:22px; border-top:1px solid var(--border);
  font-family:var(--mono); font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--faint); }
.foot-bottom a:hover { color:var(--text); }

/* ----- responsive ----- */
@media (max-width:1150px) {
  .foot-grid { flex-direction:column; gap:36px; }
  .ff-cols { width:100%; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); }
}
@media (max-width:1040px) {
  .nav-signin, .nav-acct { display:none; }
  .nav-burger { display:block; width:44px; height:44px; }
  .nav-links { display:none; position:fixed; top:70px; left:0; right:0; z-index:54; flex-direction:column; align-items:stretch; gap:0;
    padding:6px 22px 14px; background:rgba(7,7,16,.96); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border); }
  .nav-links.open { display:flex; }
  .nav-links > a { padding:15px 2px; font-size:1.04rem; border-bottom:1px solid var(--border); }
  .nd { border-bottom:1px solid var(--border); }
  .nd-btn { width:100%; justify-content:space-between; padding:15px 2px; font-size:1.04rem; }
  .nd-panel { position:static; transform:none; min-width:0; background:none; border:0; box-shadow:none; padding:0 0 12px;
    backdrop-filter:none; -webkit-backdrop-filter:none; }
  .nd-panel::before { display:none; }
  .nd.open .nd-panel { transform:none; }
  .nd-grid { grid-template-columns:1fr; }
}
@media (max-width:520px) { .btn-nav { padding:10px 14px; font-size:.84rem; } }



/* ================================================================
   ===== MOBILE (≤768px) — interior-page touch polish =====
   chrome.css backs the interior/content pages (and the RoVer compare
   page). The nav drawer + footer stacking already live above; this is
   the shared mobile-ergonomics layer mirroring site.css: ≥44px tap
   targets, iOS-zoom-proof inputs, full-width CTAs, scrollable data
   tables, and overflow guards. Desktop (≥769px) untouched.
   ================================================================ */

@media (max-width:768px) {
  /* overflow guard */
  html, body { max-width:100%; overflow-x:clip; }
  img, svg, video, pre, table { max-width:100%; }
  pre, code { overflow-x:auto; }
  .bgfx, .vig { pointer-events:none !important; }

  /* iOS tap-to-zoom guard */
  input, select, textarea { font-size:16px !important; }

  /* touch targets ≥44px */
  .btn, .btn-nav, .btn-sm, .nav-burger, .nd-btn, .nd-item,
  .nav-links > a, .nav-signin, .foot-col a, .nd-all {
    min-height:44px;
  }
  .btn { display:inline-flex; align-items:center; justify-content:center; }
  .nav-burger { display:grid; place-items:center; }
  .nd-item { justify-content:center; }
  .foot-col a { align-items:center; }

  /* responsive data tables — block-scroll keeps columns aligned */
  main table, .article table, .post table, .prose table, .glass table {
    display:block;
    width:max-content;
    min-width:100%;
    max-width:none;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  main table th, main table td,
  .article table th, .article table td { white-space:normal; min-width:max-content; }
  main table::-webkit-scrollbar, .article table::-webkit-scrollbar { height:6px; }
  main table::-webkit-scrollbar-thumb, .article table::-webkit-scrollbar-thumb {
    background:color-mix(in srgb,var(--a2) 50%,transparent); border-radius:3px; }
}

/* full-width CTAs on the smallest phones */
@media (max-width:600px) {
  .glass .btn, main > .wrap .btn-primary, .hero-cta .btn { width:100%; }
  .hero-cta { flex-direction:column; align-items:stretch; gap:12px; }
}

/* drawer body-scroll lock (mobile.js toggles body.nav-open) */
body.nav-open { overflow:hidden; touch-action:none; }
