/* =====================================================================
   LE · MVP STORE — "Field Armory" tactical theme
   Gunmetal + hazard amber · Oswald display · angular HUD panels
   ===================================================================== */
:root{
  --bg:#0b0a07; --bg2:#100d09; --panel:#15110b; --panel2:#1c1710;
  --line:#2c2415; --line2:#41351f;
  --ink:#f1e9d8; --ink-dim:#9a917c; --ink-faint:#6c6552;
  --amber:#f3a712; --amber2:#ffc24b; --amber-soft:rgba(243,167,18,.14);
  --blood:#e24a36; --steel:#67b3c0; --good:#7ac74f; --gold:#f3a712;
  --on-accent:#1a1304;
  --wash1:rgba(243,167,18,.10); --wash2:rgba(103,179,192,.06);
  --r:4px;
  --disp:'Oswald',system-ui,sans-serif;
  --body:'Hanken Grotesk',system-ui,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;
}
/* ===== Theme flavors (set html[data-theme]) ===== */
html[data-theme="purple"]{
  --bg:#0a0812;--bg2:#0e0b18;--panel:#14101f;--panel2:#1a1528;--line:#272138;--line2:#3a3052;
  --ink:#ede9f6;--ink-dim:#9890ad;--ink-faint:#665f7d;
  --amber:#a855f7;--amber2:#c79bff;--amber-soft:rgba(168,85,247,.16);--gold:#a855f7;--steel:#ec4899;
  --on-accent:#fff;--wash1:rgba(168,85,247,.18);--wash2:rgba(236,72,153,.10);
}
html[data-theme="ice"]{
  --bg:#070b10;--bg2:#0a0f16;--panel:#0f1620;--panel2:#152030;--line:#1d2a3a;--line2:#2c4055;
  --ink:#e8f2fb;--ink-dim:#8aa0b4;--ink-faint:#5b7186;
  --amber:#46c8ff;--amber2:#9fe6ff;--amber-soft:rgba(70,200,255,.15);--gold:#46c8ff;--steel:#7c8cff;
  --on-accent:#04141d;--wash1:rgba(70,200,255,.15);--wash2:rgba(124,140,255,.08);
}
html[data-theme="crimson"]{
  --bg:#0d0707;--bg2:#120909;--panel:#180c0c;--panel2:#211010;--line:#3a1c1c;--line2:#532727;
  --ink:#f6e9e9;--ink-dim:#b39595;--ink-faint:#7d5c5c;
  --amber:#ff3b5c;--amber2:#ff7d92;--amber-soft:rgba(255,59,92,.15);--gold:#ff3b5c;--steel:#ff9e57;
  --on-accent:#fff;--wash1:rgba(255,59,92,.16);--wash2:rgba(255,158,87,.08);
}
html[data-theme="toxic"]{
  --bg:#070a06;--bg2:#0b100a;--panel:#101710;--panel2:#152015;--line:#1e2e1c;--line2:#2f4a2c;
  --ink:#ecf6e9;--ink-dim:#92a88c;--ink-faint:#5f7359;
  --amber:#9ae22e;--amber2:#c4ff5a;--amber-soft:rgba(154,226,46,.14);--gold:#9ae22e;--steel:#46c8ff;
  --on-accent:#0a1402;--wash1:rgba(154,226,46,.13);--wash2:rgba(70,200,255,.06);
}
/* Clash.gg — dark slate + lime, Bai Jamjuree font (their UI font) */
html[data-theme="clash"]{
  --bg:#0f1113;--bg2:#131619;--panel:#171a1d;--panel2:#1d2125;--line:#262b30;--line2:#363d44;
  --ink:#d9dada;--ink-dim:#82898b;--ink-faint:#5b6266;
  --amber:#a3e635;--amber2:#caff66;--amber-soft:rgba(163,230,53,.15);--gold:#a3e635;--steel:#28d7ee;
  --on-accent:#0e1402;--wash1:rgba(163,230,53,.12);--wash2:rgba(40,215,238,.06);
  --body:'Bai Jamjuree',system-ui,sans-serif;--disp:'Bai Jamjuree',system-ui,sans-serif;
}
html[data-theme="midnight"]{
  --bg:#06080f;--bg2:#0a0e18;--panel:#0e1322;--panel2:#141b30;--line:#1e2740;--line2:#2c3a5c;
  --ink:#e6ecf7;--ink-dim:#8b96ad;--ink-faint:#5c6680;
  --amber:#5b8def;--amber2:#9bb8ff;--amber-soft:rgba(91,141,239,.16);--gold:#5b8def;--steel:#7c5cff;
  --on-accent:#fff;--wash1:rgba(91,141,239,.16);--wash2:rgba(124,92,255,.08);
}
html[data-theme="emerald"]{
  --bg:#04100b;--bg2:#071710;--panel:#0a1f16;--panel2:#0f2a1e;--line:#173a2a;--line2:#235440;
  --ink:#e6f6ee;--ink-dim:#8db3a1;--ink-faint:#5e7d6e;
  --amber:#10b981;--amber2:#4ee0ad;--amber-soft:rgba(16,185,129,.16);--gold:#10b981;--steel:#f3c64b;
  --on-accent:#03140d;--wash1:rgba(16,185,129,.15);--wash2:rgba(243,198,75,.07);
}
html[data-theme="royal"]{
  --bg:#0a0a0c;--bg2:#0f0f12;--panel:#16161b;--panel2:#1e1e25;--line:#2c2c36;--line2:#42424f;
  --ink:#f3eede;--ink-dim:#a59c86;--ink-faint:#726a58;
  --amber:#e7c14d;--amber2:#ffe08a;--amber-soft:rgba(231,193,77,.16);--gold:#e7c14d;--steel:#b08bff;
  --on-accent:#1a1404;--wash1:rgba(231,193,77,.14);--wash2:rgba(176,139,255,.07);
}
html[data-theme="cyber"]{
  --bg:#080611;--bg2:#0d0a1a;--panel:#130f24;--panel2:#1b1533;--line:#2a2148;--line2:#3e3168;
  --ink:#f0e9ff;--ink-dim:#9d92bd;--ink-faint:#6a6090;
  --amber:#ff2bd6;--amber2:#ff7ee8;--amber-soft:rgba(255,43,214,.16);--gold:#ff2bd6;--steel:#22d3ee;
  --on-accent:#fff;--wash1:rgba(255,43,214,.15);--wash2:rgba(34,211,238,.09);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--bg);
  min-height:100vh;overflow-x:hidden;position:relative;letter-spacing:.1px;
}
body::before{
  content:'';position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(70% 50% at 78% -8%,var(--wash1),transparent 60%),
    radial-gradient(60% 50% at -8% 8%,var(--wash2),transparent 60%),
    linear-gradient(180deg,var(--bg2),var(--bg) 60%);
}
body::after{
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:34px auto;padding:0 22px}
.muted,.text-dim{color:var(--ink-dim)}
.mono{font-family:var(--mono)}
::selection{background:var(--amber);color:var(--on-accent)}
.card,.item,.pkg,.tool,.pod,.unbox-box,.shop-toolbar{position:relative}

