:root{--primary: #6366f1;--primary-dark: #4f46e5;--primary-light: #818cf8;--secondary: #8b5cf6;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--bg-primary: #000000;--bg-secondary: #0a0a0a;--bg-tertiary: #141414;--text-primary: #ffffff;--text-secondary: #b4b4b4;--text-muted: #6b6b6b;--border: #1f1f1f;--shadow: rgba(0, 0, 0, .5)}*{margin:0;padding:0;box-sizing:border-box}button,label,.room-tile,.nav-item,.toggle-switch,[role=button]{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overscroll-behavior:none}#root{min-height:100vh;display:flex}.app-container{display:flex;width:100%;min-height:100vh}.sidebar{width:260px;background:var(--bg-primary);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:100}.sidebar-header{padding:2rem 1.5rem;border-bottom:1px solid var(--border)}.sidebar-header h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.sidebar-header p{font-size:.875rem;color:var(--text-muted)}.sidebar-nav{flex:1;padding:1.5rem 0;overflow-y:auto}.nav-section{margin-bottom:2rem}.nav-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:0 1.5rem;margin-bottom:.5rem}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:var(--text-secondary);text-decoration:none;transition:all .15s ease;border-left:2px solid transparent;margin:.125rem 0}.nav-link:hover{background:#6366f10d;color:var(--text-primary)}.nav-link.active{background:#6366f11a;color:var(--primary-light);border-left-color:var(--primary)}.nav-link-icon{font-size:1.25rem}.nav-link-text{font-size:.938rem;font-weight:500}.status-dot{width:8px;height:8px;border-radius:50%;margin-left:auto}.status-dot.connected{background:var(--success)}.status-dot.disconnected{background:var(--error)}.main-content{flex:1;margin-left:260px;min-height:100vh}.page-container{max-width:1400px;margin:0 auto;padding:2rem}.page-header{margin-bottom:2rem}.page-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.page-description{font-size:1rem;color:var(--text-secondary)}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;transition:all .2s ease}.card:hover{border-color:#6366f180;transform:translateY(-2px)}.card.swiping{border-color:var(--primary)}.card[style*="cursor: pointer"]{touch-action:pan-y pinch-zoom;-webkit-tap-highlight-color:transparent}.card[style*="cursor: pointer"]:active{opacity:.95}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.card-title{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.card-actions{display:flex;gap:.5rem}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid-4{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.938rem;font-weight:500;border-radius:12px;border:none;cursor:pointer;transition:all .15s ease;text-decoration:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);opacity:.9}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:#1a1a1a;border-color:#6366f14d}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover:not(:disabled){background:#d97706}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.form-control{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:.938rem;transition:all .15s ease}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.slider{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:var(--bg-tertiary);outline:none;margin:.75rem 0}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;transition:all .2s}.slider::-webkit-slider-thumb:hover{background:var(--primary-light);transform:scale(1.2)}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;transition:all .2s}.slider::-moz-range-thumb:hover{background:var(--primary-light);transform:scale(1.2)}.color-picker-container{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.color-swatch{width:48px;height:48px;border-radius:12px;cursor:pointer;border:2px solid transparent;transition:all .15s ease}.color-swatch:hover{transform:scale(1.05);border-color:#fff3}.color-swatch.active{border-color:var(--primary);box-shadow:0 0 0 2px #6366f14d}.badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:8px;font-size:.813rem;font-weight:500;border:1px solid}.badge-success{background:#10b98114;color:var(--success);border-color:#10b98133}.badge-warning{background:#f59e0b14;color:var(--warning);border-color:#f59e0b33}.badge-error{background:#ef444414;color:var(--error);border-color:#ef444433}.badge-info{background:#6366f114;color:var(--primary-light);border-color:#6366f133}.alert{padding:1rem 1.25rem;border-radius:12px;margin-bottom:1.5rem;border:1px solid;border-left-width:3px}.alert-success{background:#10b9810f;border-color:var(--success);color:var(--success)}.alert-error{background:#ef44440f;border-color:var(--error);color:var(--error)}.alert-warning{background:#f59e0b0f;border-color:var(--warning);color:var(--warning)}.alert-info{background:#6366f10f;border-color:var(--primary);color:var(--primary-light)}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--bg-tertiary);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:1.5rem}.stat-label{font-size:.875rem;color:var(--text-muted);margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary)}.stat-icon{font-size:2rem;margin-bottom:.5rem;opacity:.8}.progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin:.5rem 0}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));transition:width .3s ease}.toggle-switch{position:relative;display:inline-block;width:50px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-tertiary);transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.toggle-slider{background-color:var(--primary)}input:checked+.toggle-slider:before{transform:translate(24px)}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border);padding:.5rem 0;padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0px));z-index:100;justify-content:space-around;align-items:center}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .75rem;color:var(--text-muted);text-decoration:none;font-size:.625rem;font-weight:500;transition:color .2s ease;-webkit-tap-highlight-color:transparent}.mobile-nav-item:active{transform:scale(.95)}.mobile-nav-item.active{color:var(--primary-light)}.mobile-nav-item svg{transition:transform .2s ease}.mobile-nav-item.active svg{transform:scale(1.1)}@media (max-width: 768px){.mobile-bottom-nav{display:flex}.sidebar{display:none}.main-content{margin-left:0;width:100%}.page-container{padding:1rem;padding-top:calc(1rem + env(safe-area-inset-top,0px));padding-bottom:calc(5rem + env(safe-area-inset-bottom,0px))}.page-header{position:sticky;top:0;z-index:100;margin:-1rem -1rem 1rem;padding:1rem;padding-top:calc(1rem + env(safe-area-inset-top,0px));background:#000000d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.page-container{padding-top:0}.page-title{font-size:1.5rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;gap:1rem}.btn{min-height:44px;padding:.75rem 1rem;font-size:1rem}.btn-sm{min-height:40px;padding:.625rem .875rem;font-size:.875rem}.card{border-radius:8px;padding:1rem;margin-bottom:1rem}.card-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.card-title{font-size:1.125rem}.sidebar-header{padding:1.5rem 1rem}.sidebar-header h1{font-size:1.25rem}.nav-link{padding:1rem 1.5rem;gap:1rem}.nav-link-text{font-size:1rem}.form-control{font-size:1rem;padding:.875rem}.color-swatch{width:44px;height:44px}.stats-grid{grid-template-columns:1fr;gap:.75rem}.stat-card{padding:1rem}.form-group{margin-bottom:1rem}.badge{align-self:flex-start}.page-description{font-size:.875rem}.slider::-webkit-slider-thumb{width:24px;height:24px}.slider::-moz-range-thumb{width:24px;height:24px}.slider{height:8px}.toggle-switch{width:56px;height:30px}.toggle-slider:before{height:24px;width:24px}input:checked+.toggle-slider:before{transform:translate(26px)}.alert{font-size:.875rem;padding:.875rem 1rem}.color-picker-container{gap:.5rem}.card .badge-info:not(.badge-success):not(.badge-error):not(.badge-warning){display:none}.card .card{margin-bottom:0}.stat-value{font-size:1.75rem}.stat-icon{font-size:1.5rem}.page-container{overflow-x:hidden}.card[style*="cursor: pointer"]{position:relative}.card[style*="cursor: pointer"]:after{content:"Tap to toggle • Swipe left/right for brightness";position:absolute;bottom:.5rem;left:50%;transform:translate(-50%);font-size:.65rem;color:var(--text-muted);opacity:0;white-space:nowrap;pointer-events:none;transition:opacity .3s}.card[style*="cursor: pointer"]:active:after{opacity:.7}.card.swiping:after{content:"";opacity:0}}.room-tiles-container{display:flex;flex-direction:column;gap:.75rem}.room-tile{position:relative;display:flex;flex-direction:column;min-height:100px;padding:1rem 1.25rem;border-radius:20px;background:var(--bg-tertiary);overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .3s ease;-webkit-tap-highlight-color:transparent;touch-action:pan-y;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}.room-tile:active{transform:scale(.98)}.room-tile.active{background:linear-gradient(135deg,#fbbf24e6,#f59e0bd9 30%,#d97706bf);box-shadow:0 4px 20px #f59e0b4d}.room-tile.active.dim{background:linear-gradient(135deg,#b48c3cb3,#a07832a6 30%,#8c64288c)}.room-tile.active.bright{background:linear-gradient(135deg,#fde047f2,#fbbf24e6 30%,#f59e0bcc);box-shadow:0 4px 30px #fde04766}.room-tile-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:auto}.room-tile-info{display:flex;align-items:center;gap:.75rem}.room-tile-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--text-secondary);transition:color .3s ease}.room-tile.active .room-tile-icon{color:#fffffff2}.room-tile-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);transition:color .3s ease}.room-tile.active .room-tile-name{color:#fffffff2}.room-tile.active svg{color:#fffffff2}.room-tile-toggle{position:relative;width:51px;height:31px;flex-shrink:0}.room-tile-toggle input{opacity:0;width:0;height:0}.room-tile-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#78788052;transition:.3s;border-radius:31px}.room-tile-toggle-slider:before{position:absolute;content:"";height:27px;width:27px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 5px #0003}.room-tile-toggle input:checked+.room-tile-toggle-slider{background-color:#ffffff80}.room-tile-toggle input:checked+.room-tile-toggle-slider:before{transform:translate(20px)}.room-tile-brightness{position:relative;width:100%;margin-top:.75rem;height:6px}.room-tile-brightness-track{position:absolute;width:100%;height:6px;background:#fff3;border-radius:3px;overflow:hidden}.room-tile.active .room-tile-brightness-track{background:#00000026}.room-tile-brightness-fill{height:100%;background:#fff9;border-radius:3px;transition:width .15s ease}.room-tile.active .room-tile-brightness-fill{background:#ffffffe6}.room-tile-brightness-input{position:absolute;width:100%;height:20px;top:-7px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer;z-index:2}.room-tile-brightness-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 6px #0000004d;transition:transform .15s ease}.room-tile-brightness-input::-webkit-slider-thumb:hover{transform:scale(1.1)}.room-tile-brightness-input::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#fff;cursor:pointer;border:none;box-shadow:0 2px 6px #0000004d}.room-tile-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:.25rem;transition:color .3s ease}.room-tile.active .room-tile-subtitle{color:#ffffffb3}.room-tile.unreachable{opacity:.5}.room-tile.unreachable .room-tile-toggle-slider,.room-tile.unreachable .room-tile-brightness-input{cursor:not-allowed}.drag-handle{position:absolute;top:.75rem;right:.75rem;padding:.5rem;cursor:grab;color:var(--text-muted);opacity:.5;transition:opacity .2s ease,color .2s ease;touch-action:none;z-index:10}.drag-handle:hover{opacity:1}.drag-handle:active{cursor:grabbing}.room-tile.active .drag-handle{color:#ffffff80}.room-tile.active .drag-handle:hover{color:#fffc}.room-tile.dragging{box-shadow:0 8px 32px #0000004d;cursor:grabbing;transition:box-shadow .3s ease}.room-tile.dragging:active{transform:none}.room-tile.dragging .drag-handle{cursor:grabbing;opacity:1}@media (max-width: 768px){.room-tile{min-height:90px;padding:.875rem 1rem;border-radius:16px}.room-tile-name{font-size:1rem}.room-tile-icon{width:32px;height:32px}.room-tile-toggle{width:46px;height:28px}.room-tile-toggle-slider:before{height:24px;width:24px}.room-tile-toggle input:checked+.room-tile-toggle-slider:before{transform:translate(18px)}.room-tile-brightness-input::-webkit-slider-thumb{width:24px;height:24px}.room-tile-brightness-input::-moz-range-thumb{width:24px;height:24px}}.room-tile.active.cooling{background:linear-gradient(135deg,#3b82f6e6,#2563ebd9 30%,#1d4ed8bf);box-shadow:0 4px 20px #3b82f64d}.room-tile.active.heating{background:linear-gradient(135deg,#fbbf24e6,#f59e0bd9 30%,#d97706bf);box-shadow:0 4px 20px #f59e0b4d}.room-tile.active.drying{background:linear-gradient(135deg,#14b8a6e6,#0d9488d9 30%,#0f766ebf);box-shadow:0 4px 20px #14b8a64d}.room-tile.active.fan{background:linear-gradient(135deg,#6b7280e6,#4b5563d9 30%,#374151bf);box-shadow:0 4px 20px #6b72804d}.room-tile.active.auto-mode{background:linear-gradient(135deg,#8b5cf6e6,#7c3aedd9 30%,#6d28d9bf);box-shadow:0 4px 20px #8b5cf64d}.ac-tile-temp{font-size:1.5rem;font-weight:700;line-height:1;color:var(--text-primary);transition:color .3s ease}.room-tile.active .ac-tile-temp{color:#fffffff2}.ac-tile-current-temp{font-size:.875rem;color:var(--text-muted);margin-top:.25rem;transition:color .3s ease}.room-tile.active .ac-tile-current-temp{color:#ffffffb3}.ac-tile-mode{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:500;background:#ffffff26;color:var(--text-secondary);transition:all .3s ease}.room-tile.active .ac-tile-mode{background:#ffffff40;color:#ffffffe6}.ac-tile-controls{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.room-tile:not(.active) .ac-tile-controls{border-top-color:var(--border)}.ac-tile-controls-wrapper{overflow:hidden;max-height:0;opacity:0;transition:max-height .35s ease-out,opacity .25s ease-out,margin-top .35s ease-out;margin-top:0}.ac-tile-controls-wrapper.expanded{max-height:600px;opacity:1;margin-top:.75rem;transition:max-height .4s ease-in,opacity .3s ease-in .1s,margin-top .35s ease-in}.ac-tile-controls-wrapper .ac-tile-controls{margin-top:0}.ac-quick-temp{display:flex;gap:.5rem;margin-top:0}.ac-quick-temp button{width:56px;height:56px;border-radius:14px;border:none;font-size:2rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.ac-quick-temp button{width:64px;height:64px;font-size:2.25rem;border-radius:16px}}.ac-quick-temp button.decrease{background:#ffffff26;color:var(--text-primary)}.room-tile.active .ac-quick-temp button.decrease{background:#ffffff40;color:#fffffff2}.ac-quick-temp button.increase{background:#ffffff26;color:var(--text-primary)}.room-tile.active .ac-quick-temp button.increase{background:#ffffff40;color:#fffffff2}.ac-quick-temp button:active{transform:scale(.95)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,rgba(255,255,255,.08) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:12px}.skeleton-tile{min-height:100px;padding:1rem 1.25rem;border-radius:20px;margin-bottom:.75rem}.skeleton-tile-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.skeleton-icon{width:36px;height:36px;border-radius:50%}.skeleton-text{height:1rem;border-radius:4px}.skeleton-text.short{width:60%}.skeleton-text.medium{width:80%}.skeleton-text.long{width:100%}.skeleton-slider{height:6px;border-radius:3px;margin-top:.75rem}@keyframes toggleBounce{0%{transform:scale(1)}50%{transform:scale(.92)}to{transform:scale(1)}}@keyframes pulseGlow{0%,to{box-shadow:0 4px 20px #f59e0b4d}50%{box-shadow:0 4px 30px #f59e0b80}}.room-tile{transition:transform .2s ease,box-shadow .3s ease,background .3s ease}.room-tile.toggling{animation:toggleBounce .3s ease}.room-tile.active{animation:pulseGlow 3s ease-in-out infinite}.room-tile.active.cooling,.room-tile.active.heating,.room-tile.active.drying,.room-tile.active.fan,.room-tile.active.auto-mode{animation:none}.room-tile-icon{transition:transform .2s ease}.room-tile.toggling .room-tile-icon{animation:toggleBounce .3s ease}.page-header-glass{position:sticky;top:0;z-index:50;margin:-2rem -2rem 1.5rem;padding:1.5rem 2rem;background:#000000b3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.05)}@media (max-width: 768px){.page-header-glass{margin:-1rem -1rem 1rem;padding:1rem}}.status-summary{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.813rem;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;margin-left:-1rem;margin-right:-1rem;padding-left:1rem;padding-right:1rem;padding-bottom:.25rem}.status-summary::-webkit-scrollbar{display:none}.status-summary-item{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:20px;white-space:nowrap;flex-shrink:0;color:var(--text-secondary);transition:all .2s ease}.status-summary-item.active{background:#34c75926;border-color:#34c7594d;color:var(--text-primary)}.status-summary-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-summary-dot.on{background:var(--success);box-shadow:0 0 6px var(--success)}.status-summary-dot.off{background:var(--text-muted)}.light-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .2s ease}.light-popup-overlay.active{opacity:1;pointer-events:auto}.light-popup{background:var(--bg-secondary);border:1px solid var(--border);border-radius:24px;padding:1.5rem;width:100%;max-width:320px;transform:scale(.9);transition:transform .2s ease}.light-popup-overlay.active .light-popup{transform:scale(1)}.light-popup-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.light-popup-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-secondary)}.light-popup-icon.on{background:linear-gradient(135deg,#fbbf24e6,#f59e0bd9);color:#000000b3}.light-popup-title{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.light-popup-subtitle{font-size:.813rem;color:var(--text-muted)}.light-popup-brightness{margin-bottom:1.5rem}.light-popup-brightness-label{display:flex;justify-content:space-between;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.light-popup-brightness-value{font-weight:600;color:var(--text-primary)}.light-popup-slider{width:100%;height:40px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(to right,var(--bg-tertiary),var(--warning));border-radius:20px;outline:none}.light-popup-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:36px;height:36px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 8px #0000004d}.light-popup-slider::-moz-range-thumb{width:36px;height:36px;border-radius:50%;background:#fff;cursor:pointer;border:none;box-shadow:0 2px 8px #0000004d}.light-popup-actions{display:flex;gap:.75rem}.light-popup-actions .btn{flex:1;height:48px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center}.empty-state-icon{width:80px;height:80px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:var(--text-muted)}.empty-state-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.empty-state-description{font-size:.938rem;color:var(--text-muted);max-width:280px;line-height:1.5}.empty-state-action{margin-top:1.5rem}.swipe-indicator{position:absolute;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;background:#000000b3;color:#fff;pointer-events:none;opacity:0;transition:opacity .2s ease}.room-tile.swiping .swipe-indicator{opacity:1}.swipe-indicator.left{left:.5rem}.swipe-indicator.right{right:.5rem}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;-webkit-tap-highlight-color:transparent}.bottom-sheet-overlay.open{opacity:1;visibility:visible}.bottom-sheet{position:fixed;bottom:0;left:0;right:0;z-index:1001;background:var(--bg-secondary);border-radius:20px 20px 0 0;max-height:85vh;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);padding-bottom:env(safe-area-inset-bottom,0px);overflow:hidden;display:flex;flex-direction:column}.bottom-sheet.open{transform:translateY(0)}.bottom-sheet-handle{width:36px;height:5px;background:#ffffff4d;border-radius:3px;margin:12px auto;flex-shrink:0}.bottom-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.bottom-sheet-title{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.bottom-sheet-close{width:30px;height:30px;border-radius:50%;background:#ffffff1a;border:none;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease}.bottom-sheet-close:hover{background:#fff3}.bottom-sheet-content{padding:1.25rem;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1}.bottom-sheet-actions{display:flex;flex-direction:column;gap:.5rem}.bottom-sheet-action{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff0d;border-radius:12px;border:none;color:var(--text-primary);font-size:1rem;text-align:left;cursor:pointer;transition:background .2s ease;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.bottom-sheet-action:hover{background:#ffffff1a}.bottom-sheet-action:active{background:#ffffff26;transform:scale(.98)}.bottom-sheet-action.selected{background:var(--primary)}.bottom-sheet-action-icon{width:40px;height:40px;border-radius:10px;background:#ffffff1a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bottom-sheet-action.selected .bottom-sheet-action-icon{background:#fff3}.bottom-sheet-action-text{flex:1}.bottom-sheet-action-title{font-weight:500}.bottom-sheet-action-subtitle{font-size:.813rem;color:var(--text-muted);margin-top:.125rem}.bottom-sheet-action.selected .bottom-sheet-action-subtitle{color:#ffffffb3}.bottom-sheet-settings{display:flex;flex-direction:column;gap:1.5rem}.bottom-sheet-section{display:flex;flex-direction:column;gap:.75rem}.bottom-sheet-label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.bottom-sheet-sublabel{font-size:.75rem;color:var(--text-muted)}.bottom-sheet-subsection{display:flex;flex-direction:column;gap:.5rem}.bottom-sheet-button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.5rem}.bottom-sheet-button-row{display:flex;gap:.375rem;flex-wrap:wrap}.bottom-sheet-btn{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.75rem 1rem;border:none;border-radius:12px;background:var(--bg-tertiary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease,transform .1s ease;-webkit-tap-highlight-color:transparent}.bottom-sheet-btn:active{transform:scale(.97)}.bottom-sheet-btn.selected{background:var(--accent);color:#fff}.bottom-sheet-btn-sm{flex:1;min-width:40px;padding:.625rem .5rem;border:none;border-radius:10px;background:var(--bg-tertiary);color:var(--text-primary);font-size:.813rem;font-weight:500;cursor:pointer;transition:background .2s ease,transform .1s ease;-webkit-tap-highlight-color:transparent}.bottom-sheet-btn-sm:active{transform:scale(.95)}.bottom-sheet-btn-sm.selected{background:var(--accent);color:#fff}@media (prefers-reduced-motion: reduce){.bottom-sheet,.bottom-sheet-overlay,.room-tile,.btn,*{transition-duration:.01ms!important;animation-duration:.01ms!important}}
