:root{
  --bg:#0f1115; --bg2:#171a21; --card:#1b1f27; --ink:#e6e8ec; --muted:#9aa3b2;
  --line:#2a2f3a; --accent:#3b82f6; --accent-d:#2563eb;
  --ok:#22c55e; --warn:#f59e0b; --bad:#ef4444;
  --disp:#14532d; --disp-i:#86efac; --resv:#713f12; --resv-i:#fde68a;
  --blok:#7f1d1d; --blok-i:#fecaca;
  --radius:14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--ink);font-size:15px;line-height:1.45;
  -webkit-text-size-adjust:100%}
header{background:var(--bg2);border-bottom:1px solid var(--line);padding:14px 18px;
  font-weight:600;font-size:17px;display:flex;justify-content:space-between;align-items:center;
  position:sticky;top:0;z-index:10}
header .sub{font-size:12px;color:var(--muted);font-weight:400}
header .lk{color:var(--muted);font-size:13px;text-decoration:none;border:1px solid var(--line);
  padding:5px 10px;border-radius:8px;cursor:pointer;background:none}
.wrap{max-width:1200px;margin:0 auto;padding:16px;padding-bottom:88px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;margin-bottom:16px}
h2{font-size:16px;margin:0 0 12px}h3{font-size:13px;margin:0 0 8px;color:var(--muted)}
label{display:block;font-size:13px;color:var(--muted);margin:9px 0 3px}
input,select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;
  font-size:16px;background:#10131a;color:var(--ink)}
input:focus,select:focus{outline:2px solid var(--accent);border-color:var(--accent)}
.row{display:flex;gap:10px}.row>*{flex:1}
button{background:var(--accent);color:#fff;border:0;border-radius:10px;padding:12px 16px;
  font-size:15px;font-weight:600;cursor:pointer}
button:hover{background:var(--accent-d)}
button.ghost{background:transparent;color:var(--accent);border:1px solid var(--accent)}
button.mini{padding:6px 10px;font-size:13px}
button.danger{background:var(--bad)}
.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600}
.badge.disponible{background:var(--disp);color:var(--disp-i)}
.badge.reservada{background:var(--resv);color:var(--resv-i)}
.badge.bloqueada{background:var(--blok);color:var(--blok-i)}
.sobra{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}
.sobra:last-child{border-bottom:0}
.sobra .meas{font-weight:600}.sobra .meta{font-size:12px;color:var(--muted)}
.muted{color:var(--muted);font-size:13px}
.pill{font-size:11px;background:#1e293b;color:#93c5fd;padding:1px 7px;border-radius:6px;margin-left:6px}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:8px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:600;font-size:12px}
.grid2{display:grid;grid-template-columns:380px 1fr;gap:16px;align-items:start}
@media(max-width:900px){.grid2{grid-template-columns:1fr}}
.hide{display:none}
.refilado-box{border:1px dashed var(--line);border-radius:10px;padding:10px;margin-top:8px}
.toast{position:fixed;bottom:84px;left:50%;transform:translateX(-50%);background:#000;color:#fff;
  padding:11px 18px;border-radius:10px;opacity:0;transition:opacity .25s;z-index:50;border:1px solid var(--line)}
.toast.show{opacity:.97}
.plan-sobra{margin-bottom:18px}
.plan-sobra .cap{font-weight:600;margin-bottom:6px;font-size:14px}
.result-ok{color:var(--ok);font-weight:600}
.result-bad{background:var(--blok);color:var(--blok-i);padding:12px;border-radius:10px}
svg .panel{fill:#0c0f14;stroke:#3a4150;stroke-width:1.5}
svg .pieza{fill:#1e3a8a;stroke:#60a5fa;stroke-width:1}
svg .resto{fill:#11151c;stroke:#374151;stroke-width:1;stroke-dasharray:4 3}
svg text{fill:#e6e8ec}
/* Tabla de piezas compacta (que no se salga de la tarjeta) */
#piezas td{padding:6px 3px}
#piezas input{padding:7px 6px;font-size:14px}
#piezas input[type=checkbox]{width:18px;height:18px;margin:0}
.tabs,.bottomnav{display:flex;gap:8px}
.tabs{margin-bottom:14px}
.tabs button{background:transparent;color:var(--ink);border:1px solid var(--line)}
.tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent)}
/* Navegación inferior (móvil) */
.bottomnav{position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-top:1px solid var(--line);
  padding:8px;justify-content:space-around;z-index:20}
.bottomnav button{flex:1;background:transparent;color:var(--muted);border:0;font-size:13px;padding:8px}
.bottomnav button.active{color:var(--accent)}
/* Login */
.login-wrap{max-width:360px;margin:12vh auto;padding:16px}
.login-wrap h1{font-size:22px;text-align:center;margin-bottom:6px}
.login-wrap p{text-align:center;color:var(--muted);margin-top:0;font-size:13px}
.err{color:var(--bad);font-size:13px;min-height:18px;margin-top:8px;text-align:center}
