*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #161A1F;--bg-secondary: rgba(22,26,31,.97);--bg-card: rgba(255,255,255,.055);--bg-hover: rgba(255,255,255,.09);--border: rgba(255,255,255,.11);--text-primary: #F0EDE8;--text-secondary: #D4D0CA;--text-muted: #6E6C6A;--accent: #F5A623;--accent-hover: #e09518;--blue: #4B9EFF;--success: #4ECB71;--warning: #F5A623;--danger: #FF6B6B;--radius: 4px;--radius-lg: 6px;--font-title: "Barlow Condensed", sans-serif}body{font-family:Barlow Condensed,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh;width:100vw}#root{height:100vh;width:100vw;max-width:none;margin:0;padding:0;text-align:left}.app-layout{display:flex;flex-direction:column;height:100vh}.app-main{flex:1;overflow:hidden;position:relative}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:56px;background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:100}.header-left{display:flex;align-items:center;gap:12px}.header-back{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--bg-hover);color:var(--text-primary);border-radius:var(--radius);cursor:pointer;transition:background .2s}.header-back:hover{background:var(--accent)}.header-title{font-size:18px;font-weight:600;letter-spacing:-.02em}.header-right{display:flex;align-items:center;gap:16px}.header-user{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.header-role{padding:2px 8px;background:var(--bg-hover);border-radius:999px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--accent)}.header-logout{padding:6px 14px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;font-size:13px;transition:all .2s}.header-logout:hover{border-color:var(--danger);color:var(--danger)}.building-view{width:100%;height:100%;position:relative}.building-view canvas{width:100%!important;height:100%!important}.building-view:after{content:"";position:absolute;inset:0;pointer-events:none;z-index:5;background:radial-gradient(ellipse 90% 80% at 50% 50%,transparent 50%,#1e293b 100%)}.zone-labels{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;gap:12px}.zone-label-button{padding:10px 24px;background:#111118d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-lg);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.zone-label-button:hover{background:#3b82f626;border-color:var(--accent);color:var(--accent)}.hud-overlay{position:absolute;top:0;left:0;right:0;pointer-events:none;padding:24px;display:flex;justify-content:space-between;z-index:10}.hud-top-left{display:flex;flex-direction:column;gap:4px}.hud-company{font-family:var(--font-title);font-size:14px;font-weight:700;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}.hud-time-row{display:flex;align-items:center;gap:12px}.hud-time{font-family:var(--font-title);font-size:52px;font-weight:600;color:var(--text-primary);line-height:1;letter-spacing:.04em}.hud-date{font-family:var(--font-title);font-size:16px;font-weight:600;color:var(--text-secondary);text-transform:capitalize;letter-spacing:.05em}.hud-weather{display:flex;align-items:center;gap:8px;margin-top:8px}.hud-weather-icon{font-size:20px}.hud-weather-temp{font-family:var(--font-title);font-size:20px;font-weight:700;color:var(--text-primary)}.hud-weather-state{font-size:13px;font-weight:400;color:var(--text-muted)}.hud-top-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;pointer-events:auto}.hud-user{display:flex;align-items:center;gap:8px;background:#161a1fb3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 16px;border-radius:var(--radius);border:1px solid var(--border)}.hud-username{font-size:13px;font-weight:600;color:var(--text-secondary)}.hud-role{font-size:10px;font-weight:600;color:var(--accent);letter-spacing:.1em;text-transform:uppercase}.hud-logout{padding:4px 12px;background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;font-size:11px;transition:all .2s}.hud-logout:hover{border-color:var(--danger);color:var(--danger)}.hud-temps{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.hud-indoor-temp{display:flex;align-items:center;gap:8px;background:#161a1fb3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 16px;border-radius:var(--radius);border:1px solid var(--border)}.hud-temp-label{font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}.hud-temp-value{font-family:var(--font-title);font-size:18px;font-weight:700;color:var(--text-primary)}.debug-camera-btn{position:absolute;bottom:12px;left:12px;padding:6px 14px;background:#3b82f633;border:1px solid var(--accent);color:var(--accent);border-radius:var(--radius);cursor:pointer;font-size:12px;z-index:10}.floorplan-view{width:100%;height:100%;display:flex;flex-direction:column}.floorplan-header{padding:16px 24px;border-bottom:1px solid var(--border)}.floorplan-header h2{font-size:20px;font-weight:600}.floorplan-container{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:24px}.floorplan-svg{width:100%;height:100%;max-width:100%;max-height:100%}.floorplan-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:var(--text-muted)}.interactive-element{cursor:pointer;user-select:none;-webkit-user-select:none}.interactive-element-bg{transition:opacity .2s,filter .2s}.interactive-element:hover .interactive-element-bg{opacity:1;filter:brightness(1.2)}.context-menu{position:fixed;min-width:200px;background:var(--bg-secondary);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 16px 48px #0009;z-index:1000;overflow:hidden;animation:contextMenuIn .15s ease-out}@keyframes contextMenuIn{0%{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.context-menu-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.context-menu-entity{font-size:13px;font-weight:600;color:var(--text-primary)}.context-menu-state{font-size:12px;color:var(--text-secondary);padding:2px 8px;background:var(--bg-hover);border-radius:999px}.context-menu-actions{padding:4px}.context-menu-action{display:block;width:100%;padding:10px 12px;border:none;background:transparent;color:var(--text-primary);text-align:left;font-size:14px;cursor:pointer;border-radius:var(--radius);transition:background .15s}.context-menu-action:hover:not(:disabled){background:var(--bg-hover)}.context-menu-action:disabled{color:var(--text-muted);cursor:not-allowed}.building-layout{display:flex;width:100%;height:100%}.building-layout>.building-view{flex:1;min-width:0}.control-panel{width:280px;flex-shrink:0;background:var(--bg-primary);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100%;overflow:hidden}.control-panel-toggle{display:none}.control-panel-content{flex:1;overflow-y:auto}.control-panel-content::-webkit-scrollbar{width:4px}.control-panel-content::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.control-panel-brand{padding:20px 20px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.control-panel-logo{width:100%;height:auto;display:block}.control-panel-section-title{padding:14px 20px 8px;font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}.control-panel-groups{padding:8px 0}.control-panel-group{border-bottom:1px solid rgba(255,255,255,.04)}.control-panel-group:last-child{border-bottom:none}.control-panel-category{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;background:transparent;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;text-align:left}.control-panel-category:hover{background:var(--bg-hover)}.control-panel-category--active{background:#ffffff0a}.control-panel-category-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-muted)}.control-panel-category:hover .control-panel-category-icon,.control-panel-category--active .control-panel-category-icon{color:var(--text-secondary)}.control-panel-category-label{flex:1}.control-panel-category-count{font-size:12px;color:var(--text-muted);background:#ffffff0f;padding:2px 8px;border-radius:999px}.control-panel-chevron{display:none}.control-panel-devices{padding:0 8px 8px;animation:devicesSlideIn .15s ease-out}@keyframes devicesSlideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.control-panel-device{padding:10px 12px;border-radius:var(--radius-lg);margin-bottom:2px;transition:background .15s}.control-panel-device:hover{background:var(--bg-hover)}.control-panel-device--active{border-left:2px solid var(--blue);padding-left:10px}.control-panel-device-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.control-panel-device-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.control-panel-device-state{font-size:11px;color:var(--text-muted);text-transform:capitalize;flex-shrink:0}.control-panel-device--active .control-panel-device-state{color:var(--blue)}.control-panel-device-climate{display:flex;align-items:center;gap:8px}.control-panel-temp-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:50%;background:transparent;color:var(--text-primary);font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.control-panel-temp-btn:hover:not(:disabled){background:var(--bg-hover);border-color:#fff3}.control-panel-temp-btn:disabled{opacity:.3;cursor:not-allowed}.control-panel-temp-target{font-size:13px;font-weight:500;color:var(--text-secondary);min-width:36px;text-align:center}.control-panel-current-temp{font-size:15px;font-weight:700;color:var(--text-primary)}.control-panel-device-dimmer{display:flex;align-items:center;min-width:90px}.control-panel-slider{width:100%;height:4px;-webkit-appearance:none;appearance:none;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.control-panel-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent, #fff);border:none;cursor:pointer}.control-panel-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent, #fff);border:none;cursor:pointer}.control-panel-slider:disabled{opacity:.4;cursor:not-allowed}.control-panel-device-actions{display:flex;gap:4px}.control-panel-action{flex:1;padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-secondary);font-size:11px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.control-panel-action:hover:not(:disabled){background:var(--bg-hover);border-color:#fff3;color:var(--text-primary)}.control-panel-action--current{background:#4b9eff1f;border-color:#4b9eff4d;color:var(--blue)}.control-panel-action:disabled{color:var(--text-muted);cursor:not-allowed;opacity:.5}.cover-controls{display:flex;align-items:center;gap:6px;width:100%;margin-top:6px}.cover-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.cover-btn:hover:not(:disabled){background:var(--bg-hover);border-color:#fff3;color:var(--text-primary)}.cover-btn:disabled{color:var(--text-muted);cursor:not-allowed;opacity:.5}.cover-slider{flex:1;min-width:0}.security-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px 12px;color:var(--text-muted)}.security-placeholder svg{opacity:.4}.security-placeholder-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.security-placeholder-status{font-size:11px;color:var(--text-muted);opacity:.7}.media-player-device{display:flex;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--text-primary);font-size:13px;cursor:pointer;border-radius:var(--radius-lg);transition:background .15s;text-align:left}.media-player-device:hover{background:var(--bg-hover)}.media-player-device--selected{background:#4b9eff14;border-left:2px solid var(--blue);padding-left:10px}.media-player-presets-label{padding:10px 12px 4px;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.media-player-presets{display:flex;flex-wrap:wrap;gap:4px;padding:0 8px 8px}.media-player-preset{padding:5px 12px;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--text-secondary);font-size:11px;cursor:pointer;transition:background .15s,border-color .15s}.media-player-preset:hover{background:var(--bg-hover);border-color:#4b9eff66;color:var(--text-primary)}.camera-thumbnails{display:grid;grid-template-columns:1fr 1fr;gap:6px}.camera-thumbnail{position:relative;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#000;cursor:pointer;padding:0;transition:border-color .15s}.camera-thumbnail:hover{border-color:#ffffff4d}.camera-thumbnail-img{width:100%;aspect-ratio:16 / 9;object-fit:cover;display:block}.camera-thumbnail-placeholder{background:var(--bg-secondary)}.camera-thumbnail-label{position:absolute;bottom:0;left:0;right:0;padding:2px 6px;font-size:10px;color:#fff;background:linear-gradient(transparent,#000000b3);text-align:left}.camera-view-all-btn{width:100%;margin-top:6px;padding:8px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:background .15s,color .15s}.camera-view-all-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.camera-overlay{position:absolute;inset:0;z-index:50;background:#000000d9;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.camera-overlay-content{width:95%;max-width:1200px;max-height:90%;display:flex;flex-direction:column}.camera-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:8px 0 12px}.camera-overlay-title{font-size:16px;font-weight:600;color:#fff}.camera-overlay-close{width:32px;height:32px;border:none;border-radius:50%;background:#ffffff1a;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.camera-overlay-close:hover{background:#fff3}.camera-single{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.camera-single-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}.camera-grid-full{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:10px;overflow-y:auto;flex:1;min-height:0}.camera-grid-item{position:relative;border:1px solid rgba(255,255,255,.1);border-radius:8px;overflow:hidden;background:#000;cursor:pointer;padding:0;transition:border-color .15s}.camera-grid-item:hover{border-color:#ffffff4d}.camera-grid-img{width:100%;aspect-ratio:16 / 9;object-fit:cover;display:block}.camera-grid-label{position:absolute;bottom:0;left:0;right:0;padding:4px 10px;font-size:13px;font-weight:500;color:#fff;background:linear-gradient(transparent,#000000b3)}.media-bar{flex-shrink:0;border-top:1px solid var(--border);background:var(--bg-primary)}.media-bar-compact{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:transparent;cursor:pointer;text-align:left;transition:background .15s}.media-bar-compact:hover{background:var(--bg-hover)}.media-bar-art{width:36px;height:36px;border-radius:var(--radius);object-fit:cover;flex-shrink:0}.media-bar-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.media-bar-title{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-bar-artist{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-bar-play{flex-shrink:0;color:var(--text-primary);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;transition:background .15s}.media-bar-play:hover{background:var(--bg-hover)}.media-bar-expanded{padding:4px 16px 14px;animation:devicesSlideIn .15s ease-out}.media-bar-transport{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:10px}.media-player-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.media-player-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.media-player-btn--play{width:36px;height:36px;border:1.5px solid var(--border);border-radius:50%;color:var(--text-primary)}.media-player-btn--play:hover{border-color:#ffffff40;background:var(--bg-hover)}.media-player-volume{display:flex;align-items:center;gap:8px}.media-player-volume-icon{color:var(--text-muted);flex-shrink:0}.media-player-slider{flex:1;-webkit-appearance:none;appearance:none;height:3px;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.media-player-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text-primary);cursor:pointer;transition:transform .1s}.media-player-slider::-webkit-slider-thumb:hover{transform:scale(1.3)}.media-player-slider::-moz-range-thumb{width:12px;height:12px;border:none;border-radius:50%;background:var(--text-primary);cursor:pointer}.media-player-volume-val{font-size:11px;color:var(--text-muted);width:24px;text-align:right;flex-shrink:0}.login-container{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary)}.login-card{width:100%;max-width:380px;padding:40px 32px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px}.login-logo{display:block;width:100%;max-width:240px;margin:0 auto 32px}.login-form{display:flex;flex-direction:column;gap:16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:13px;font-weight:500;color:var(--text-secondary)}.form-field input{padding:10px 14px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s}.form-field input:focus{border-color:var(--accent)}.login-error{padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius);color:var(--danger);font-size:13px}.login-button{padding:12px;background:var(--accent);border:none;border-radius:var(--radius);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:8px}.login-button:hover:not(:disabled){background:var(--accent-hover)}.login-button:disabled{opacity:.6;cursor:not-allowed}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-secondary);font-size:16px}@media(max-width:768px){.building-layout{flex-direction:column;height:100vh;height:100dvh}.building-layout>.building-view{height:40vh;height:40dvh;flex:none}.building-layout>.control-panel{display:none}.zone-labels{display:none}.building-view:after{background:radial-gradient(ellipse 95% 90% at 50% 50%,transparent 60%,var(--bg-primary) 100%)}.hud-overlay{padding:12px 16px}.hud-overlay--compact .hud-top-right{display:none}.hud-overlay--compact .hud-time{font-size:28px}.hud-overlay--compact .hud-date{display:none}.hud-overlay--compact .hud-weather{margin-top:2px}.hud-overlay--compact .hud-weather-temp{font-size:16px}.hud-overlay--compact .hud-weather-state{display:none}.context-menu{top:auto!important;left:0!important;right:0!important;bottom:0;min-width:100%;max-width:100%;border-radius:16px 16px 0 0;animation:contextMenuSlideUp .2s ease-out}@keyframes contextMenuSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.context-menu-backdrop{position:fixed;inset:0;background:#00000080;z-index:999}.camera-overlay{position:fixed}.camera-overlay-content{width:100%;max-width:100%;padding:8px}.camera-grid-full{grid-template-columns:1fr}.app-header{padding:0 12px;height:48px}.header-title{font-size:16px}.floorplan-container{padding:12px}.login-card{margin:16px;padding:32px 24px}.mobile-bottom-sheet .control-panel{display:flex;width:100%;height:auto;border-right:none;overflow:visible}.mobile-bottom-sheet .control-panel-brand{display:none}.mobile-bottom-sheet .control-panel-content{overflow:visible}.mobile-bottom-sheet .control-panel-device-name{max-width:none}.debug-camera-btn{display:none}}.mobile-bottom-sheet{position:relative;flex:1;display:flex;flex-direction:column;background:var(--bg-primary);border-top:1px solid var(--border);overflow:hidden;touch-action:none;transition:flex .3s ease}.mobile-sheet-drag{display:flex;align-items:center;justify-content:center;padding:8px 0 4px;cursor:grab;flex-shrink:0}.mobile-sheet-drag:active{cursor:grabbing}.mobile-sheet-handle{width:36px;height:4px;border-radius:2px;background:#fff3}.mobile-sheet-status{display:flex;align-items:center;gap:12px;padding:4px 16px 8px;flex-shrink:0;overflow-x:auto;scrollbar-width:none}.mobile-sheet-status::-webkit-scrollbar{display:none}.mobile-status-pill{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;white-space:nowrap;flex-shrink:0}.mobile-status-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.mobile-status-value{font-size:13px;font-weight:700;color:var(--text-primary)}.mobile-tab-bar{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;padding:0 8px}.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border:none;background:transparent;color:var(--text-muted);font-size:10px;font-weight:500;cursor:pointer;transition:color .15s;border-bottom:2px solid transparent}.mobile-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.mobile-tab-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.mobile-sheet-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:env(safe-area-inset-bottom,0px)}.mobile-sheet-content::-webkit-scrollbar{width:3px}.mobile-sheet-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.mobile-home-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px 16px}.mobile-home-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:background .15s,border-color .15s;text-align:center}.mobile-home-card:active{background:var(--bg-hover)}.mobile-home-card--wide{grid-column:1 / -1}.mobile-home-card-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:24px}.mobile-home-card-label{font-size:13px;font-weight:600;color:var(--text-primary)}.mobile-home-card-state{font-size:11px;color:var(--text-muted)}.mobile-home-card--active{border-color:#4b9eff4d}.mobile-home-card--active .mobile-home-card-icon{color:var(--blue)}.mobile-home-zones{display:flex;gap:8px;padding:0 16px 12px}.mobile-home-zone-btn{flex:1;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.mobile-home-zone-btn:active{background:var(--bg-hover);border-color:var(--accent)}.mobile-devices-tab,.mobile-devices-tab .control-panel-groups{padding:0}.mobile-devices-tab .control-panel-section-title{padding:12px 16px 6px}.mobile-cameras-tab{padding:12px 16px}.mobile-cameras-tab .camera-thumbnails{grid-template-columns:1fr 1fr;gap:8px}.mobile-music-tab{padding:0}.mobile-bottom-sheet .media-bar{flex-shrink:0;padding-bottom:env(safe-area-inset-bottom,0px)}.context-menu-divider{height:1px;background:var(--border);margin:4px 0}.context-menu-section-label{padding:8px 12px 4px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.context-menu-chips{display:flex;gap:6px;padding:4px 8px 8px}.context-menu-chip{padding:6px 14px;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--text-primary);font-size:13px;cursor:pointer;transition:background .15s,border-color .15s}.context-menu-chip:hover{background:var(--bg-hover);border-color:#3b82f666}.context-menu-chip:disabled{color:var(--text-muted);cursor:not-allowed}.context-menu-time-picker{display:flex;align-items:center;gap:8px;padding:4px 8px 8px}.context-menu-time-input{flex:1;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-primary);color:var(--text-primary);font-size:14px;color-scheme:dark}.context-menu-time-input:focus{outline:none;border-color:#3b82f680}.context-menu-cancel{color:#ef4444d9!important}.context-menu-simulate{color:#3b82f6b3!important;font-style:italic;border-top:1px solid var(--border);margin-top:4px}.lock-card{padding:10px 12px;border-radius:var(--radius-lg);margin-bottom:4px;border-left:3px solid var(--danger);transition:background .15s,border-color .15s}.lock-card--unlocked{border-left-color:var(--success)}.lock-card-header{display:flex;align-items:center;justify-content:space-between}.lock-card-name{font-size:13px;font-weight:500;color:var(--text-primary)}.lock-card-right{display:flex;align-items:center;gap:10px}.lock-card-timer{font-size:11px;font-weight:600;color:var(--accent);background:#f5a6231f;padding:2px 8px;border-radius:999px}.lock-card-toggle{position:relative;width:44px;height:24px;border:none;border-radius:12px;background:var(--danger);cursor:pointer;padding:0;transition:background .2s;flex-shrink:0}.lock-card-toggle--on{background:var(--success)}.lock-card-toggle:disabled{opacity:.4;cursor:not-allowed}.lock-card-toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s;pointer-events:none}.lock-card-toggle--on .lock-card-toggle-thumb{transform:translate(20px)}.lock-card-timed{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.06)}.lock-card-clock-btn{display:flex;align-items:center;gap:6px;padding:4px 0;border:none;background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;transition:color .15s}.lock-card-clock-btn:hover{color:var(--text-secondary)}.lock-card-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.lock-card-chip{padding:4px 12px;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--text-secondary);font-size:11px;cursor:pointer;transition:background .15s,border-color .15s}.lock-card-chip:hover{background:var(--bg-hover);border-color:#4b9eff66;color:var(--text-primary)}.lock-card-chip:disabled{color:var(--text-muted);cursor:not-allowed}.lock-card-time-input{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-primary);color:var(--text-primary);font-size:12px;color-scheme:dark;width:100px}.lock-card-cancel{padding:4px 0;border:none;background:transparent;color:var(--danger);font-size:12px;cursor:pointer}.speaker-card{margin-bottom:4px;padding:8px 12px;border-radius:var(--radius-lg);overflow:hidden;transition:background .15s}.speaker-card--active{border-left:3px solid var(--blue);background:#4b9eff0a}.speaker-card-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.speaker-card-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.speaker-card-state{font-size:11px;color:var(--text-muted);flex-shrink:0;margin-left:8px}.speaker-card-volume{display:flex;align-items:center;gap:8px}.floating-quick-actions{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:8px;z-index:8;pointer-events:auto}.floating-pill{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#161a1fd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1.5px solid var(--danger);border-radius:999px;color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.floating-pill:active{transform:scale(.95)}.floating-pill--locked{border-color:var(--danger)}.floating-pill--locked svg{color:var(--danger)}.floating-pill--unlocked{border-color:var(--success)}.floating-pill--unlocked svg{color:var(--success)}.mobile-panel{position:relative;flex:1;display:flex;flex-direction:column;background:var(--bg-primary);border-top:1px solid var(--border);overflow:hidden}.mobile-panel-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:env(safe-area-inset-bottom,0px)}.mobile-panel-scroll::-webkit-scrollbar{width:3px}.mobile-panel-scroll::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.mobile-section-header{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;border-bottom:1px solid rgba(255,255,255,.04);background:transparent;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;text-align:left}.mobile-section-header:hover{background:var(--bg-hover)}.mobile-section-header--active{background:#ffffff0a}.mobile-section-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-muted)}.mobile-section-header--active .mobile-section-icon{color:var(--accent)}.mobile-section-label{flex:1}.mobile-section-count{font-size:12px;color:var(--text-muted);background:#ffffff0f;padding:2px 8px;border-radius:999px}.mobile-section-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .15s}.mobile-panel-section-content{padding:4px 8px 8px;animation:devicesSlideIn .15s ease-out}.mobile-panel .control-panel-device-name{max-width:none}
