/* ============================================================
   BixiPlay — Dark neon gaming platform
   Brand: deep navy canvas · electric cyan · bright orange
   Type:  Sora (display/wordmark) · Manrope (UI/body)
   ============================================================ */

:root{
  /* canvas */
  --bg:        #060c1a;
  --bg-2:      #0a1325;
  --panel:     #0d1a33;
  --surface:   #11203f;
  --surface-2: #16294c;
  --line:      rgba(120,162,224,.14);
  --line-2:    rgba(120,162,224,.26);

  /* brand */
  --navy:        #1c3f73;
  --navy-bright: #2f63b8;
  --cyan:        #2ec4ff;
  --cyan-soft:   #74dcff;
  --cyan-deep:   #0f86c9;
  --orange:      #ff7d1f;
  --orange-soft: #ffa45c;

  /* accent (tweakable) */
  --accent:      var(--cyan);
  --accent-soft: var(--cyan-soft);
  --accent-deep: var(--cyan-deep);

  /* text */
  --text:    #eaf1fb;
  --text-2:  #b8c8e4;
  --muted:   #8398bd;
  --muted-2: #5e7299;

  --r-sm: 10px;
  --r:    16px;
  --r-lg: 22px;
  --r-xl: 28px;

  --shadow:  0 18px 50px -18px rgba(0,0,0,.7);
  --glow:    0 0 0 1px rgba(46,196,255,.25), 0 0 34px -6px rgba(46,196,255,.55);
  --glow-or: 0 0 0 1px rgba(255,125,31,.3), 0 0 30px -6px rgba(255,125,31,.5);

  --maxw: 1240px;
  --nav-h: 74px;
  --font-display: "Sora", system-ui, sans-serif;
  --font-ui: "Manrope", system-ui, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-ui);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
img{ display:block; max-width:100%; }
ul{ list-style:none; }

