:root{--bg: #0f172a;--bg-elev: #111c34;--bg-card: #1a2541;--border: #28365a;--fg: #e2e8f0;--fg-dim: #94a3b8;--accent: #38bdf8;--accent-strong: #0ea5e9;--danger: #f87171;--ok: #34d399;--radius: 10px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji";font-size:14px;color:var(--fg);background:linear-gradient(180deg,#0b1226 0%,var(--bg) 100%);min-height:100%}button{font-family:inherit;font-size:14px;padding:8px 14px;border:1px solid var(--border);background:var(--accent-strong);color:#fff;border-radius:var(--radius);cursor:pointer;transition:filter .12s ease}button:hover:not(:disabled){filter:brightness(1.1)}button:disabled{opacity:.55;cursor:not-allowed}input[type=email],input[type=password],input[type=text]{width:100%;padding:9px 11px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-elev);color:var(--fg);font-size:14px}input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #38bdf82e}.page{min-height:100%;display:flex;flex-direction:column}.page-center{align-items:center;justify-content:center;padding:24px}.muted{color:var(--fg-dim)}.form-error{background:#f871711f;color:var(--danger);border:1px solid rgba(248,113,113,.4);border-radius:var(--radius);padding:8px 12px;margin:8px 0}.login-card{width:100%;max-width:360px;background:var(--bg-card);padding:28px;border-radius:14px;border:1px solid var(--border);box-shadow:0 10px 40px #00000059}.login-card h1{margin:0;font-size:20px}.login-subtitle{margin:4px 0 20px;color:var(--fg-dim)}.login-card form{display:flex;flex-direction:column;gap:12px}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--fg-dim)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-bottom:1px solid var(--border);background:#0f172ad9;-webkit-backdrop-filter:saturate(140%) blur(6px);backdrop-filter:saturate(140%) blur(6px)}.brand{font-weight:600;letter-spacing:.4px}.topbar-right{display:flex;align-items:center;gap:14px}.content{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:20px;padding:22px;max-width:1400px;width:100%;margin:0 auto}@media (max-width: 900px){.content{grid-template-columns:1fr}}.camera{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px}.camera-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.camera-header h2{margin:0;font-size:16px}.player{position:relative;background:#000;border-radius:10px;overflow:hidden}.player video{display:block;width:100%;aspect-ratio:16 / 9;background:#000}.player-status{padding:8px 12px;font-size:12px;color:var(--fg-dim);background:#00000080}.player-status-playing{color:var(--ok)}.player-status-failed,.player-status-disconnected,.player-error{color:var(--danger)}.player-placeholder{display:flex;align-items:center;justify-content:center;text-align:center;aspect-ratio:16 / 9;border:1px dashed var(--border);border-radius:10px;color:var(--fg-dim);padding:18px}.recordings{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px;align-self:start}.recordings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.recordings-header h2{margin:0;font-size:16px}.recordings-table{width:100%;border-collapse:collapse;font-size:13px}.recordings-table th,.recordings-table td{padding:8px 6px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}.recordings-table th{color:var(--fg-dim);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.recordings-table tr:last-child td{border-bottom:none}.recordings-table button{padding:4px 10px;font-size:12px;background:transparent;border:1px solid var(--border);color:var(--accent)}.device-control{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px;align-self:start}.device-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.device-header h2{margin:0;font-size:16px}.device-title{font-weight:600;margin-top:2px}.device-meta{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin:10px 0 6px}.device-pills{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid var(--border);font-size:12px}.pill-ok{color:var(--ok);border-color:#34d39966;background:#34d39914}.pill-bad{color:var(--danger);border-color:#f8717166;background:#f8717114}.device-details{display:grid;gap:6px;margin:10px 0 14px;font-size:12px}.device-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--accent)}.schedule-editor{border-top:1px solid var(--border);padding-top:14px}.schedule-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.schedule-header h3{margin:0;font-size:14px}.schedule-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.schedule-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px;margin:10px 0 12px}@media (max-width: 900px){.schedule-grid{grid-template-columns:1fr}}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12px;color:var(--fg-dim)}.rules{margin-top:8px}.rules-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.rules-list{display:grid;gap:8px}.rule{display:grid;grid-template-columns:90px 140px auto;gap:8px;align-items:center}.rule select{width:100%;padding:9px 11px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-elev);color:var(--fg);font-size:14px}.rule input[type=time]{width:100%}.schedule-note{margin:12px 0 0;font-size:12px}
