:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.devices-modal-button-warning{background:#fdcb6e;color:#232323;border:none;font-weight:600}.devices-modal-button-warning:hover{background:#ffeaa7}.devices-page-container{width:100%;max-width:600px;margin:20px auto;background:#1e2230;border-radius:12px;padding:20px 16px;box-shadow:0 2px 16px #00000052;box-sizing:border-box;position:relative;min-height:460px;min-width:249px}.devices-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .2s ease-out}.devices-modal{background:#232936;border-radius:12px;padding:24px 20px 20px;max-width:320px;width:calc(100% - 48px);box-shadow:0 20px 60px #00000080;border:1px solid rgba(208,211,219,.08);animation:scaleIn .25s cubic-bezier(.34,1.56,.64,1)}.devices-modal-title{color:#d0d3db;font-size:17px;font-weight:500;margin-bottom:8px;letter-spacing:.2px}.devices-modal-text{color:#95a5a6;font-size:13px;margin:0;line-height:1.5}.devices-modal-actions{display:flex;gap:10px;margin-top:20px}.devices-modal-button{flex:1;padding:11px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none}.devices-modal-button-cancel{background:#d0d3db0f;color:#a8abb5;border:1px solid rgba(208,211,219,.1)}.devices-modal-button-cancel:hover{background:#d0d3db1f;color:#d0d3db}.devices-modal-button-delete{background:#e74c3c;color:#fff;border:none}.devices-modal-button-delete:hover{background:#c0392b}.devices-title{margin-bottom:18px;color:#d0d3db;font-size:20px;font-weight:500;letter-spacing:.3px}.devices-error{color:#e74c3c;background:#e74c3c14;border-radius:8px;padding:8px 12px;margin-bottom:12px;text-align:center;font-size:13px;border:1px solid rgba(231,76,60,.24)}.device-card{background:#d0d3db0a;border-radius:10px;padding:14px 16px;margin-bottom:12px;border:1px solid rgba(208,211,219,.08);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);animation:slideInUp .4s cubic-bezier(.4,0,.2,1) backwards;transform-origin:center}.device-card:hover{background:#d0d3db14;border-color:#2d8cf033;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.device-card-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.device-card-info{flex:1;min-width:0}.device-card-header{display:flex;align-items:center;justify-content:space-between;position:relative}.device-card-id{color:#d0d3db;font-size:15px;font-weight:500;word-break:break-all;flex:1;text-align:left;justify-content:flex-start}.device-copy-button{background:transparent;color:#95a5a6;border:none;border-radius:6px;padding:6px;font-size:16px;cursor:pointer;transition:all .2s;outline:none;display:flex;align-items:center;justify-content:center;opacity:.7;margin-left:8px}.device-copy-button:hover{color:#2d8cf0;opacity:1;background:#2d8cf014}.device-card-user{color:#a8abb5;font-size:13px;margin-bottom:2px;text-align:left;justify-content:flex-start}.device-card-lastseen{color:#95a5a6;font-size:12px;display:flex;align-items:center}.device-delete-button{padding:8px 16px;background:#e74c3c1f;color:#e74c3c;border:1px solid rgba(231,76,60,.24);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;margin-left:12px;min-width:64px}.device-delete-button:hover{background:#e74c3c33;border-color:#e74c3c66}.device-add-container{display:flex;gap:12px;margin-bottom:12px;margin-top:16px}.device-input{flex:1;background:#232936;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;padding:12px 14px;font-size:14px;outline:none;transition:all .2s}.device-add-button{width:100%;padding:12px 16px;background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;min-height:48px}.device-add-button:hover{background:#2d8cf033;border-color:#2d8cf066}.device-card-menu{position:relative;margin-left:8px}.device-menu-btn{background:none;border:none;padding:4px;cursor:pointer;border-radius:50%;color:#7f8fa6;font-size:18px;outline:none;box-shadow:none;transition:none}.device-menu-popup{position:absolute;top:28px;right:0;min-width:80px;background:#232936;border-radius:8px;box-shadow:0 2px 8px #0000002e;z-index:10;padding:6px 0;display:flex;flex-direction:column;align-items:stretch}.device-menu-delete{background:none;border:none;color:#e74c3c;font-size:15px;padding:8px 16px;text-align:left;cursor:pointer;border-radius:6px;transition:background .2s}.device-menu-delete:hover{background:#2d2f3a}.device-status-dot{display:inline-block;vertical-align:middle;margin-right:6px;box-shadow:0 0 2px #0000001f}.edit-dashboard-header{display:flex;align-items:center;justify-content:flex-start;gap:12px;margin-bottom:8px}.edit-dashboard-add-btn{position:absolute;top:16px;right:16px;background:none;border:none;color:#7f8fa6;cursor:pointer;font-size:22px;padding:0;display:inline-flex;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);z-index:10}.edit-dashboard-add-btn:hover{color:#2d8cf0;transform:rotate(90deg) scale(1.1)}.edit-dashboard-save-btn{position:absolute;top:16px;right:56px;background:none;border:none;color:#7f8fa6;cursor:pointer;font-size:22px;padding:0;display:inline-flex;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);z-index:10}.edit-dashboard-save-btn:hover:not(:disabled){color:#0f0;transform:scale(1.1)}.edit-dashboard-save-btn:disabled{opacity:.3;cursor:not-allowed}.edit-dashboard-success{color:#0f0;text-align:center;font-size:14px;margin-bottom:8px;animation:slideDown .3s cubic-bezier(.4,0,.2,1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.edit-dashboard-container{width:100%;max-width:600px;margin:20px auto;background:#1e2230;border-radius:12px;padding:20px 12px;box-shadow:0 2px 16px #00000052;box-sizing:border-box;position:relative;min-height:450px;min-width:296px}.edit-dashboard-title{color:#d0d3db;font-size:20px;font-weight:500;letter-spacing:.3px;text-align:center;margin-bottom:18px}.edit-dashboard-back-btn{position:absolute;top:16px;left:16px;background:none;border:none;color:#7f8fa6;cursor:pointer;font-size:22px;padding:0;display:inline-flex;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);z-index:10}.edit-dashboard-back-btn:hover{color:#d0d3db;transform:translate(-3px)}.edit-dashboard-grid{position:relative;width:302px;height:500px;background:#232936;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:10px 10px;border-radius:10px;margin:0 auto;overflow:hidden}.dashboard-item-positioned{position:absolute;cursor:grab;display:flex;align-items:center;justify-content:center;pointer-events:auto;-webkit-user-select:none;user-select:none;transition:opacity .2s ease,transform .2s ease;touch-action:none;animation:fadeInScale .4s cubic-bezier(.4,0,.2,1) backwards}.dashboard-item-positioned:nth-child(1){animation-delay:0s}.dashboard-item-positioned:nth-child(2){animation-delay:.05s}.dashboard-item-positioned:nth-child(3){animation-delay:.1s}.dashboard-item-positioned:nth-child(4){animation-delay:.15s}.dashboard-item-positioned:nth-child(5){animation-delay:.2s}.dashboard-item-positioned:nth-child(6){animation-delay:.25s}.dashboard-item-positioned:nth-child(7){animation-delay:.3s}.dashboard-item-positioned:nth-child(8){animation-delay:.35s}.dashboard-item-positioned:nth-child(9){animation-delay:.4s}.dashboard-item-positioned:nth-child(10){animation-delay:.45s}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.dashboard-item-positioned:hover{opacity:.9;filter:brightness(1.1)}.dashboard-item-positioned:active{cursor:grabbing;opacity:.6;z-index:1000;transform:scale(.95)}.dashboard-item-positioned.dragging{opacity:.3}.dashboard-item-preview{position:absolute;border-radius:8px;border:2px solid;pointer-events:none;z-index:999;transition:all .1s ease}.dashboard-item-preview.led-preview{border-radius:50%}.dashboard-item-preview.valid{background:#0f03;border-color:#0f0;box-shadow:0 0 20px #0f06}.dashboard-item-preview.invalid{background:#f003;border-color:red;box-shadow:0 0 20px #f006}.dashboard-item-positioned{box-sizing:border-box}.dashboard-item-preview{position:absolute;pointer-events:none;z-index:999;transition:all .1s ease}.dashboard-btn-wrapper{position:relative;display:flex;flex-direction:column;align-items:flex-start}.dashboard-btn-label{position:absolute;top:2px;left:0;font-size:11px;color:#a8abb5;font-weight:400;background:transparent;pointer-events:none;z-index:2}.dashboard-btn{width:90px;height:90px;border-radius:50%;font-size:1.6rem;font-weight:600;border:1px solid;background:#232936;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease;box-shadow:0 2px 12px #0000003d;cursor:pointer;outline:none;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:16px}button{-webkit-tap-highlight-color:transparent}.dashboard-btn.yellow{color:#ffc107;border-color:#ffc107}.dashboard-btn.yellow.active{background:#ffe082;border-color:#ffe082;color:#222}.dashboard-btn.cyan{color:#00eaff;border-color:#00eaff}.dashboard-btn.cyan.active{background:#b2faff;border-color:#b2faff;color:#222}.dashboard-btn.dark{color:#e0e0e0;border-color:#e0e0e0}.dashboard-btn.dark.active{background:#e0e0e0;border-color:#e0e0e0;color:#222}.dashboard-btn:hover,.dashboard-btn.active{box-shadow:0 4px 20px #00000052}.dashboard-btn[disabled]{pointer-events:none}@media(max-width:400px){.dashboard-btn{width:80px;height:80px;font-size:1.3rem;border:.5px solid}}@media(max-width:320px){.dashboard-btn{width:70px;height:70px;font-size:1.1rem}}.dashboard-led-container{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:0;padding:0;box-sizing:border-box}.dashboard-led-container.align-left{align-items:flex-start}.dashboard-led-container.align-center{align-items:center}.dashboard-led-container.align-right{align-items:flex-end}.dashboard-led-label{font-size:11px;color:#a8abb5;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;margin-bottom:0;line-height:1}.dashboard-led-wrapper{display:flex;align-items:center;justify-content:center}.dashboard-led-indicator{width:32px;height:32px;border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1);border:2px solid rgba(127,143,166,.3)}.dashboard-led-indicator.on{animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.dashboard-value-container{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 12px 12px;box-sizing:border-box;background:#23293680;border-radius:8px;position:relative}.dashboard-value-fieldset{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 12px 12px;box-sizing:border-box;background:#23293680;border-radius:8px;border:1px solid rgba(127,143,166,.3)}.dashboard-value-label{font-size:11px;color:#a8abb5;font-weight:500;white-space:nowrap;padding:0 6px;z-index:1}.dashboard-value-label.align-left{text-align:left}.dashboard-value-label.align-center{text-align:center}.dashboard-value-label.align-right{text-align:right}.dashboard-value-wrapper{flex:1;display:flex;align-items:center;justify-content:center;width:100%}.dashboard-value-wrapper.align-left{justify-content:flex-start}.dashboard-value-wrapper.align-center{justify-content:center}.dashboard-value-wrapper.align-right{justify-content:flex-end}.dashboard-value-display{font-size:24px;font-weight:600;line-height:1;text-shadow:0 0 10px currentColor}.dashboard-value-unit{font-size:16px;margin-left:4px;opacity:.8}.dashboard-speed-container{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px 12px;box-sizing:border-box;background:#23293680;border-radius:8px;border:1px solid rgba(127,143,166,.3)}.dashboard-speed-label{font-size:11px;color:#a8abb5;font-weight:400;white-space:nowrap;padding:0 6px;z-index:1}.dashboard-speed-label.align-left{text-align:left}.dashboard-speed-label.align-center{text-align:center}.dashboard-speed-label.align-right{text-align:right}.dashboard-speed-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;width:100%}.dashboard-speed-wrapper.align-left{align-items:flex-start}.dashboard-speed-wrapper.align-center{align-items:center}.dashboard-speed-wrapper.align-right{align-items:flex-end}.dashboard-speed-value{font-size:28px;font-weight:700;line-height:1;text-shadow:0 0 10px currentColor}.dashboard-speed-value{display:inline-flex;align-items:baseline;justify-content:center;gap:6px}.dashboard-speed-slider{width:100%;height:6px;border-radius:3px;background:#7f8fa633;outline:none;-webkit-appearance:none;appearance:none}.dashboard-speed-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--slider-color, #40c4ff);cursor:pointer;box-shadow:0 0 10px var(--slider-color, #40c4ff);transition:all .2s}.dashboard-speed-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 15px var(--slider-color, #40c4ff)}.dashboard-speed-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--slider-color, #40c4ff);cursor:pointer;border:none;box-shadow:0 0 10px var(--slider-color, #40c4ff);transition:all .2s}.dashboard-speed-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 15px var(--slider-color, #40c4ff)}.dashboard-speed-slider:disabled{opacity:.5;cursor:not-allowed}.dashboard-speed-slider:disabled::-webkit-slider-thumb{cursor:not-allowed}.dashboard-speed-slider:disabled::-moz-range-thumb{cursor:not-allowed}.dashboard-speed-unit{font-size:16px;margin-left:0;opacity:.85;font-weight:500}.devices-toast{position:fixed;top:20px;left:50%;transform:translate(-50%);color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;box-shadow:0 4px 16px #0000003d;z-index:11000;animation:slideDown .3s cubic-bezier(.4,0,.2,1)}.devices-toast--success{background:#27ae60f2}.devices-toast--validation{background:#f1c40ff2;color:#232323}.devices-toast--error{background:#e74c3cf2}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}.pin-selector-clear-btn{position:absolute;right:25px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#aaa;font-size:18px;cursor:pointer;padding:0 8px;outline:none;display:flex;align-items:center;z-index:2}.pin-selector-clear-btn:hover{color:#e74c3c}.pin-selector-wrapper{position:relative;width:100%;min-width:0!important;max-width:100%!important;box-sizing:border-box;margin:0!important;padding:0!important;height:100%}.pin-selector-input-group{display:flex;gap:0;border:1px solid #444b5a;border-radius:8px;background:#232936;overflow:hidden;box-shadow:0 1px 3px #0003;width:100%;min-width:0!important;max-width:100%!important;box-sizing:border-box;height:100%}.pin-selector-input{flex:1;padding:12px 16px;border:none;outline:none;font-size:14px;background:#232936;color:#f5f6fa}.pin-selector-input::placeholder{color:#7f8fa6;opacity:.6}.pin-selector-input:focus{background:#1e2230}.pin-selector-dropdown-btn{padding:4px 8px;border:none;background:#1e2230;cursor:pointer;font-size:11px;color:#7f8fa6;transition:background .2s;flex-shrink:0}.pin-selector-dropdown-btn:hover{background:#232936}.pin-selector-dropdown-btn:active{background:#2d3748}.pin-selector-dropdown{position:absolute;top:100%;left:0;right:0;background:#232936;border:1px solid rgba(127,143,166,.2);border-top:none;border-radius:0 0 6px 6px;max-height:200px;overflow-y:auto;z-index:1001;box-shadow:0 4px 12px #0000004d;margin-top:0}.pin-selector-item{padding:8px 10px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .15s;color:#d0d3db;font-size:.95rem;border:none}.pin-selector-item:last-child{border-bottom:none}.pin-selector-item:hover:not(.disabled){background:#2d8cf026;color:#2d8cf0}.pin-selector-item.active{background:#2d8cf040;color:#2d8cf0;font-weight:500}.pin-selector-item.disabled{color:#7f8fa6;cursor:default;background:transparent}.pin-selector-overlay{position:fixed;inset:0;z-index:1000}.pin-selector-dropdown::-webkit-scrollbar{width:6px}.pin-selector-dropdown::-webkit-scrollbar-track{background:#1a1f28}.pin-selector-dropdown::-webkit-scrollbar-thumb{background:#444b5a;border-radius:3px}.pin-selector-dropdown::-webkit-scrollbar-thumb:hover{background:#5a6370}.setting-popup-content{display:flex;flex-direction:column;gap:18px}.setting-header-block{display:flex;justify-content:space-between;align-items:center;margin-bottom:-4px}.setting-header-title{font-size:1.5rem;font-weight:600;color:#d0d3db;letter-spacing:.3px}.setting-ok-icon-btn{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:all .2s}.setting-ok-icon-btn svg{width:32px;height:32px}.setting-ok-icon-btn circle{fill:#232936;stroke:#7f8fa6;stroke-width:1.5;transition:stroke .2s}.setting-ok-icon-btn path{stroke:#7f8fa6;transition:stroke .2s}.setting-ok-icon-btn:hover circle,.setting-ok-icon-btn:hover path{stroke:#0f0}.setting-preview-btn{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60px;margin:4px 0 8px}.setting-preview-label{position:absolute;top:-16px;left:87px;font-size:12px;color:#b0b3bb;font-weight:400;background:transparent;pointer-events:none;z-index:2;letter-spacing:.2px}.preview-btn-circle{width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;border:3px solid #00e676;color:#00e676;background:#232936;box-shadow:0 2px 12px #0000004d}.preview-btn-green{border-color:#00e676;color:#00e676}.preview-btn-yellow{border-color:#ffd54f;color:#ffd54f}.preview-btn-red{border-color:#ff5252;color:#ff5252}.preview-btn-blue{border-color:#40c4ff;color:#40c4ff}.setting-block{margin-bottom:0}.setting-block-title{font-size:.9rem;font-weight:500;color:#d0d3db;margin-bottom:6px;text-align:left;letter-spacing:.2px}.setting-card{background:#232936;border:1px solid rgba(127,143,166,.2);border-radius:8px;padding:9px 11px;display:flex;align-items:center;gap:8px}.setting-card>.pin-selector-wrapper{width:100%;height:100%;margin:0;padding:0}.setting-input{width:100%;border:none;background:transparent;color:#d0d3db;font-size:.95rem;padding:4px 0;outline:none}.setting-input::placeholder{color:#7f8fa6;opacity:.6}.setting-align-group{gap:6px;padding:4px}.align-btn{flex:1;background:#1e2230;border:1.5px solid rgba(127,143,166,.3);border-radius:6px;padding:8px;cursor:pointer;transition:all .2s;color:#7f8fa6}.align-btn:hover{border-color:#7f8fa680;background:#232936}.align-btn.active{border-color:#00e676;background:#00e67626;color:#00e676}.setting-color-picker{gap:8px;padding:10px;justify-content:center}.color-option{width:32px;height:32px;border-radius:5px;border:2px solid transparent;cursor:pointer;transition:all .2s;position:relative;display:flex;align-items:center;justify-content:center}.color-option:hover{transform:scale(1.13)}.color-option.active{border-color:#d0d3db;box-shadow:0 0 0 2px #232936,0 0 8px #d0d3db80}.color-other{background:#1e2230;border:1.5px dashed rgba(127,143,166,.4);color:#7f8fa6}.color-other:hover{border-color:#7f8fa6b3;color:#d0d3db}.color-popup-overlay{position:fixed;inset:0;background:#1e2230b3;z-index:9999;display:flex;align-items:center;justify-content:center}.color-popup{background:#232936;border-radius:16px;box-shadow:0 4px 32px #00000052;padding:48px 16px 16px;min-width:280px;max-width:90vw;width:auto;position:relative}.color-popup-close-btn{position:absolute;top:8px;right:8px;background:none;border:none;padding:0;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;transition:color .2s}@media(max-width:480px){.color-popup{min-width:0;max-width:95vw;width:95vw;padding:40px 8px 16px}.color-popup-grid,.color-popup-row{gap:4px}.color-option{width:29px;height:29px;border-radius:6px}}.color-popup-close-btn svg{width:28px;height:28px}.color-popup-close-btn circle{fill:#232936;stroke:#7f8fa6;transition:stroke .2s}.color-popup-close-btn path{stroke:#7f8fa6;transition:stroke .2s}.color-popup-close-btn:hover circle,.color-popup-close-btn:hover path{stroke:#0f0}.color-popup-grid{display:flex;flex-direction:column;gap:4px;margin-top:0}.color-popup-row{display:flex;gap:4px;justify-content:center}.color-popup-close{margin:16px auto 0;display:block;background:#1e2230;color:#d0d3db;border:1px solid #7f8fa6;border-radius:8px;padding:7px 22px;font-size:1rem;cursor:pointer;transition:background .2s,color .2s}.color-popup-close:hover{background:#232936;color:#00e676}.pin-dropdown{width:100%;background:#232936;color:#d0d3db;font-size:.95rem;border:none;border-radius:8px;padding:4px 0;outline:none;appearance:none}.pin-dropdown option{background:#232936;color:#d0d3db}.virtualpins-container{min-height:535px;min-width:230px}.virtualpin-confirm-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#1e223073;z-index:9999;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .2s ease-out}.virtualpin-confirm-popup{background:#232936;border-radius:12px;box-shadow:0 2px 16px #00000052;padding:28px 32px 20px;min-width:320px;max-width:90vw;color:#d0d3db;text-align:center;animation:scaleIn .25s cubic-bezier(.34,1.56,.64,1)}.virtualpin-confirm-title{font-size:17px;font-weight:600;margin-bottom:10px}.virtualpin-confirm-desc{font-size:14px;margin-bottom:18px}.virtualpin-confirm-actions{display:flex;gap:16px;justify-content:center}.virtualpin-confirm-btn{padding:8px 22px;border-radius:8px;background:#2d8cf0;color:#fff;border:none;font-size:15px;font-weight:500;cursor:pointer;transition:background .2s}.virtualpin-confirm-btn.cancel{background:#7f8fa6;color:#fff}.virtualpin-type-label{font-size:11px;margin-top:2px;text-align:center;font-weight:400;letter-spacing:.2px}.virtualpin-type-label.type-bool{background:#00b894;color:#fff;border-radius:6px;padding:2px 8px;display:inline-block}.virtualpin-type-label.type-num{background:#0984e3;color:#fff;border-radius:6px;padding:2px 8px;display:inline-block}.virtualpin-type-label.type-text{background:#fdcb6e;color:#232323;border-radius:6px;padding:2px 8px;display:inline-block}} .virtualpins-container{margin-top:12px}.virtualpins-title{margin-bottom:14px;color:#d0d3db;font-size:16px;font-weight:500;letter-spacing:.3px;text-align:center}.virtualpins-error{color:#e74c3c;background:#e74c3c14;border-radius:8px;padding:8px 12px;margin-bottom:12px;text-align:center;font-size:13px;border:1px solid rgba(231,76,60,.24)}.virtualpins-button-group{display:flex;gap:10px;margin-bottom:16px}.virtualpins-button{flex:1;padding:11px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;min-height:48px}.virtualpins-button:disabled{cursor:not-allowed;opacity:.6}.virtualpins-button-add{flex:1;padding:11px 16px;background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;min-height:48px}.virtualpins-button-add:hover:not(:disabled){background:#2d8cf033;border-color:#2d8cf066}.virtualpins-button-add.processing,.virtualpins-button-add:disabled{background:#2d8cf00f;color:#95a5a6;border:1px solid rgba(149,165,166,.24);cursor:not-allowed;opacity:.6}.virtualpins-button-delete{flex:1;padding:11px 16px;background:#e74c3c1f;color:#e74c3c;border:1px solid rgba(231,76,60,.24);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;min-height:48px}.virtualpins-button-delete:hover:not(:disabled){background:#e74c3c33;border-color:#e74c3c66}.virtualpins-button-delete.processing,.virtualpins-button-delete:disabled{background:#e74c3c0f;color:#95a5a6;border:1px solid rgba(149,165,166,.24);cursor:not-allowed;opacity:.6}.virtualpin-card{background:#d0d3db0a;border-radius:10px;padding:14px 16px;margin-bottom:10px;border:1px solid rgba(208,211,219,.08);transition:all .25s cubic-bezier(.4,0,.2,1);animation:slideInUp .4s cubic-bezier(.4,0,.2,1) backwards}.virtualpin-card:hover{background:#d0d3db14;border-color:#2d8cf033;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.virtualpin-card:nth-child(1){animation-delay:0s}.virtualpin-card:nth-child(2){animation-delay:.05s}.virtualpin-card:nth-child(3){animation-delay:.1s}.virtualpin-card:nth-child(4){animation-delay:.15s}.virtualpin-card:nth-child(5){animation-delay:.2s}.virtualpin-card:nth-child(6){animation-delay:.25s}.virtualpin-card:nth-child(7){animation-delay:.3s}.virtualpin-card:nth-child(8){animation-delay:.35s}.virtualpin-card:nth-child(9){animation-delay:.4s}.virtualpin-card:nth-child(10){animation-delay:.45s}.virtualpin-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.virtualpin-label{color:#d0d3db;font-size:15px;font-weight:500}.virtualpin-input{width:100%;background:#232936;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;padding:10px 12px;font-size:14px;outline:none;box-sizing:border-box}.virtualpin-input:focus{border-color:#2d8cf066}.device-selector-clear-btn{position:absolute;right:40px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#aaa;font-size:18px;cursor:pointer;padding:0 8px;outline:none;display:flex;align-items:center;z-index:2}.device-selector-clear-btn:hover{color:#e74c3c}.device-selector-wrapper{position:relative;width:100%}.device-selector-input-group{display:flex;gap:0;border:1px solid #444b5a;border-radius:8px;background:#232936;overflow:hidden;box-shadow:0 1px 3px #0003}.device-selector-input{flex:1;padding:12px 16px;border:none;outline:none;font-size:14px;background:#232936;color:#f5f6fa}.device-selector-input:focus{background:#232936;border-color:#2d8cf0}.device-selector-dropdown-btn{padding:12px 16px;border:none;background:#1a1f28;cursor:pointer;font-size:12px;color:#95a5a6;transition:background .2s}.device-selector-dropdown-btn:hover{background:#232936}.device-selector-dropdown-btn:active{background:#2d3748}.device-selector-dropdown{position:absolute;top:100%;left:0;right:0;background:#232936;border:1px solid #444b5a;border-top:none;border-radius:0 0 8px 8px;max-height:250px;overflow-y:auto;z-index:1001;box-shadow:0 4px 12px #0000004d}.device-selector-item{padding:12px 16px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:background .15s;border-bottom:1px solid #2d3748;color:#d0d3db}.device-selector-item-token{font-size:12px;color:#7f8fa6;margin-left:auto;flex-shrink:0;white-space:nowrap}.device-selector-item:hover:not(.disabled){background:#2d8cf026;color:#2d8cf0}.device-selector-item:hover:not(.disabled) .device-selector-item-token{color:#2d8cf0}.device-selector-item.active{background:#2d8cf040;color:#2d8cf0;font-weight:500}.device-selector-item.disabled{color:#7f8fa6;cursor:default;background:transparent}.device-selector-overlay{position:fixed;inset:0;z-index:1000}.device-selector-dropdown::-webkit-scrollbar{width:6px}.device-selector-dropdown::-webkit-scrollbar-track{background:#1a1f28}.device-selector-dropdown::-webkit-scrollbar-thumb{background:#444b5a;border-radius:3px}.device-selector-dropdown::-webkit-scrollbar-thumb:hover{background:#5a6370}.testconnect-container{width:100%;max-width:680px;margin:20px auto;background:#1e2230;border-radius:12px;padding:20px 16px;box-shadow:0 2px 16px #00000052;box-sizing:border-box}.testconnect-title{margin-bottom:18px;color:#d0d3db;font-size:20px;font-weight:500;letter-spacing:.3px}.testconnect-status{margin-bottom:14px;padding:8px 12px;background:#d0d3db0a;border-radius:8px;color:#d0d3db;font-size:14px;display:flex;align-items:center;gap:8px}.testconnect-status-label{font-size:13px;opacity:.7}.testconnect-status-value{font-weight:500}.testconnect-status-value.connected{color:#27ae60}.testconnect-status-value.disconnected{color:#95a5a6}.testconnect-button-group{display:flex;gap:10px;margin-bottom:14px}.testconnect-button{flex:1;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;min-height:48px}.testconnect-button:disabled{cursor:not-allowed;opacity:.6}.testconnect-button-connect{background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24)}.testconnect-button-connect:hover:not(:disabled){background:#2d8cf033;border-color:#2d8cf066}.testconnect-button-connect:disabled{background:#2d8cf00f;color:#95a5a6;border:1px solid rgba(149,165,166,.24)}.testconnect-button-disconnect{background:#e74c3c1f;color:#e74c3c;border:1px solid rgba(231,76,60,.24)}.testconnect-button-disconnect:hover:not(:disabled){background:#e74c3c33;border-color:#e74c3c66}.testconnect-button-disconnect:disabled{background:#e74c3c0f;color:#95a5a6;border:1px solid rgba(149,165,166,.24)}.testconnect-select{width:100%;max-width:100%;background:#232936;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;padding:12px 14px;font-size:14px;outline:none;cursor:pointer;transition:all .2s;box-sizing:border-box;margin-bottom:14px}.testconnect-select:focus{border-color:#2d8cf066}.testconnect-select option{background:#232936;color:#d0d3db}.device-selector-wrapper{margin-bottom:14px}*** End Patch .testconnect-samples{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}.testconnect-sample-button{padding:6px 12px;background:#2d8cf01a;color:#2d8cf0;border:1px solid rgba(45,140,240,.18);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;margin-bottom:2px;margin-right:3px}.testconnect-sample-button:hover{background:#2d8cf02e;border-color:#2d8cf052}.testconnect-label{margin-bottom:8px;color:#d0d3db;font-size:14px;font-weight:500}.testconnect-textarea{width:100%;max-width:100%;background:#232936;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;padding:10px 12px;font-size:13px;font-family:monospace;outline:none;resize:vertical;transition:all .2s;box-sizing:border-box;min-width:0}.testconnect-textarea:focus{border-color:#2d8cf066}.testconnect-send-button{width:100%;padding:12px 16px;margin-bottom:14px;background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;min-height:48px}.testconnect-send-button:hover{background:#2d8cf033;border-color:#2d8cf066}.testconnect-received{background:#232936;padding:10px 12px;border-radius:8px;color:#a8abb5;font-size:12px;font-family:monospace;overflow:auto;margin:0;border:1px solid rgba(208,211,219,.08);word-wrap:break-word;word-break:break-all;white-space:pre-wrap;max-width:100%;box-sizing:border-box}.testconnect-devices-section{margin-top:20px}.testconnect-devices-list{list-style:none;padding:0;margin:0}.testconnect-device-item{padding:12px 14px;border-radius:8px;background:#2d8cf014;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.testconnect-device-info{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.testconnect-device-indicator{display:block;width:8px;height:8px;border-radius:50%;background:#27ae60;flex-shrink:0}.testconnect-device-id{color:#d0d3db;font-size:14px;font-weight:500;word-break:break-all}.testconnect-device-ip{color:#95a5a6;font-size:12px}.testconnect-no-devices{color:#95a5a6;font-size:13px}.usermgmt-container{width:100%;max-width:600px;margin:20px auto;background:#1e2230;border-radius:14px;padding:24px 20px;box-shadow:0 2px 16px #00000052;box-sizing:border-box}.usermgmt-title{margin-bottom:18px;color:#d0d3db;font-size:20px;font-weight:500;letter-spacing:.3px}.usermgmt-form{margin-bottom:18px}.usermgmt-input{width:100%;margin-bottom:12px;background:#232936;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;padding:10px 12px;font-size:14px;outline:none;transition:all .2s;box-sizing:border-box}.usermgmt-input:focus{border-color:#2d8cf066}.usermgmt-select{width:100%;margin-bottom:14px;background:#232936;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;padding:10px 12px;font-size:14px;outline:none;cursor:pointer}.usermgmt-button-create{width:100%;padding:10px 16px;background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none}.usermgmt-button-create:hover:not(:disabled){background:#2d8cf033;border-color:#2d8cf066}.usermgmt-button-create.loading,.usermgmt-button-create:disabled{opacity:.6;cursor:not-allowed}.usermgmt-error{color:#e74c3c;background:#e74c3c14;border-radius:8px;padding:8px 12px;margin-bottom:16px;text-align:center;font-size:13px;border:1px solid rgba(231,76,60,.24)}.user-card{background:#d0d3db0a;border-radius:10px;padding:16px;margin-bottom:12px;border:1px solid rgba(208,211,219,.08);transition:all .25s cubic-bezier(.4,0,.2,1);animation:slideInUp .4s cubic-bezier(.4,0,.2,1) backwards}.user-card:hover{background:#d0d3db14;border-color:#2d8cf033;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.user-card:nth-child(1){animation-delay:0s}.user-card:nth-child(2){animation-delay:.05s}.user-card:nth-child(3){animation-delay:.1s}.user-card:nth-child(4){animation-delay:.15s}.user-card:nth-child(5){animation-delay:.2s}.user-card:nth-child(6){animation-delay:.25s}.user-card:nth-child(7){animation-delay:.3s}.user-card:nth-child(8){animation-delay:.35s}.user-card:nth-child(9){animation-delay:.4s}.user-card:nth-child(10){animation-delay:.45s}.user-card-view{display:flex;justify-content:space-between;align-items:center}.user-card-info{margin-bottom:12px}.user-card-name{color:#d0d3db;font-size:16px;font-weight:500;margin-bottom:4px}.user-card-meta{display:flex;gap:12px;align-items:center;font-size:13px}.user-card-role{color:#a8abb5}.user-card-separator{color:#7f8fa6}.user-card-date{color:#7f8fa6;font-size:12px}.user-card-actions{display:flex;gap:8px}.user-button-edit{flex:1;padding:10px 16px;background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;min-height:44px}.user-button-edit:hover{background:#2d8cf033;border-color:#2d8cf066}.user-button-delete{flex:1;padding:10px 16px;background:#e74c3c1f;color:#e74c3c;border:1px solid rgba(231,76,60,.24);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;min-height:44px}.user-button-delete:hover{background:#e74c3c33;border-color:#e74c3c66}.user-edit-field{margin-bottom:12px}.user-edit-label{display:block;color:#a8abb5;font-size:12px;margin-bottom:6px}.user-edit-input{width:100%;background:#232936;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;padding:10px 12px;font-size:14px;outline:none;box-sizing:border-box;margin-bottom:10px}.user-edit-input:focus{border-color:#2d8cf066}.user-edit-select{width:100%;background:#232936;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;padding:10px 12px;font-size:14px;outline:none;box-sizing:border-box}.user-edit-actions{display:flex;gap:8px}.user-button-save{flex:1;padding:11px 16px;background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;min-height:44px;transition:all .2s;outline:none}.user-button-save:hover{background:#2d8cf033;border-color:#2d8cf066}.user-button-cancel{flex:1;padding:11px 16px;background:#d0d3db14;color:#a8abb5;border:1px solid rgba(208,211,219,.16);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;min-height:44px;transition:all .2s;outline:none}.user-button-cancel:hover{background:#d0d3db26;border-color:#d0d3db3d}.dashboard-edit-btn{position:absolute;top:16px;right:16px;background:none;border:none;color:#7f8fa6;cursor:pointer;font-size:22px;padding:0;display:inline-flex;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);z-index:10}.dashboard-edit-btn:hover{color:#2d8cf0;transform:rotate(45deg) scale(1.1)}.dashboard-container{width:100%;max-width:600px;margin:20px auto;background:#1e2230;border-radius:12px;padding:20px 12px;box-shadow:0 2px 16px #00000052;box-sizing:border-box;position:relative;min-height:585px;min-width:325px}.dashboard-title{margin-bottom:24px;color:#d0d3db;font-size:20px;font-weight:500;letter-spacing:.3px;text-align:center}.dashboard-back-btn{position:absolute;top:16px;left:16px;background:none;border:none;color:#7f8fa6;cursor:pointer;font-size:22px;padding:0;display:inline-flex;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);z-index:10}.dashboard-back-btn:hover{color:#d0d3db;transform:translate(-3px)}.dashboard-back-icon{vertical-align:middle}.dashboard-loading{text-align:center;color:#a8abb5;margin-bottom:12px}.dashboard-error{text-align:center;color:#e74c3c;margin-bottom:12px;animation:shake .4s cubic-bezier(.36,.07,.19,.97)}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px;justify-items:center;position:absolute;top:60px;left:3px}.dashboard-item{display:flex;flex-direction:column;align-items:center;width:100%;max-width:120px}.dashboard-item-label{font-size:13px;color:#a8abb5;margin-bottom:8px;text-align:center;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.dashboard-item-type{font-size:11px;color:#fbc531;margin-bottom:4px;text-align:center;font-weight:400;letter-spacing:.2px}.bottom-drawer{position:fixed;bottom:0;left:0;right:0;background:#1a1f28;border-top:1px solid #2d3748;box-shadow:0 -4px 16px #0006;z-index:100;max-height:50vh;display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.4,0,.2,1)}.bottom-drawer.closed{transform:translateY(calc(100% - 40px))}.bottom-drawer.open{transform:translateY(0)}.bottom-drawer-handle{display:flex;align-items:center;justify-content:center;padding:10px 16px;background:linear-gradient(180deg,#232936,#1a1f28);border-bottom:1px solid #2d3748;cursor:pointer;-webkit-user-select:none;user-select:none;min-height:40px;position:relative;transition:background-color .2s ease}.bottom-drawer-handle:hover{background:linear-gradient(180deg,#2d3748,#232936)}.bottom-drawer-handle-bar{width:32px;height:3px;background:#444b5a;border-radius:1.5px;position:absolute;top:10px;left:50%;transform:translate(-50%);transition:background-color .2s ease}.bottom-drawer-handle:hover .bottom-drawer-handle-bar{background:#555c6a}.bottom-drawer-title{font-size:13px;font-weight:600;color:#e8eaef;text-align:center;letter-spacing:.3px;margin-top:4px}.bottom-drawer-toggle-icon{font-size:11px;color:#7f8fa6;position:absolute;right:16px;bottom:25px;transition:transform .3s ease,color .2s ease;display:flex;align-items:center;gap:6px}.bottom-drawer-new-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0;animation:pulse 2s infinite;transition:background-color .3s ease;box-shadow:0 0 8px #0000004d}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.bottom-drawer.open .bottom-drawer-toggle-icon{transform:rotate(180deg)}.bottom-drawer-content{flex:1;overflow-y:auto;padding:0;background:#1a1f28;min-height:0}.bottom-drawer-logs{display:flex;flex-direction:column;gap:0;padding:12px 16px;font-size:13px;line-height:1.5;text-align:left}.bottom-drawer-log-item{display:flex;gap:12px;align-items:center;padding:8px 0;border-bottom:1px solid #232936;word-break:break-word;text-align:left;min-height:20px}.bottom-drawer-log-item:last-child{border-bottom:none}.bottom-drawer-log-item.empty{color:#7f8fa6;justify-content:center;text-align:center;padding:24px 0;border:none;font-size:13px;min-height:auto}.bottom-drawer-log-time{color:#6b7684;flex-shrink:0;white-space:nowrap;font-family:Courier New,Courier,monospace;font-size:12px;font-weight:500;letter-spacing:.2px;display:flex;align-items:center;height:100%}.bottom-drawer-log-message{color:#d4d8e0;word-break:break-all;flex:1;font-size:13px;line-height:1.4;display:flex;align-items:center}.bottom-drawer-log-item.new-log .bottom-drawer-log-time,.bottom-drawer-log-item.new-log .bottom-drawer-log-message{color:#10b981;font-weight:600}.bottom-drawer-log-item.new-log{background:#10b9810d;border-left:3px solid #10b981;padding-left:9px}.bottom-drawer-content::-webkit-scrollbar{width:6px}.bottom-drawer-content::-webkit-scrollbar-track{background:transparent}.bottom-drawer-content::-webkit-scrollbar-thumb{background:#3a4150;border-radius:3px;transition:background .2s ease}.bottom-drawer-content::-webkit-scrollbar-thumb:hover{background:#4a5160}@media(max-width:600px){.bottom-drawer{max-height:21vh}.bottom-drawer.closed{transform:translateY(calc(100% - 38px))}.bottom-drawer-handle{min-height:38px;padding:9px 14px}.bottom-drawer-handle-bar{top:9px}.bottom-drawer-title{font-size:12px;margin-top:3px}.bottom-drawer-logs{font-size:12px;padding:10px 14px}.bottom-drawer-log-item{padding:8px 0;gap:10px}.bottom-drawer-log-time{font-size:11px}.bottom-drawer-log-message{font-size:12px}.bottom-drawer-log-item.empty{padding:20px 0}}@media(max-width:380px){.bottom-drawer{max-height:40vh}.bottom-drawer.closed{transform:translateY(calc(100% - 36px))}.bottom-drawer-handle{min-height:36px;padding:8px 12px}.bottom-drawer-title,.bottom-drawer-logs{font-size:11px}.bottom-drawer-log-item{padding:6px 0}.bottom-drawer-log-message{font-size:11px}}.schedule-list{display:flex;flex-direction:column;gap:12px}.schedule-card{background:#d0d3db0a;border-radius:10px;padding:14px 16px;border:1px solid rgba(208,211,219,.08);transition:all .25s cubic-bezier(.4,0,.2,1);animation:slideInUp .4s cubic-bezier(.4,0,.2,1) backwards}.schedule-card:nth-child(1){animation-delay:.05s}.schedule-card:nth-child(2){animation-delay:.1s}.schedule-card:nth-child(3){animation-delay:.15s}.schedule-card:nth-child(4){animation-delay:.2s}.schedule-card:nth-child(5){animation-delay:.25s}.schedule-card:hover{background:#d0d3db14;border-color:#2d8cf033;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.schedule-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.schedule-card-title{color:#d0d3db;font-size:15px;font-weight:500;flex:1;line-height:1.4;text-align:left;margin-right:12px}.schedule-card-actions{display:flex;gap:8px}.schedule-btn-icon{background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24);border-radius:6px;padding:6px;cursor:pointer;transition:all .2s ease-out;display:flex;align-items:center;justify-content:center}.schedule-btn-icon:active{transform:scale(.95)}.schedule-btn-icon:hover{background:#2d8cf033}.schedule-btn-delete{background:#e74c3c1f;color:#e74c3c;border-color:#e74c3c3d}.schedule-btn-delete:hover{background:#e74c3c33}.schedule-card-info{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.schedule-info-row{display:flex;justify-content:space-between;align-items:center}.schedule-label{color:#95a5a6;font-size:13px}.schedule-value{color:#d0d3db;font-size:13px}.schedule-badge{padding:3px 10px;border-radius:6px;font-size:12px;font-weight:500}.badge-on{background:#2ecc7126;color:#2ecc71}.badge-off{background:#95a5a626;color:#95a5a6}.badge-value{background:#3498db26;color:#3498db}.schedule-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid rgba(208,211,219,.08)}.schedule-status{font-size:12px;padding:4px 10px;border-radius:6px}.status-active{background:#3498db26;color:#3498db}.status-done{background:#95a5a626;color:#95a5a6}.schedule-toggle{position:relative;display:inline-block;width:44px;height:24px}.schedule-toggle input{opacity:0;width:0;height:0}.schedule-toggle-slider{position:absolute;cursor:pointer;inset:0;background:#95a5a64d;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:24px}.schedule-toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;transition:.3s;border-radius:50%}.schedule-toggle input:checked+.schedule-toggle-slider{background:#2ecc71}.schedule-toggle input:checked+.schedule-toggle-slider:before{transform:translate(20px)}.schedule-devices-section{margin-top:12px;padding-top:12px;border-top:1px solid rgba(208,211,219,.08)}.schedule-devices-label{color:#95a5a6;font-size:12px;margin-bottom:8px;font-weight:500}.schedule-devices-list{display:flex;flex-direction:column;gap:6px}.schedule-device-item{background:#d0d3db08;border:1px solid rgba(208,211,219,.06);border-radius:6px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;animation:fadeIn .3s ease-out backwards}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.schedule-device-item:nth-child(1){animation-delay:.1s}.schedule-device-item:nth-child(2){animation-delay:.15s}.schedule-device-item:nth-child(3){animation-delay:.2s}.schedule-device-item:nth-child(4){animation-delay:.25s}.schedule-device-name{color:#d0d3db;font-size:13px;font-weight:500;margin-right:5px}.schedule-device-details{display:flex;gap:8px;align-items:center}.schedule-device-pin{color:#95a5a6;font-size:12px;background:#95a5a61a;padding:2px 8px;border-radius:4px}.schedule-list-empty{color:#95a5a6}.dropdown-wrapper{position:relative;width:100%}.dropdown-input-group{display:flex;gap:0;border:1px solid #444b5a;border-radius:8px;background:#232936;overflow:hidden;box-shadow:0 1px 3px #0003;transition:border-color .2s}.dropdown-input-group:focus-within{border-color:#2d8cf0}.dropdown-input{flex:1;padding:12px 16px;border:none;outline:none;font-size:14px;background:transparent;color:#f5f6fa}.dropdown-input::placeholder{color:#7f8fa6}.dropdown-clear-btn{position:absolute;right:40px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#aaa;font-size:18px;cursor:pointer;padding:0 8px;outline:none;display:flex;align-items:center;z-index:2;transition:color .2s}.dropdown-clear-btn:hover{color:#e74c3c}.dropdown-toggle-btn{padding:12px 16px;border:none;background:#1a1f28;cursor:pointer;font-size:12px;color:#95a5a6;transition:background .2s}.dropdown-toggle-btn:hover{background:#232936}.dropdown-toggle-btn:active{background:#2d3748}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#232936;border:1px solid #444b5a;border-radius:8px;max-height:250px;overflow-y:auto;z-index:1001;box-shadow:0 4px 12px #0000004d;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{padding:12px 16px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:background .15s;border-bottom:1px solid #2d3748;color:#d0d3db;font-size:14px;font-weight:400}.dropdown-item-label{text-align:left;flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover:not(.disabled){background:#2d8cf026;color:#2d8cf0}.dropdown-item.active{background:#2d8cf040;color:#2d8cf0;font-weight:500}.dropdown-item.disabled{color:#7f8fa6;cursor:default;background:transparent}.dropdown-item-badge{font-size:12px;padding:4px 8px;border-radius:6px;background:#2d8cf014;color:#2d8cf0;font-weight:600;min-width:40px;text-align:center}.dropdown-item>span,.dropdown-item>div,.dropdown-item>p{color:inherit;font-size:14px;line-height:1}.dropdown-item:hover .dropdown-item-badge,.dropdown-item.active .dropdown-item-badge{background:#2d8cf040;color:#fff}.dropdown-menu::-webkit-scrollbar{width:6px}.dropdown-menu::-webkit-scrollbar-track{background:#1a1f28}.dropdown-menu::-webkit-scrollbar-thumb{background:#444b5a;border-radius:3px}.dropdown-menu::-webkit-scrollbar-thumb:hover{background:#5a6370}.schedule-form-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.schedule-form{background:#232936;border-radius:12px;padding:0;max-width:420px;width:calc(100% - 32px);box-shadow:0 20px 60px #00000080;border:1px solid rgba(208,211,219,.08);animation:scaleIn .25s cubic-bezier(.34,1.56,.64,1);overflow:hidden}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.schedule-form-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(208,211,219,.08)}.schedule-form-title{color:#d0d3db;font-size:18px;font-weight:500;margin:0}.schedule-form-close{background:none;border:none;color:#95a5a6;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.schedule-form-close:hover{background:#d0d3db14;color:#d0d3db}.schedule-form-body{padding:20px;max-height:60vh;overflow-y:auto}.schedule-form-label{display:block;margin-bottom:16px}.schedule-form-label span{display:block;color:#a8abb5;font-size:13px;font-weight:500;margin-bottom:6px}.schedule-form-input{width:100%;padding:11px 14px;background:#1e2230;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;font-size:14px;outline:none;transition:all .2s;box-sizing:border-box}.schedule-form-input:focus{border-color:#2d8cf066;background:#232936;transform:translateY(-1px);box-shadow:0 2px 8px #2d8cf026}.schedule-form-input::placeholder{color:#7f8fa6}.schedule-form-actions{display:flex;gap:10px;padding:16px 20px;border-top:1px solid rgba(208,211,219,.08)}.schedule-form-btn{flex:1;padding:11px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease-out;outline:none;border:none}.schedule-form-btn:active{transform:scale(.98)}.schedule-btn-cancel{background:#d0d3db0f;color:#a8abb5;border:1px solid rgba(208,211,219,.1)}.schedule-btn-cancel:hover{background:#d0d3db1f;color:#d0d3db}.schedule-btn-save{background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24)}.schedule-btn-save:hover{background:#2d8cf033;border-color:#2d8cf066}.schedule-form-section{margin-top:16px;padding-top:16px;border-top:1px solid rgba(208,211,219,.08)}.schedule-form-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.schedule-form-section-header span{color:#a8abb5;font-size:13px;font-weight:500}.schedule-add-device-btn{background:#2ecc711f;color:#2ecc71;border:1px solid rgba(46,204,113,.24);border-radius:6px;padding:4px 10px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:4px}.schedule-add-device-btn:hover{background:#2ecc7133;transform:translateY(-1px)}.schedule-add-device-btn:active{transform:scale(.95)}.schedule-action-item{background:#d0d3db08;border:1px solid rgba(208,211,219,.08);border-radius:8px;padding:12px;margin-bottom:10px;animation:slideInRight .3s cubic-bezier(.4,0,.2,1) backwards}@keyframes slideInRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.schedule-action-item:nth-child(1){animation-delay:.05s}.schedule-action-item:nth-child(2){animation-delay:.1s}.schedule-action-item:nth-child(3){animation-delay:.15s}.schedule-action-item:nth-child(4){animation-delay:.2s}.schedule-action-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.schedule-action-number{color:#95a5a6;font-size:12px;font-weight:600}.schedule-remove-action-btn{background:#e74c3c1f;color:#e74c3c;border:1px solid rgba(231,76,60,.24);border-radius:6px;padding:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.schedule-remove-action-btn:hover{background:#e74c3c33;transform:rotate(90deg)}.schedule-remove-action-btn:active{transform:rotate(90deg) scale(.9)}.schedule-action-row{display:flex;gap:8px}.schedule-input-half{flex:1}.schedule-action-item .schedule-form-input{margin-bottom:8px}.schedule-action-item .schedule-form-input:last-child{margin-bottom:0}.schedule-form-sublabel{display:block;margin-bottom:10px;animation:slideDown .3s cubic-bezier(.4,0,.2,1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px);max-height:0}to{opacity:1;transform:translateY(0);max-height:100px}}.schedule-form-sublabel span{display:block;color:#7f8fa6;font-size:12px;font-weight:500;margin-bottom:4px}.schedule-form-input[type=time],.schedule-form-input select,select.schedule-form-input{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2395a5a6' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer;background-color:#232936;border:1px solid #444b5a}.schedule-form-input[type=time]:hover,.schedule-form-input select:hover,select.schedule-form-input:hover{border-color:#2d8cf04d}.schedule-form-input[type=time]:focus,.schedule-form-input select:focus,select.schedule-form-input:focus{border-color:#2d8cf0;background-color:#232936;box-shadow:0 2px 8px #2d8cf033}.schedule-form-input select option,select.schedule-form-input option{background:#232936;color:#d0d3db;padding:12px 16px;border-bottom:1px solid #2d3748}.schedule-form-input select option:hover,select.schedule-form-input option:hover{background:#2d8cf026;color:#2d8cf0}.schedule-form-input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer}.schedule-days-selector{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.schedule-day-btn{flex:1;min-width:70px;padding:10px 8px;background:#232936;border:1px solid #444b5a;border-radius:8px;color:#95a5a6;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.schedule-day-btn:hover{border-color:#2d8cf080;background:#2d8cf014;color:#d0d3db}.schedule-day-btn.active{background:#2d8cf0;border-color:#2d8cf0;color:#fff;box-shadow:0 2px 8px #2d8cf04d}.schedule-day-btn.active:hover{background:#3a9bff;border-color:#3a9bff}.schedule-page-container{width:100%;max-width:600px;margin:20px auto;background:#1e2230;border-radius:12px;padding:20px 16px;box-shadow:0 2px 16px #00000052;box-sizing:border-box;min-width:300px}.schedule-title{margin-bottom:18px;color:#d0d3db;font-size:20px;font-weight:500;letter-spacing:.3px}.schedule-add-btn{width:100%;padding:12px 16px;background:#2d8cf01f;color:#2d8cf0;border:1px solid rgba(45,140,240,.24);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;outline:none;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px}.schedule-add-btn:hover{background:#2d8cf033;border-color:#2d8cf066}.connect-page{width:100%;max-width:100%;margin:0;padding:0 16px 20px;box-sizing:border-box;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.connect-header{margin-bottom:20px}.connect-title{color:#d0d3db;font-size:22px;font-weight:500;margin:0 0 8px}.connect-count{color:#7f8fa6;font-size:14px}.connect-loading,.connect-error{text-align:center;padding:40px 20px;color:#95a5a6;font-size:15px}.connect-error{color:#e74c3c}.connect-empty{text-align:center;padding:60px 20px;color:#7f8fa6}.connect-empty svg{margin-bottom:16px;opacity:.5}.connect-empty p{margin:0;font-size:15px}.connect-devices-list{display:flex;flex-direction:column;gap:12px}.connect-device-card{background:#232936;border:1px solid #444b5a;border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease-out;animation:slideInUp .3s ease-out backwards;min-width:200px}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.connect-device-card:nth-child(1){animation-delay:.05s}.connect-device-card:nth-child(2){animation-delay:.1s}.connect-device-card:nth-child(3){animation-delay:.15s}.connect-device-card:nth-child(4){animation-delay:.2s}.connect-device-card:nth-child(5){animation-delay:.25s}.connect-device-card:hover{border-color:#2d8cf066;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.connect-device-card.active{border-color:#2d8cf0;box-shadow:0 4px 16px #2d8cf026}.connect-device-header{display:flex;justify-content:space-between;align-items:center}.connect-device-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.connect-device-icon{width:40px;height:40px;background:#2d8cf01f;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#2d8cf0;flex-shrink:0}.connect-device-id{color:#d0d3db;font-size:16px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.connect-device-count{color:#7f8fa6;font-size:13px;margin-top:2px}.connect-expand-icon{color:#95a5a6;font-size:12px;transition:transform .2s;flex-shrink:0;margin-left:8px}.connect-device-card.active .connect-expand-icon{color:#2d8cf0}.connect-connections-list{margin-top:16px;padding-top:16px;border-top:1px solid rgba(208,211,219,.08);display:flex;flex-direction:column;gap:12px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.connect-connection-item{background:#d0d3db08;border:1px solid rgba(208,211,219,.08);border-radius:8px;padding:12px;display:flex;gap:12px;animation:fadeIn .3s ease-out backwards}.connect-connection-item:nth-child(1){animation-delay:.05s}.connect-connection-item:nth-child(2){animation-delay:.1s}.connect-connection-item:nth-child(3){animation-delay:.15s}.connect-connection-number{color:#95a5a6;font-size:11px;font-weight:600;background:#95a5a61f;padding:2px 8px;border-radius:4px;height:fit-content}.connect-connection-details{flex:1;display:flex;flex-direction:column;gap:6px}.connect-connection-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.connect-label{color:#7f8fa6;font-size:12px;font-weight:500;white-space:nowrap}.connect-value{color:#d0d3db;font-size:13px;text-align:right;word-break:break-all}.connect-duration{color:#2ecc71;font-weight:500}.connect-no-connections{text-align:center;padding:40px 20px;color:#7f8fa6}.connect-no-connections svg{margin-bottom:12px;opacity:.5}.connect-no-connections p{margin:0;font-size:14px}body{background:#181c24;color:#f5f6fa;font-family:Roboto,Arial,sans-serif}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}fieldset{margin-inline:0px!important}.material-input{width:100%;padding:12px 16px;margin-bottom:20px;border-radius:8px;border:1px solid #444b5a;background:#232936;color:#f5f6fa;font-size:16px;outline:none;box-sizing:border-box;transition:border-color .2s}.material-input:focus{border-color:#2d8cf0}.material-btn{padding:12px 0;border-radius:8px;border:none;font-weight:600;font-size:16px;cursor:pointer;width:100%;margin-bottom:12px;box-shadow:0 2px 8px #2d8cf02e;transition:background .2s}.btn-login{background:#444b5a;color:#fff}.btn-login:hover{background:#232936}.btn-add{background:#2d8cf0;color:#fff}.btn-add:hover{background:#1976d2}.btn-delete{background:#e74c3c;color:#fff}.btn-delete:hover{background:#c0392b}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.loadding-text{text-align:center;padding:40px 20px;color:#95a5a6;font-size:15px}.app-container{max-width:720px;margin:0 auto;background:#181c24;min-height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden;font-family:Roboto,Arial,sans-serif;color:#f5f6fa}.menu-button{position:fixed;top:16px;left:16px;z-index:200;background:#232936;color:#f5f6fa;border:none;border-radius:12px;padding:10px 14px;font-size:20px;font-weight:400;box-shadow:0 2px 12px #0000003d;cursor:pointer;transition:all .2s;outline:none;display:flex;align-items:center;justify-content:center;min-height:44px;min-width:44px}.menu-button:hover{background:#2d8cf0;box-shadow:0 4px 16px #2d8cf03d}.menu-button-icon{font-size:22px}.drawer-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0000007a;z-index:299;transition:opacity .3s}.drawer{position:fixed;top:0;left:0;width:200px;height:100vh;background:#1e2230;z-index:300;box-shadow:4px 0 24px #0000007a;display:flex;flex-direction:column;padding:16px 0 0;border-top-right-radius:16px;border-bottom-right-radius:16px;transform:translate(0);transition:transform .3s ease-out}.drawer-menu-item{display:flex;align-items:center;gap:10px;padding:12px 16px;margin:4px 8px;border-radius:10px;color:#d0d3db;background:transparent;font-weight:400;font-size:14px;cursor:pointer;transition:all .2s ease;letter-spacing:.3px;min-height:44px;border:none;width:calc(100% - 16px);text-align:left}.drawer-menu-item.active{color:#2d8cf0;background:#2d8cf01f;font-weight:600}.drawer-menu-item:hover{background:#d0d3db14}.drawer-menu-item.active:hover{background:#2d8cf01f}.drawer-menu-icon{font-size:18px;opacity:.85}.logout-button{margin:auto 8px 16px;padding:12px 16px;color:#d0d3db;background:#d0d3db14;border-radius:10px;font-weight:500;font-size:13px;box-shadow:none;border:1px solid rgba(208,211,219,.12);text-align:center;outline:none;cursor:pointer;letter-spacing:.5px;transition:all .2s ease;min-height:48px}.logout-button:hover{background:#d0d3db26;border-color:#d0d3db3d}.logout-icon{font-size:16px;margin-right:6px;vertical-align:middle}.close-drawer-button{position:absolute;top:10px;right:10px;background:transparent;color:#d0d3db;border:none;font-size:22px;cursor:pointer;border-radius:8px;padding:6px 10px;transition:all .2s ease;opacity:.7;min-height:36px;min-width:36px}.close-drawer-button:hover{background:#d0d3db1f;opacity:1}.main-content{flex:1;padding:0}.app-title{text-align:center;font-size:24px;margin:20px 0;color:#d0d3db;font-weight:500;letter-spacing:.5px;text-shadow:none}.user-info{text-align:center;color:#a8abb5;font-size:15px;margin-bottom:12px}.username{color:#2d8cf0;font-weight:500}.content-area{min-height:600px;transition:min-height .2s}.virtual-pins-container{width:100%;max-width:660px;margin:20px auto;background:#1e2230;border-radius:12px;padding:16px;box-shadow:0 2px 16px #00000052;box-sizing:border-box}.device-input{margin-bottom:0;background:#232936;color:#d0d3db;border:1px solid rgba(208,211,219,.12);border-radius:8px;padding:12px 14px;font-size:14px;box-shadow:none;outline:none;transition:all .2s ease;min-height:48px;width:100%;box-sizing:border-box}.device-input:focus{border-color:#2d8cf066}