/* ambient background field */
.bg-field{
  position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden;
  background:
    radial-gradient(60vw 60vw at 78% -8%, rgba(46,196,255,.16), transparent 60%),
    radial-gradient(48vw 48vw at 8% 18%, rgba(28,63,115,.4), transparent 62%),
    radial-gradient(46vw 46vw at 92% 88%, rgba(255,125,31,.1), transparent 60%);
}
.bg-field::before{
  content:""; position:absolute; inset:-2px;
  background-image:
    linear-gradient(rgba(120,162,224,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120,162,224,.05) 1px, transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(120vw 90vh at 50% 0%, #000 30%, transparent 78%);
          mask-image:radial-gradient(120vw 90vh at 50% 0%, #000 30%, transparent 78%);
}
.app{ position:relative; z-index:1; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }

/* ---------- type ---------- */
.eyebrow{
  font:700 12.5px/1 var(--font-ui);
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--accent-soft);
  display:inline-flex; align-items:center; gap:9px;
}
.eyebrow::before{ content:""; width:24px; height:2px; border-radius:2px; background:var(--accent); box-shadow:0 0 10px var(--accent); }
h1,h2,h3{ font-family:var(--font-display); font-weight:800; line-height:1.04; letter-spacing:-.02em; }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:26px; flex-wrap:wrap; }
.section-head h2{ font-size:clamp(26px,3.2vw,40px); }
.section-head p{ color:var(--muted); margin-top:6px; max-width:46ch; }
.link-more{ color:var(--accent-soft); font-weight:700; font-size:14.5px; display:inline-flex; align-items:center; gap:7px; white-space:nowrap; }
.link-more:hover{ color:var(--cyan-soft); }
.link-more svg{ transition:transform .2s; }
.link-more:hover svg{ transform:translateX(4px); }

section{ padding:clamp(56px,8vw,96px) 0; position:relative; }

/* ---------- wordmark + logo ---------- */
.logo{ display:inline-flex; align-items:center; gap:11px; }
.logo .mark{
  width:42px; height:42px; flex:none;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.4));
}
.wordmark{ font-family:var(--font-display); font-weight:800; font-size:25px; letter-spacing:-.02em; line-height:1; }
.wordmark .b{ color:var(--text); }
.wordmark .p{ color:var(--accent); }
.logo:hover .mark{ animation:bob .8s ease; }
@keyframes bob{ 50%{ transform:translateY(-4px) rotate(-3deg); } }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-ui); font-weight:700; font-size:15px;
  padding:13px 22px; border-radius:999px; white-space:nowrap;
  transition:transform .16s ease, box-shadow .2s ease, background .2s, color .2s;
}
.btn:active{ transform:translateY(1px) scale(.99); }
.btn-primary{
  background:linear-gradient(135deg, var(--accent), var(--accent-deep));
  color:#04111f; box-shadow:var(--glow);
}
.btn-primary:hover{ box-shadow:0 0 0 1px var(--accent), 0 0 42px -4px var(--accent); transform:translateY(-2px); }
.btn-orange{ background:linear-gradient(135deg, var(--orange), #e85f00); color:#1a0c00; box-shadow:var(--glow-or); }
.btn-orange:hover{ box-shadow:0 0 0 1px var(--orange), 0 0 40px -4px var(--orange); transform:translateY(-2px); }
.btn-ghost{ background:rgba(120,162,224,.08); color:var(--text); border:1px solid var(--line-2); }
.btn-ghost:hover{ background:rgba(120,162,224,.16); border-color:var(--accent); color:#fff; }
.btn-lg{ padding:16px 28px; font-size:16px; }
.btn-block{ width:100%; }

/* ---------- nav ---------- */
.nav{
  position:sticky; top:0; z-index:50; height:var(--nav-h);
  display:flex; align-items:center;
  background:rgba(6,12,26,.72);
  -webkit-backdrop-filter:blur(16px) saturate(150%); backdrop-filter:blur(16px) saturate(150%);
  border-bottom:1px solid var(--line);
}
.nav .wrap{ display:flex; align-items:center; gap:18px; }
.nav-links{ display:flex; align-items:center; gap:4px; margin-left:14px; }
.nav-links a{
  font-weight:600; font-size:14.5px; color:var(--text-2);
  padding:9px 14px; border-radius:999px; transition:.18s; position:relative;
}
.nav-links a:hover{ color:#fff; background:rgba(120,162,224,.08); }
.nav-links a.active{ color:#fff; }
.nav-links a.active::after{
  content:""; position:absolute; left:14px; right:14px; bottom:2px; height:2px; border-radius:2px;
  background:var(--accent); box-shadow:0 0 10px var(--accent);
}
.nav-right{ margin-left:auto; display:flex; align-items:center; gap:12px; }

/* language switch */
.lang{ display:inline-flex; background:rgba(120,162,224,.1); border:1px solid var(--line); border-radius:999px; padding:3px; }
.lang button{ font-size:12.5px; font-weight:800; letter-spacing:.04em; color:var(--muted); padding:6px 11px; border-radius:999px; transition:.18s; }
.lang button.on{ color:#04111f; background:var(--accent); box-shadow:0 0 16px -4px var(--accent); }
.link-btn{ font-weight:700; font-size:14.5px; color:var(--text-2); padding:9px 6px; }
.link-btn:hover{ color:#fff; }

.burger{ display:none; width:42px; height:42px; border-radius:12px; border:1px solid var(--line-2); align-items:center; justify-content:center; }
.burger svg{ width:20px; height:20px; }

/* ---------- HERO shared ---------- */
.hero{ padding-top:clamp(40px,6vw,72px); padding-bottom:clamp(48px,7vw,90px); position:relative; }
.hero h1{ font-size:clamp(40px,6.4vw,82px); }
.hero h1 .grad{
  background:linear-gradient(110deg, var(--accent-soft), var(--accent) 45%, var(--orange));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-sub{ color:var(--text-2); font-size:clamp(16px,1.5vw,19px); max-width:52ch; margin-top:22px; }
.hero-cta{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero-stats{ display:flex; gap:32px; margin-top:42px; flex-wrap:wrap; }
.hero-stats .num{ font-family:var(--font-display); font-weight:800; font-size:30px; color:#fff; }
.hero-stats .lbl{ color:var(--muted); font-size:13px; font-weight:600; }

.mascot-orb{ position:relative; display:grid; place-items:center; }
.mascot-orb::before{
  content:""; position:absolute; width:90%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle, rgba(46,196,255,.5), rgba(28,63,115,.25) 45%, transparent 70%);
  filter:blur(6px); animation:pulse 5s ease-in-out infinite;
}
.mascot-orb::after{
  content:""; position:absolute; width:78%; aspect-ratio:1; border-radius:50%;
  border:1px dashed rgba(116,220,255,.3); animation:spin 26s linear infinite;
}
@keyframes pulse{ 50%{ transform:scale(1.06); opacity:.85; } }
@keyframes spin{ to{ transform:rotate(360deg); } }
.mascot-img{
  position:relative; width:100%; max-width:560px;
  -webkit-mask-image:radial-gradient(closest-side at 50% 46%, #000 60%, rgba(0,0,0,.4) 80%, transparent 96%);
          mask-image:radial-gradient(closest-side at 50% 46%, #000 60%, rgba(0,0,0,.4) 80%, transparent 96%);
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.55));
  animation:float 6s ease-in-out infinite;
}
@keyframes float{ 50%{ transform:translateY(-14px); } }

/* hero variant A — split spotlight */
.hero-a .hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:36px; align-items:center; }

/* hero variant B — centered cosmic */
.hero-b{ text-align:center; }
.hero-b .hero-grid{ display:flex; flex-direction:column; align-items:center; }
.hero-b .hero-sub{ margin-left:auto; margin-right:auto; }
.hero-b .hero-cta{ justify-content:center; }
.hero-b .mascot-orb{ margin-top:6px; }
.hero-b .mascot-img{ max-width:440px; }
.hero-b .float-tiles{ position:absolute; inset:0; pointer-events:none; }
.float-tiles .tile{
  position:absolute; width:96px; border-radius:14px; overflow:hidden;
  box-shadow:var(--shadow); border:1px solid var(--line-2);
  animation:float 7s ease-in-out infinite;
}
.float-tiles .tile .cover{ height:74px; }
.float-tiles .tile span{ display:block; font-size:10px; font-weight:700; padding:6px 8px; background:var(--surface); }

/* hero variant C — immersive showcase */
.hero-c .showcase{
  position:relative; border-radius:var(--r-xl); overflow:hidden;
  border:1px solid var(--line-2); box-shadow:var(--shadow);
  min-height:460px; display:flex; align-items:flex-end;
}
.hero-c .showcase-bg{ position:absolute; inset:0; }
.hero-c .showcase-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(6,12,26,.92) 28%, rgba(6,12,26,.4) 60%, transparent); }
.hero-c .showcase .panel-c{ position:relative; padding:clamp(28px,4vw,52px); max-width:620px; }
.hero-c .showcase .mascot-peek{
  position:absolute; right:2%; bottom:0; width:min(42%,420px);
  filter:drop-shadow(0 20px 40px rgba(0,0,0,.6));
  -webkit-mask-image:linear-gradient(#000 86%, transparent);
          mask-image:linear-gradient(#000 86%, transparent);
  animation:float 6s ease-in-out infinite;
}
.badge-live{ display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--orange-soft); }
.badge-live .dot{ width:8px; height:8px; border-radius:50%; background:var(--orange); box-shadow:0 0 12px var(--orange); animation:blink 1.6s infinite; }
@keyframes blink{ 50%{ opacity:.35; } }

/* ---------- pills / chips ---------- */
.pill-row{ display:flex; gap:10px; flex-wrap:wrap; }
.chip{
  display:inline-flex; align-items:center; gap:8px;
  font-size:13.5px; font-weight:700; color:var(--text-2);
  padding:9px 15px; border-radius:999px; border:1px solid var(--line-2);
  background:rgba(120,162,224,.06); transition:.18s; cursor:pointer;
}
.chip:hover{ color:#fff; border-color:var(--accent); background:rgba(46,196,255,.1); }
.chip.on{ color:#04111f; background:var(--accent); border-color:transparent; box-shadow:0 0 18px -5px var(--accent); }
.chip .ic{ font-size:15px; }

/* ---------- game cards ---------- */
.game-row{
  display:grid; grid-auto-flow:column; grid-auto-columns:minmax(228px,1fr);
  gap:18px; overflow-x:auto; padding-bottom:10px; scroll-snap-type:x mandatory;
  scrollbar-width:thin; scrollbar-color:var(--line-2) transparent;
}
.game-row::-webkit-scrollbar{ height:8px; }
.game-row::-webkit-scrollbar-thumb{ background:var(--line-2); border-radius:8px; }
.grid-games{ display:grid; grid-template-columns:repeat(auto-fill,minmax(212px,1fr)); gap:20px; }

.card{
  position:relative; border-radius:var(--r); overflow:hidden;
  background:var(--surface); border:1px solid var(--line);
  transition:transform .2s ease, box-shadow .25s ease, border-color .2s;
  scroll-snap-align:start; cursor:pointer;
}
.card:hover{ transform:translateY(-6px); border-color:var(--line-2); box-shadow:var(--shadow), var(--glow); }
.card .cover{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.card .cover .play{
  position:absolute; inset:0; display:grid; place-items:center;
  background:radial-gradient(circle at 50% 50%, rgba(6,12,26,.45), rgba(6,12,26,.7));
  opacity:0; transition:.2s;
}
.card:hover .cover .play{ opacity:1; }
.card .cover .play span{
  width:56px; height:56px; border-radius:50%; display:grid; place-items:center;
  background:var(--accent); color:#04111f; box-shadow:0 0 28px -2px var(--accent); transform:scale(.8); transition:.2s;
}
.card:hover .cover .play span{ transform:scale(1); }
.card .cat-tag{
  position:absolute; top:10px; left:10px; font-size:11px; font-weight:800; letter-spacing:.04em;
  padding:5px 9px; border-radius:999px; background:rgba(6,12,26,.7); color:var(--accent-soft);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); text-transform:uppercase;
}
.card .hot{
  position:absolute; top:10px; right:10px; font-size:11px; font-weight:800;
  padding:5px 9px; border-radius:999px; background:linear-gradient(135deg,var(--orange),#e85f00); color:#1a0c00;
}
.card .meta{ padding:13px 14px 15px; }
.card .meta h3{ font-family:var(--font-ui); font-weight:800; font-size:15.5px; letter-spacing:-.01em; }
.card .meta .sub{ display:flex; align-items:center; gap:12px; margin-top:7px; color:var(--muted); font-size:12.5px; font-weight:600; }
.card .meta .sub .star{ color:var(--orange-soft); }

/* cover art (generated tiles) */
.cover-art{ position:absolute; inset:0; display:grid; place-items:center; overflow:hidden; }
.cover-art .glyph{ width:46%; height:46%; opacity:.92; filter:drop-shadow(0 6px 14px rgba(0,0,0,.35)); }
.cover-art .veil{ position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%, rgba(6,12,26,.55)); }
.cover-art .ttl{ position:absolute; left:12px; bottom:10px; font-family:var(--font-display); font-weight:800; font-size:17px; color:#fff; text-shadow:0 2px 10px rgba(0,0,0,.5); line-height:1.05; padding-right:10px; }

/* ---------- categories ---------- */
.cat-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(184px,1fr)); gap:16px; }
.cat-card{
  position:relative; border-radius:var(--r); padding:22px 18px; min-height:128px;
  border:1px solid var(--line); overflow:hidden;
  display:flex; flex-direction:column; justify-content:space-between;
  background:var(--surface); transition:.2s; cursor:pointer;
}
.cat-card:hover{ transform:translateY(-5px); border-color:var(--line-2); box-shadow:var(--shadow); }
.cat-card .gl{ position:absolute; right:-18px; top:-18px; width:96px; height:96px; border-radius:50%; filter:blur(8px); opacity:.55; transition:.25s; }
.cat-card:hover .gl{ opacity:.9; transform:scale(1.15); }
.cat-card .ic{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; background:rgba(6,12,26,.5); position:relative; }
.cat-card .ic svg{ width:24px; height:24px; }
.cat-card h3{ font-family:var(--font-ui); font-weight:800; font-size:16.5px; margin-top:auto; }
.cat-card .count{ color:var(--muted); font-size:12.5px; font-weight:600; }

/* ---------- value strip ---------- */
.value-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; }
.value-card{ padding:24px; border-radius:var(--r); background:var(--panel); border:1px solid var(--line); }
.value-card .vic{ width:48px; height:48px; border-radius:14px; display:grid; place-items:center; background:rgba(46,196,255,.12); color:var(--accent-soft); margin-bottom:14px; }
.value-card h3{ font-family:var(--font-ui); font-weight:800; font-size:17px; }
.value-card p{ color:var(--muted); font-size:14px; margin-top:7px; }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; border-radius:var(--r-xl); overflow:hidden; border:1px solid var(--line-2); background:linear-gradient(120deg, var(--navy) 0%, var(--bg-2) 60%); padding:clamp(32px,5vw,60px); display:grid; grid-template-columns:1.4fr .8fr; gap:24px; align-items:center; }
.cta-band::before{ content:""; position:absolute; inset:0; background:radial-gradient(50% 120% at 90% 50%, rgba(46,196,255,.25), transparent 60%); }
.cta-band h2{ font-size:clamp(28px,4vw,46px); position:relative; }
.cta-band p{ color:var(--text-2); margin-top:14px; max-width:48ch; position:relative; }
.cta-band .cta-mascot{ position:relative; justify-self:center; }
.cta-band .cta-mascot img{ width:min(320px,90%); filter:drop-shadow(0 20px 40px rgba(0,0,0,.5)); animation:float 6s ease-in-out infinite; -webkit-mask-image:radial-gradient(closest-side at 50% 46%,#000 64%,transparent 95%); mask-image:radial-gradient(closest-side at 50% 46%,#000 64%,transparent 95%); }

/* ---------- footer ---------- */
.footer{ border-top:1px solid var(--line); padding:56px 0 36px; margin-top:20px; background:var(--bg-2); }
.footer-grid{ display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:32px; }
.footer p.desc{ color:var(--muted); font-size:14px; margin-top:16px; max-width:34ch; }
.footer h4{ font-family:var(--font-ui); font-weight:800; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--text-2); margin-bottom:14px; }
.footer ul li{ margin-bottom:10px; }
.footer ul a{ color:var(--muted); font-size:14px; }
.footer ul a:hover{ color:var(--accent-soft); }
.footer-bot{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-top:42px; padding-top:24px; border-top:1px solid var(--line); color:var(--muted); font-size:13px; flex-wrap:wrap; }
.socials{ display:flex; gap:10px; }
.socials a{ width:38px; height:38px; border-radius:11px; border:1px solid var(--line-2); display:grid; place-items:center; color:var(--text-2); transition:.18s; }
.socials a:hover{ color:#fff; border-color:var(--accent); background:rgba(46,196,255,.1); }

/* ---------- auth modal ---------- */
.modal-scrim{ position:fixed; inset:0; z-index:200; background:rgba(3,7,16,.7); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); display:grid; place-items:center; padding:20px; animation:fade .2s ease; }
@keyframes fade{ from{ opacity:0; } }
.modal{
  width:100%; max-width:420px; background:var(--panel); border:1px solid var(--line-2);
  border-radius:var(--r-lg); padding:30px; box-shadow:var(--shadow); position:relative;
  animation:rise .25s cubic-bezier(.2,.8,.2,1);
}
@keyframes rise{ from{ transform:translateY(16px); opacity:0; } }
.modal .x{ position:absolute; top:16px; right:16px; width:34px; height:34px; border-radius:10px; display:grid; place-items:center; color:var(--muted); }
.modal .x:hover{ color:#fff; background:rgba(120,162,224,.12); }
.modal .mark{ width:48px; height:48px; margin-bottom:14px; }
.modal h3{ font-size:24px; }
.modal .msub{ color:var(--muted); font-size:14px; margin-top:6px; margin-bottom:22px; }
.field{ margin-bottom:14px; }
.field label{ display:block; font-size:12.5px; font-weight:700; color:var(--text-2); margin-bottom:7px; }
.field input{
  width:100%; padding:13px 15px; border-radius:12px; font-size:15px; font-family:inherit;
  background:var(--bg-2); border:1px solid var(--line-2); color:var(--text); transition:.18s;
}
.field input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(46,196,255,.16); }
.field input::placeholder{ color:var(--muted-2); }
.modal .alt{ text-align:center; color:var(--muted); font-size:13.5px; margin-top:18px; }
.modal .alt button{ color:var(--accent-soft); font-weight:800; }
.divider{ display:flex; align-items:center; gap:12px; color:var(--muted-2); font-size:12px; margin:18px 0; }
.divider::before,.divider::after{ content:""; flex:1; height:1px; background:var(--line); }

/* ---------- browse page ---------- */
.page-head{ padding:42px 0 8px; }
.page-head h1{ font-size:clamp(32px,4.4vw,52px); }
.page-head p{ color:var(--muted); margin-top:10px; }
.search{ position:relative; margin-top:26px; max-width:560px; }
.search input{
  width:100%; padding:15px 18px 15px 50px; border-radius:999px; font-size:15.5px; font-family:inherit;
  background:var(--surface); border:1px solid var(--line-2); color:var(--text);
}
.search input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(46,196,255,.14); }
.search svg{ position:absolute; left:18px; top:50%; transform:translateY(-50%); color:var(--muted); width:20px; height:20px; }

.browse-layout{ display:grid; grid-template-columns:248px 1fr; gap:32px; align-items:start; padding-bottom:90px; }
.filters{ position:sticky; top:calc(var(--nav-h) + 18px); background:var(--panel); border:1px solid var(--line); border-radius:var(--r); padding:20px; }
.filters .fg{ margin-bottom:22px; }
.filters .fg:last-child{ margin-bottom:0; }
.filters h4{ font-family:var(--font-ui); font-weight:800; font-size:12.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--text-2); margin-bottom:13px; }
.filt-item{ display:flex; align-items:center; gap:10px; padding:8px 9px; border-radius:10px; color:var(--text-2); font-size:14px; font-weight:600; cursor:pointer; transition:.15s; }
.filt-item:hover{ background:rgba(120,162,224,.08); color:#fff; }
.filt-item.on{ background:rgba(46,196,255,.12); color:#fff; }
.filt-item .cnt{ margin-left:auto; font-size:12px; color:var(--muted); font-weight:700; }
.filt-item .bx{ width:16px; height:16px; border-radius:5px; border:1.5px solid var(--line-2); flex:none; display:grid; place-items:center; }
.filt-item.on .bx{ background:var(--accent); border-color:var(--accent); color:#04111f; }
.filt-item.on .bx svg{ width:11px; height:11px; }

.browse-top{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:20px; flex-wrap:wrap; }
.browse-top .res{ color:var(--muted); font-size:14px; font-weight:600; }
.browse-top .res b{ color:var(--text); }
.sortbar{ display:flex; align-items:center; gap:8px; }
.sortbar select{
  font-family:inherit; font-weight:700; font-size:13.5px; color:var(--text);
  background:var(--surface); border:1px solid var(--line-2); border-radius:10px; padding:9px 12px; cursor:pointer;
}
.active-chips{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }

.filters-toggle{ display:none; }
.empty{ text-align:center; padding:70px 20px; color:var(--muted); }
.empty img{ width:130px; margin:0 auto 18px; opacity:.85; }

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .hero-a .hero-grid{ grid-template-columns:1fr; }
  .hero-a .mascot-orb{ order:-1; max-width:420px; margin:0 auto; }
  .cta-band{ grid-template-columns:1fr; }
  .cta-band .cta-mascot{ display:none; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .browse-layout{ grid-template-columns:1fr; }
  .filters{ position:fixed; inset:0; z-index:120; border-radius:0; overflow-y:auto;
    transform:translateX(-100%); transition:transform .26s ease; max-width:320px; }
  .filters.open{ transform:none; box-shadow:var(--shadow); }
  .filters-toggle{ display:inline-flex; }
  .filt-scrim{ position:fixed; inset:0; z-index:110; background:rgba(3,7,16,.6); }
}
@media (max-width:760px){
  .nav-links, .nav-right .desk{ display:none; }
  .burger{ display:flex; }
  .mobile-menu{ position:fixed; inset:var(--nav-h) 0 0; z-index:49; background:var(--bg);
    padding:24px; display:flex; flex-direction:column; gap:6px; animation:fade .2s; }
  .mobile-menu a{ font-family:var(--font-display); font-weight:700; font-size:22px; padding:14px 4px; border-bottom:1px solid var(--line); }
  .mobile-menu .m-actions{ margin-top:auto; display:flex; flex-direction:column; gap:12px; }
  .hero-stats{ gap:22px; }
  .footer-grid{ grid-template-columns:1fr; gap:24px; }
  .footer-bot{ flex-direction:column; align-items:flex-start; }
  .section-head{ align-items:flex-start; }
}
@media (max-width:460px){
  .wrap{ padding:0 16px; }
  .hero-stats .num{ font-size:25px; }
}

/* utility */
.sr{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }
.nowrap{ white-space:nowrap; }
