:root{--tile:300px;--bg:#0e1014;--panel:#161a20;--text:#e7eaef;--muted:#8a93a0;--accent:#e2b53c}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,"Segoe UI",Roboto,Arial,sans-serif}
header{padding:28px 24px 10px;text-align:center}
header h1{margin:0;font-size:clamp(24px,4vw,40px);letter-spacing:.5px}
header p{margin:6px 0 0;color:var(--muted);font-size:14px}
.controls{position:sticky;top:0;z-index:5;background:rgba(14,16,20,.92);backdrop-filter:blur(6px);
 border-bottom:1px solid #20262e;display:flex;gap:16px 18px;align-items:center;justify-content:center;padding:12px 16px;flex-wrap:wrap}
.controls label{color:var(--muted);font-size:13px;display:flex;align-items:center;gap:8px}
.controls select{background:var(--panel);color:var(--text);border:1px solid #2c3540;border-radius:7px;padding:5px 8px;font-size:13px}
.controls input[type=range]{width:170px;accent-color:var(--accent)}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{border:1px solid #2c3540;background:var(--panel);color:var(--text);border-radius:20px;padding:4px 11px;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:6px}
.chip .dot{width:10px;height:10px;border-radius:50%}
.chip.active{border-color:var(--accent);color:#fff}
.count{color:var(--muted);font-size:13px}
main{padding:18px clamp(12px,3vw,40px) 60px}
.grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(var(--tile),1fr))}
.card{background:var(--panel);border-radius:12px;overflow:hidden;cursor:pointer;border:1px solid #20262e;transition:transform .12s,box-shadow .12s}
.card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.5);border-color:#2c3540}
.card .imgwrap{aspect-ratio:936/1290;background:#0b0d11;
 background-image:linear-gradient(45deg,#15181d 25%,transparent 25%),linear-gradient(-45deg,#15181d 25%,transparent 25%),
 linear-gradient(45deg,transparent 75%,#15181d 75%),linear-gradient(-45deg,transparent 75%,#15181d 75%);
 background-size:22px 22px;background-position:0 0,0 11px,11px -11px,-11px 0}
.card img{width:100%;height:100%;object-fit:contain;display:block}
.card .cap{padding:8px 10px;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;justify-content:center;gap:7px}
.card .lvl{font-size:11px;color:var(--muted);border:1px solid #2c3540;border-radius:5px;padding:0 5px}
.card .cdot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.lb{position:fixed;inset:0;background:rgba(6,7,9,.94);display:none;align-items:center;justify-content:center;z-index:50}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.lb .nav{position:absolute;top:0;bottom:0;width:18vw;min-width:64px;border:0;background:transparent;color:#fff;font-size:44px;cursor:pointer;opacity:.55}
.lb .nav:hover{opacity:1}
.lb .prev{left:0}.lb .next{right:0}
.lb .close{position:absolute;top:16px;right:22px;background:transparent;border:0;color:#fff;font-size:34px;cursor:pointer;opacity:.7;line-height:1}
.lb .close:hover{opacity:1}
.lb .lbcap{position:absolute;bottom:18px;left:0;right:0;text-align:center;color:#dfe4ea;font-size:15px;text-shadow:0 1px 4px #000}
.grouphdr{grid-column:1/-1;display:flex;align-items:center;gap:9px