*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --font:'Inter',sans-serif;
  --text:#f0f0f2;
  --muted:rgba(255,255,255,.42);
  --border:rgba(255,255,255,.13);
  --bh:rgba(255,255,255,.24);
  --card-bg:rgba(8,8,16,.68);
  --radius:14px;
}
html,body{height:100%;font-family:var(--font);color:var(--text);overflow:hidden}

#bg{position:fixed;inset:0;width:100%;height:100%;border:none;z-index:0;pointer-events:none}
#root{position:relative;z-index:2;height:100vh;display:flex;flex-direction:column;overflow:hidden}
.hidden{display:none!important}

.glass{
  background:rgba(8,8,18,.72);
  backdrop-filter:blur(28px) saturate(170%);
  -webkit-backdrop-filter:blur(28px) saturate(170%);
  border:1px solid var(--border);
  border-radius:var(--radius);
}

header{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 22px;
  background:rgba(5,5,12,.55);
  backdrop-filter:blur(30px);
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.logo{font-size:16px;font-weight:700;letter-spacing:.4px}
.logo small{font-weight:300;opacity:.45;font-size:12px;margin-left:6px}
#app-header{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--muted)}
#app-header strong{color:var(--text)}

.btn{font-family:var(--font);font-size:12px;font-weight:500;padding:7px 14px;border-radius:9px;border:1px solid transparent;cursor:pointer;transition:all .14s;white-space:nowrap}
.bprimary{background:rgba(255,255,255,.9);color:#111;border-color:rgba(255,255,255,.9)}
.bprimary:hover{background:#fff}
.bprimary:disabled{opacity:.4;cursor:not-allowed}
.bfull{width:100%;padding:11px;font-size:14px;margin-top:8px}
.bghost{background:rgba(255,255,255,.06);color:var(--muted);border-color:var(--border)}
.bghost:hover{background:rgba(255,255,255,.11);color:var(--text)}
.bdanger{background:rgba(255,70,70,.12);color:#ff7070;border-color:rgba(255,70,70,.25)}
.bdanger:hover{background:rgba(255,70,70,.22)}

#login-screen{flex:1;display:flex;align-items:center;justify-content:center}
.lcard{width:370px;padding:30px 26px}
.lcard h2{font-size:20px;font-weight:600;margin-bottom:4px}
.lcard p{font-size:13px;color:var(--muted);margin-bottom:22px;line-height:1.6}
.field{margin-bottom:13px}
.field label{display:block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:5px}
.ginput{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:9px;color:var(--text);font-family:var(--font);font-size:13px;padding:9px 12px;outline:none;transition:border-color .2s,background .2s;resize:vertical}
.ginput:focus{border-color:rgba(255,255,255,.32);background:rgba(255,255,255,.08)}
.hint-box{margin-top:7px;padding:9px 11px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:9px;font-size:11px;color:var(--muted);line-height:1.7}
.hint-box strong{color:var(--text)}
#login-err{font-size:12px;color:#ff6b6b;min-height:16px;margin:4px 0}

#app-screen{flex:1;display:flex;flex-direction:column;overflow:hidden}
#grid{flex:1;overflow-y:auto;padding:18px 20px 40px;display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:11px;align-content:start}
#grid::-webkit-scrollbar{width:4px}
#grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.loading{grid-column:1/-1;text-align:center;color:var(--muted);padding:60px;font-size:13px}

.card{
  background:var(--card-bg);
  backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:13px 13px 11px;
  transition:border-color .18s,transform .14s;
}
.card:hover{border-color:var(--bh)}
.card-empty{opacity:.35}

.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px}
.head-left{display:flex;align-items:center;gap:7px}
.pill{font-size:10px;font-weight:700;color:var(--muted);background:rgba(255,255,255,.07);border:1px solid var(--border);border-radius:20px;padding:2px 8px}
.cname{font-size:13px;font-weight:600;cursor:pointer;transition:opacity .14s}
.cname:hover{opacity:.65;text-decoration:underline;text-underline-offset:3px}
.cdate{font-size:10px;color:var(--muted)}

.slots{display:flex;gap:4px;margin-bottom:9px}
.cell{flex:1;aspect-ratio:1;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.07);border-radius:7px;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;overflow:hidden;transition:border-color .13s,background .13s,transform .1s}
.cell:not(.empty):hover{border-color:rgba(255,255,255,.32);background:rgba(255,255,255,.08);transform:scale(1.09);z-index:2}
.cell.empty{cursor:default}
.icon{width:74%;height:74%;object-fit:contain;image-rendering:pixelated}
.abbr{font-size:8px;font-weight:700;color:var(--muted);display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.cnt{position:absolute;bottom:2px;right:3px;font-size:8px;font-weight:700;color:#fff;text-shadow:1px 1px 0 #000;line-height:1}

.card-foot{display:flex;gap:6px;justify-content:flex-end;align-items:center}
.emtxt{font-size:11px;color:var(--muted);margin-right:auto}

.mov{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100}
.mbox{width:460px;max-width:95vw;padding:22px;max-height:85vh;overflow-y:auto}
.mtitle{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:600;margin-bottom:16px}
.micon{width:24px;height:24px;image-rendering:pixelated}
.mclose{margin-left:auto;background:none;border:none;color:var(--muted);font-size:15px;cursor:pointer;padding:2px 6px;border-radius:6px;transition:background .13s}
.mclose:hover{background:rgba(255,255,255,.08);color:var(--text)}
.mlabel{display:block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:5px}
.nbtarea{min-height:150px;font-family:'Courier New',monospace;font-size:11px;line-height:1.5}
.mfoot{display:flex;gap:8px;margin-top:14px}
.mfoot .bprimary{flex:1;margin:0;width:auto;padding:9px}
.merr{font-size:11px;color:#ff6b6b;min-height:14px;margin-top:5px}
.dim{color:var(--muted);font-size:9px;text-transform:none;letter-spacing:0}

.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(56px);background:rgba(12,12,22,.88);backdrop-filter:blur(18px);border:1px solid var(--border);border-radius:100px;padding:8px 20px;font-size:12px;color:var(--text);z-index:200;opacity:0;pointer-events:none;transition:transform .28s cubic-bezier(.34,1.56,.64,1),opacity .22s}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast.terr{border-color:rgba(255,70,70,.4);color:#ff7070}