*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#1a1a2e;color:#eee;min-height:100vh}.app{max-width:1200px;margin:0 auto;padding:2rem}.header{text-align:center;margin-bottom:2rem}.header h1{font-size:2rem;color:#00d9ff;margin-bottom:.5rem}.header p{color:#888}.card{background:#16213e;border-radius:12px;padding:1.5rem;margin-bottom:1rem;border:1px solid #0f3460}.card h2{font-size:1.2rem;margin-bottom:1rem;color:#00d9ff}.status{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.status-dot{width:10px;height:10px;border-radius:50%}.status-dot.connected{background:#0f8}.status-dot.disconnected{background:#f44}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#aaa;font-size:.9rem}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #0f3460;border-radius:6px;background:#1a1a2e;color:#eee;font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#00d9ff}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s}.btn-primary{background:#00d9ff;color:#000}.btn-primary:hover{background:#00b8d9}.btn-primary:disabled{background:#555;cursor:not-allowed}.btn-secondary{background:#0f3460;color:#eee}.btn-secondary:hover{background:#1a4a7a}.btn-danger{background:#f44;color:#fff}.btn-danger:hover{background:#c33}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.device-list{list-style:none}.device-list li{padding:1rem;background:#1a1a2e;border-radius:6px;margin-bottom:.5rem;cursor:pointer;transition:all .2s}.device-list li:hover{background:#0f3460}.device-list li.selected{border:2px solid #00d9ff}.device-name{font-weight:700}.device-vendor{color:#888;font-size:.9rem}.log{background:#0a0a15;border-radius:6px;padding:1rem;font-family:Monaco,Consolas,monospace;font-size:.85rem;max-height:300px;overflow-y:auto}.log-entry{margin-bottom:.25rem}.log-entry.tx{color:#0f8}.log-entry.rx{color:#fa0}.log-entry.error{color:#f44}.log-entry.info{color:#00d9ff}.hex-input{font-family:Monaco,Consolas,monospace}.response-data{font-family:Monaco,Consolas,monospace;background:#0a0a15;padding:1rem;border-radius:6px;word-break:break-all}.flex{display:flex;gap:1rem;align-items:center}.flex-1{flex:1}.mt-1{margin-top:1rem}.mb-1{margin-bottom:1rem}.btn-small{padding:.4rem .8rem;font-size:.85rem}.client-id{font-size:.8rem;color:#666;margin-top:.5rem}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:#16213e;border-radius:12px;border:1px solid #0f3460;width:90%;max-width:450px;max-height:90vh;overflow:auto}.dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #0f3460}.dialog-header h2{margin:0;color:#00d9ff;font-size:1.2rem}.dialog-close{background:none;border:none;color:#888;font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.dialog-close:hover{color:#fff}.dialog-body{padding:1.5rem}.dialog-body p{color:#aaa;margin-bottom:1.5rem}.dialog-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1rem 1.5rem;border-top:1px solid #0f3460}.dialog-error{color:#f44;margin-top:1rem;padding:.75rem;background:#ff44441a;border-radius:6px}.dialog-instructions{margin-top:1.5rem;padding:1rem;background:#1a1a2e;border-radius:6px}.dialog-instructions p{margin-bottom:.5rem;color:#888}.dialog-instructions ol{margin-left:1.5rem;color:#aaa}.dialog-instructions li{margin-bottom:.25rem}.dialog-instructions code{background:#0f3460;padding:.2rem .4rem;border-radius:3px;color:#00d9ff}.pairing-code-input{display:flex;justify-content:center;gap:.5rem;margin:1.5rem 0}.pairing-digit{width:50px;height:60px;text-align:center;font-size:1.5rem;font-family:Monaco,Consolas,monospace;background:#1a1a2e;border:2px solid #0f3460;border-radius:8px;color:#fff}.pairing-digit:focus{outline:none;border-color:#00d9ff}.pairing-digit:disabled{opacity:.5}.device-selector{margin-top:1rem}.device-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.device-selector-header h3{font-size:1rem;color:#aaa;margin:0}.device-selector-empty{text-align:center;padding:2rem 1rem;color:#666}.device-selector-empty p{margin-bottom:.5rem}.device-selector-list{list-style:none;padding:0;margin:0}.device-selector-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#1a1a2e;border-radius:6px;margin-bottom:.5rem;cursor:pointer;transition:all .2s}.device-selector-item:hover{background:#0f3460}.device-selector-item.selected{border:1px solid #00d9ff}.device-selector-item.offline{opacity:.7}.device-selector-info{display:flex;align-items:center;gap:.75rem}.device-selector-status .status-dot{width:8px;height:8px}.device-selector-details{flex:1}.device-selector-name{font-weight:500;color:#fff}.device-selector-id{font-size:.8rem;color:#666;font-family:Monaco,Consolas,monospace}.device-selector-actions{display:flex;gap:.5rem}
