@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";:root{--bg: #0b1220;--surface: #111827;--surface2: #1e293b;--border: #334155;--text: #f1f5f9;--muted: #94a3b8;--accent: #38bdf8;--accent2: #818cf8;--success: #34d399;--danger: #f87171;--warning: #fbbf24;font-family:DM Sans,system-ui,-apple-system,sans-serif;line-height:1.45;color:var(--text);background:var(--bg)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit;color:inherit}.admin-root{display:grid;grid-template-columns:240px 1fr;min-height:100vh}@media(max-width:840px){.admin-root{grid-template-columns:1fr}.admin-sidebar{flex-direction:row;flex-wrap:wrap;align-items:center;gap:.75rem;padding:1rem!important}.admin-brand{width:100%}}.admin-sidebar{background:linear-gradient(180deg,#0f172a,#020617);border-right:1px solid var(--border);padding:1.25rem 1rem;display:flex;flex-direction:column;gap:.5rem}.admin-brand{font-weight:700;font-size:1.1rem;letter-spacing:.02em;margin-bottom:.75rem;color:var(--text)}.admin-brand span{display:block;font-weight:400;font-size:.75rem;color:var(--muted);margin-top:.15rem}.admin-nav{display:flex;flex-direction:column;gap:.25rem}.admin-nav a{padding:.55rem .75rem;border-radius:8px;color:var(--muted);text-decoration:none;font-weight:500;transition:background .15s,color .15s}.admin-nav a:hover{background:var(--surface2);color:var(--text);text-decoration:none}.admin-nav a.active{background:linear-gradient(90deg,rgba(56,189,248,.2),transparent);color:var(--accent);border:1px solid rgba(56,189,248,.35)}.admin-main{padding:1.5rem clamp(1rem,3vw,2.5rem);max-width:1200px;width:100%;margin:0 auto}.admin-page-title{margin:0 0 .35rem;font-size:1.65rem}.admin-lead{margin:0 0 1.5rem;color:var(--muted);max-width:52ch}.panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.35rem;margin-bottom:1.25rem}.panel h2{margin:0 0 1rem;font-size:1.05rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.form-grid{display:grid;gap:.85rem;max-width:420px}label.field{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:var(--muted)}label.field input,label.field textarea,label.field select{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:.55rem .65rem;color:var(--text)}label.field input:focus,label.field textarea:focus,label.field select:focus{outline:2px solid rgba(56,189,248,.45);border-color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1rem;border-radius:8px;border:1px solid transparent;cursor:pointer;font-weight:600;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#0f172a;transition:filter .15s,transform .1s}.btn:hover:not(:disabled){filter:brightness(1.08)}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface2);filter:none}.btn-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.webcam-wrap{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#000;max-width:520px;aspect-ratio:4 / 3}.webcam-wrap video{width:100%;height:100%;object-fit:cover;display:block}.badge{display:inline-block;padding:.2rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600}.badge.ok{background:#34d39933;color:var(--success)}.badge.warn{background:#fbbf2426;color:var(--warning)}.badge.err{background:#f8717126;color:var(--danger)}.room-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1rem}.room-card{border-radius:14px;padding:1.1rem;min-height:220px;display:flex;flex-direction:column;border:1px solid var(--border);transition:box-shadow .2s,transform .15s}.room-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000059}.room-card.empty{background:linear-gradient(160deg,#1e293b,#0f172a);border-style:dashed;opacity:.95}.room-card.occupied{background:linear-gradient(145deg,#38bdf81f,#818cf81a);border-color:#38bdf859}.room-num{font-size:2rem;font-weight:700;line-height:1;background:linear-gradient(90deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.room-status{margin-top:.35rem;font-size:.85rem;color:var(--muted)}.room-guest{margin-top:auto;display:flex;flex-direction:column;gap:.5rem}.room-guest-avatar{width:72px;height:72px;border-radius:12px;object-fit:cover;border:2px solid rgba(56,189,248,.4)}.room-guest-name{font-weight:600;font-size:1rem}.room-guest-meta{font-size:.8rem;color:var(--muted)}.events-list{list-style:none;padding:0;margin:0}.events-list li{padding:.75rem 0;border-bottom:1px solid var(--border)}.events-list li:last-child{border-bottom:none}.table-list{width:100%;border-collapse:collapse;font-size:.9rem}.table-list th,.table-list td{text-align:left;padding:.55rem .5rem;border-bottom:1px solid var(--border)}.table-list th{color:var(--muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.muted{color:var(--muted)}.flash-ok{color:var(--success)}.flash-err{color:var(--danger);white-space:pre-wrap;word-break:break-word;padding:.55rem .65rem;margin-bottom:.55rem;background:#f8717114;border:1px solid rgba(248,113,113,.35);border-radius:8px}.registration-shell{--rs-text: #1e293b;--rs-text-soft: #475569;--rs-muted: #64748b;--rs-surface: #ffffff;--rs-surface-inset: #f8fafc;--rs-line: rgba(15, 23, 42, .07);--rs-accent: #0d9488;--rs-accent-hover: #0f766e;--rs-accent-secondary: #0891b2;--rs-shadow: 0 2px 14px rgba(15, 23, 42, .06);--rs-shadow-sm: 0 1px 4px rgba(15, 23, 42, .05);--border: rgba(15, 23, 42, .1);color:var(--rs-text);background:linear-gradient(165deg,#f1f5f9,#e8eef4 48%,#e2e8f0);border-radius:16px;padding:clamp(1rem,2.5vw,1.5rem);margin:0 0 1rem;border:none;box-shadow:none}.registration-shell .admin-page-title{color:#0f172a;font-weight:700}.registration-shell .admin-lead{color:var(--rs-text-soft);max-width:62ch}.registration-shell .admin-lead strong{color:var(--rs-text)}.registration-shell .panel{background:var(--rs-surface);border:none;border-radius:14px;box-shadow:var(--rs-shadow)}.registration-shell .panel h2{color:var(--rs-muted)}.registration-shell label.field{color:var(--rs-text-soft);font-weight:500}.registration-shell label.field input,.registration-shell label.field textarea,.registration-shell label.field select{background:var(--rs-surface-inset);border:1px solid var(--rs-line);color:var(--rs-text);box-shadow:none}.registration-shell label.field input:focus,.registration-shell label.field textarea:focus,.registration-shell label.field select:focus{outline:none;border-color:#0d948873;box-shadow:0 0 0 3px #0d94882e}.registration-shell .webcam-wrap{border:none;box-shadow:var(--rs-shadow-sm)}.registration-shell .btn{background:linear-gradient(135deg,#14b8a6,#0d9488 45%,#0e7490);color:#f0fdfa;border:none;box-shadow:0 1px 2px #0f172a0f}.registration-shell .btn:hover:not(:disabled){filter:brightness(1.05)}.registration-shell .btn-ghost{background:#ffffffbf;color:var(--rs-text);border:1px solid var(--rs-line)}.registration-shell .btn-ghost:hover:not(:disabled){background:#f1f5f9;filter:none}.registration-shell .muted{color:var(--rs-muted)!important}.registration-shell .flash-ok{color:#047857;background:#10b9811a;padding:.5rem .65rem;border-radius:8px;border:none}.registration-shell .flash-err{color:#b91c1c;background:#ef444414;border:none;border-left:3px solid #dc2626;border-radius:8px}.registration-shell .room-card{border:none;box-shadow:var(--rs-shadow-sm)}.registration-shell .room-card.empty{background:linear-gradient(160deg,#f8fafc,#f1f5f9);opacity:1;border:1px dashed var(--rs-line);box-shadow:none}.registration-shell .room-card.occupied{background:linear-gradient(145deg,#0d94881a,#0891b214);border:none}.registration-shell .room-card:hover{box-shadow:var(--rs-shadow)}.registration-shell .room-num{background:linear-gradient(90deg,#0d9488,#0891b2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.registration-shell .table-list th,.registration-shell .table-list td{border-bottom:1px solid var(--rs-line)}.registration-shell .badge.ok{background:#10b98126;color:#047857}.registration-shell .badge.warn{background:#f59e0b1f;color:#b45309}
