*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #f8f9fa;--text-primary: #213547;--text-secondary: #666;--text-tertiary: #333;--border-color: #e0e0e0;--border-color-light: #ccc;--accent-color: #1a73e8;--accent-hover: #1557b0;--shadow: rgba(0, 0, 0, .1);--shadow-hover: rgba(26, 115, 232, .15);--gradient-start: #f8f9fa;--gradient-end: #e8eaf6;--info-bg: #e3f2fd;--warning-bg: #fff3cd;--warning-border: #ffcc00;--warning-text: #856404}:root.dark-mode{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #242424;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-tertiary: #d0d0d0;--border-color: #404040;--border-color-light: #555;--accent-color: #4a9eff;--accent-hover: #6bb1ff;--shadow: rgba(0, 0, 0, .3);--shadow-hover: rgba(74, 158, 255, .2);--gradient-start: #2d2d2d;--gradient-end: #1f2937;--info-bg: #1e3a5f;--warning-bg: #3d3520;--warning-border: #997a00;--warning-text: #ffcc00}:root{color:var(--text-primary);background-color:var(--bg-primary)}body{margin:0;min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}a{font-weight:500;color:var(--accent-color);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit}code{font-family:Courier New,monospace}.app{max-width:900px;margin:0 auto;padding:2rem 1rem;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.header{text-align:center;margin-bottom:2rem}.header h1{font-size:2.5rem;margin-bottom:.5rem;color:var(--accent-color)}.subtitle{font-size:1.1rem;color:var(--text-secondary);margin:0}.main{display:flex;flex-direction:column;gap:1.5rem}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px var(--shadow)}.card h2{margin-top:0;margin-bottom:1rem;font-size:1.3rem;color:var(--text-tertiary)}.card h3{margin-top:0;margin-bottom:.5rem;font-size:1.1rem;color:var(--text-tertiary)}.card.warning{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-tertiary)}.select-input{width:100%;padding:.75rem;font-size:1rem;border:1px solid var(--border-color-light);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer}.select-input:disabled{background:var(--bg-tertiary);cursor:not-allowed}.device-preview{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg,var(--gradient-start) 0%,var(--gradient-end) 100%);border-radius:8px;cursor:pointer;transition:all .2s;border:2px solid transparent}.device-preview:hover{border-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-hover)}.device-preview-image{width:120px;height:90px;background:var(--bg-secondary);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px var(--shadow)}.device-preview-placeholder{font-size:1.5rem;font-weight:700;color:var(--accent-color)}.device-preview-info{flex:1}.device-preview-info h3{margin:0 0 .5rem;font-size:1.2rem;color:var(--text-tertiary)}.device-preview-badges{display:flex;gap:.5rem;flex-wrap:wrap}.badge-chip{padding:.4rem .8rem;background:var(--accent-color);color:#fff;border-radius:4px;font-size:.85rem;font-weight:500}.btn-change{padding:.75rem 1.5rem;background:var(--accent-color);color:#fff;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:all .2s}.btn-change:hover{background:var(--accent-hover);transform:scale(1.05)}.device-info{margin-top:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:4px}.info-grid{display:grid;gap:.75rem;margin-top:.5rem}.info-grid>div{font-size:.95rem}.features{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.badge{display:inline-block;padding:.25rem .75rem;background:var(--accent-color);color:#fff;border-radius:12px;font-size:.85rem;font-weight:500}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.checkbox-hint{margin:.5rem 0 0 1.75rem;font-size:.9rem;color:var(--text-secondary)}.manual-upload{background:var(--bg-tertiary);border:2px dashed var(--border-color-light);border-radius:8px;padding:1.5rem;text-align:center;transition:all .2s}.manual-upload:hover{border-color:var(--accent-color);background:var(--gradient-start)}.upload-section{margin-bottom:1rem}.upload-label{display:block;font-weight:500;margin-bottom:.75rem;color:var(--text-tertiary)}.file-input{display:block;margin:0 auto;padding:.5rem;border:1px solid var(--border-color-light);border-radius:4px;cursor:pointer;background:var(--bg-secondary);color:var(--text-primary)}.file-name{margin-top:.5rem;color:#34a853;font-weight:500}.upload-hint{font-size:.9rem;color:var(--text-secondary);margin:0}.upload-hint a{color:var(--accent-color);font-weight:500}.info-box{margin-top:1rem;padding:1rem;background:var(--info-bg);border-left:4px solid var(--accent-color);border-radius:4px}.info-box ul{margin:.5rem 0 0;padding-left:1.5rem}.info-box li{margin-bottom:.25rem}.flash-controls{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:#5f6368;color:#fff}.btn-secondary:hover:not(:disabled){background:#3c4043}.btn-success{background:#34a853;color:#fff}.btn-success:hover:not(:disabled){background:#2d8e47}.btn-danger{background:#ea4335;color:#fff}.btn-danger:hover:not(:disabled){background:#d33426}.btn-warning{background:#f9ab00;color:#fff}.btn-warning:hover:not(:disabled){background:#e09600}.btn-small{padding:.25rem .75rem;font-size:.9rem;background:#5f6368;color:#fff;border:none;border-radius:4px;cursor:pointer}.btn-small:hover{background:#3c4043}.btn-icon{font-size:1.2rem}.progress-container{margin-top:1rem}.progress-bar{width:100%;height:24px;background:var(--border-color);border-radius:12px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-color),var(--accent-hover));transition:width .3s ease}.progress-text{text-align:center;margin-top:.5rem;font-weight:500;color:var(--text-tertiary)}.console{margin-top:1rem}.console-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-weight:500}.console-content{max-height:300px;overflow-y:auto;padding:1rem;background:#1e1e1e;color:#d4d4d4;font-family:Courier New,monospace;font-size:.9rem;border-radius:4px;line-height:1.6}.console-line{margin:.25rem 0;white-space:pre-wrap;word-break:break-word}.console-line.success{color:#4ec9b0}.console-line.error{color:#f48771}.console-timestamp{color:#858585}.card ol{margin:.5rem 0;padding-left:1.5rem}.card li{margin-bottom:.5rem}.footer{text-align:center;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color);color:var(--text-secondary)}.footer a{color:var(--accent-color);text-decoration:none}.footer a:hover{text-decoration:underline}.footer .small{font-size:.9rem;margin-top:.5rem}.theme-toggle{position:fixed;top:1rem;right:1rem;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50%;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px var(--shadow);font-size:1.5rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;z-index:1000}.theme-toggle:hover{transform:scale(1.1) rotate(20deg);box-shadow:0 4px 12px var(--shadow-hover);background:var(--bg-tertiary)}@media(max-width:768px){.app{padding:1rem .5rem}.header h1{font-size:2rem}.flash-controls{flex-direction:column}.btn{width:100%;justify-content:center}.theme-toggle{top:.5rem;right:.5rem;width:45px;height:45px;font-size:1.3rem}}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-secondary);border-radius:12px;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;padding:2rem;color:var(--text-primary)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:1.5rem;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-filters{margin-bottom:2rem}.filter-section{margin-bottom:1rem}.filter-section label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-secondary);font-size:.9rem}.filter-chips{display:flex;flex-wrap:wrap;gap:.5rem}.filter-chip{padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;color:var(--text-primary);cursor:pointer;transition:all .2s;font-size:.9rem}.filter-chip:hover{background:var(--bg-secondary);border-color:var(--border-color-light)}.filter-chip.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;margin-top:1.5rem}.device-card{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s;position:relative;display:flex;flex-direction:column}.device-card:hover{border-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-hover)}.device-card.selected{border-color:#34a853;background:var(--bg-secondary)}.device-image{aspect-ratio:4/3;background:var(--bg-secondary);border-radius:4px;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:.5rem}.device-image img{width:100%;height:100%;object-fit:contain}.device-placeholder{font-size:1.5rem;font-weight:700;color:var(--accent-color);text-align:center;padding:1rem}.device-info-card{flex:1}.device-info-card h5{margin:0 0 .5rem;font-size:1rem;color:var(--text-primary);line-height:1.3}.device-badges{display:flex;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.badge-chip{padding:.25rem .5rem;background:var(--accent-color);color:#fff;border-radius:4px;font-size:.75rem;font-weight:500}.badge-vendor{padding:.25rem .5rem;background:#5f6368;color:#fff;border-radius:4px;font-size:.75rem;font-weight:500}.device-specs{font-size:.85rem;color:var(--text-secondary)}.selected-indicator{position:absolute;top:.5rem;right:.5rem;background:#34a853;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.no-devices{text-align:center;padding:3rem;color:var(--text-secondary)}@media(max-width:768px){.modal-content{padding:1rem}.devices-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.filter-chips{gap:.25rem}.filter-chip{padding:.4rem .8rem;font-size:.85rem}}.firmware-version-badge{display:inline-flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,var(--accent-color) 0%,var(--accent-hover) 100%);color:#fff;padding:.75rem 1.5rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500}.version-label{font-size:.9rem;opacity:.9}.version-number{font-size:1.1rem;font-weight:600}.firmware-options{display:flex;flex-direction:column;gap:1.5rem}.option-group{display:flex;flex-direction:column;gap:.75rem}.option-label{font-weight:600;color:var(--text-tertiary);font-size:1rem}.protocol-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.protocol-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s;text-align:left}.protocol-card:hover{border-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-hover)}.protocol-card.selected{border-color:#34a853;background:var(--bg-tertiary);box-shadow:0 4px 12px #34a85333}.protocol-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.protocol-name{font-weight:600;color:var(--text-tertiary);font-size:.95rem}.check-icon{color:#34a853;font-size:1.2rem;font-weight:700}.protocol-description{font-size:.85rem;color:var(--text-secondary);line-height:1.4}.ble-toggle{display:flex;align-items:center;gap:1rem;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s;text-align:left;width:100%}.ble-toggle:hover{border-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-hover)}.ble-toggle.enabled{border-color:#34a853;background:var(--bg-tertiary)}.toggle-icon{width:24px;height:24px;border:2px solid var(--border-color-light);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;color:#fff;font-weight:700}.ble-toggle.enabled .toggle-icon{background:#34a853;border-color:#34a853}.toggle-content{display:flex;flex-direction:column;gap:.25rem}.toggle-title{font-weight:600;color:var(--text-tertiary);font-size:.95rem}.toggle-hint{font-size:.85rem;color:var(--text-secondary)}.upload-area{background:var(--bg-tertiary);border:2px dashed var(--border-color-light);border-radius:8px;padding:1.5rem;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.upload-area:hover{border-color:var(--accent-color);background:var(--bg-secondary)}.file-input-hidden{display:none}.upload-button{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 2rem;background:var(--accent-color);color:#fff;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500;border:none;font-size:1rem;min-width:200px}.upload-button:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-hover)}.upload-icon{font-size:1.3rem}.uploaded-file{display:inline-flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;background:#e8f5e9;border:2px solid #34a853;border-radius:6px;color:#1b5e20;font-weight:500;margin-top:.5rem}.file-icon{color:#34a853;font-size:1.3rem;font-weight:700}.file-name{font-size:.95rem}.upload-hint-top{margin:0 0 1rem;font-size:.9rem;color:var(--text-secondary);width:100%}.upload-hint-top a{color:var(--accent-color);font-weight:500;text-decoration:none}.upload-hint-top a:hover{text-decoration:underline}
