html,body,#root{min-height:100%}:root{--bg-1: #f3f5f8;--bg-2: #dfe7ef;--ink-strong: #102033;--ink-soft: #44576d;--card: #ffffff;--line: #d3dde8;--success: #0f9d58;--danger: #c4362d;--accent: #145ea8;--accent-2: #1f8a70}*{box-sizing:border-box}body{margin:0;font-family:Space Grotesk,Avenir Next,Segoe UI,sans-serif;color:var(--ink-strong);background:radial-gradient(circle at top left,var(--bg-2),var(--bg-1) 55%);min-height:100vh}.loading-screen,.login-shell,.app-shell{min-height:100vh}.loading-screen{display:grid;place-items:center}.login-shell{display:grid;place-items:center;padding:2rem}.login-card{width:min(460px,100%);background:var(--card);border:1px solid var(--line);border-radius:18px;padding:1.6rem;box-shadow:0 14px 36px #0920371f}.login-card h1{margin:0 0 .4rem}.subtitle{margin:0 0 1rem;color:var(--ink-soft)}.login-form{display:grid;gap:.9rem}label{display:grid;gap:.4rem;font-size:.95rem;color:var(--ink-soft)}input,select,button{font:inherit}input,select{width:100%;border:1px solid var(--line);border-radius:10px;padding:.6rem .7rem;background:#fff}button{border:0;border-radius:10px;padding:.58rem .9rem;cursor:pointer;background:linear-gradient(110deg,var(--accent),var(--accent-2));color:#fff;font-weight:600}button:disabled{opacity:.6;cursor:not-allowed}button.off,button.danger{background:var(--danger)}.error{margin:0;color:var(--danger);font-size:.9rem}.app-shell{padding:1rem}.topbar{background:#ffffffeb;border:1px solid var(--line);border-radius:16px;padding:1rem;display:flex;justify-content:space-between;gap:1rem;align-items:center}.topbar h1{margin:0;font-size:1.3rem}.topbar p{margin:.2rem 0 0;color:var(--ink-soft)}.global-error{margin:.9rem 0}.device-grid{margin-top:1rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.9rem}.device-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:.95rem}.device-card header{display:flex;justify-content:space-between;align-items:center;gap:.6rem}.device-card h3{margin:0}.badge{font-size:.75rem;padding:.25rem .5rem;border-radius:999px;font-weight:700}.badge.online{background:#0f9d5829;color:var(--success)}.badge.offline{background:#c4362d1f;color:var(--danger)}.device-location,.last-update,.power-state,.small{margin:.45rem 0;color:var(--ink-soft)}.controls{margin-top:.7rem;display:flex;gap:.5rem}.schedule-shell{margin-top:1rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.8rem}.schedule-shell>div{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:.95rem}.schedule-shell h3{margin-top:0}.schedule-form{display:grid;gap:.6rem}.schedule-edit-form{display:grid;gap:.45rem}.schedule-list ul,.schedule-runs ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}.schedule-list li,.schedule-runs li{border:1px solid var(--line);border-radius:10px;padding:.55rem}.schedule-list li.selected{border-color:var(--accent);box-shadow:inset 0 0 0 1px #145ea859}.schedule-actions{margin-top:.4rem;display:flex;gap:.4rem;flex-wrap:wrap}@media(max-width:720px){.topbar{flex-direction:column;align-items:flex-start}.controls{flex-direction:column}}