/* ---------- topbar ---------- */
.topbar{display:flex;align-items:center;gap:24px;padding:14px 26px;position:sticky;top:0;z-index:60;
  background:linear-gradient(180deg,rgba(11,10,7,.96),rgba(11,10,7,.82));
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.topbar::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;
  background:linear-gradient(90deg,var(--amber),transparent 38%)}
.brand{display:flex;align-items:center;gap:12px}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-title{font-family:var(--disp);font-weight:700;font-size:18px;letter-spacing:2px;text-transform:uppercase}
.brand-sub{font-family:var(--mono);font-size:10px;color:var(--amber);letter-spacing:3px;text-transform:uppercase;margin-top:3px}
.le-mark{position:relative;z-index:0;width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-weight:700;font-size:16px;
  letter-spacing:1px;color:var(--on-accent);background:linear-gradient(135deg,var(--amber2),var(--amber));
  clip-path:polygon(0 0,100% 0,100% 70%,82% 100%,0 100%);box-shadow:0 4px 18px rgba(243,167,18,.35)}
.le-mark::before{content:'';position:absolute;inset:-2px;z-index:-1;
  background:conic-gradient(from 0deg,var(--amber),var(--steel),var(--amber));
  clip-path:polygon(0 0,100% 0,100% 70%,82% 100%,0 100%);filter:blur(7px);opacity:.5;animation:le-spin 9s linear infinite}
@keyframes le-spin{to{transform:rotate(360deg)}}

.topnav{display:flex;gap:2px;margin-left:8px}
.topnav a{font-family:var(--disp);font-weight:500;text-transform:uppercase;letter-spacing:1.4px;font-size:13px;
  color:var(--ink-dim);padding:9px 14px;position:relative;transition:color .15s}
.topnav a:hover{color:var(--ink)}
.topnav a.on{color:var(--amber)}
.topnav a.on::after{content:'';position:absolute;left:14px;right:14px;bottom:2px;height:2px;background:var(--amber)}
.topnav a.admin{color:var(--steel)}
.topnav a.admin.on{color:var(--steel)} .topnav a.admin.on::after{background:var(--steel)}

.userbox{margin-left:auto;display:flex;align-items:center;gap:14px}
.coins{display:inline-flex;align-items:baseline;gap:6px;border:1px solid var(--line2);
  padding:6px 12px;clip-path:polygon(8px 0,100% 0,100% 100%,0 100%,0 8px);background:var(--amber-soft)}
.coins-n{font-family:var(--mono);font-weight:700;color:var(--amber);font-size:14px}
.coins-u{font-family:var(--disp);font-size:10px;color:#bf932f;text-transform:uppercase;letter-spacing:1.5px}
.uname{font-family:var(--disp);font-weight:500;text-transform:uppercase;letter-spacing:1px;color:var(--ink-dim);font-size:14px}
.uname-link:hover{color:var(--amber)}
.avatar{width:30px;height:30px;border:1px solid var(--line2)}
.pill{font-family:var(--disp);padding:3px 9px;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase}
.pill-vip{background:linear-gradient(135deg,var(--amber2),var(--amber));color:var(--on-accent)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;cursor:pointer;border:1px solid var(--line2);background:var(--panel2);
  color:var(--ink);font-family:var(--disp);font-weight:500;font-size:13px;letter-spacing:1.4px;text-transform:uppercase;
  padding:10px 18px;border-radius:var(--r);transition:.14s}
.btn:hover{border-color:var(--amber);color:var(--amber);transform:translateY(-1px)}
.btn-primary,.btn.primary{background:linear-gradient(135deg,var(--amber2),var(--amber));border:0;color:var(--on-accent);font-weight:600}
.btn-primary:hover,.btn.primary:hover{color:var(--on-accent);box-shadow:0 8px 22px -10px var(--amber);transform:translateY(-1px)}
.btn-ghost,.btn.ghost{background:transparent}
.btn.danger{background:transparent;border-color:#5b2620;color:#e98579}
.btn.danger:hover{border-color:var(--blood);color:var(--blood)}
.btn-steam{background:linear-gradient(135deg,#243240,#16202a);border:1px solid #2c3d4a;color:#cfe3ee}
.btn-steam:hover{border-color:var(--steel);color:#fff}
.btn-sm{padding:7px 13px;font-size:12px}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}

/* ---------- headings ---------- */
.page-h1{font-family:var(--disp);font-weight:600;font-size:30px;letter-spacing:1px;text-transform:uppercase;margin:6px 0}
.section-title{font-family:var(--disp);font-weight:600;font-size:22px;letter-spacing:1.5px;text-transform:uppercase;
  margin:34px 0 16px;display:flex;align-items:center;gap:14px;color:var(--ink)}
.section-title::before{content:'';width:14px;height:14px;background:var(--amber);
  clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%);flex:none}
.section-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--line2),transparent)}

/* ---------- hero ---------- */
.hero{position:relative;text-align:center;padding:96px 20px 64px;max-width:780px;margin:0 auto}
.hero h1{font-family:var(--disp);font-size:clamp(40px,7vw,68px);font-weight:700;letter-spacing:2px;text-transform:uppercase;
  margin:0 0 16px;line-height:.98}
.hero h1 .glow-text,.glow-text{color:var(--amber);text-shadow:0 0 32px rgba(243,167,18,.4)}
.hero p{color:var(--ink-dim);font-size:17px;line-height:1.7;max-width:560px;margin:0 auto 30px}
.hero .btn-steam{font-size:14px;padding:15px 30px}
.hero::before{content:'';position:absolute;left:50%;top:0;transform:translateX(-50%);width:420px;height:300px;z-index:-1;
  background:radial-gradient(circle,rgba(243,167,18,.16),transparent 65%);filter:blur(30px)}
.lb-hero{text-align:center;padding:32px 0 6px}
.lb-hero h1{font-family:var(--disp);font-size:42px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin:0 0 4px}

/* ---------- layout / panels ---------- */
.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.cols-3{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}

.card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--r);padding:20px}
.card.glass{background:rgba(21,17,11,.7)}
.card::before,.tool::before,.pkg::before{content:'';position:absolute;top:-1px;left:-1px;width:14px;height:14px;
  border-top:2px solid var(--amber);border-left:2px solid var(--amber);opacity:.55;pointer-events:none}
