@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-dark:#090a0f;--card-bg:#16171e99;--card-border:#ffffff0f;--card-border-active:#ffffff1f;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-gold:#ffbd4f;--accent-gold-rgb:255,189,79;--accent-blue:#3b82f6;--accent-blue-rgb:59,130,246;--accent-purple:#a855f7;--accent-purple-rgb:168,85,247;--accent-green:#10b981}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body,html{background:var(--bg-dark);color:var(--text-primary);overflow-x:hidden;overflow-y:hidden;width:100vw;height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app-container{position:relative;display:flex;background:radial-gradient(circle at 20% 50%,rgba(var(--accent-gold-rgb),0)0%,var(--bg-dark)100%);overflow-x:hidden;overflow-y:hidden;z-index:1;justify-content:center;align-items: center;width:100vw;max-width:100vw;min-height:100dvh;padding:1.5rem;transition:background .8s cubic-bezier(.16,1,.3,1)}.app-container.light-on{background:radial-gradient(circle at 30% 50%,rgba(var(--accent-gold-rgb),.12)0%,var(--bg-dark)85%)}.iot-dashboard{display:grid;grid-template-columns:1fr 1.25fr;border:1px solid var(--card-border);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);overflow:hidden;animation:fadeIn .8s ease-out;background:#0f111773;border-radius:28px;width:920px;max-width:95vw;height:560px;max-height:90vh;box-shadow:0 30px 60px #00000080,inset 0 1px #ffffff0d}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.visualizer-panel{display:flex;border-right:1px solid var(--card-border);position:relative;background:#ffffff04;flex-direction:column;justify-content:space-between;padding:2.25rem}.panel-header{display:flex;justify-content:space-between;align-items: center}.status-indicator{display:flex;background:#ffffff08;border:1px solid #ffffff0d;border-radius:20px;align-items: center;gap:8px;padding:6px 12px}.pulse-dot{border-radius:50%;width:6px;height:6px}.pulse-dot.green{background:var(--accent-green);box-shadow:0 0 8px var(--accent-green);animation:pulseGreen 2s infinite}@keyframes pulseGreen{0%{transform:scale(.95);box-shadow:0 0 #10b98180}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.indicator-label{letter-spacing:.02em;color:var(--text-secondary);font-size:11px;font-weight:500}.status-badge{letter-spacing:.05em;border-radius:6px;padding:4px 10px;transition:all .3s;font-size:11px;font-weight:700}.status-badge.on{background:rgba(var(--accent-gold-rgb),.15);color:var(--accent-gold);border:1px solid rgba(var(--accent-gold-rgb),.3);box-shadow:0 0 10px rgba(var(--accent-gold-rgb),.15)}.status-badge.off{color:var(--text-muted);background:#ffffff08;border:1px solid #ffffff0d}.bulb-display{display:flex;position:relative;justify-content:center;align-items: center;height:220px}.glow-ring{position:absolute;background:radial-gradient(circle,rgba(var(--accent-gold-rgb),.45)0%,rgba(var(--accent-gold-rgb),0)70%);pointer-events:none;opacity:0;border-radius:50%;width:180px;height:180px;transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);transform:scale(.8)}.glow-ring.is-on{opacity:1;transform:scale(1.15)}.bulb-svg{z-index:2;transition:filter .5s}.bulb-svg.glowing{filter:drop-shadow(0 0 25px rgba(var(--accent-gold-rgb),.5))}.telemetry-box{display:grid;grid-template-columns:minmax(0,1fr)minmax(0,1fr);background:#ffffff05;border:1px solid #ffffff0a;border-radius:18px;gap:12px;padding:1rem}.telemetry-item{display:flex;flex-direction:column;gap:4px}.telemetry-item:first-child{border-right:1px solid #ffffff0d;padding-right:10px}.telemetry-title{display:flex;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);align-items: center;gap:6px;font-size:11px;font-weight:500}.telemetry-icon{flex-shrink:0}.telemetry-icon.yellow{color:var(--accent-gold)}.telemetry-icon.blue{color:var(--accent-blue)}.telemetry-value{color:var(--text-primary);letter-spacing:-.02em;font-size:20px;font-weight:600}.telemetry-value .unit{color:var(--text-secondary);font-size:12px;font-weight:400}.telemetry-value.text-small{color:var(--text-secondary);margin-top:4px;font-size:13px;font-weight:500}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.controls-panel{display:flex;flex-direction:column;justify-content:space-between;padding:2.25rem}.controls-header{margin-bottom:1rem}.dashboard-title{letter-spacing:-.02em;margin-bottom:2px;font-size:22px;font-weight:700}.dashboard-subtitle{color:var(--text-muted);font-size:13px}.controls-list{display:flex;overflow-y:visible;flex-direction:column;flex-grow:1;gap:12px;padding-right:2px}.control-card{display:flex;background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;justify-content:space-between;align-items: center;padding:12px 16px;transition:all .3s}@media (hover:hover){.control-card:hover{border-color:var(--card-border-active);background:#16171ebf}}.control-card.flex-column{flex-direction:column;align-items:stretch;gap:0}.control-card-main-row{display:flex;justify-content:space-between;align-items: center;width:100%}.control-info{display:flex;flex-direction:column;gap:2px}.control-title-row{display:flex;align-items: center;gap:8px}.control-icon{color:var(--text-muted);transition:color .3s}.control-icon.yellow{color:var(--accent-gold)}.control-icon.blue{color:var(--accent-blue)}.control-icon.purple{color:var(--accent-purple)}.control-label{color:var(--text-primary);font-size:14px;font-weight:600}.control-desc{color:var(--text-secondary);font-size:11px}.switch-btn{position:relative;cursor:pointer;outline:none;background:#ffffff14;border:1px solid #ffffff0d;border-radius:100px;flex-shrink:0;width:44px;height:24px;padding:0;transition:all .35s cubic-bezier(.16,1,.3,1)}@media (hover:hover){.switch-btn:hover{background:#ffffff1f}}.switch-knob{position:absolute;background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .35s cubic-bezier(.16,1,.3,1);top:2px;left:2px;box-shadow:0 2px 4px #0003}.switch-btn.active{background:var(--accent-gold);border-color:rgba(var(--accent-gold-rgb),.2)}.switch-btn.active .switch-knob{transform:translate(20px)}.sub-control-panel{opacity:0;overflow:hidden;width:100%;max-height:0;margin-top:0;transition:max-height .35s cubic-bezier(.16,1,.3,1),opacity .3s,margin-top .35s}.sub-control-panel.expanded{opacity:1;border-top:1px solid #ffffff0a;max-height:48px;margin-top:8px;padding-top:8px}.sub-control-panel.expanded-large{opacity:1;border-top:1px solid #ffffff0a;max-height:160px;margin-top:8px;padding-top:8px}.motion-simulator{display:flex;justify-content:center}.btn-motion-trigger{color:var(--text-primary);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;width:100%;padding:6px 12px;transition:all .3s;font-family:inherit;font-size:11px;font-weight:500}.btn-motion-trigger:hover:not(:disabled){background:rgba(var(--accent-blue-rgb),.1);border-color:rgba(var(--accent-blue-rgb),.3);color:var(--accent-blue)}.btn-motion-trigger.triggered{background:rgba(var(--accent-blue-rgb),.2);border-color:rgba(var(--accent-blue-rgb),.5);color:#fff;box-shadow:0 0 12px rgba(var(--accent-blue-rgb),.2);animation:pulseBlue 1.5s infinite;font-weight:600}@keyframes pulseBlue{0%{box-shadow:0 0 #3b82f666}70%{box-shadow:0 0 0 6px #3b82f600}to{box-shadow:0 0 #3b82f600}}.btn-motion-trigger:disabled{opacity:.5;cursor:not-allowed}.lux-simulator{display:flex;flex-direction:column;gap:6px}.lux-header{display:flex;color:var(--text-secondary);justify-content:space-between;font-size:11px;font-weight:500}.lux-value{color:var(--text-primary);font-weight:600}.lux-value.glow-low{color:var(--accent-gold)}.lux-slider{-webkit-appearance:none;appearance:none;outline:none;background:#ffffff14;border-radius:10px;width:100%;height:5px;margin:4px 0;transition:all .3s}.lux-slider:disabled{opacity:.4}.lux-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;cursor:pointer;background:#fff;border-radius:50%;width:12px;height:12px;transition:transform .2s,background-color .2s;box-shadow:0 1px 3px #0000004d}.lux-slider:not(:disabled)::-webkit-slider-thumb:hover{background:var(--accent-gold);transform:scale(1.3)}.schedule-picker-box{display:flex;justify-content:space-between;align-items: center;gap:12px;margin-bottom:8px}.time-field{display:flex;flex-direction:column;flex:1;gap:4px}.time-field label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:10px;font-weight:600}.time-input-wrapper{position:relative;display:flex;align-items: center}.time-picker-input{color:var(--text-primary);outline:none;cursor:pointer;background:#ffffff08;border:1px solid #ffffff0f;border-radius:8px;width:100%;padding:8px 12px;transition:all .3s;font-family:inherit;font-size:13px;font-weight:500}.time-picker-input::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer;opacity:.6;transition:opacity .2s}.time-picker-input::-webkit-calendar-picker-indicator:hover{opacity:1}@media (hover:hover){.time-picker-input:hover:not(:disabled){background:#ffffff0d;border-color:#ffffff1f}}.time-picker-input:focus:not(:disabled){border-color:var(--accent-purple);background:#ffffff0f;box-shadow:0 0 0 3px #a855f726}.time-picker-input:disabled{opacity:.5;cursor:not-allowed}.time-divider{color:var(--text-muted);align-self: flex-end;padding-bottom:8px;font-size:11px;font-weight:500}.schedule-status-row{display:flex;color:var(--text-secondary);justify-content:space-between;align-items: center;padding:2px 2px 0;font-size:11px}.time-bold{color:var(--text-primary);font-weight:600}.schedule-match-badge{color:var(--text-muted);background:#ffffff0a;border:1px solid #ffffff05;border-radius:10px;padding:2px 8px;transition:all .3s;font-size:10px;font-weight:600}.schedule-action-row{display:flex;justify-content:space-between;align-items: center;width:100%;margin-top:8px;margin-bottom:8px}.confirm-btn{background:var(--accent-purple);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-left:auto;padding:6px 14px;transition:all .3s;font-family:inherit;font-size:11px;font-weight:600;box-shadow:0 4px 10px #a855f740}@media (hover:hover){.confirm-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 6px 14px #a855f759}}.confirm-btn:active:not(:disabled){transform:translateY(0)}.confirm-btn:disabled{color:var(--text-muted);cursor:not-allowed;box-shadow:none;background:#ffffff0d}.save-status-msg{color:var(--accent-green);animation:fadeIn .2s ease-out;font-size:11px;font-weight:500}.schedule-match-badge.active{color:var(--accent-purple);background:#a855f71f;border-color:#a855f740;box-shadow:0 0 8px #a855f71a}.meta-footer{display:flex;color:var(--text-muted);border-top:1px solid #ffffff0a;justify-content:space-between;align-items: center;margin-top:auto;padding-top:12px;font-size:11px}.footer-item{display:flex;align-items: center;gap:6px}.flatpickr-calendar.hasTime.noCalendar{background:#12131a!important;border:1px solid #ffffff14!important;border-radius:12px!important;width:120px!important;box-shadow:0 10px 25px #0009!important}.flatpickr-time{border:none!important;height:40px!important;line-height:40px!important}.flatpickr-time input{color:#fff!important;font-size:14px!important;font-weight:500!important}.flatpickr-time .flatpickr-am-pm{color:#fff!important}.flatpickr-time input:hover,.flatpickr-time .flatpickr-am-pm:hover,.flatpickr-time input:focus,.flatpickr-time .flatpickr-am-pm:focus{background:#ffffff0d!important}.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowTop:after{border-bottom-color:#ffffff14!important}.flatpickr-hour:hover,.flatpickr-hour:focus{border-radius:8px 0 0 8px!important}.flatpickr-minute:hover,.flatpickr-minute:focus{border-radius:0 8px 8px 0!important}@media (max-width:768px){body,html{overflow-y:auto}.app-container{overflow-y:auto;height:auto;min-height:100vh;padding:0!important}.iot-dashboard{grid-template-columns:1fr;backdrop-filter:none;-webkit-backdrop-filter:none;width:100%;height:auto;min-height:100vh;max-height:none;box-shadow:none!important;background:#090a0f73!important;border:none!important;border-radius:0!important}.visualizer-panel{border-right:none;border-bottom:1px solid var(--card-border);gap:1.5rem;padding:1.5rem}.bulb-display{height:140px}.glow-ring{width:120px;height:120px}.bulb-svg{transform:scale(.85)}.controls-panel{gap:1.5rem;padding:1.5rem}.controls-header{margin-bottom:.5rem}.sub-control-panel.expanded-large{max-height:250px}.schedule-picker-box{flex-direction:column;align-items:stretch;gap:8px}.time-divider{align-self: center;padding-bottom:0}}button:focus,.switch-btn:focus,.btn-motion-trigger:focus,.btn-close-dropdown:focus{outline:none!important;box-shadow:none!important}button:focus-visible{outline:none!important;box-shadow:none!important}.switch-btn:focus-visible{outline:none!important;box-shadow:none!important}.btn-motion-trigger:focus-visible{outline:none!important;box-shadow:none!important}.btn-close-dropdown:focus-visible{outline:none!important;box-shadow:none!important}.flatpickr-time input::selection,.time-picker-input::selection{color:inherit!important;background:0 0!important}.flatpickr-time input::-moz-selection{color:inherit!important;background:0 0!important}.time-picker-input::-moz-selection{color:inherit!important;background:0 0!important}.flatpickr-time input,.time-picker-input{user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important}.control-card.disabled{opacity:.45;pointer-events:none;filter:grayscale(.4)}.status-badge-mini{color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;display:inline-block;vertical-align:middle;background:#ffffff0d;border:1px solid #ffffff05;border-radius:4px;margin-left:8px;padding:2px 6px;font-size:9px;font-weight:700}.status-badge-mini.active{background:rgba(var(--accent-blue-rgb),.15);color:var(--accent-blue);border-color:rgba(var(--accent-blue-rgb),.3);box-shadow:0 0 8px rgba(var(--accent-blue-rgb),.15)}.status-badge-mini.light-active.active{background:rgba(var(--accent-gold-rgb),.15);color:var(--accent-gold);border-color:rgba(var(--accent-gold-rgb),.3);box-shadow:0 0 8px rgba(var(--accent-gold-rgb),.15)}.loading-overlay{position:absolute;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;z-index:100;opacity:1;visibility:visible;background:#0a0b10bf;justify-content:center;align-items: center;width:100%;height:100%;transition:opacity .5s cubic-bezier(.16,1,.3,1),visibility .5s;top:0;left:0}.loading-overlay.fade-out{opacity:0;visibility:hidden;pointer-events:none}.loading-content{display:flex;text-align:center;flex-direction:column;align-items: center;gap:16px}.loading-spinner{border:3px solid #ffffff0d;border-top-color:var(--accent-gold);animation:spin 1s linear infinite;border-radius:50%;width:48px;height:48px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.loading-subtext{color:var(--text-muted);font-size:12px;font-weight:400}.visualizer-panel,.controls-panel{opacity:1;transition:opacity .5s cubic-bezier(.16,1,.3,1)}.visualizer-panel.hidden-panel,.controls-panel.hidden-panel{pointer-events:none;opacity:0!important}
