:root{
  --bg:#0d0f12; --panel:#171a1f; --panel2:#1e222a; --line:#2c313a;
  --text:#f1f3f6; --muted:#9aa1ad; --accent:#fd8b0e; --accent2:#25d366;
  --danger:#ef4444; --radius:12px;
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.45}
.hidden{display:none!important}
.muted{color:var(--muted)}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
input,textarea,select{font-family:inherit;font-size:14px;width:100%;padding:10px 12px;
  background:var(--panel2);border:1px solid var(--line);border-radius:9px;color:var(--text);outline:none}
input:focus,textarea:focus,select:focus{border-color:var(--accent)}
textarea{resize:vertical;min-height:80px}
label{display:block;font-size:12.5px;color:var(--muted);margin:10px 0 5px;font-weight:600}

/* login */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(120% 60% at 50% -10%,rgba(253,139,14,.12),transparent 60%),var(--bg)}
.login-card{width:340px;max-width:100%;background:var(--panel);border:1px solid var(--line);
  border-radius:18px;padding:32px 26px;text-align:center}
.login-logo{font-size:46px;margin-bottom:6px}
.login-card h1{font-size:22px;margin-bottom:2px}
.login-card input{margin:18px 0 12px;text-align:center}
.login-card button{width:100%;padding:12px;background:var(--accent);border:0;border-radius:9px;
  color:#000;font-weight:700;font-size:15px}
.err{color:var(--danger);font-size:13px;margin-top:10px;min-height:18px}

/* layout */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding:12px 18px;background:rgba(13,15,18,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{font-size:15px}
.tabs{display:flex;gap:6px;flex:1;flex-wrap:wrap}
.tabs button{background:transparent;border:1px solid transparent;color:var(--muted);
  padding:8px 14px;border-radius:9px;font-size:14px;font-weight:600}
.tabs button:hover{color:var(--text);background:var(--panel)}
.tabs button.active{color:#000;background:var(--accent)}
.top-actions{display:flex;gap:8px}
.ghost{background:var(--panel);border:1px solid var(--line);color:var(--text);
  padding:8px 12px;border-radius:9px;font-size:13px;text-decoration:none;display:inline-block}
.ghost:hover{border-color:var(--accent)}
main{max-width:1000px;margin:0 auto;padding:22px 18px 80px}

/* generic */
.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:24px 0 12px}
.section-head h2{font-size:18px}
.btn{background:var(--accent);color:#000;border:0;padding:9px 14px;border-radius:9px;font-weight:700;font-size:14px}
.btn.sec{background:var(--panel2);color:var(--text);border:1px solid var(--line)}
.btn.sm{padding:6px 10px;font-size:13px}
.btn.danger{background:transparent;border:1px solid var(--danger);color:var(--danger)}
.row-flex{display:flex;gap:10px;align-items:center}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-bottom:14px}
.pill{font-size:11px;font-weight:700;text-transform:uppercase;padding:2px 8px;border-radius:20px;
  background:var(--panel2);border:1px solid var(--line);color:var(--muted)}
.iconbtn{background:var(--panel2);border:1px solid var(--line);color:var(--text);width:30px;height:30px;
  border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:15px;line-height:1}
.iconbtn:hover{border-color:var(--accent)}
.iconbtn.del:hover{border-color:var(--danger);color:var(--danger)}

/* games */
.subtabs{display:flex;gap:8px;margin-bottom:12px}
.subtabs button{background:var(--panel);border:1px solid var(--line);color:var(--muted);
  padding:7px 16px;border-radius:9px;font-weight:600;font-size:14px}
.subtabs button.active{color:#000;background:var(--accent);border-color:var(--accent)}
.games{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.gcard{background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden;position:relative}
.gcard img{aspect-ratio:3/4;object-fit:cover;width:100%}
.gcard .ov{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;padding:6px}
.gcard .ov .iconbtn{width:26px;height:26px;font-size:13px;background:rgba(0,0,0,.6)}
.gcard .meta{padding:7px 8px;font-size:12px}
.gcard .meta .gb{color:var(--accent);font-weight:700}
.gcard.hidden-item{opacity:.45}

/* menu */
.cat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}
.cat-head{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--panel2);border-bottom:1px solid var(--line)}
.cat-head input{background:transparent;border:0;font-size:16px;font-weight:700;padding:4px 0}
.cat-head input:focus{border-bottom:1px solid var(--accent)}
.cat-body{padding:12px 14px}
.mitem{display:flex;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line)}
.mitem:last-child{border-bottom:0}
.mitem img{width:52px;height:52px;object-fit:cover;border-radius:8px;flex:none}
.mitem .ph{width:52px;height:52px;border-radius:8px;background:var(--panel2);display:flex;align-items:center;
  justify-content:center;color:var(--muted);flex:none;font-size:20px}
.mitem .info{flex:1;min-width:0}
.mitem .info b{font-size:14.5px}
.mitem .info .d{color:var(--muted);font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:46ch}
.mitem .price{color:var(--accent);font-weight:700;font-size:13.5px;white-space:nowrap}
.mitem .acts{display:flex;gap:5px;flex:none}
.stop{opacity:.5}

/* settings */
.fieldset{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;margin-bottom:16px}
.fieldset h3{font-size:15px;margin-bottom:8px}
.kv{display:grid;grid-template-columns:1fr 130px 34px;gap:8px;margin-bottom:8px;align-items:center}
.kv3{display:grid;grid-template-columns:120px 1fr 34px;gap:8px;margin-bottom:8px;align-items:center}
.save-bar{position:sticky;bottom:0;background:linear-gradient(transparent,var(--bg) 40%);
  padding:14px 0 4px;display:flex;gap:10px;justify-content:flex-end}

/* modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;
  justify-content:center;padding:16px;z-index:50}
.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;
  width:460px;max-width:100%;max-height:90vh;overflow:auto;padding:22px}
.modal-card h3{margin-bottom:14px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.drop{border:2px dashed var(--line);border-radius:10px;padding:18px;text-align:center;color:var(--muted);
  cursor:pointer;font-size:13px}
.drop:hover{border-color:var(--accent)}
.drop img{max-height:140px;margin:0 auto;border-radius:8px}

/* toast */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--panel2);border:1px solid var(--line);color:var(--text);padding:11px 18px;
  border-radius:10px;font-size:14px;opacity:0;transition:.25s;pointer-events:none;z-index:60}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:var(--accent2)}
.toast.bad{border-color:var(--danger)}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--line);
  border-top-color:var(--accent);border-radius:50%;animation:s .7s linear infinite;vertical-align:-2px}
@keyframes s{to{transform:rotate(360deg)}}