.card h2{font-family:var(--disp);font-weight:500;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--amber);margin:0 0 14px}
.stat .v{font-family:var(--disp);font-size:32px;font-weight:600;line-height:1;letter-spacing:.5px}
.stat .l{font-family:var(--disp);color:var(--ink-dim);font-size:12px;letter-spacing:1.4px;text-transform:uppercase;margin-top:6px}

/* ---------- toolbar / tabs / search ---------- */
.shop-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:8px 0 20px;padding:8px;
  border:1px solid var(--line);border-radius:var(--r);background:rgba(16,13,9,.8);position:sticky;top:64px;z-index:30}
.tabs{display:flex;gap:4px;flex-wrap:wrap}
.tab{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:1px solid transparent;background:transparent;
  font-family:var(--disp);font-weight:500;font-size:13px;letter-spacing:1.4px;text-transform:uppercase;color:var(--ink-dim);
  padding:9px 15px;border-radius:var(--r);transition:.14s}
.tab:hover{color:var(--ink)}
.tab.on{color:var(--on-accent);background:linear-gradient(135deg,var(--amber2),var(--amber))}
.tab-count{font-family:var(--mono);font-size:11px;font-weight:700;background:rgba(0,0,0,.22);padding:1px 7px;border-radius:2px}
.tab.on .tab-count{background:rgba(0,0,0,.25)}
.toolbar-spacer{flex:1}
.search{position:relative}
.search input{width:240px;max-width:46vw;background:#0c0a06;border:1px solid var(--line2);color:var(--ink);
  border-radius:var(--r);padding:9px 12px 9px 34px;font-family:var(--body);font-size:14px;outline:none}
.search input:focus{border-color:var(--amber)}
.search::before{content:'';position:absolute;left:11px;top:48%;width:12px;height:12px;transform:translateY(-50%);
  border:2px solid var(--ink-dim);border-radius:50%}
.search::after{content:'';position:absolute;left:21px;top:62%;width:7px;height:2px;background:var(--ink-dim);transform:rotate(45deg)}
select.filter,.input{background:#0c0a06;border:1px solid var(--line2);color:var(--ink);border-radius:var(--r);
  padding:9px 12px;font-family:var(--body);font-size:14px;outline:none}
select.filter{cursor:pointer}.input:focus,select.filter:focus{border-color:var(--amber)}
select.input{appearance:none;cursor:pointer}
.hide{display:none !important}

