*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f5f7fa;--surface:#fff;--card:#fff;--card-hover:#f8fafc;--card-active:#eef4ff;--border:#0d1b2a14;--border-md:#0d1b2a1f;--border-glow:#38b6ff66;--primary:#38b6ff;--primary-dim:#38b6ff1a;--primary-glow:#38b6ff38;--accent:#0d1b2a;--on:#22c55e;--on-dim:#22c55e1a;--off:#d1d5db;--text:#0d1b2a;--text-dim:#415a77;--text-muted:#8592a3;--danger:#ef4444;--danger-dim:#ef44441a;--warning:#f59e0b;--warning-dim:#f59e0b1a;--radius-xs:6px;--radius-sm:10px;--radius:14px;--radius-lg:20px;--radius-xl:28px;--shadow-sm:0 1px 6px #0d1b2a0f;--shadow:0 4px 24px #0d1b2a14;--shadow-lg:0 16px 48px #0d1b2a1f;--shadow-glow:0 0 24px #38b6ff26;--transition:.2s cubic-bezier(.4,0,.2,1);--spring:.35s cubic-bezier(.34,1.56,.64,1);--font:"Inter", system-ui, -apple-system, sans-serif;--sidebar-w:240px;--header-h:64px}html{font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer;border:none;outline:none}input,select,textarea{font-family:var(--font)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0d1b2a1f;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#0d1b2a38}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition)}.card:hover{background:var(--card-hover);border-color:var(--border-md)}.glass{-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);background:#ffffffa6}.btn{border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer;letter-spacing:.01em;align-items:center;gap:7px;padding:9px 18px;font-size:13.5px;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary);color:#000}.btn-primary:hover{box-shadow:0 6px 24px var(--primary-glow);background:#5ac8ff;transform:translateY(-1px)}.btn-ghost{color:var(--text-dim);border:1px solid var(--border-md);background:#0d1b2a0a}.btn-ghost:hover{color:var(--text);background:#0d1b2a14;border-color:#0d1b2a2e}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid #ff453a33}.btn-danger:hover{background:var(--danger);color:#fff;box-shadow:0 4px 16px #ff453a4d}.btn-icon{border-radius:var(--radius-sm);justify-content:center;width:36px;height:36px;padding:0}.badge{letter-spacing:.03em;border-radius:99px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.badge-on{background:var(--on-dim);color:var(--on)}.badge-off{color:var(--text-muted);background:#0d1b2a0d}.badge-online{background:var(--on-dim);color:var(--on)}.badge-offline{background:var(--danger-dim);color:var(--danger)}.badge-warning{background:var(--warning-dim);color:var(--warning)}.badge-primary{background:var(--primary-dim);color:var(--primary)}.spinner{border:2.5px solid #0d1b2a14;border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.input{background:var(--surface);border:1px solid var(--border-md);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:var(--transition);padding:10px 14px;font-size:14px}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim);background:var(--surface);outline:none}.input::placeholder{color:var(--text-muted)}.select{background:var(--surface);border:1px solid var(--border-md);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:var(--transition);appearance:none;cursor:pointer;padding:10px 14px;font-size:14px}.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim);outline:none}.select option{background:var(--surface);color:var(--text)}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:1000;background:#000000bf;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-box{background:var(--card);border:1px solid var(--border-md);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-lg);padding:28px;animation:.25s cubic-bezier(.4,0,.2,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{font-size:17px;font-weight:700}.modal-close{border-radius:var(--radius-xs);border:1px solid var(--border);width:30px;height:30px;color:var(--text-dim);cursor:pointer;transition:var(--transition);background:#0d1b2a0a;justify-content:center;align-items:center;font-size:16px;display:flex}.modal-close:hover{background:var(--danger-dim);color:var(--danger);border-color:#ff453a40}.toggle{cursor:pointer;flex-shrink:0;width:52px;height:28px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--off);border-radius:99px;transition:background .22s;position:absolute;inset:0}.toggle input:checked~.toggle-track{background:var(--on);box-shadow:0 0 10px #22c55e40}.toggle-thumb{background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .22s cubic-bezier(.4,0,.2,1);position:absolute;top:3px;left:3px;box-shadow:0 2px 8px #00000080}.toggle input:checked~.toggle-track~.toggle-thumb,.toggle input:checked+.toggle-track+.toggle-thumb{transform:translate(24px)}.toggle-sm{width:42px!important;height:24px!important}.toggle-sm .toggle-thumb{width:18px!important;height:18px!important}.toggle-sm input:checked~.toggle-track~.toggle-thumb,.toggle-sm input:checked+.toggle-track+.toggle-thumb{transform:translate(18px)!important}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);border-right:1px solid var(--border);z-index:100;transition:transform var(--transition);background:#fff;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:2px 0 12px #0d1b2a0d}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px 18px 18px;display:flex}.sidebar-logo img{object-fit:contain;flex-shrink:0;width:38px;height:38px}.sidebar-logo-text{letter-spacing:-.03em;white-space:nowrap;font-size:19px;font-weight:800;line-height:1.1}.sidebar-logo-sub{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;margin-top:2px;font-size:9.5px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:14px 10px;display:flex;overflow-y:auto}.nav-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:12px 10px 6px;font-size:10px;font-weight:700}.nav-item{border-radius:var(--radius-sm);color:var(--text-dim);transition:var(--transition);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13.5px;font-weight:500;display:flex}.nav-item:hover{color:var(--text);background:#38b6ff0f}.nav-item.active{background:var(--primary-dim);color:var(--primary);border-color:#38b6ff2e;font-weight:600}.nav-item .nav-icon{text-align:center;flex-shrink:0;width:22px;font-size:17px}.nav-item .nav-badge{background:var(--primary-dim);color:var(--primary);border-radius:99px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.sidebar-divider{background:var(--border);height:1px;margin:8px 10px}.sidebar-footer{border-top:1px solid var(--border);padding:12px 10px}.user-chip{border-radius:var(--radius-sm);border:1px solid var(--border);transition:var(--transition);background:#0d1b2a08;align-items:center;gap:10px;padding:10px 12px;display:flex}.user-chip:hover{background:#0d1b2a0f}.user-avatar{background:linear-gradient(135deg, var(--primary), #5856d6);color:#fff;letter-spacing:.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-email{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11px;overflow:hidden}.logout-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-xs);transition:var(--transition);background:0 0;border:none;padding:4px 6px;font-size:15px;line-height:1}.logout-btn:hover{color:var(--danger);background:var(--danger-dim)}.main-content{margin-left:var(--sidebar-w);max-width:calc(100vw - var(--sidebar-w));flex:1;min-height:100vh;padding:32px 36px 48px}.page-header{margin-bottom:28px}.page-title{letter-spacing:-.025em;color:var(--text);font-size:24px;font-weight:800}.page-subtitle{color:var(--text-dim);margin-top:4px;font-size:13.5px}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-lg);transform:translate(0)}.main-content{max-width:100vw;margin-left:0;padding:20px 16px 90px}.mobile-nav{display:flex!important}.rooms-grid{grid-template-columns:1fr}}.mobile-nav{border-top:1px solid var(--border);z-index:200;background:#fff;justify-content:space-around;align-items:center;height:68px;padding:0 4px;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #0d1b2a0f}.mobile-nav-item{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:var(--transition);letter-spacing:.04em;text-transform:uppercase;background:0 0;border:none;flex-direction:column;align-items:center;gap:3px;padding:8px 20px;font-size:10px;font-weight:600;display:flex}.mobile-nav-item .icon{font-size:21px}.mobile-nav-item.active{color:var(--primary)}.mobile-nav-item.active .icon{filter:drop-shadow(0 0 6px var(--primary-glow))}.mobile-hamburger{z-index:201;background:var(--card);border:1px solid var(--border-md);border-radius:var(--radius-sm);cursor:pointer;width:40px;height:40px;color:var(--text);box-shadow:var(--shadow-sm);transition:var(--transition);justify-content:center;align-items:center;font-size:18px;display:none;position:fixed;top:16px;left:16px}.mobile-hamburger:hover{background:var(--card-hover)}@media (width<=768px){.mobile-hamburger{display:flex}}.stats-row{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-bottom:28px;display:grid}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);padding:18px 20px}.stat-card:hover{border-color:var(--border-md);transform:translateY(-2px)}.stat-value{letter-spacing:-.04em;font-size:30px;font-weight:800;line-height:1}.stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-top:6px;font-size:11.5px;font-weight:600}.stat-on .stat-value{color:var(--on)}.stat-off .stat-value{color:var(--text-muted)}.stat-primary .stat-value{color:var(--primary)}.welcome-banner{border-radius:var(--radius-lg);background:linear-gradient(135deg,#38b6ff17 0%,#0d1b2a0a 100%);border:1px solid #38b6ff33;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;padding:20px 24px;display:flex}.welcome-title{color:var(--text);font-size:18px;font-weight:700}.welcome-sub{color:var(--text-dim);margin-top:3px;font-size:13px}.all-off-btn{border-radius:var(--radius-sm);color:var(--danger);cursor:pointer;transition:var(--transition);white-space:nowrap;background:#ff453a1a;border:1px solid #ff453a33;flex-shrink:0;align-items:center;gap:8px;padding:9px 16px;font-size:13px;font-weight:600;display:flex}.all-off-btn:hover{background:var(--danger);color:#fff;box-shadow:0 4px 20px #ff453a4d}.room-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition);overflow:hidden}.room-section:hover{border-color:var(--border-md)}.room-section-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition);justify-content:space-between;align-items:center;padding:15px 20px;display:flex}.room-section-header:hover{background:#0d1b2a05}.room-section-header:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.unlinked-header{cursor:default;border-radius:var(--radius-lg);border:1px dashed var(--border-md);background:#0d1b2a05;margin-bottom:8px;padding:14px 20px}.unlinked-header:hover{background:#0d1b2a0a}.room-icon-bubble{background:var(--primary-dim);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:19px;display:flex}.room-section-name{color:var(--text);font-size:14.5px;font-weight:700}.room-section-sub{color:var(--text-dim);margin-top:2px;font-size:11.5px}.room-chevron{color:var(--text-muted);font-size:20px;line-height:1;transition:transform .2s cubic-bezier(.4,0,.2,1);display:inline-block}.devices-list{flex-direction:column;display:flex}.devices-list>.device-card:not(:last-child){border-bottom:1px solid var(--border);border-radius:0}.devices-list>.device-card:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:none}.devices-list>.device-card:only-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}.device-card{transition:background var(--transition);background:0 0;border:none;padding:0}.device-card:hover{background:#38b6ff08}.device-card-offline{opacity:.55}.device-card-header{align-items:center;gap:12px;padding:13px 20px;display:flex}.device-card-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.device-card-sub{color:var(--text-dim);margin-top:2px;font-size:11.5px}.device-status-dot,.relay-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:background .25s,box-shadow .25s}.dot-on{background:var(--on);box-shadow:0 0 7px #30d158a6}.dot-off{background:var(--off)}.dot-offline{background:var(--danger)}.device-chevron-btn{border:1px solid var(--border);border-radius:var(--radius-xs);cursor:pointer;width:26px;height:26px;transition:var(--transition);color:var(--text-muted);background:#0d1b2a08;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.device-chevron-btn:hover{color:var(--text);border-color:var(--border-md);background:#0d1b2a0f}.device-chevron{font-size:16px;line-height:1;transition:transform .2s cubic-bezier(.4,0,.2,1);display:inline-block}.relay-list{border-top:1px solid var(--border);background:#f8fafc;flex-direction:column;animation:.18s cubic-bezier(.4,0,.2,1) relaySlide;display:flex}@keyframes relaySlide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.relay-row{border-bottom:1px solid var(--border);transition:background var(--transition);align-items:center;gap:11px;padding:10px 20px 10px 46px;display:flex}.relay-row:last-child{border-bottom:none}.relay-row:hover{background:#38b6ff0a}.relay-label{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;font-weight:500;overflow:hidden}.bottom-sheet-overlay{-webkit-backdrop-filter:blur(6px);z-index:500;background:#000000a6;align-items:flex-end;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.bottom-sheet{border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-top:1px solid var(--border-md);background:#fff;flex-direction:column;width:100%;max-height:78vh;animation:.26s cubic-bezier(.32,.72,0,1) sheetUp;display:flex;overflow:hidden;box-shadow:0 -12px 48px #0d1b2a26}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{background:var(--border-md);border-radius:99px;flex-shrink:0;width:38px;height:4px;margin:12px auto 2px}.sheet-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px 14px;display:flex}.sheet-title{font-size:15px;font-weight:700}.sheet-sub{color:var(--text-dim);margin-top:2px;font-size:12px}.sheet-relays{flex:1;padding-bottom:28px;overflow-y:auto}.sheet-relays .relay-row{padding-left:20px;padding-right:20px}.schedule-list{flex-direction:column;gap:10px;display:flex}.schedule-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);align-items:center;gap:16px;padding:16px 20px;display:flex}.schedule-card:hover{border-color:var(--border-md);background:var(--card-hover)}.schedule-time{letter-spacing:-.03em;min-width:76px;font-size:24px;font-weight:800}.schedule-info{flex:1;min-width:0}.schedule-device{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.schedule-days{flex-wrap:wrap;gap:4px;margin-top:5px;display:flex}.schedule-day-pill{color:var(--text-muted);border:1px solid var(--border);background:#0d1b2a0a;border-radius:99px;padding:2px 7px;font-size:10px;font-weight:700}.form-group{margin-bottom:16px}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px;font-size:11px;font-weight:700;display:block}.icon-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px;display:grid}.icon-option{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;transition:var(--transition);color:var(--text-muted);text-align:center;background:#0d1b2a05;flex-direction:column;align-items:center;gap:4px;padding:9px 6px;font-size:10.5px;display:flex}.icon-option .emoji{font-size:20px}.icon-option.selected{background:var(--primary-dim);color:var(--primary);border-color:#38b6ff59}.icon-option:hover{border-color:var(--border-md);color:var(--text-dim);background:#0d1b2a0f}.tab-bar{border-radius:var(--radius-sm);background:#0d1b2a0a;gap:4px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.tab-btn{cursor:pointer;color:var(--text-dim);border-radius:var(--radius-xs);transition:var(--transition);font-size:13.5px;font-weight:600;font-family:var(--font);background:0 0;border:none;padding:8px 18px}.tab-btn.active{background:var(--card);color:var(--text);box-shadow:var(--shadow-sm)}.tab-btn:hover:not(.active){color:var(--text)}.day-selector{flex-wrap:wrap;gap:6px;display:flex}.day-btn{border:1px solid var(--border-md);width:36px;height:36px;color:var(--text-dim);cursor:pointer;transition:var(--transition);font-size:11px;font-weight:700;font-family:var(--font);background:#0d1b2a08;border-radius:50%;justify-content:center;align-items:center;display:flex}.day-btn.selected{background:var(--primary-dim);color:var(--primary);border-color:#38b6ff66}.day-btn:hover:not(.selected){color:var(--text);background:#0d1b2a0f}.action-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;display:flex}.action-bar-title{flex:1;font-size:19px;font-weight:700}.divider{background:var(--border);height:1px;margin:16px 0}.fab{background:var(--primary);color:#000;width:54px;height:54px;box-shadow:0 8px 28px var(--primary-glow);cursor:pointer;transition:var(--spring);z-index:50;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:24px;font-weight:700;display:flex;position:fixed;bottom:88px;right:24px}.fab:hover{box-shadow:0 12px 36px var(--primary-glow);transform:scale(1.1)rotate(12deg)}@media (width>=769px){.fab{bottom:28px}}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:64px 24px;display:flex}.empty-icon{opacity:.35;font-size:44px}.empty-title{color:var(--text-dim);font-size:17px;font-weight:700}.empty-subtitle{color:var(--text-muted);max-width:260px;font-size:13.5px;line-height:1.5}.rooms-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;display:grid}.device-name-input{color:var(--text);border-radius:var(--radius-xs);width:100%;box-shadow:none;transition:var(--transition);background:0 0;border:1px solid #0000;outline:none;margin-left:-8px;padding:4px 8px;font-size:14.5px;font-weight:700}.device-name-input:hover{border-color:var(--border);background:#0d1b2a0a}.device-name-input:focus{background:var(--surface);border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}
