*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f8f6f2;--surface:#fff;--card:#fff;--card-hover:#faf8f5;--border:#0d1b2a14;--border-glow:#38b6ff59;--primary:#38b6ff;--primary-dim:#38b6ff1f;--accent:#0d1b2a;--accent-dim:#0d1b2a14;--on:#22c55e;--on-dim:#22c55e1f;--off:#e0e0e0;--text:#0d1b2a;--text-dim:#415a77;--text-muted:#8592a3;--danger:#ff4757;--danger-dim:#ff47571f;--radius-sm:8px;--radius:14px;--radius-lg:20px;--radius-xl:28px;--shadow-sm:0 2px 8px #0d1b2a0a;--shadow:0 12px 40px #0d1b2a14;--shadow-glow:0 0 24px #38b6ff26;--transition:.2s cubic-bezier(.4,0,.2,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:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition)}.card:hover{background:var(--card-hover);border-color:#ffffff1a}.glass{-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);background:#ffffffb3}.btn{border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:#5ac8ff;transform:translateY(-1px);box-shadow:0 4px 20px #38b6ff4d}.btn-ghost{color:var(--text-dim);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--card);color:var(--text);border-color:#ffffff1f}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid #ff4d6d33}.btn-danger:hover{background:var(--danger);color:#fff}.badge{letter-spacing:.03em;border-radius:99px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-on{background:var(--on-dim);color:var(--on)}.badge-off{background:var(--off);color:var(--text-muted)}.badge-online{background:var(--on-dim);color:var(--on)}.badge-offline{background:var(--danger-dim);color:var(--danger)}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.input{background:var(--surface);border:1px solid var(--border);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);outline:none}.input::placeholder{color:var(--text-muted)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#000000b3;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);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow);padding:28px;animation:.25s cubic-bezier(.4,0,.2,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)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:18px;font-weight:700}.modal-close{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);width:32px;height:32px;color:var(--text-dim);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;font-size:18px;display:flex}.modal-close:hover{background:var(--danger-dim);color:var(--danger)}.toggle{cursor:pointer;flex-shrink:0;width:52px;height:28px;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--off);border:1px solid #ffffff0d;border-radius:99px;transition:background .25s;position:absolute;inset:0}.toggle input:checked~.toggle-track{background:var(--on)}.toggle-thumb{background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .25s cubic-bezier(.4,0,.2,1);position:absolute;top:3px;left:3px;box-shadow:0 2px 6px #0006}.toggle input:checked~.toggle-track~.toggle-thumb,.toggle input:checked+.toggle-track+.toggle-thumb{transform:translate(24px)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:100;transition:transform var(--transition);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px 20px 16px;display:flex}.sidebar-logo-mark{background:linear-gradient(135deg, var(--primary), var(--accent));border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex;box-shadow:0 4px 12px #38b6ff4d}.sidebar-logo-text{letter-spacing:-.02em;font-size:16px;font-weight:800}.sidebar-logo-sub{color:var(--text-dim);letter-spacing:.05em;text-transform:uppercase;font-size:10px;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex;overflow-y:auto}.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:10px 12px;font-size:14px;font-weight:500;display:flex}.nav-item:hover{background:var(--card);color:var(--text)}.nav-item.active{background:var(--primary-dim);color:var(--primary);border-color:#38b6ff33}.nav-item .nav-icon{text-align:center;width:20px;font-size:18px}.sidebar-footer{border-top:1px solid var(--border);padding:12px}.user-chip{border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--border);align-items:center;gap:10px;padding:10px 12px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;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;font-size:11px;overflow:hidden}.logout-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:6px;padding:4px;font-size:16px}.logout-btn:hover{color:var(--danger)}.main-content{margin-left:var(--sidebar-w);max-width:calc(100vw - var(--sidebar-w));flex:1;padding:32px}.page-header{margin-bottom:28px}.page-title{letter-spacing:-.02em;font-size:26px;font-weight:800}.page-subtitle{color:var(--text-dim);margin-top:4px;font-size:14px}.rooms-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{max-width:100vw;margin-left:0;padding:20px 16px 80px}.mobile-nav{display:flex!important}.rooms-grid{grid-template-columns:1fr}}.mobile-nav{background:var(--surface);border-top:1px solid var(--border);z-index:200;justify-content:space-around;align-items:center;height:64px;padding:0 8px;display:none;position:fixed;bottom:0;left:0;right:0}.mobile-nav-item{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:var(--transition);letter-spacing:.03em;text-transform:uppercase;background:0 0;border:none;flex-direction:column;align-items:center;gap:3px;padding:8px 16px;font-size:10px;font-weight:600;display:flex}.mobile-nav-item .icon{font-size:22px}.mobile-nav-item.active{color:var(--primary)}.mobile-hamburger{z-index:201;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:40px;height:40px;color:var(--text);justify-content:center;align-items:center;font-size:20px;display:none;position:fixed;top:16px;left:16px}@media (width<=768px){.mobile-hamburger{display:flex}}.day-selector{flex-wrap:wrap;gap:6px;display:flex}.day-btn{background:var(--surface);border:1px solid var(--border);width:36px;height:36px;color:var(--text-dim);cursor:pointer;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.day-btn.selected{background:var(--primary-dim);color:var(--primary);border-color:#38b6ff66}.form-group{margin-bottom:16px}.form-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.icon-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.icon-option{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:var(--transition);color:var(--text-dim);text-align:center;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;font-size:11px;display:flex}.icon-option .emoji{font-size:22px}.icon-option.selected{background:var(--primary-dim);color:var(--primary);border-color:#38b6ff66}.icon-option:hover{background:var(--card);border-color:#ffffff26}.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:#ffffff1a}.schedule-time{letter-spacing:-.02em;min-width:80px;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:4px;display:flex}.schedule-day-pill{background:var(--surface);color:var(--text-dim);border:1px solid var(--border);border-radius:99px;padding:2px 7px;font-size:10px;font-weight:700}.fab{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;cursor:pointer;width:56px;height:56px;transition:var(--transition);z-index:50;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:26px;display:flex;position:fixed;bottom:88px;right:24px;box-shadow:0 8px 24px #38b6ff59}.fab:hover{transform:scale(1.08)rotate(15deg);box-shadow:0 12px 32px #38b6ff73}@media (width>=769px){.fab{bottom:24px}}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-icon{opacity:.5;font-size:48px}.empty-title{color:var(--text-dim);font-size:18px;font-weight:700}.empty-subtitle{color:var(--text-muted);max-width:280px;font-size:14px}.divider{background:var(--border);height:1px;margin:16px 0}.select{background:var(--surface);border:1px solid var(--border);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}.action-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;display:flex}.action-bar-title{flex:1;font-size:20px;font-weight:700}.stats-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:28px;display:grid}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:20px}.stat-value{letter-spacing:-.03em;font-size:32px;font-weight:800}.stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:12px;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)}