/* ---------- item cards ---------- */
.items{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(208px,1fr))}
.items.songs{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.item{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  background:linear-gradient(180deg,var(--panel2),var(--bg2));transition:.16s}
.item:hover{border-color:var(--amber);transform:translateY(-3px);box-shadow:0 16px 34px -22px var(--amber)}
.item-img{height:148px;display:flex;align-items:center;justify-content:center;padding:12px;position:relative;
  background:
    radial-gradient(circle at 50% 35%,rgba(243,167,18,.10),transparent 70%),
    repeating-linear-gradient(135deg,#0b0905,#0b0905 9px,#0d0b07 9px,#0d0b07 18px);
  border-bottom:1px solid var(--line)}
.item-img img{max-width:100%;max-height:120px;object-fit:contain;filter:drop-shadow(0 10px 14px rgba(0,0,0,.7))}
.item-img .ph{font-family:var(--disp);font-weight:700;font-size:22px;letter-spacing:2px;color:rgba(243,167,18,.22)}
.item-body{padding:13px 14px;display:flex;flex-direction:column;gap:6px;flex:1;position:relative}
.item-name{font-family:var(--disp);font-weight:500;font-size:15px;letter-spacing:.6px;line-height:1.2}
.item-sub{font-family:var(--mono);color:var(--ink-dim);font-size:11px;letter-spacing:.5px;text-transform:uppercase}
.item-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:6px}
.item .price{font-family:var(--mono);font-weight:700;color:var(--amber);font-size:15px}
.item .price small{font-family:var(--disp);font-size:10px;color:var(--ink-dim);font-weight:400;letter-spacing:1px;text-transform:uppercase}
.item-badge{position:absolute;top:10px;right:10px;z-index:2;font-family:var(--disp);font-size:10px;font-weight:500;
  letter-spacing:1.5px;text-transform:uppercase;padding:3px 8px;background:rgba(7,6,4,.7);backdrop-filter:blur(3px)}
.item-badge.owned{color:var(--good);border:1px solid rgba(122,199,79,.5)}
.item-badge.vip{color:var(--amber);border:1px solid rgba(243,167,18,.55)}
.item-badge.eq{color:var(--steel);border:1px solid rgba(103,179,192,.6)}
.item.compact{flex-direction:row;align-items:stretch}
.item.compact .accent{width:4px;flex:none}
.item.upg .lvlbar{height:5px;background:#0c0a06;overflow:hidden;margin-top:4px;border:1px solid var(--line)}
.item.upg .lvlbar i{display:block;height:100%;background:linear-gradient(90deg,var(--amber),var(--amber2))}
.empty-state{grid-column:1/-1;text-align:center;color:var(--ink-dim);padding:34px;border:1px dashed var(--line2);border-radius:var(--r)}

.rb{display:inline-block;font-family:var(--disp);font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:1.2px;
  padding:3px 8px;color:var(--rc);border:1px solid color-mix(in srgb,var(--rc) 45%,transparent);
  background:color-mix(in srgb,var(--rc) 12%,transparent)}
.rarity-row{display:flex;gap:12px;flex-wrap:wrap}
.rar-cell{flex:1;min-width:108px;text-align:center;padding:16px 10px;border:1px solid color-mix(in srgb,var(--rc) 30%,var(--line));
  background:color-mix(in srgb,var(--rc) 7%,var(--panel))}
.rar-n{font-family:var(--disp);font-size:28px;font-weight:600;color:var(--rc)}

/* ---------- podium ---------- */
.podium{display:flex;align-items:flex-end;justify-content:center;gap:16px;margin:26px auto 6px;max-width:780px;flex-wrap:wrap}
.pod{flex:1;min-width:168px;text-align:center;padding:18px 14px 0;border:1px solid var(--line);border-bottom:0;
  background:linear-gradient(180deg,var(--panel),var(--bg2))}
.pod::before{content:none}
.pod-medal{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--ink-dim);letter-spacing:2px}
.pod-name{font-family:var(--disp);font-weight:500;letter-spacing:.6px;text-transform:uppercase;margin:6px 0 2px;font-size:15px}
.pod-coins{font-family:var(--mono);color:var(--amber);font-weight:700;font-size:18px;margin-bottom:14px}
.pod-bar{height:14px}
.pod-gold{transform:translateY(-22px);border-color:rgba(243,167,18,.5);box-shadow:0 0 40px -14px rgba(243,167,18,.7)}
.pod-gold .pod-medal{color:var(--amber)} .pod-gold .pod-bar{background:linear-gradient(180deg,var(--amber2),#9a6a10);height:120px}
.pod-silver .pod-bar{background:linear-gradient(180deg,#c9cfd6,#828a94);height:86px}.pod-silver .pod-medal{color:#c9cfd6}
.pod-bronze .pod-bar{background:linear-gradient(180deg,#cb8a4e,#7d5026);height:64px}.pod-bronze .pod-medal{color:#cb8a4e}

/* ---------- tables ---------- */
table.data{width:100%;border-collapse:collapse}
table.data th,table.data td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line)}
table.data tbody tr:last-child td{border-bottom:0}
table.data th{font-family:var(--disp);color:var(--ink-dim);font-size:11px;letter-spacing:1.4px;text-transform:uppercase;font-weight:500}
table.data tbody tr{transition:background .12s}
table.data tbody tr:hover{background:var(--amber-soft)}
.rk{font-family:var(--mono);color:var(--amber);font-weight:700;width:42px}
.num{text-align:right;font-family:var(--mono);font-weight:700}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--r)}
.table-wrap table.data thead th{position:sticky;top:0;background:#0e0b07;z-index:1}
.text-center{text-align:center}

.badge{display:inline-block;font-family:var(--disp);padding:3px 9px;font-size:11px;font-weight:500;letter-spacing:1px;
  text-transform:uppercase;border:1px solid var(--line2);color:var(--ink-dim);background:rgba(255,255,255,.03)}
.badge.active{color:var(--good);border-color:rgba(122,199,79,.4);background:rgba(122,199,79,.1)}
.badge.warn{color:var(--amber);border-color:rgba(243,167,18,.4);background:var(--amber-soft)}
.badge.perm{color:var(--steel);border-color:rgba(103,179,192,.45);background:rgba(103,179,192,.1)}
.badge.bad{color:var(--blood);border-color:rgba(226,74,54,.4);background:rgba(226,74,54,.1)}

.card-header{margin:-20px -20px 14px;padding:14px 20px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.015)}
.card-header h2{margin:0;font-family:var(--disp);font-size:14px;letter-spacing:1.5px;text-transform:uppercase;color:var(--amber)}

.tool{display:block;padding:20px;border:1px solid var(--line);background:linear-gradient(180deg,var(--panel2),var(--bg2));transition:.16s}
.tool:hover{border-color:var(--amber);transform:translateY(-3px)}
.tool h3{font-family:var(--disp);font-weight:500;letter-spacing:1px;text-transform:uppercase;margin:0 0 6px;font-size:16px}
.tool p{margin:0;color:var(--ink-dim);font-size:13px}
.feature{padding-top:22px}
.feature-kicker{display:inline-block;font-family:var(--disp);font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;
  color:var(--amber);border:1px solid rgba(243,167,18,.3);padding:3px 9px;margin-bottom:12px;background:var(--amber-soft)}
.feature h2{font-family:var(--disp);color:var(--ink);font-size:18px;letter-spacing:1px;text-transform:uppercase;margin:0 0 8px}

.pkgs{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.pkg{border:1px solid var(--line);padding:24px 20px;text-align:center;background:linear-gradient(180deg,var(--panel),var(--bg2))}
.pkg:hover{border-color:var(--amber);transform:translateY(-3px);transition:.16s}
.pkg-vip{border-color:rgba(243,167,18,.4);background:linear-gradient(180deg,rgba(243,167,18,.08),var(--bg2))}
.pkg-kicker{font-family:var(--disp);font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--amber);margin-bottom:12px}
.pkg-amount{font-family:var(--disp);font-size:40px;font-weight:600;line-height:1}
.pkg-amount small{font-family:var(--body);font-size:14px;font-weight:600;color:var(--ink-dim);margin-left:5px}
.pkg-label{color:var(--ink-dim);font-size:13px;margin:6px 0 14px}
.pkg-price{font-family:var(--mono);font-size:19px;font-weight:700;color:var(--amber);margin-bottom:16px}
.pkg-price span{font-size:12px;color:var(--ink-dim)}

.tile{position:relative;border:1px solid var(--line);border-radius:var(--r);padding:16px;background:linear-gradient(180deg,var(--panel2),var(--bg2));display:flex;flex-direction:column;gap:8px}
.tile .name{font-family:var(--disp);font-weight:500;letter-spacing:.5px}
.tile .meta{color:var(--ink-dim);font-size:13px}
.tile .tag{position:absolute;top:12px;right:12px;font-family:var(--disp);font-size:10px;font-weight:500;letter-spacing:1px;text-transform:uppercase;padding:3px 8px;border:1px solid var(--line2)}

.flash{padding:13px 16px;margin-bottom:18px;font-weight:500;border:1px solid;border-left-width:3px;border-radius:var(--r)}
.flash-success{background:rgba(122,199,79,.08);border-color:#36592a;border-left-color:var(--good);color:#bce8a3}
.flash-error{background:rgba(226,74,54,.08);border-color:#5b2620;border-left-color:var(--blood);color:#f0a99e}
.flash-info{background:var(--amber-soft);border-color:#5a4717;border-left-color:var(--amber);color:#e8c989}
.pending{display:flex;align-items:center;gap:8px;background:var(--amber-soft);border:1px solid #5a4717;border-left:3px solid var(--amber);
  color:#e8c989;padding:10px 14px;margin-bottom:10px;border-radius:var(--r)}

.foot{max-width:1180px;margin:40px auto;padding:22px;color:var(--ink-faint);display:flex;gap:12px;justify-content:center;
  font-family:var(--disp);font-size:12px;letter-spacing:1.4px;text-transform:uppercase}
.foot a:hover{color:var(--amber)}

.prof-head{display:flex;align-items:center;gap:18px;margin-top:8px}
.prof-head .le-mark{width:64px;height:64px;font-size:22px}
.pl{color:inherit}.pl:hover{color:var(--amber)}

/* ---------- cases / unbox ---------- */
.crate-glyph{font-family:var(--disp);font-weight:700;font-size:24px;letter-spacing:5px;color:rgba(243,167,18,.28)}
.crate-chips{display:flex;flex-wrap:wrap;gap:5px;margin:2px 0}
.crate-card .item-img{background:radial-gradient(circle at 50% 40%,rgba(243,167,18,.16),transparent 70%),repeating-linear-gradient(135deg,#0b0905,#0b0905 9px,#0d0b07 9px,#0d0b07 18px)}
.skin-thumb{width:46px;height:30px;object-fit:contain;background:#0c0a06;border:1px solid var(--line);vertical-align:middle}

.unbox{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:rgba(5,4,2,.85);backdrop-filter:blur(6px)}
.unbox-box{width:min(900px,94vw);background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line2);
  padding:28px;text-align:center;box-shadow:0 40px 90px -30px #000}
.unbox-title{font-family:var(--disp);font-size:22px;font-weight:600;letter-spacing:2px;text-transform:uppercase;margin-bottom:18px}
.reel-window{position:relative;height:172px;overflow:hidden;border:1px solid var(--line);
  background:repeating-linear-gradient(90deg,#0a0805,#0a0805 145px,#0d0b07 145px,#0d0b07 146px)}
.reel-marker{position:absolute;left:50%;top:0;bottom:0;width:3px;transform:translateX(-50%);z-index:3;background:var(--amber);box-shadow:0 0 18px var(--amber)}
.reel{display:flex;gap:16px;padding:14px 0;height:100%;align-items:center;will-change:transform}
.rc{flex:0 0 130px;width:130px;height:140px;border:1px solid color-mix(in srgb,var(--rc) 50%,var(--line));
  background:linear-gradient(180deg,color-mix(in srgb,var(--rc) 12%,#0d0b07),#0a0805);
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;border-bottom:3px solid var(--rc)}
.rc-img{height:80px;display:flex;align-items:center;justify-content:center}
.rc-img img{max-width:118px;max-height:78px;object-fit:contain;filter:drop-shadow(0 6px 10px rgba(0,0,0,.6))}
.rc-glyph{font-family:var(--disp);font-weight:600;color:var(--rc);font-size:14px;letter-spacing:1px}
.rc-name{font-family:var(--disp);font-size:11px;color:var(--ink);margin-top:6px;text-align:center;line-height:1.2;max-height:28px;overflow:hidden;letter-spacing:.5px}
.unbox-result{margin-top:20px;display:flex;flex-direction:column;align-items:center}
.unbox-result .rc{transform:scale(1.18);box-shadow:0 0 44px -8px var(--rc)}
.rwd-rarity{font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:2px;margin-top:16px;font-size:14px}

@media(max-width:640px){.topnav{display:none}.brand-sub{display:none}}

/* theme switcher */
.themebar{display:flex;align-items:center;justify-content:center;gap:10px;margin:34px auto 0;
  font-family:var(--disp);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--ink-faint)}
.swatch{width:20px;height:20px;border:2px solid var(--line2);background:var(--sw);cursor:pointer;padding:0;
  clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%);transition:.14s}
.swatch:hover{transform:translateY(-2px);border-color:var(--ink-dim)}
.swatch.on{border-color:#fff;box-shadow:0 0 0 2px var(--sw)}

/* case contents / odds */
.contents-btn{width:100%;background:transparent;border:1px solid var(--line2);color:var(--ink-dim);font-family:var(--disp);
  font-size:11px;letter-spacing:1.4px;text-transform:uppercase;padding:7px;cursor:pointer;margin:2px 0 4px;border-radius:var(--r);transition:.14s}
.contents-btn:hover{border-color:var(--amber);color:var(--amber)}
.contents-list{display:flex;flex-direction:column;gap:8px;max-height:58vh;overflow:auto;text-align:left}
.crow{display:flex;align-items:center;gap:12px;padding:8px 10px;border:1px solid color-mix(in srgb,var(--rc) 35%,var(--line));
  border-left:3px solid var(--rc);background:color-mix(in srgb,var(--rc) 7%,var(--panel2))}
.crow-ic{width:58px;height:42px;flex:none;display:flex;align-items:center;justify-content:center;background:#0a0805;border:1px solid var(--line)}
.crow-ic img{max-width:54px;max-height:38px;object-fit:contain}
.crow-meta{flex:1;min-width:0}
.crow-name{font-family:var(--disp);font-weight:500;letter-spacing:.5px;font-size:14px}
.crow-rar{font-family:var(--disp);font-size:10px;text-transform:uppercase;letter-spacing:1.2px}
.crow-odds{width:120px;flex:none;text-align:right}
.crow-pct{font-family:var(--mono);font-weight:700;color:var(--ink);font-size:14px}
.crow-bar{height:5px;background:#0a0805;border:1px solid var(--line);margin-top:4px;overflow:hidden}
.crow-bar i{display:block;height:100%}

/* VIP perks list */
.perk-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px}
.perk-list li{position:relative;padding:10px 12px 10px 30px;border:1px solid var(--line);background:var(--panel2);border-radius:var(--r);font-size:14px}
.perk-list li::before{content:'';position:absolute;left:11px;top:50%;transform:translateY(-50%);width:9px;height:9px;
  background:var(--amber);clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%)}

/* =====================================================================
   v25 — Leaderboard redesign
   ===================================================================== */
@keyframes lb-rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes lb-fade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.reveal{animation:lb-fade .5s both;animation-delay:var(--d,0ms)}

/* hero */
.lb-hero{text-align:center;padding:30px 0 10px}
.lb-kicker{font-family:var(--disp);letter-spacing:5px;text-transform:uppercase;font-size:12px;color:var(--amber);margin-bottom:6px}
.lb-title{font-family:var(--disp);font-weight:700;font-size:clamp(38px,7vw,62px);letter-spacing:3px;margin:0;line-height:.9}
.lb-title span{color:var(--amber);text-shadow:0 0 34px color-mix(in srgb,var(--amber) 55%,transparent)}
.lb-strip{display:flex;justify-content:center;flex-wrap:wrap;gap:10px;margin:22px auto 0;max-width:760px}
.lb-s{flex:1;min-width:130px;border:1px solid var(--line);background:rgba(255,255,255,.02);border-radius:var(--r);padding:14px 10px}
.lb-s .lb-sv{display:block;font-family:var(--mono);font-weight:700;font-size:24px}
.lb-s .lb-sl{font-family:var(--disp);text-transform:uppercase;letter-spacing:1.2px;font-size:11px;color:var(--ink-dim)}

/* champions podium */
.champions{display:grid;grid-template-columns:1fr 1.25fr 1fr;align-items:end;gap:14px;max-width:840px;margin:30px auto 6px}
.champ{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;
  border:1px solid var(--line);border-bottom:0;background:linear-gradient(180deg,var(--panel),var(--bg2));
  padding:18px 12px 0;border-radius:8px 8px 0 0;animation:lb-rise .55s both}
.champ-crown{position:absolute;top:-13px;font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:2px;
  background:linear-gradient(135deg,var(--amber2),var(--amber));color:var(--on-accent);padding:3px 12px;border-radius:3px;text-transform:uppercase;box-shadow:0 4px 16px color-mix(in srgb,var(--amber) 50%,transparent)}
.champ-av{position:relative;width:58px;height:58px;display:flex;align-items:center;justify-content:center;
  font-family:var(--disp);font-weight:700;font-size:20px;color:var(--on-accent);
  background:linear-gradient(135deg,var(--amber2),var(--amber));clip-path:polygon(0 0,100% 0,100% 72%,80% 100%,0 100%);margin-bottom:10px}
.champ-rk{position:absolute;right:-8px;bottom:-8px;font-family:var(--mono);font-size:11px;font-weight:700;
  background:var(--panel2);color:var(--ink);border:1px solid var(--line2);border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.champ-name{font-family:var(--disp);font-weight:500;letter-spacing:.5px;text-transform:uppercase;font-size:14px;margin-bottom:4px}
.champ-val{font-family:var(--mono);font-weight:700;font-size:22px;color:var(--gold)}
.champ-unit{font-family:var(--disp);font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink-dim);margin-bottom:12px}
.champ-base{width:100%;border-top:2px solid var(--line2)}
.champ-one{z-index:2}
.champ-one .champ-av{width:74px;height:74px;font-size:26px;box-shadow:0 0 40px -8px var(--amber)}
.champ-one .champ-base{height:120px;background:linear-gradient(180deg,color-mix(in srgb,var(--amber) 30%,transparent),transparent)}
.champ-one{border-color:color-mix(in srgb,var(--amber) 45%,var(--line))}
.champ-two .champ-base{height:84px;background:linear-gradient(180deg,rgba(201,207,214,.22),transparent)}
.champ-three .champ-base{height:60px;background:linear-gradient(180deg,rgba(203,138,78,.22),transparent)}

/* your standing */
.yourank{display:flex;align-items:center;gap:14px;margin:8px 0 4px;padding:14px 16px;border:1px solid var(--line2);
  border-left:3px solid var(--amber);background:var(--amber-soft);border-radius:var(--r)}
.yr-badge{font-family:var(--disp);font-weight:700;font-size:22px;color:var(--amber);min-width:54px;text-align:center}
.yr-main{flex:1}
.yr-label{font-family:var(--disp);text-transform:uppercase;letter-spacing:1px;font-weight:500}
.yr-sub{color:var(--ink-dim);font-size:13px;margin-top:2px}

/* crate luck bar */
.lb-secrow{display:flex;align-items:center;justify-content:space-between;gap:12px}
.luckbar{display:flex;height:26px;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#0a0805}
.luck-seg{--rc:#888;background:color-mix(in srgb,var(--rc) 70%,#000);display:flex;align-items:center;justify-content:center;
  border-right:1px solid rgba(0,0,0,.4);transition:flex .3s}
.luck-seg span{font-family:var(--mono);font-size:11px;font-weight:700;color:#0a0805;text-shadow:0 1px 0 rgba(255,255,255,.25)}
.luck-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px}
.ll{font-family:var(--disp);text-transform:uppercase;letter-spacing:1px;font-size:11px;color:var(--ink-dim);display:flex;align-items:center;gap:6px}
.ll i{width:10px;height:10px;display:inline-block;border-radius:2px}.ll b{color:var(--ink);font-family:var(--mono)}

/* ranked boards */
.boards{margin-top:18px}
.board{border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--panel),var(--bg2));overflow:hidden}
.board-head{font-family:var(--disp);text-transform:uppercase;letter-spacing:1.5px;font-size:13px;color:var(--amber);
  padding:13px 16px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.02)}
.board-body{padding:6px 8px}
.lbrow{display:flex;align-items:center;gap:10px;padding:8px 8px;border-radius:6px;transition:background .12s}
.lbrow:hover{background:var(--amber-soft)}
.lbrk{width:30px;text-align:center;font-family:var(--mono);font-weight:700;color:var(--ink-dim);flex:none}
.lbrk .medal{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;
  font-size:12px;color:var(--on-accent);clip-path:polygon(50% 0,100% 38%,82% 100%,18% 100%,0 38%)}
.top1 .medal{background:linear-gradient(135deg,#ffd66b,#e0a012)}
.top2 .medal{background:linear-gradient(135deg,#dfe5ec,#9aa3af)}
.top3 .medal{background:linear-gradient(135deg,#dC9a5e,#a5683a)}
.lbnm{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.lbvl{font-family:var(--mono);font-weight:700;flex:none}
.top1{background:linear-gradient(90deg,color-mix(in srgb,var(--amber) 12%,transparent),transparent)}

/* recent pulls */
.pulls{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.pull{position:relative;border:1px solid color-mix(in srgb,var(--rc) 45%,var(--line));border-left:3px solid var(--rc);
  background:linear-gradient(180deg,color-mix(in srgb,var(--rc) 8%,var(--panel2)),var(--bg2));border-radius:var(--r);padding:12px 14px}
.pull-r{position:absolute;top:10px;right:12px;font-family:var(--disp);font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--rc)}
.pull-item{font-family:var(--disp);font-weight:500;letter-spacing:.5px;font-size:15px;padding-right:60px}
.pull-who{color:var(--ink-dim);font-size:12px;margin-top:3px}

@media(max-width:680px){.champions{grid-template-columns:1fr;max-width:340px}.champ{border-bottom:1px solid var(--line);border-radius:var(--r);margin-bottom:8px}.champ-base{display:none}}

/* =====================================================================
   v26 — mobile nav
   ===================================================================== */
.navtoggle{display:none;margin-left:auto;background:transparent;border:1px solid var(--line2);border-radius:var(--r);
  width:42px;height:38px;cursor:pointer;flex-direction:column;gap:4px;align-items:center;justify-content:center;padding:0}
.navtoggle span{display:block;width:20px;height:2px;background:var(--ink);transition:.2s}
.topbar.nav-open .navtoggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.topbar.nav-open .navtoggle span:nth-child(2){opacity:0}
.topbar.nav-open .navtoggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:760px){
  .topbar{flex-wrap:wrap}
  .navtoggle{display:flex}
  .brand-sub{display:none}
  .topnav{display:none;order:3;flex-basis:100%;flex-direction:column;gap:2px;margin:8px 0 4px}
  .topbar.nav-open .topnav{display:flex}
  .topnav a{padding:11px 12px;border-radius:var(--r);border:1px solid transparent}
  .topnav a:hover,.topnav a.on{background:var(--amber-soft)}
  .topnav a.on::after{display:none}
  .userbox{margin-left:0}
  .wrap{margin-top:18px}
}

/* =====================================================================
   v27 — site-wide entrance polish (staggered card reveal)
   ===================================================================== */
@media (prefers-reduced-motion: no-preference){
  .items .item, .pkgs .pkg, .grid .tool, .grid .card{animation:lb-fade .45s both}
  .items .item:nth-child(1),.pkgs .pkg:nth-child(1){animation-delay:.02s}
  .items .item:nth-child(2),.pkgs .pkg:nth-child(2){animation-delay:.06s}
  .items .item:nth-child(3),.pkgs .pkg:nth-child(3){animation-delay:.10s}
  .items .item:nth-child(4),.pkgs .pkg:nth-child(4){animation-delay:.14s}
  .items .item:nth-child(5){animation-delay:.18s}
  .items .item:nth-child(6){animation-delay:.22s}
  .items .item:nth-child(7){animation-delay:.26s}
  .items .item:nth-child(8){animation-delay:.30s}
  .items .item:nth-child(n+9){animation-delay:.34s}
}
/* page heading kicker accent */
.page-h1{position:relative;padding-left:16px}
.page-h1::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:.72em;
  background:linear-gradient(180deg,var(--amber2),var(--amber));clip-path:polygon(0 0,100% 0,100% 72%,55% 100%,0 100%)}

/* =====================================================================
   v28 — daily quests
   ===================================================================== */
.quest{position:relative}
.quest-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:12px}
.quest-name{font-family:var(--disp);font-weight:600;letter-spacing:.5px;text-transform:uppercase;font-size:16px}
.quest-desc{color:var(--ink-dim);font-size:13px;margin-top:2px}
.quest-reward{font-family:var(--mono);font-weight:700;color:var(--gold);white-space:nowrap}
.quest-claimed{font-family:var(--disp);font-size:11px;letter-spacing:1px;color:var(--good);border:1px solid rgba(122,199,79,.4);padding:2px 8px;border-radius:999px}
.quest-bar{height:8px;background:#0a0805;border:1px solid var(--line);border-radius:5px;overflow:hidden}
.quest-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--amber),var(--amber2));transition:width .4s}
.quest-prog{font-family:var(--mono);font-size:12px;color:var(--ink-dim);margin-top:6px}
.quest-done{border-color:color-mix(in srgb,var(--good) 45%,var(--line))}
.quest-done .quest-bar i{background:linear-gradient(90deg,var(--good),#a7f3c4)}

/* ======================================================================
   CLASH FX — site-wide effects (glows, hover-lift, shine, reveals).
   Theme-aware via the --amber/--gold/--wash tokens. Additive + reversible.
   ====================================================================== */
*{scrollbar-width:thin;scrollbar-color:var(--line2) transparent}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--line2);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
*::-webkit-scrollbar-thumb:hover{background:var(--amber);background-clip:padding-box}

/* atmospheric, theme-tinted background glows */
body{
  background-color:var(--bg);
  background-image:
    radial-gradient(58vw 52vh at 8% -10%, var(--wash1), transparent 60%),
    radial-gradient(52vw 50vh at 100% -4%, var(--wash2), transparent 58%),
    radial-gradient(64vw 54vh at 50% 118%, var(--wash1), transparent 66%);
  background-attachment:fixed;
}

/* universal smoothing */
.btn,.btn-sm,.tab,.item,.card,.tool,.swatch,.pill,.item-badge,input,select,.coins,.avatar,.topnav a{
  transition:transform .16s ease, box-shadow .22s ease, border-color .2s ease, background .2s ease, color .15s ease;
}

/* primary buttons — gradient, glow, lift, shine sweep */
.btn-primary,.btn-steam{position:relative;overflow:hidden}
.btn-primary{background:linear-gradient(135deg,var(--amber),var(--amber2));color:var(--on-accent);border:none;
  box-shadow:0 4px 16px -5px var(--amber), inset 0 0 0 1px rgba(255,255,255,.06)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px -6px var(--amber)}
.btn-primary::after,.btn-steam::after{content:"";position:absolute;top:0;left:-70%;width:45%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-20deg);
  transition:left .55s ease;pointer-events:none}
.btn-primary:hover::after,.btn-steam:hover::after{left:135%}
.btn:hover,.btn-sm:hover{transform:translateY(-1px)}

/* cards / admin tiles — lift + accent glow */
.card:hover,.tool:hover{transform:translateY(-3px);border-color:var(--amber);
  box-shadow:0 16px 44px -14px rgba(0,0,0,.6), 0 0 0 1px var(--amber-soft), 0 0 32px -12px var(--amber)}

/* shop / case / skin cards — showpiece hover */
.item{position:relative;overflow:hidden}
.item::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .25s ease;
  background:radial-gradient(75% 60% at 50% -8%, var(--amber-soft), transparent 60%)}
.item:hover{transform:translateY(-4px);border-color:var(--amber);
  box-shadow:0 18px 46px -16px rgba(0,0,0,.7), 0 0 0 1px var(--amber-soft), 0 0 30px -10px var(--amber)}
.item:hover::before{opacity:1}
.item-img img{transition:transform .28s ease}
.item:hover .item-img img{transform:scale(1.08)}

/* top bar + brand */
.topbar{box-shadow:0 1px 0 rgba(255,255,255,.03), 0 14px 34px -26px var(--amber)}
.le-mark{box-shadow:0 0 18px -5px var(--amber)}
.brand:hover .le-mark{box-shadow:0 0 28px -3px var(--amber);transform:translateY(-1px)}
.coins:hover{box-shadow:0 0 0 1px var(--amber-soft),0 0 20px -8px var(--amber)}

/* nav links — animated underline */
.topnav a{position:relative}
.topnav a::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--amber),var(--amber2));transition:right .25s ease;opacity:.9}
.topnav a:hover::after,.topnav a.on::after{right:0}

/* tabs active glow + pills + inputs */
.tab.on,.tab.active{box-shadow:0 0 0 1px var(--amber-soft), 0 6px 16px -10px var(--amber)}
.pill,.item-badge,.rb{box-shadow:0 0 12px -5px currentColor}
input:focus,select:focus,.input:focus,input[type="search"]:focus{
  border-color:var(--amber)!important;box-shadow:0 0 0 2px var(--amber-soft), 0 0 18px -9px var(--amber)!important;outline:none}

/* table row hover */
.data-table tbody tr{transition:background .12s ease}
.data-table tbody tr:hover>*{background:var(--wash1)}

/* staggered load reveal for grids */
@keyframes fxrise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.items>.item,.grid>.card,.grid>.tool,.cols-3>*,.cols-2>*{animation:fxrise .5s cubic-bezier(.22,1,.36,1) both}
.items>.item:nth-child(2){animation-delay:.04s}.items>.item:nth-child(3){animation-delay:.08s}
.items>.item:nth-child(4){animation-delay:.12s}.items>.item:nth-child(5){animation-delay:.16s}
.items>.item:nth-child(n+6){animation-delay:.2s}
/* ============================================================
   AMPLIFIED FX  — always-on, visible without hovering (v30)
   ============================================================ */
/* 1 · living atmosphere: the background washes slowly drift + breathe */
body::before{animation:fxatmos 26s ease-in-out infinite alternate;will-change:transform}
@keyframes fxatmos{0%{transform:translate3d(0,0,0) scale(1.03)}100%{transform:translate3d(-3.5%,2.6%,0) scale(1.16)}}

/* 2 · cards & tools: resting glow + hairline so they read premium at a glance */
.card,.tool{box-shadow:0 16px 40px -24px #000, 0 0 0 1px var(--amber-soft)}

/* 3 · shop / case items: resting lift-shadow + accent edge */
.item{box-shadow:0 12px 28px -20px #000, 0 0 0 1px var(--amber-soft)}

/* 4 · brand mark: soft heartbeat */
.le-mark{animation:lepulse 3.6s ease-in-out infinite}
@keyframes lepulse{0%,100%{box-shadow:0 0 16px -6px var(--amber)}50%{box-shadow:0 0 32px -1px var(--amber)}}

/* 5 · CTAs: periodic shine sweep (not hover-only) + standing glow */
.btn-primary::after,.btn-steam::after{animation:fxshine 5s ease-in-out infinite}
@keyframes fxshine{0%,72%{left:-70%}100%{left:170%}}
.btn-primary{box-shadow:0 6px 18px -6px var(--amber), 0 0 24px -12px var(--amber)}
.btn-steam{box-shadow:0 0 0 1px var(--amber-soft), 0 8px 24px -12px #000, 0 0 22px -13px var(--amber)}
.btn-steam:hover{border-color:var(--amber)!important;box-shadow:0 0 0 1px var(--amber-soft),0 10px 26px -10px #000,0 0 30px -10px var(--amber)}

/* 6 · hero / headings: breathing glow */
.page-h1,.hero h1,.hero-title{text-shadow:0 0 24px var(--amber-soft)}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}

/* ============================================================
   ACHIEVEMENTS showcase (Steam-style)
   ============================================================ */
.ach-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:6px}
.ach-progress{display:flex;align-items:center;gap:14px}
.ach-ring{position:relative;width:76px;height:76px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;
  background:conic-gradient(var(--amber) calc(var(--p)*1%), var(--line2) 0)}
.ach-ring::before{content:"";position:absolute;inset:8px;border-radius:50%;background:var(--panel)}
.ach-ring span{position:relative;z-index:1;font:700 16px/1 var(--disp);color:var(--ink)}
.ach-count{font:700 24px/1 var(--disp);color:var(--amber)}
.ach-filter{display:flex;gap:8px;margin:14px 0 16px;flex-wrap:wrap}
.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:12px}
.ach{position:relative;display:flex;gap:14px;align-items:center;padding:14px;border:1px solid var(--line);border-radius:var(--r);background:var(--panel);overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.ach:hover{transform:translateY(-3px);box-shadow:0 16px 36px -22px #000}
.ach-off{opacity:.6}
.ach-off .ach-ic img{filter:grayscale(1) brightness(.65)}
.ach-on{border-color:var(--amber-soft);box-shadow:0 0 0 1px var(--amber-soft),0 12px 28px -20px #000}
.ach-on::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(70% 90% at 0% 0%,var(--amber-soft),transparent 58%)}
.ach-ic{flex:0 0 auto;width:60px;height:60px;display:grid;place-items:center;position:relative;z-index:1}
.ach-ic img{width:60px;height:60px;object-fit:contain;filter:drop-shadow(0 5px 12px rgba(0,0,0,.55))}
.ach-body{flex:1;min-width:0;position:relative;z-index:1}
.ach-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.ach-name{flex:1;min-width:0;font:600 15px/1.2 var(--disp);letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ach-rew{flex:0 0 auto;font:600 11px/1 var(--mono);color:var(--gold);background:var(--wash1);border:1px solid var(--amber-soft);padding:3px 7px;border-radius:999px}
.ach-desc{color:var(--ink-dim);font-size:12.5px;margin:3px 0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ach-foot{font-size:11.5px}
.ach-done{color:var(--amber);font-weight:600}
.ach-prog{height:6px;border-radius:4px;background:var(--line2);overflow:hidden;margin:2px 0 5px;max-width:78%}
.ach-prog i{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,var(--amber2),var(--amber))}
.ach-rarity{position:absolute;bottom:9px;right:12px;font:600 10px/1 var(--mono);color:var(--ink-faint)}
@media(max-width:560px){.ach-grid{grid-template-columns:1fr}}
/* profile mini achievement strip */
.ach-mini{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.ach-chip{width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line);border-radius:10px;background:var(--panel2);transition:transform .15s ease}
.ach-chip:hover{transform:translateY(-2px)}
.ach-chip img{width:32px;height:32px;object-fit:contain;filter:drop-shadow(0 3px 7px rgba(0,0,0,.5))}
.mini-link{font:500 12px/1 var(--body);color:var(--amber);margin-left:8px}

/* ===== games hub ===== */
.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.game-card{position:relative;display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--line);border-radius:var(--r);background:var(--panel);overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;color:var(--ink)}
.game-card:hover{transform:translateY(-3px);border-color:var(--amber);box-shadow:0 16px 36px -20px #000,0 0 0 1px var(--amber-soft)}
.game-soon{opacity:.58;cursor:default}
.game-soon:hover{transform:none;border-color:var(--line);box-shadow:none}
.game-ic{flex:0 0 auto;width:54px;height:54px;display:grid;place-items:center}
.game-ic img{width:54px;height:54px;object-fit:contain;filter:drop-shadow(0 5px 12px rgba(0,0,0,.55))}
.game-body{flex:1;min-width:0}
.game-name{font:600 16px/1.1 var(--disp);letter-spacing:.3px}
.game-tag{color:var(--ink-dim);font-size:12.5px;margin-top:3px}
.soon-tag{font:600 9px/1 var(--mono);text-transform:uppercase;letter-spacing:.1em;background:var(--wash1);border:1px solid var(--line);color:var(--ink-faint);padding:3px 6px;border-radius:999px;vertical-align:middle;margin-left:4px}
.game-go{position:absolute;right:14px;bottom:12px;font:600 11px/1 var(--mono);color:var(--amber);opacity:0;transition:opacity .18s}
.game-card:hover .game-go{opacity:1}
.sfx-toggle{margin-left:14px;font:600 11px/1 var(--mono);color:var(--ink-dim);background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:6px 11px;cursor:pointer;transition:.15s}
.sfx-toggle:hover{color:var(--ink);border-color:var(--amber-soft)}
.sfx-toggle.off{color:var(--ink-faint);opacity:.7}
