:root{--bg: #0f172a;--card: #1e293b;--card2: #273449;--line: #334155;--text: #e2e8f0;--muted: #94a3b8;--accent: #38bdf8;--accent-d: #0ea5e9;--green: #22c55e;--green-bg: #14321f;--red: #ef4444;--red-bg: #3a1717;--male: #60a5fa;--female: #f472b6}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:-apple-system,system-ui,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{max-width:720px;margin:0 auto;padding:0 14px 90px}.topbar{position:sticky;top:0;z-index:10;background:var(--bg);padding:14px 0 8px}.topbar h1{margin:0;font-size:20px;display:flex;align-items:center;gap:8px}.topbar .sub{color:var(--muted);font-size:13px}.event-pick{display:flex;gap:8px;align-items:center;margin-top:10px}.event-pick select{flex:1}.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:20;display:flex;background:var(--card);border-top:1px solid var(--line)}.tabbar button{flex:1;background:none;border:none;color:var(--muted);padding:10px 4px 14px;font-size:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px}.tabbar button .ic{font-size:20px}.tabbar button.active{color:var(--accent)}.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:12px}.card h2{margin:0 0 10px;font-size:16px}.section-title{font-size:14px;color:var(--muted);margin:18px 0 8px;text-transform:uppercase;letter-spacing:.5px}label{display:block;font-size:13px;color:var(--muted);margin:10px 0 4px}input,select{width:100%;padding:11px 12px;font-size:16px;background:var(--card2);border:1px solid var(--line);border-radius:9px;color:var(--text)}input:focus,select:focus{outline:none;border-color:var(--accent)}.row{display:flex;gap:10px}.row>*{flex:1}button.btn{width:100%;padding:12px;font-size:15px;font-weight:600;cursor:pointer;background:var(--accent-d);border:none;border-radius:9px;color:#04212e;margin-top:14px}button.btn:disabled{opacity:.5;cursor:not-allowed}button.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--text)}button.btn.danger{background:transparent;border:1px solid var(--red);color:#fca5a5}button.mini{font-size:12px;padding:6px 10px;border-radius:7px;border:1px solid var(--line);background:var(--card2);color:var(--text);cursor:pointer}button.mini.danger{color:#fca5a5;border-color:var(--red)}.badge{display:inline-block;font-size:12px;padding:2px 9px;border-radius:999px;font-weight:600}.badge.male{background:#60a5fa2e;color:var(--male)}.badge.female{background:#f472b62e;color:var(--female)}.room-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}.room-row:last-child{border-bottom:none}.room-row .name{font-weight:600;flex:1}.vac{font-size:13px;font-weight:700;padding:4px 10px;border-radius:8px;white-space:nowrap}.vac.free{background:var(--green-bg);color:#86efac}.vac.full{background:var(--red-bg);color:#fca5a5}.vac.some{background:#2b2a10;color:#fde68a}.list-clickable{cursor:pointer}.list-clickable:active{opacity:.7}.msg{padding:10px 12px;border-radius:9px;font-size:14px;margin:10px 0}.msg.err{background:var(--red-bg);color:#fca5a5}.msg.ok{background:var(--green-bg);color:#86efac}.msg.warn{background:#2b2a10;color:#fde68a}.muted{color:var(--muted);font-size:13px}.empty{text-align:center;color:var(--muted);padding:30px 10px}.login-wrap{max-width:360px;margin:60px auto 0;padding:0 16px}.login-wrap .brand{text-align:center;font-size:28px;font-weight:800;margin-bottom:4px}.login-wrap .brand .dot{color:var(--accent)}.login-wrap .tag{text-align:center;color:var(--muted);margin-bottom:24px;font-size:14px}.alloc-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--line);font-size:14px}.alloc-item .lbl{flex:1}.alloc-item .cnt{color:var(--muted);font-size:12px}.seg{display:flex;gap:6px;margin:4px 0 12px}.seg button{flex:1;padding:9px;border-radius:8px;border:1px solid var(--line);background:var(--card2);color:var(--muted);font-size:13px;cursor:pointer}.seg button.active{background:var(--accent-d);color:#04212e;border-color:var(--accent-d);font-weight:600}.sugg{border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:8px;cursor:pointer;background:var(--card2)}.sugg.sel{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}.sugg.alt{padding:10px 12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:50;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;max-width:480px;width:100%;max-height:90vh;overflow:auto}.modal h2{margin:0 0 6px;font-size:16px}
