:root{--bg:#0f1419;--surface:#1a2129;--surface-2:#232c36;--border:#2c3742;--text:#e6edf3;--muted:#8b98a5;--accent:#4c8bf5;--accent-d:#3a6fd0;--green:#2ea043;--amber:#d29922;--red:#f85149;--blue:#4c8bf5;--purple:#a371f7;--gray:#6e7681;--radius:14px;--shadow:0 2px 10px #0000004d;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}.app{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;gap:4px;width:220px;height:100vh;padding:18px 12px;display:flex;position:sticky;top:0}.brand{letter-spacing:-.5px;padding:8px 12px 18px;font-size:22px;font-weight:800}.brand span{color:var(--accent)}.nav-link{color:var(--muted);border-radius:10px;align-items:center;gap:10px;padding:13px 14px;font-size:15px;font-weight:600;display:flex}.nav-link.active{background:var(--surface-2);color:var(--text)}.nav-link:hover{color:var(--text)}.nav-spacer{flex:1}.who{color:var(--muted);border-top:1px solid var(--border);padding:10px 14px;font-size:13px}.who b{color:var(--text);font-size:15px;display:block}.main{flex:1;max-width:1400px;padding:28px 34px}.page-title{margin:0 0 4px;font-size:28px;font-weight:800}.page-sub{color:var(--muted);margin:0 0 24px}.grid{gap:16px;display:grid}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}.rooms-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.stat .n{font-size:38px;font-weight:800;line-height:1}.stat .l{color:var(--muted);margin-top:8px;font-size:14px;font-weight:600}.room{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;flex-direction:column;gap:8px;min-height:120px;padding:16px;transition:transform 80ms;display:flex}.room:hover{transform:translateY(-2px)}.room .num{font-size:26px;font-weight:800}.room .meta{color:var(--muted);font-size:13px}.room .bar{border-radius:4px;height:6px;margin-top:auto}.badge{text-transform:uppercase;letter-spacing:.3px;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-block}.b-ready{color:#56d364;background:#2ea0432e}.b-dirty{color:#e3b341;background:#d299222e}.b-cleaning{color:#79b8ff;background:#4c8bf52e}.b-inspection{color:#c297ff;background:#a371f72e}.b-blocked{color:#ff7b72;background:#f851492e}.b-occupied,.b-gray{color:#adbac7;background:#6e768133}.btn{border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:10px;padding:10px 16px;font-size:14px;font-weight:600}.btn:hover{border-color:var(--accent)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-d)}.btn-sm{padding:7px 12px;font-size:13px}.btn-row{flex-wrap:wrap;gap:8px;display:flex}.row{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:14px;margin-bottom:10px;padding:14px 16px;display:flex}.row .grow{flex:1;min-width:0}.row .title{font-size:16px;font-weight:700}.row .sub{color:var(--muted);margin-top:2px;font-size:13px}.attn{background:#f8514914;border-color:#f851494d}input,select{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:10px;width:100%;padding:11px 13px;font-family:inherit;font-size:15px}label{color:var(--muted);margin:12px 0 5px;font-size:13px;font-weight:600;display:block}.overlay{z-index:50;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:460px;max-width:92vw;max-height:88vh;padding:24px;overflow:auto}.modal h3{margin:0 0 16px;font-size:20px}.check{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 0;display:flex}.check input{width:22px;height:22px}.check.done span{color:var(--muted);text-decoration:line-through}.login{flex-direction:column;justify-content:center;align-items:center;gap:22px;min-height:100vh;display:flex}.pinpad{grid-template-columns:repeat(3,86px);gap:14px;display:grid}.pinpad button{background:var(--surface);border:1px solid var(--border);height:86px;color:var(--text);border-radius:50%;font-size:28px;font-weight:700}.pinpad button:hover{border-color:var(--accent)}.pindots{gap:14px;height:22px;display:flex}.pindot{border:2px solid var(--muted);border-radius:50%;width:18px;height:18px}.pindot.on{background:var(--accent);border-color:var(--accent)}.hint{color:var(--muted);text-align:center;font-size:14px}.err{color:var(--red);font-weight:600}.toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.muted{color:var(--muted)}.pill{background:var(--surface-2);color:var(--muted);border-radius:20px;padding:3px 9px;font-size:12px;font-weight:700}.empty{color:var(--muted);text-align:center;padding:50px}
