@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap";:root{--color-primary:#ff7a2f;--color-primary-start:#ffb14a;--color-primary-end:#ff5a1f;--gradient-primary:linear-gradient(135deg, var(--color-primary-start), var(--color-primary-end));--color-bg:#0a0a0a;--color-surface:#181818;--color-surface-hover:#1e1e1e;--color-elevated:#222;--color-border:#2a2a2a;--color-border-hover:#444;--color-border-subtle:#ffffff0f;--color-text:#f2f2f2;--color-text-secondary:#aaa;--color-text-muted:#888;--color-success:#22c55e;--color-error:#f87171;--radius-sm:6px;--radius-md:8px;--radius-lg:10px}*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg);color:var(--color-text);margin:0;font-family:Montserrat,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.config-panel{padding:0 2rem}@media (width<=600px){.config-panel{padding:0}}.config-header{padding:2rem 0 0}.config-header h2{color:var(--color-text);margin:0;font-size:1.5rem;font-weight:700}.config-sections{flex-direction:column;gap:1rem;padding:1.5rem 0;display:flex}.config-disabled{opacity:.3;pointer-events:none}.config-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;transition:border-color .15s}.config-section:hover{border-color:#333}.section-header{align-items:flex-start;gap:.75rem;margin-bottom:1.25rem;display:flex}.section-icon{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-primary);background:#ff7a2f1f;flex-shrink:0;justify-content:center;align-items:center;display:flex}.section-header h3{color:var(--color-text);margin:0;font-size:.95rem;font-weight:600}.section-desc{color:var(--color-text-muted);margin:2px 0 0;font-size:.75rem}.config-field{border-bottom:1px solid var(--color-elevated);margin-bottom:1.25rem;padding-bottom:1.25rem}.config-field:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.config-field>label{color:var(--color-text);margin-bottom:.5rem;font-size:.8rem;font-weight:500;display:block}.option-cards{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.option-card{border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:left;cursor:pointer;background:#111;flex-direction:column;gap:.25rem;padding:.75rem;transition:border-color .15s,background .15s;display:flex}.option-card:hover{border-color:var(--color-border-hover);background:var(--color-surface-hover)}.option-card.selected{border-color:var(--color-primary);background:#ff7a2f0f}.option-card-title{color:var(--color-text);font-size:.85rem;font-weight:600}.option-card-desc{color:var(--color-text-muted);font-size:.7rem}.option-card.selected .option-card-desc{color:var(--color-text-secondary)}.field-warning{color:var(--color-error);background:#f8717114;border-radius:6px;align-items:flex-start;gap:.5rem;margin:1.25rem 0 0;padding:.5rem .75rem;font-size:.75rem;line-height:1.4;display:flex}.field-warning-icon{flex-shrink:0;margin-top:1px}.toggle-field{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.toggle-text label{color:var(--color-text);font-size:.8rem;font-weight:500;display:block}.toggle-desc{color:var(--color-text-muted);margin-top:2px;font-size:.7rem;display:block}.toggle{cursor:pointer;background:#333;border:1px solid #555;border-radius:999px;flex-shrink:0;width:44px;height:24px;padding:2px;transition:background .2s,border-color .2s;position:relative}.toggle:hover{border-color:#666}.toggle.on{background:var(--color-primary);border-color:var(--color-primary)}.toggle-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s,background .2s;display:block}.toggle.on .toggle-knob{background:#fff;transform:translate(20px)}.learn-field{justify-content:space-between;align-items:center;gap:1rem;display:flex}.learn-info label{color:var(--color-text);font-size:.8rem;font-weight:500;display:block}.learn-status{color:var(--color-text-muted);margin-top:2px;font-size:.7rem;display:block}.btn-learn{background:var(--color-elevated);border:1px solid var(--color-border-hover);border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;padding:.45rem 1rem;font-size:.8rem;font-weight:600;transition:border-color .15s,color .15s}.btn-learn:hover:not(:disabled){border-color:var(--color-primary)}.btn-learn:disabled{opacity:.3;cursor:not-allowed}.btn-learn-clear{border-color:var(--color-border);color:var(--color-text-muted);background:0 0}.btn-learn-clear:hover:not(:disabled){border-color:var(--color-error);color:var(--color-error)}.learn-actions{gap:.5rem;display:flex}.mfl-learning{flex-direction:column;gap:.75rem;display:flex}.mfl-learning-prompt{color:var(--color-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);border-color:var(--color-primary);text-align:center;padding:.75rem 1rem;font-size:.85rem;font-weight:500}.mfl-learning-actions{gap:.5rem;display:flex}.config-unsupported{opacity:.35;pointer-events:none}.btn-advanced{width:100%;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:.75rem 0;font-size:.8rem;font-weight:500;transition:color .15s;display:flex}.btn-advanced:hover{color:var(--color-text)}.advanced-chevron{transition:transform .2s}.advanced-chevron.open{transform:rotate(180deg)}.config-diff{border-radius:var(--radius-md);background:#ff7a2f0f;border:1px solid #ff7a2f26;margin:0 0 1rem;padding:1rem}.config-diff h4{color:var(--color-primary);margin:0 0 .75rem;font-size:.8rem;font-weight:600}.diff-list{flex-direction:column;gap:.4rem;display:flex}.diff-row{align-items:center;gap:.5rem;font-size:.8rem;display:flex}.diff-label{color:var(--color-text);min-width:140px;font-weight:500}.diff-from{color:var(--color-text-muted);text-decoration:line-through}.diff-arrow{color:var(--color-primary)}.diff-to{color:var(--color-text);font-weight:600}.config-error{border-radius:var(--radius-md);color:var(--color-error);background:#f871710f;border:1px solid #f8717133;margin:0 0 1rem;padding:.75rem 1rem;font-size:.8rem}.config-section-inline{flex-wrap:wrap;align-items:center;gap:1.25rem;display:flex}.config-section-inline .section-header{flex:1 1 0;min-width:200px;margin-bottom:0}.config-section-inline .btn-reboot{margin:0 auto}.btn-reboot{background:var(--color-elevated);border:1px solid var(--color-border-hover);border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;flex-shrink:0;align-items:center;gap:.5rem;padding:.45rem 1rem;font-size:.8rem;font-weight:600;transition:border-color .15s,color .15s;display:inline-flex}.btn-reboot:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-reboot:disabled{opacity:.3;cursor:not-allowed}.btn-apply{background:var(--gradient-primary);border-radius:var(--radius-md);width:100%;color:var(--color-bg);cursor:pointer;border:none;margin:0 0 6rem;padding:.75rem 1rem;font-size:.9rem;font-weight:700;transition:opacity .15s;display:block}.btn-apply:hover:not(:disabled){opacity:.85}.btn-apply:disabled{opacity:.25;cursor:not-allowed}.device-picker{margin-top:.5rem}.picker-title{color:var(--color-text-secondary);margin-bottom:.5rem;font-size:.8rem}.picker-loading{color:var(--color-text-secondary);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.picker-list{flex-direction:column;gap:.375rem;display:flex}.picker-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);text-align:left;cursor:pointer;padding:.5rem .75rem;font-family:SF Mono,Fira Code,monospace;font-size:.8rem;transition:border-color .15s;display:block}.picker-item:hover{border-color:var(--color-primary)}.picker-authorize{color:var(--color-primary);border-style:dashed;font-family:inherit}.picker-authorize:hover{background:#ff7a2f0d}.picker-cancel{color:var(--color-text-muted);text-align:center;background:0 0;border-style:none;font-family:inherit}.picker-cancel:hover{color:var(--color-text)}.dfu-programmer{padding:2rem}@media (width<=600px){.dfu-programmer{padding:2rem 0}}.dfu-header{margin-bottom:2rem}.dfu-header h2{color:var(--color-text);margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.dfu-subtitle{color:var(--color-text-secondary);margin:0;font-size:.875rem}.dfu-disabled{opacity:.3;pointer-events:none}.dfu-unsupported{background:var(--color-surface);border:1px solid var(--color-error);border-radius:var(--radius-md);text-align:center;padding:1.5rem}.dfu-unsupported h3{color:var(--color-error);margin:0 0 .5rem}.dfu-unsupported p{color:var(--color-text-secondary);margin:0}.dfu-steps{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.dfu-step{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);opacity:.4;align-items:flex-start;gap:1rem;padding:1rem;transition:opacity .2s,border-color .2s;display:flex}.dfu-step.active{opacity:1;border-color:var(--color-primary)}.dfu-step.done{opacity:.7;border-color:var(--color-success)}.step-number{background:var(--color-border);width:28px;height:28px;color:var(--color-text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.dfu-step.active .step-number{background:var(--color-primary);color:#fff}.dfu-step.done .step-number{background:var(--color-success);color:#fff}.step-content h4{color:var(--color-text);margin:0 0 .25rem;font-size:.95rem;font-weight:600}.step-content p{color:var(--color-text-secondary);margin:0 0 .75rem;font-size:.8rem}.file-input-label{background:var(--color-elevated);border:1px dashed var(--color-border-hover);border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;padding:.5rem 1rem;font-size:.85rem;transition:border-color .2s;display:inline-block}.file-input-label:hover{border-color:var(--color-primary)}.file-input-label input[type=file]{display:none}.btn-program{background:var(--gradient-primary);color:var(--color-bg);border-radius:var(--radius-sm);cursor:pointer;border:none;padding:.6rem 1.5rem;font-size:.9rem;font-weight:600;transition:opacity .2s}.btn-program:hover:not(:disabled){opacity:.85}.btn-program:disabled{opacity:.3;cursor:not-allowed}.program-actions{flex-direction:column;align-items:flex-start;gap:.5rem;display:flex}.btn-dfu-direct{color:var(--color-text-secondary);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-size:.8rem;text-decoration:underline}.btn-dfu-direct:hover:not(:disabled){color:var(--color-text)}.btn-dfu-direct:disabled{opacity:.3;cursor:not-allowed}.dfu-status{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;display:flex}.dfu-success{border-color:var(--color-success)}.dfu-success .status-text{color:var(--color-success)}.dfu-error{border-color:var(--color-error)}.dfu-error .status-text{color:var(--color-error)}.status-text{color:var(--color-text);flex:1;min-width:0;font-size:.85rem}.dfu-status-progress{flex-direction:column;gap:.5rem}.progress-bar{background:var(--color-border);border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-fill{background:var(--gradient-primary);border-radius:3px;height:100%;transition:width .15s ease-out}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.dfu-log{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#111;margin-bottom:1rem;padding:.75rem 1rem;font-family:SF Mono,Fira Code,monospace;font-size:.75rem;position:relative}.dfu-log-lines{max-height:200px;overflow-y:auto}.log-line{color:var(--color-text-muted);line-height:1.6}.log-line:last-child{color:var(--color-text)}.btn-copy-log{background:var(--color-border);color:var(--color-text-secondary);cursor:pointer;border:none;border-radius:4px;padding:.2rem .5rem;font-size:.7rem;transition:color .15s,background .15s;position:absolute;top:.5rem;right:.5rem}.btn-copy-log:hover{color:var(--color-text);background:#333}.btn-reset{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff1a;border:none;border-radius:5px;flex-shrink:0;padding:.4rem 1rem;font-size:.8rem;font-weight:600;transition:background .15s}.btn-reset:hover{background:#fff3}.connect-bar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:.75rem;padding:.6rem 1rem;display:flex}.connect-bar.connected{background:linear-gradient(135deg,#ffb14a14,#ff5a1f14);border-color:#ff7a2f40}.connect-info{align-items:center;gap:.5rem;display:flex}.connect-dot{background:var(--color-border-hover);border-radius:50%;flex-shrink:0;width:8px;height:8px}.connect-dot.online{background:var(--color-success);box-shadow:0 0 8px #22c55e66}.connect-dot.error{background:var(--color-error);box-shadow:0 0 8px #f8717166}.connect-title{color:var(--color-text);font-size:.8rem;font-weight:600}.btn-connect{background:var(--gradient-primary);border-radius:var(--radius-sm);color:var(--color-bg);cursor:pointer;border:none;margin-left:auto;padding:.4rem 1rem;font-size:.8rem;font-weight:600;transition:opacity .15s}.btn-connect:hover:not(:disabled){opacity:.85}.btn-disconnect{background:var(--color-elevated);color:var(--color-text);border:1px solid var(--color-border-hover)}.btn-disconnect:hover:not(:disabled){border-color:var(--color-error);color:var(--color-error)}.btn-connect:disabled{opacity:.3;cursor:not-allowed}.proto-monitor{z-index:100;background:var(--color-bg);border-top:1px solid var(--color-border);position:fixed;bottom:0;left:0;right:0}.proto-toggle{background:var(--color-surface);width:100%;color:var(--color-text-secondary);cursor:pointer;border:none;justify-content:flex-end;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:Montserrat,sans-serif;font-size:.75rem;font-weight:600;display:flex}.proto-toggle:hover{color:var(--color-text)}.proto-chevron{transition:transform .2s}.proto-chevron.open{transform:rotate(180deg)}.proto-count{background:var(--color-elevated);color:var(--color-text-muted);border-radius:999px;padding:0 .4rem;font-size:.65rem}.proto-panel{flex-direction:column;height:240px;display:flex}.proto-toolbar{border-bottom:1px solid var(--color-border);gap:.5rem;padding:.35rem 1rem;display:flex}.proto-btn{background:var(--color-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;padding:.2rem .6rem;font-size:.65rem;font-weight:600}.proto-btn:hover{border-color:var(--color-border-hover);color:var(--color-text)}.proto-log{flex:1;padding:.5rem 0;font-family:SF Mono,Cascadia Code,Consolas,monospace;font-size:.7rem;line-height:1.6;overflow-y:auto}.proto-empty{text-align:center;color:var(--color-text-muted);padding:1rem;font-family:Montserrat,sans-serif}.proto-entry{white-space:nowrap;gap:.6rem;padding:0 1rem;display:flex}.proto-entry:hover{background:var(--color-surface)}.proto-time{color:var(--color-text-muted);min-width:7.5em}.proto-dir{min-width:1.8em;font-weight:700}.proto-dir-tx{color:var(--color-primary)}.proto-dir-rx{color:var(--color-success)}.proto-cmd{color:var(--color-text);min-width:10em;font-weight:600}.proto-seq{color:var(--color-text-muted);min-width:2.5em}.proto-payload{color:var(--color-text-secondary)}.proto-raw{color:var(--color-text-muted);opacity:.5;margin-left:auto}.app{background:var(--color-bg);min-height:100vh;color:var(--color-text)}.app.app-static{min-height:0}.app-header-bar{border-bottom:1px solid var(--color-border-subtle)}.app-header{justify-content:space-between;align-items:center;max-width:1400px;height:5rem;margin:0 auto;padding:0 4rem 0 2rem;display:flex}.app-header .logo{height:6.75rem}.app-layout{grid-template-columns:1fr 420px;max-width:1400px;margin:0 auto;padding:0 2rem;display:grid}.app-col-secondary{border-left:1px solid var(--color-border-subtle)}@media (width<=900px){.app-layout{grid-template-columns:1fr}.app-col-secondary{border-left:none;border-top:1px solid var(--color-border-subtle)}}.app-unsupported{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:center;max-width:480px;margin:2rem auto;padding:1.5rem}.app-unsupported h3{color:var(--color-text);margin:0 0 .5rem}.app-unsupported p{color:var(--color-text-secondary);margin:0 0 1.25rem;line-height:1.5}.supported-browsers{justify-content:center;gap:1.5rem;display:flex}.supported-browser{flex-direction:column;align-items:center;gap:.4rem;display:flex}.supported-browser img{width:32px;height:32px}.supported-browser span{color:var(--color-text-muted);font-size:.7rem}@media (width<=600px){.app-header{flex-direction:column;gap:.5rem;height:auto;padding:1rem}.app-header .logo{height:5rem}.app-header .connect-bar{width:100%}.app-layout{padding:0 1rem}}
