@import"https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=Syne:wght@400;700;800&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh}:root{--off-bg: #0a0a0a;--on-bg: #0d0b06;--accent: #f5c842;--mono: "DM Mono", monospace;--display: "Syne", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--mono);background:var(--off-bg);color:#fff;min-height:100vh;transition:background 1.2s ease}body.is-on{background:var(--on-bg)}#root{min-height:100vh}.home-page{min-height:100vh;padding:48px 32px;display:flex;flex-direction:column;gap:48px}.home-header{padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.06)}.home-header-row{display:flex;justify-content:space-between;align-items:flex-end;gap:12px}.home-header h1{font-family:var(--display);font-size:2.4rem;font-weight:800;letter-spacing:-.03em;margin-bottom:8px}.home-header p{font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;opacity:.3}.connection-pill{display:inline-flex;align-items:center;margin-top:14px;font-size:.62rem;letter-spacing:.13em;text-transform:uppercase;padding:6px 10px;border:1px solid;border-radius:2px}.connection-pill.connected{color:#4ade80;border-color:#4ade804d;background:#4ade8014}.connection-pill.connecting{color:var(--accent);border-color:#f5c8424d;background:#f5c84214}.connection-pill.disconnected,.connection-pill.error{color:#f87171;border-color:#f871714d;background:#f8717114}.global-controls{display:flex;gap:12px;flex-wrap:wrap;padding:24px 0}.global-btn.add-strip{border-color:#4ade8059;color:#4ade80}.global-btn.add-strip:hover{border-color:#4ade80;background:#4ade8014}.global-btn.add-strip:disabled{border-color:#ffffff14;color:#ffffff4d}.add-strip-panel{border:1px solid rgba(255,255,255,.09);border-radius:4px;background:#ffffff05;padding:20px;display:flex;flex-direction:column;gap:16px;max-width:980px}.add-strip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.add-strip-grid label{display:flex;flex-direction:column;gap:8px;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;opacity:.7}.add-strip-grid input,.add-strip-grid select{padding:10px 12px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:2px;color:#fff;font-family:var(--mono);font-size:.8rem}.add-strip-grid input[type=color]{min-height:40px;padding:4px}.add-strip-grid input[type=range]{padding:0}.add-strip-actions{display:flex;justify-content:flex-end}.global-btn{flex:1;min-width:140px;padding:14px 20px;font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(255,255,255,.12);border-radius:2px;background:#ffffff05;color:#fff9;cursor:pointer;transition:all .3s;position:relative}.global-btn:hover{border-color:var(--accent);background:#ffffff0a;color:var(--accent)}.global-btn.enable:hover{border-color:#4ade80;color:#4ade80}.global-btn.disable:hover{border-color:#f87171;color:#f87171}.global-btn.pir.active{border-color:var(--accent);background:#f5c84214;color:var(--accent)}.motion-indicator{margin-left:8px;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.tiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;max-width:1400px}.tile{aspect-ratio:1;border:1px solid rgba(255,255,255,.08);border-radius:4px;background:#ffffff05;padding:28px;display:flex;flex-direction:column;justify-content:space-between;position:relative;cursor:pointer;transition:all .3s;animation:tileReveal .6s ease forwards}.tile-button{appearance:none;text-align:left;width:100%;color:inherit}@keyframes tileReveal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tile:nth-child(1){animation-delay:.05s}.tile:nth-child(2){animation-delay:.1s}.tile:nth-child(3){animation-delay:.15s}.tile.active:hover{border-color:var(--accent);background:#ffffff0a;transform:translateY(-4px)}.tile.disabled{cursor:not-allowed;opacity:.4}.tile-empty{cursor:default;border-style:dashed;border-color:#ffffff2e}.tile-icon{font-size:2.6rem;filter:grayscale(1) opacity(.5);transition:filter .3s}.tile.active:hover .tile-icon{filter:grayscale(0) opacity(1)}.tile-title{font-family:var(--display);font-size:1.3rem;font-weight:700;letter-spacing:-.01em;margin-bottom:6px}.tile-desc{font-size:.7rem;letter-spacing:.08em;opacity:.4}.tile-badge{position:absolute;top:20px;right:20px;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;padding:4px 10px;border:1px solid;border-radius:2px}.tile-badge.active{color:#4ade80;border-color:#4ade804d;background:#4ade8014}.tile-badge.soon{color:#ffffff4d;border-color:#ffffff1a;background:#ffffff05}.strip-color-indicator{position:absolute;bottom:20px;left:20px;width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,.2);transition:all .3s}.strip-tile:hover .strip-color-indicator{transform:scale(1.1);box-shadow:0 0 12px #ffffff4d}.strip-name-input{background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.1);color:#fff;font-family:var(--display);font-size:1.9rem;font-weight:800;letter-spacing:-.02em;text-align:center;padding:4px 8px;margin-bottom:6px;transition:border-color .3s}.strip-name-input:focus{outline:none;border-bottom-color:var(--accent)}.strip-name-input::placeholder{color:#ffffff4d}.device-page{min-height:100vh;padding:32px;display:flex;flex-direction:column;align-items:center;gap:32px}.device-container{max-width:600px;width:100%;display:flex;flex-direction:column;gap:24px}.device-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.06)}.device-header h1{font-family:var(--display);font-size:2rem;font-weight:800;letter-spacing:-.02em}.device-status{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:2px;border:1px solid}.device-status.online{color:#4ade80;border-color:#4ade804d;background:#4ade8014}.device-status.offline{color:#f87171;border-color:#f871714d;background:#f8717114}.device-info-card,.ota-card,.pir-card{border:1px solid rgba(255,255,255,.07);border-radius:4px;background:#ffffff05;padding:24px;display:flex;flex-direction:column;gap:16px}.ota-card h2,.pir-card h2{font-family:var(--display);font-size:1.3rem;font-weight:700;letter-spacing:-.01em;margin-bottom:8px}.pir-status{padding:4px 12px;border-radius:2px;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase}.pir-status.enabled{color:#4ade80;background:#4ade801a;border:1px solid rgba(74,222,128,.3)}.pir-status.disabled{color:#fff6;background:#ffffff08;border:1px solid rgba(255,255,255,.1)}.motion-status{padding:4px 12px;border-radius:2px;font-size:.7rem;letter-spacing:.1em}.motion-status.detected{color:var(--accent);background:#f5c8421a;border:1px solid rgba(245,200,66,.3);animation:pulse 1s infinite}.motion-status.idle{color:#fff6}.pir-timeout-slider{width:100%;display:flex;flex-direction:column;gap:8px;padding:16px 0;border-top:1px solid rgba(255,255,255,.04)}.pir-timeout-slider label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;opacity:.5;display:flex;justify-content:space-between;align-items:center}.pir-timeout-slider input[type=range]{width:100%;height:6px;border-radius:3px;background:#ffffff14;outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}.pir-timeout-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;transition:all .2s}.pir-timeout-slider input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 8px var(--accent)}.pir-timeout-slider input[type=range]::-moz-range-thumb{width:16px;height:16px;border:none;border-radius:50%;background:var(--accent);cursor:pointer;transition:all .2s}.pir-timeout-slider input[type=range]::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 8px var(--accent)}.slider-labels{display:flex;justify-content:space-between;font-size:.6rem;opacity:.3;letter-spacing:.08em}.btn.active{border-color:var(--accent);background:#f5c84214;color:var(--accent)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.info-row:last-child{border-bottom:none}.info-label{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;opacity:.4}.info-value{font-size:.85rem;font-weight:500;font-family:var(--mono)}.ota-status{padding:12px;background:#ffffff08;border-radius:2px;font-size:.75rem;letter-spacing:.08em;text-align:center}.led-page{min-height:100vh;display:grid;place-items:center;padding:32px;position:relative}.glow{position:fixed;top:-20vh;left:50%;transform:translate(-50%);width:60vw;height:60vw;border-radius:50%;background:radial-gradient(circle,rgba(245,200,66,.18) 0%,transparent 70%);opacity:0;transition:opacity 1.4s ease,background .3s ease;pointer-events:none;filter:blur(40px)}body.is-on .glow{opacity:1}.back-btn{position:fixed;top:32px;left:32px;padding:10px 20px;font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(255,255,255,.1);border-radius:2px;background:#ffffff05;color:#ffffff80;cursor:pointer;transition:all .3s;z-index:10}.back-btn:hover{border-color:var(--accent);color:var(--accent)}.global-btn:focus-visible,.tile-button:focus-visible,.back-btn:focus-visible,.btn:focus-visible,.login-btn:focus-visible,.input-group input:focus-visible,.add-strip-grid input:focus-visible,.add-strip-grid select:focus-visible,.strip-name-input:focus-visible,.strip-config-field input:focus-visible,.strip-config-field select:focus-visible,.color-picker-wrap input[type=color]:focus-visible,.brightness-slider-wrap input[type=range]:focus-visible,.pir-timeout-slider input[type=range]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:40px;padding:56px 64px;border:1px solid rgba(255,255,255,.07);border-radius:4px;background:#ffffff05;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:380px;width:100%}.header{text-align:center}.header h1{font-family:var(--display);font-size:1.9rem;font-weight:800;letter-spacing:-.02em;margin-bottom:6px}.header p{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;opacity:.3}.strip-config-grid{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.strip-config-field{display:flex;flex-direction:column;gap:8px}.strip-config-field label{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;opacity:.5}.strip-config-field input,.strip-config-field select{width:100%;padding:10px 12px;background:#ffffff08;border:1px solid rgba(255,255,255,.12);border-radius:2px;color:#fff;font-family:var(--mono);font-size:.8rem}.bulb-wrap{position:relative;width:100px;height:100px;display:grid;place-items:center}.bulb-ring,.bulb-ring-2{position:absolute;border-radius:50%;border:1px solid rgba(245,200,66,.12);transition:opacity .8s,transform .8s,box-shadow .8s,border-color .3s}.bulb-ring{inset:0;transform:scale(.9);opacity:0}.bulb-ring-2{inset:-14px;border-color:#f5c8420f;opacity:0}body.is-on .bulb-ring{opacity:1;transform:scale(1);box-shadow:0 0 30px 6px #f5c84226}body.is-on .bulb-ring-2{opacity:1}.bulb{width:72px;height:72px;border-radius:50%;border:1.5px solid rgba(255,255,255,.1);background:radial-gradient(circle at 35% 35%,#2a2a2a,#111);display:grid;place-items:center;transition:all .9s ease,filter .3s ease,background .3s ease}body.is-on .bulb{background:radial-gradient(circle at 35% 35%,#fff8d6,#f5c842);border-color:#f5c84266;box-shadow:0 0 20px 8px #f5c84259,0 0 60px 20px #f5c84226}.filament{width:28px;opacity:.15;transition:opacity .3s ease}body.is-on .filament{opacity:.6}.status-row{display:flex;align-items:center;gap:8px;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase}.dot{width:6px;height:6px;border-radius:50%;background:#333;transition:all .4s}.dot.on{background:#4ade80;box-shadow:0 0 6px #4ade80}.dot.off{background:#f87171;box-shadow:0 0 6px #f87171}.dot.connecting{background:var(--accent);animation:blink 1s infinite}.dot.offline{background:#555}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}.status-text{opacity:.4}.color-picker-wrap{width:100%;display:flex;flex-direction:column;gap:8px}.color-picker-wrap label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;opacity:.5}.color-picker-wrap input[type=color]{width:100%;height:48px;border:1px solid rgba(255,255,255,.12);border-radius:2px;background:transparent;cursor:pointer;padding:4px;transition:all .3s}.color-picker-wrap input[type=color]:hover{border-color:var(--accent)}.color-picker-wrap input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-wrap input[type=color]::-webkit-color-swatch{border:none;border-radius:1px}.color-picker-wrap input[type=color]::-moz-color-swatch{border:none;border-radius:1px}.brightness-slider-wrap{width:100%;display:flex;flex-direction:column;gap:8px}.brightness-slider-wrap label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;opacity:.5;display:flex;justify-content:space-between;align-items:center}.brightness-value{opacity:.7;font-weight:500}.brightness-slider-wrap input[type=range]{width:100%;height:6px;border-radius:3px;background:#ffffff14;outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}.brightness-slider-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;transition:all .2s}.brightness-slider-wrap input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 8px var(--accent)}.brightness-slider-wrap input[type=range]::-moz-range-thumb{width:16px;height:16px;border:none;border-radius:50%;background:var(--accent);cursor:pointer;transition:all .2s}.brightness-slider-wrap input[type=range]::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 8px var(--accent)}.brightness-slider-wrap input[type=range]::-webkit-slider-runnable-track{width:100%;height:6px;background:linear-gradient(to right,#ffffff14,#fff3);border-radius:3px}.brightness-slider-wrap input[type=range]::-moz-range-track{width:100%;height:6px;background:linear-gradient(to right,#ffffff14,#fff3);border-radius:3px}.control-actions{width:100%;display:flex;gap:10px}.btn{width:100%;padding:16px;font-family:var(--mono);font-size:.75rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;border:1px solid rgba(255,255,255,.12);border-radius:2px;background:transparent;color:#ffffff80;cursor:pointer;transition:all .3s}.btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn.danger{border-color:#f8717173;color:#f87171}.btn.danger:hover:not(:disabled){border-color:#f87171;color:#f87171;background:#f8717114}.btn:disabled{opacity:.3;cursor:not-allowed}.meta{font-size:.62rem;opacity:.2;letter-spacing:.1em;text-align:center;line-height:1.8}.meta a{color:var(--accent);text-decoration:none;opacity:.4;transition:opacity .2s}.meta a:hover{opacity:1}.login-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;z-index:999}.login-box{background:#141414f2;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:40px 48px;max-width:380px;width:90%}.login-box h2{font-family:var(--display);font-size:1.6rem;font-weight:800;letter-spacing:-.02em;margin-bottom:8px}.login-box p{font-size:.7rem;opacity:.4;letter-spacing:.08em;margin-bottom:24px}.login-box form{display:flex;flex-direction:column;gap:16px}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;opacity:.5}.input-group input{padding:12px 14px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:2px;color:#fff;font-family:var(--mono);font-size:.85rem;transition:all .3s}.input-group input:focus{outline:none;border-color:var(--accent);background:#ffffff0d}.login-btn{margin-top:8px;padding:14px;font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--accent);border-radius:2px;background:var(--accent);color:#000;cursor:pointer;transition:opacity .2s}.login-btn:hover{opacity:.9}.error-msg{padding:10px;background:#f871711a;border:1px solid rgba(248,113,113,.3);border-radius:2px;font-size:.7rem;color:#f87171;letter-spacing:.08em;margin-bottom:16px}@media(max-width:768px){.home-page{padding:24px 16px 28px;gap:28px}.home-header h1{font-size:1.9rem}.tiles-grid{grid-template-columns:1fr;gap:14px}.tile{aspect-ratio:auto;min-height:160px;padding:22px}.add-strip-panel{padding:16px}.add-strip-grid{grid-template-columns:1fr}.tile-title{font-size:1.1rem}.led-page,.device-page{padding:20px 14px}.card{gap:28px;padding:44px 22px 24px;max-width:100%}.strip-config-grid{grid-template-columns:1fr}.control-actions{flex-direction:column}.device-header{flex-direction:column;align-items:flex-start;gap:12px}.device-header h1{font-size:1.5rem}.back-btn{position:static;align-self:flex-start}.device-container{gap:16px}.info-row{flex-direction:column;align-items:flex-start;gap:8px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
