.header{background-color:#202020;color:#fff;font-family:Inter,sans-serif;left:0;padding:20px 40px;position:fixed;top:0;width:100%;z-index:1000}main{padding-top:100px}.header-top-menu{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1300px}.header-left .header-title{font-size:1.4rem;font-weight:700;margin:0}h1.header-title a{color:#fff;text-decoration:none}.header-center{display:flex;flex:1 1;justify-content:center;margin:0 20px}.header-center .header-search{position:relative}.search-input{background-color:#282828;border:none;border-radius:10px;color:#ccc;font-size:.9rem;padding:10px 40px 10px 15px;transform:translateX(20px);transition:all .3s ease;width:260px}.search-input:focus{background-color:#353434;color:#fff;outline:none}.header-right{gap:25px}.header-right,.toggle-switch{align-items:center;display:flex}.toggle-switch{height:28px;position:relative;width:54px}.toggle-switch input{cursor:pointer;height:100%;opacity:0;position:absolute;width:100%;z-index:2}.toggle-switch input:checked{outline:4px solid red!important}.toggle-label{background:#353434;border-radius:34px;bottom:0;cursor:pointer;left:0;right:0;top:0;transition:background .4s ease}.toggle-label,.toggle-slider{align-items:center;display:flex;position:absolute}.toggle-slider{background-color:#fff;border-radius:50%;box-shadow:0 2px 6px #0000004d;font-size:.85rem;height:22px;justify-content:center;left:3px;pointer-events:none;top:3px;transition:transform .3s ease,background-color .3s ease,color .3s ease;width:22px;z-index:1}.toggle-slider>*{transition:opacity .2s ease,color .3s ease}.toggle-switch input:checked+.toggle-label .toggle-slider{transform:translateX(22px)}body.dark-mode .toggle-slider{background-color:#282828;color:#ffe066}.profile-section{position:relative}.profile-dropdown{align-items:center;background:#282828;border-radius:12px;cursor:pointer;display:flex;gap:10px;padding:8px 14px;transition:background-color .3s ease}.profile-dropdown:hover{background-color:#353434}.profile-picture{background-color:#777;border-radius:50%;height:28px;object-fit:cover;width:28px}.profile-name{color:#ddd;font-size:.9rem}.dropdown-arrow{font-size:.7rem}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{background-color:#1c1c1c;border-radius:10px;box-shadow:0 4px 25px #0006;display:flex;flex-direction:column;min-width:140px;top:50px;z-index:10}.dropdown-menu a{color:#ccc;font-size:.85rem;padding:10px 15px;text-decoration:none;transition:background-color .3s ease,color .3s ease}.dropdown-menu a:hover{background:linear-gradient(90deg,#a0c4ff,#bdb2ff);color:#111}@media (max-width:900px){.header{padding:12px 8px}.header-top-menu{align-items:center;flex-direction:row;gap:8px;justify-content:space-between;max-width:100%}.header-center{flex:1 1;margin:0 8px;width:auto}.search-input{font-size:.85rem;max-width:100%;min-width:80px;padding:8px 30px 8px 10px;transform:none;width:160px}.header-right{gap:10px}}@media (max-width:600px){.header{padding:8px 4px}.header-title{font-size:1rem;margin-right:6px}.header-top-menu{gap:4px}.header-center{margin:0 4px}.search-input{font-size:.75rem;min-width:60px;padding:6px 25px 6px 8px;width:90px}.profile-dropdown{gap:4px;padding:4px 6px}.profile-name{font-size:.75rem}.dropdown-menu{min-width:100px;top:36px}}@media (max-width:400px){.header-title{font-size:.85rem;margin-right:2px}.search-input{font-size:.65rem;padding:4px 18px 4px 6px;width:60px}.profile-name{display:none}}.custom-user-dropdown{display:inline-block;position:relative}.user-avatar-button{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;font-family:inherit;gap:8px;min-width:200px;padding:6px 12px;transition:all .2s ease}.user-avatar-button:hover{background-color:#f9fafb;border-color:#d1d5db}.dark-mode .user-avatar-button{background:#0000;border-color:#374151;color:#f9fafb}.dark-mode .user-avatar-button:hover{background-color:#374151;border-color:#4b5563}.user-avatar{border-radius:50%;flex-shrink:0;height:32px;overflow:hidden;width:32px}.avatar-image{height:100%;object-fit:cover;width:100%}.avatar-initials{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:flex;font-size:12px;font-weight:600;height:100%;justify-content:center;width:100%}.user-info{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;min-width:0}.user-name{color:#111827;font-size:14px;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark-mode .user-name{color:#f9fafb}.user-email{color:#6b7280;font-size:12px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark-mode .user-email{color:#9ca3af}.dropdown-arrow{color:#6b7280;transition:transform .2s ease}.dropdown-arrow.rotated{transform:rotate(180deg)}.dark-mode .dropdown-arrow{color:#9ca3af}.dropdown-menu{animation:dropdownSlideIn .15s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:4px;min-width:280px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.dark-mode .dropdown-menu{background:#1f2937;border-color:#374151;box-shadow:0 10px 15px -3px #0000004d,0 4px 6px -2px #0003}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:12px;padding:16px}.dark-mode .dropdown-header{background:#111827;border-bottom-color:#374151}.user-avatar-large{border-radius:50%;flex-shrink:0;height:48px;overflow:hidden;width:48px}.avatar-image-large{height:100%;object-fit:cover;width:100%}.avatar-initials-large{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:flex;font-size:18px;font-weight:600;height:100%;justify-content:center;width:100%}.user-details{flex:1 1;min-width:0}.user-name-large{color:#111827;font-size:16px;font-weight:600;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark-mode .user-name-large{color:#f9fafb}.user-email-small{color:#6b7280;font-size:13px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark-mode .user-email-small{color:#9ca3af}.dropdown-content{padding:8px 0}.dropdown-item{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-family:inherit;gap:12px;padding:12px 16px;text-align:left;transition:background-color .15s ease;width:100%}.dropdown-item:hover{background-color:#f3f4f6}.dark-mode .dropdown-item:hover{background-color:#374151}.dropdown-item.sign-out{color:#dc2626}.dropdown-item.sign-out:hover{background-color:#fef2f2}.dark-mode .dropdown-item.sign-out{color:#f87171}.dark-mode .dropdown-item.sign-out:hover{background-color:#450a0a}.item-icon{flex-shrink:0;font-size:16px;text-align:center;width:20px}.item-label{color:#374151;font-size:14px;font-weight:500}.dark-mode .item-label{color:#d1d5db}.dropdown-item.sign-out .item-label{color:inherit}.dropdown-divider{background-color:#e5e7eb;height:1px;margin:8px 0}.dark-mode .dropdown-divider{background-color:#374151}@media (max-width:768px){.user-avatar-button{min-width:150px}.dropdown-menu{min-width:240px}.user-email,.user-name{max-width:80px}}.login-card{background:#13325b;border-radius:16px;color:#fff;padding:24px;width:360px}.title{margin:0 0 16px}.input{border:0;border-radius:6px;margin:6px 0 12px;padding:10px}.btn-primary,.input{width:100%}.auth-wrap{background:#111;display:grid;min-height:100vh;place-items:center}.register-card{background:#13325b;border-radius:16px;color:#fff;padding:24px;width:420px}.title{margin:0 0 8px}.step{font-size:12px;margin-bottom:12px;opacity:.9}.input,.select{border:0;border-radius:6px;margin:6px 0 12px;padding:10px;width:100%}.mb16{margin-bottom:16px}.row{display:flex;gap:8px}.btn-primary{background:#1e4fa1;cursor:pointer}.btn-primary,.btn-secondary{border:0;border-radius:6px;color:#fff;padding:10px}.btn-oauth,.btn-secondary{background:#0b1f3b}.btn-oauth{border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px;transition:background .2s}.btn-oauth:hover{background:#1a2f4d}.grow{flex:1 1}.btn-full{width:100%}.msg{background:#0b1f3b;border-radius:6px;margin-top:12px;padding:8px}.link{color:#bfe3ff;text-decoration:none}.create-home-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin:0 auto;max-width:400px;padding:2rem;width:100%}.create-home-card .title{color:#333;font-size:1.5rem;font-weight:600;margin-bottom:.5rem;text-align:center}.create-home-card .subtitle{color:#666;font-size:.9rem;margin-bottom:1.5rem;text-align:center}.create-home-card label{color:#555;display:block;font-weight:500;margin-bottom:.5rem}.create-home-card .input,.create-home-card .select{border:2px solid #e1e5e9;border-radius:8px;box-sizing:border-box;font-size:1rem;margin-bottom:1rem;padding:.75rem;transition:border-color .2s ease;width:100%}.create-home-card .input:focus,.create-home-card .select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.create-home-card .input:disabled,.create-home-card .select:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.7}.create-home-card .btn-primary{background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:.875rem 1.5rem;transition:all .2s ease;width:100%}.create-home-card .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#0056b3,#004085);box-shadow:0 4px 12px #007bff4d;transform:translateY(-1px)}.create-home-card .btn-primary:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.create-home-card .error-msg{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;color:#721c24;font-size:.9rem;margin-top:1rem;padding:.75rem;text-align:center}@media (max-width:480px){.create-home-card{margin:1rem;padding:1.5rem}.create-home-card .title{font-size:1.3rem}}:root{--page-max:1300px;--gap:16px;--radius:18px;--card-min:260px;--card-pad:18px;--card-font:0.95rem;--bg:#f5f5f5;--fg:#111;--muted:#8a8a8a;--surface:#fff;--border:#00000014;--surface-elev:#0000000a}body.dark-mode{--bg:#202020;--fg:#fff;--muted:#9b9b9b;--surface:#1b1b1b;--border:#ffffff1f;--surface-elev:#ffffff0f}body{background:#f5f5f5;background:var(--bg);color:#111;color:var(--fg)}body:not(.dark-mode){background:#f5f5f5;color:#111}.home{padding:24px 20px 40px;position:relative}.center-wrap{margin:0 auto;max-width:1300px;max-width:var(--page-max)}.add-method-selector{border-bottom:2px solid #00000014;border-bottom:2px solid var(--border);display:flex;gap:8px;margin-bottom:16px;padding-bottom:8px}.method-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:#8a8a8a;color:var(--muted);cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s ease}.method-btn:hover{background:#0000000a;background:var(--surface-elev);color:#3b82f6}.manual-form{display:flex;flex-direction:column;gap:12px}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideUp .3s ease;background:#fff;background:var(--surface);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:500px;overflow:hidden;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #00000014;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px}.modal-header h3{color:#111;color:var(--fg);font-size:20px;font-weight:600;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:6px;color:#8a8a8a;color:var(--muted);cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.close-btn:hover{background:#0000000a;background:var(--surface-elev);color:#111;color:var(--fg)}.modal-body{padding:24px}.qr-scanner-container{text-align:center}.camera-viewport{aspect-ratio:1;background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:12px;margin-bottom:16px;overflow:hidden;position:relative;width:100%}.scanning-animation{inset:0;overflow:hidden;position:absolute}.scan-line{animation:scan 2s ease-in-out infinite;background:linear-gradient(90deg,#0000,#3b82f6 50%,#0000);box-shadow:0 0 10px #3b82f6;height:2px;left:0;position:absolute;right:0;top:0}@keyframes scan{0%,to{transform:translateY(0)}50%{transform:translateY(300px)}}.corner-markers{inset:20px;position:absolute}.corner{border:3px solid #3b82f6;box-shadow:0 0 15px #3b82f680;height:40px;position:absolute;width:40px}.corner.top-left{border-bottom:none;border-radius:8px 0 0 0;border-right:none;left:0;top:0}.corner.top-right{border-bottom:none;border-left:none;border-radius:0 8px 0 0;right:0;top:0}.corner.bottom-left{border-radius:0 0 0 8px;border-right:none;border-top:none;bottom:0;left:0}.corner.bottom-right{border-left:none;border-radius:0 0 8px 0;border-top:none;bottom:0;right:0}.scanner-overlay{align-items:center;display:flex;inset:0;justify-content:center;position:absolute}.camera-icon{fill:#fff3;height:64px;width:64px}.scanner-instruction{color:#111;color:var(--fg);font-size:16px;font-weight:500;margin:0 0 8px}.search-container{text-align:center}.search-animation{height:200px;margin:0 auto 24px;position:relative;width:200px}.radar-pulse,.search-animation{align-items:center;display:flex;justify-content:center}.pulse-ring,.radar-pulse{height:100%;position:absolute;width:100%}.pulse-ring{animation:pulse 2s ease-out infinite;border:3px solid #3b82f6;border-radius:50%;opacity:0}.pulse-ring:nth-child(2){animation-delay:.7s}.pulse-ring:nth-child(3){animation-delay:1.4s}@keyframes pulse{0%{opacity:1;transform:scale(.3)}to{opacity:0;transform:scale(1)}}.wifi-icon{fill:#3b82f6;animation:bounce 2s ease-in-out infinite;height:80px;position:relative;width:80px;z-index:1}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.search-status{color:#111;color:var(--fg);font-size:16px;font-weight:500;margin:0 0 16px}.search-progress{margin-bottom:24px}.progress-bar{background:#8a8a8a;background:var(--muted);border-radius:4px;height:8px;width:100%}.btn-secondary{background:#fff;background:var(--surface);border:1px solid #00000014;border:1px solid var(--border);border-radius:8px;color:#8a8a8a;color:var(--muted);cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-secondary:hover{background:#0000000a;background:var(--surface-elev);border-color:#8a8a8a;border-color:var(--muted);color:#111;color:var(--fg)}@media (max-width:640px){.modal-content{max-width:95%}.camera-viewport{aspect-ratio:4/3}.search-animation{height:150px;width:150px}.wifi-icon{height:60px;width:60px}}.add-room-row{gap:16px;justify-content:space-between;margin:0 auto 20px;padding:0 6px}.add-room-row,.add-room-section{align-items:center;display:flex;max-width:1300px}.add-room-section{justify-content:flex-end;margin:0;padding:0}.add-room-section>button{background:linear-gradient(90deg,#a0c4ff,#bdb2ff);border:none;border-radius:12px;color:#111;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 18px;transition:transform .2s ease,opacity .2s ease}.add-room-section>button:hover{opacity:.9;transform:scale(1.05)}.rooms-bar{align-items:center;display:flex;flex-wrap:nowrap;gap:12px;margin:0;max-width:1300px;overflow-x:auto;padding:6px 6px 10px;scroll-behavior:smooth;scrollbar-width:thin}.rooms-bar::-webkit-scrollbar{height:6px}.rooms-bar::-webkit-scrollbar-track{background:#0000}.rooms-bar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.rooms-bar::-webkit-scrollbar-thumb:hover{background:var(--muted)}.add-room-form{align-items:center;display:flex;gap:10px;position:relative}.add-room-form input{background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--fg);font-size:.9rem;padding:8px 12px;transition:background .2s ease,border-color .2s ease;width:180px}.add-room-form input:focus{background:var(--surface-elev);border-color:var(--muted);outline:none}.add-room-form button{background:linear-gradient(90deg,#a0c4ff,#bdb2ff);border:none;border-radius:10px;color:#111;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 18px;transition:transform .2s ease}.add-room-form button:hover{transform:scale(1.05)}.rooms-bar button{background:var(--surface);border:1px solid var(--border);border-radius:999px;color:var(--muted);cursor:pointer;font-size:1rem;gap:8px;padding:.9rem 1.3rem;position:relative;transition:transform .15s ease,background .2s ease,color .2s ease,border-color .2s ease;white-space:nowrap}.room-delete-icon,.rooms-bar button{align-items:center;display:inline-flex}.room-delete-icon{border-radius:6px;color:inherit;justify-content:center;opacity:.7;padding:2px}.room-delete-icon:hover{background:#00000014;flex-shrink:0;min-width:-webkit-fit-content;min-width:fit-content;opacity:1}.rooms-bar button:hover,.rooms-bar button[aria-current=true]{background:linear-gradient(0deg,var(--surface-elev),var(--surface));border-color:var(--border);color:var(--fg);transform:translateY(-1px)}.rooms-bar button.active{background:linear-gradient(90deg,#a0c4ff,#bdb2ff);border:none;color:#111;font-weight:500}.devices-section{margin-top:60px}.devices-section .devices-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px;position:relative}.devices-header{margin:0 auto;max-width:1300px;padding:0 6px}.devices-list{align-items:center;display:flex;justify-content:center;min-height:120px}.devices-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-left:auto;margin-right:auto;margin-top:20px;max-width:1300px}.device-card{align-items:stretch;border:1px solid #00000014;border-radius:16px;box-shadow:0 6px 20px -8px #00000026;color:#fff;display:flex;flex-direction:column;gap:12px;padding:18px;transition:transform .18s ease,box-shadow .25s ease,background .25s ease,opacity .25s ease}.device-card:hover{box-shadow:0 14px 32px -10px #00000040;transform:translateY(-3px)}.device-card.clickable{cursor:pointer}.device-card.is-on{background:#006eff}body:not(.dark-mode) .device-card.is-off{background:#cfe0ff;color:#fff}body.dark-mode .device-card.is-off{background:#0047b3;color:#fff}.device-card-header{align-items:flex-start;display:flex;justify-content:space-between}.device-head-left{align-items:center;display:flex;gap:12px}.icon-box{align-items:center;background:#000;border-radius:10px;display:inline-flex;height:42px;justify-content:center;width:42px}.icon-box svg{color:#fff;height:20px;width:20px}.device-card.is-off .icon-box{opacity:.55}.device-title{font-size:.95rem;font-weight:600}.device-title.dim{opacity:.55}.device-toggle{display:inline-block;height:28px;position:relative;width:48px}.device-toggle input{height:0;opacity:0;position:absolute;width:0}.device-toggle .slider{background:#2b2b2b;border-radius:999px;inset:0;position:absolute;transition:background .25s ease}.device-toggle .slider:before{background:#fff;border-radius:50%;content:"";height:22px;left:3px;position:absolute;top:3px;transition:transform .25s ease;width:22px}.device-toggle input:checked+.slider{background:linear-gradient(90deg,#a0c4ff,#bdb2ff)}.device-toggle input:checked+.slider:before{transform:translateX(20px)}.devices-list{grid-gap:14px;display:grid;gap:14px}.device-status-text{color:#a0c4ff;font-size:.82rem;font-weight:500;margin-top:-4px}.device-status-text.status-dim{opacity:.55}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:60px 20px;text-align:center}.empty-state-icon{color:var(--muted);margin-bottom:24px;opacity:.6}.empty-state-title{color:var(--fg);font-size:1.25rem;font-weight:600;margin:0 0 8px}.empty-state-message{color:var(--muted);font-size:.95rem;margin:0 0 4px}.empty-state-suggestion{color:var(--muted);font-size:.85rem;margin:0;opacity:.8}body.dark-mode .empty-state-icon{color:#666}.modal-backdrop{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:5000}.modal-backdrop.no-close{pointer-events:none}.modal-backdrop.no-close .modal-card{pointer-events:auto}.modal-card.camera-modal,.modal-card.light-modal,.modal-card.thermostat-modal{background:linear-gradient(135deg,#2249b7,#3f6eea);border-radius:16px;box-shadow:0 6px 20px -8px #00000026;color:#fff;display:flex;flex-direction:column;gap:20px;min-height:480px;padding:18px;position:relative;transition:filter .18s ease-in-out;width:450px}.modal-card.camera-modal.is-off,.modal-card.light-modal.is-off,.modal-card.thermostat-modal.is-off{filter:brightness(.78) saturate(.9)}.modal-row.top-controls{align-items:center;display:flex;justify-content:space-between}.modal-title{font-size:1.1rem;margin:0;text-align:center}.camera-feed{border-radius:12px;height:260px;margin:12px 0;overflow:hidden;position:relative}.camera-feed.off:after{background:#000;content:"";inset:0;opacity:.95;pointer-events:none;position:absolute}.camera-feed img{height:100%;object-fit:cover;width:100%}.color-wheel-container{display:flex;justify-content:center;margin-bottom:20px;margin-top:12px}.color-wheel{border:2px solid #ffffff26;border-radius:50%;box-shadow:0 12px 30px #00000040;display:block;height:260px;width:260px}.color-wheel.fallback{background:conic-gradient(red,#ff0,lime,aqua,blue,#f0f,red)}.color-wheel img{border-radius:50%;height:100%;object-fit:cover;width:100%}.brightness-control{align-items:center;display:flex;gap:6px;margin-bottom:8px;padding-left:16px}.brightness-label{color:#e9eefc;font-size:18px;margin:0}.brightness-value-bubble{align-items:center;background:#00000080;border-radius:4px;color:#fff;display:inline-flex;font-size:12px;height:22px;justify-content:center;line-height:1;margin-left:8px;min-width:22px;padding:0 6px;-webkit-user-select:none;user-select:none}.brightness-slider-container{padding:0 16px 12px}.brightness-slider-container input[type=range]{width:100%}.temperature-dial-container{display:flex;justify-content:center;margin:14px 0 22px}.temperature-dial{align-items:center;background:radial-gradient(circle at 50% 42%,#181818 0,#0f0f0f 55%,#000 100%);border:2px solid #ffffff1f;border-radius:50%;box-shadow:0 20px 40px #00000059;cursor:pointer;display:flex;height:220px;justify-content:center;transition:box-shadow .2s ease;width:220px}.temperature-dial.editing{box-shadow:0 20px 40px #00000059,0 0 0 2px #fff3;cursor:text}.temperature-display,.temperature-input{color:#cfe1ff;font-size:64px;font-weight:700;letter-spacing:1px}.temperature-input{background:#0000;border:none;outline:none;text-align:center;width:120px}.setpoint-control{color:#e9eefc;font-size:18px;margin-bottom:8px}.setpoint-slider{width:100%}.delete-btn{align-items:center;background:#3a3a3a;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;gap:6px;padding:6px 12px}.delete-btn:hover{background:#5a5a5a}.confirm-overlay{align-items:center;background:#00000040;display:flex;inset:0;justify-content:center;position:fixed;z-index:6000}.confirm-modal-card{background:#2c2c2c;border-radius:14px;box-shadow:0 10px 40px #00000080;color:#fff;padding:22px;text-align:center;width:320px}.confirm-title{font-size:1.1rem;margin:0 0 10px}.confirm-text{font-size:.95rem;margin-bottom:20px;opacity:.85}.confirm-actions{display:flex;gap:12px;justify-content:center}.confirm-delete-btn{background:#d32f2f;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:8px 14px}.confirm-delete-btn:hover{background:#b71c1c}.confirm-cancel-btn{background:#4a4a4a;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:8px 14px}.confirm-cancel-btn:hover{background:#6a6a6a}.add-device-btn{background:linear-gradient(90deg,#a0c4ff,#bdb2ff);border:none;border-radius:12px;color:#111;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 18px;transition:transform .2s ease,opacity .2s ease}.add-device-btn:hover{opacity:.9;transform:scale(1.05)}.add-device-form{align-items:center;display:flex;gap:10px}.add-device-form input,.add-device-form select{background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--fg);font-size:.9rem;padding:8px 12px}.add-device-form select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:16px;padding-right:32px}body.dark-mode .add-device-form select{background-color:var(--surface);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.add-device-form input:focus{background:var(--surface-elev);border-color:var(--muted);outline:none}.add-device-form select:focus{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a0c4ff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");outline:none}.add-device-form select:hover{border-color:var(--muted)}.add-device-form button{background:linear-gradient(90deg,#a0c4ff,#bdb2ff);border:none;border-radius:10px;color:#111;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:transform .2s ease}.add-device-form button:hover{transform:scale(1.05)}.add-device-form select option{background:var(--surface);color:var(--fg);padding:8px 12px}@media (max-width:600px){.add-device-form{align-items:stretch;flex-direction:column;gap:6px}.add-device-form button,.add-device-form input,.add-device-form select{box-sizing:border-box;font-size:.8rem;min-width:0;padding:6px 10px;width:100%}.add-device-form button{border-radius:8px}.add-device-form select{background-size:14px;padding-right:28px}}@media (max-width:400px){.add-device-form button,.add-device-form input,.add-device-form select{font-size:.7rem;padding:4px 6px}.add-device-form button{border-radius:6px}.add-device-form select{background-size:12px;padding-right:20px}}.all-room-errors{max-width:300px;position:fixed;right:20px;top:120px;z-index:100}.toast-device-error.global-error{word-wrap:break-word;margin-bottom:8px;position:relative;right:auto;top:auto}.toast-block-error,.toast-device-error,.toast-room-error{animation:fadeIn .2s ease-out forwards;background:#ff4d4f;border-radius:6px;box-shadow:0 4px 14px #00000040;color:#fff;font-size:.9rem;opacity:1;padding:8px 12px;position:absolute;z-index:10}.toast-device-error.fade-out,.toast-room-error.fade-out{animation:fadeOut .5s ease-in forwards;opacity:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}.toast-room-error{left:110px;top:-40px;z-index:20}.toast-device-error{animation:fadeIn .2s ease-out forwards;background:#ff4d4f;border-radius:6px;box-shadow:0 4px 14px #00000040;color:#fff;font-size:.9rem;left:65%;max-width:300px;opacity:1;padding:8px 12px;position:absolute;top:-20px;transform:translateX(-50%);width:-webkit-max-content;width:max-content;word-break:break-word;z-index:20}.toast-block-error{bottom:-32px;left:0}@media (max-width:600px){.all-room-errors{max-width:90vw;right:8px;top:70px}.toast-block-error,.toast-device-error,.toast-room-error{font-size:.8rem;max-width:90vw;padding:6px 8px}.toast-device-error,.toast-room-error{left:50%;position:absolute;top:-28px;transform:translateX(-50%);z-index:30}.toast-block-error{bottom:-16px;left:50%;transform:translateX(-50%)}}@media (max-width:400px){.all-room-errors{max-width:98vw;right:2px;top:48px}.toast-block-error,.toast-device-error,.toast-room-error{font-size:.7rem;max-width:98vw;padding:4px}.toast-device-error,.toast-room-error{left:50%;position:absolute;top:-20px;transform:translateX(-50%);z-index:30}}*{box-sizing:border-box}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;margin:0}a{color:#0366d6;text-decoration:none}a.active{font-weight:600}
/*# sourceMappingURL=main.29875811.css.map*/