.fw-mode-radio-group{display:flex;gap:1.5rem;margin:1rem 0 .5rem;align-items:center;justify-content:flex-start}.fw-mode-radio{display:flex;align-items:center;cursor:pointer;font-size:1rem;color:var(--text-primary);font-weight:500;gap:.5rem;-webkit-user-select:none;user-select:none}.fw-mode-radio input[type=radio]{appearance:none;width:1.1em;height:1.1em;border:2px solid var(--accent);border-radius:50%;background:var(--bg-card);margin:0 .5em 0 0;position:relative;outline:none;transition:border-color .2s;vertical-align:middle}.fw-mode-radio input[type=radio]:checked{border-color:var(--accent);background:var(--accent-glow)}.fw-mode-radio input[type=radio]:checked:before{content:"";display:block;width:.55em;height:.55em;border-radius:50%;background:var(--accent);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.fw-mode-radio input[type=radio]:focus{box-shadow:0 0 0 2px var(--accent-glow)}.fw-mode-radio span{color:var(--text-primary);font-size:1rem;font-weight:500}@media(max-width:600px){.screen--dashboard,.dashboard-layout{padding-top:0!important}}@media(max-width:600px){#toneSimulatorSection,#toneSimulatorSection .config-section__header,#toneSimulatorSection .config-section__body{margin-top:0!important;padding-top:0!important}}.topbar-help-btn{background:none;border:none;cursor:pointer;padding:.35rem;border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.topbar-help-btn:hover{color:var(--text-primary);background:#ffffff14}html.light .topbar-help-btn:hover{background:#0000000f}.ble-console__header{cursor:pointer}.ble-console.collapsed{max-height:48px;min-width:60px;width:60px;overflow:hidden;transition:max-height var(--transition),width var(--transition)}.ble-console.collapsed .ble-console__header{padding:.5rem 1rem}.ble-console__toggle{transition:transform var(--transition)}.ble-console.collapsed .ble-console__toggle svg{transform:rotate(180deg)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-card: #1e2a45;--bg-card-hover: #243352;--text-primary: #e8e8e8;--text-secondary: #a0a8b8;--text-muted: #6b7280;--accent: #4fc3f7;--accent-hover: #39b0e4;--accent-glow: rgba(79, 195, 247, .15);--success: #4caf50;--warning: #ff9800;--error: #ef5350;--border: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .15);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow: 0 2px 8px rgba(0, 0, 0, .15), 0 8px 24px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--transition: .2s ease;--font: "Segoe UI", system-ui, -apple-system, sans-serif;--max-width: 900px}html.light{--bg-primary: #f5f5f5;--bg-secondary: #e8edf2;--bg-card: #ffffff;--bg-card-hover: #f0f4f8;--text-primary: #1a1a2e;--text-secondary: #4a5568;--text-muted: #718096;--accent: #0288d1;--accent-hover: #0277bd;--accent-glow: rgba(2, 136, 209, .15);--success: #388e3c;--warning: #f57c00;--error: #d32f2f;--border: rgba(0, 0, 0, .1);--border-hover: rgba(0, 0, 0, .18);--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 4px 12px rgba(0, 0, 0, .12);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#ffffff08}::-webkit-scrollbar-thumb{background:#4fc3f766;border-radius:5px;transition:background .2s ease}::-webkit-scrollbar-thumb:hover{background:#4fc3f7b3;box-shadow:0 0 8px #4fc3f74d}*{scrollbar-color:rgba(79,195,247,.4) rgba(255,255,255,.03);scrollbar-width:thin}html.light ::-webkit-scrollbar-track{background:#00000008}html.light ::-webkit-scrollbar-thumb{background:#0288d159}html.light ::-webkit-scrollbar-thumb:hover{background:#0288d1a6;box-shadow:0 0 8px #0288d140}html.light *{scrollbar-color:rgba(2,136,209,.35) rgba(0,0,0,.03)}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}.theme-toggle{background:none;border:none;cursor:pointer;padding:.35rem;border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.theme-toggle:hover{color:var(--text-primary);background:#ffffff14}html.light .theme-toggle:hover{background:#0000000f}.theme-icon--light{display:none}.theme-icon--dark,html.light .theme-icon--light{display:block}html.light .theme-icon--dark{display:none}.shutdown-btn{background:none;border:none;cursor:pointer;padding:.35rem;border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.shutdown-btn:hover{color:#ff6b6b;background:#ff6b6b1a}html.light .shutdown-btn:hover{background:#ff6b6b14}.settings-menu-container{position:relative}.settings-btn{background:none;border:none;cursor:pointer;padding:.35rem;border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.settings-btn:hover{color:var(--text-primary);background:#ffffff14}html.light .settings-btn:hover{background:#0000000f}.settings-menu{position:absolute;top:100%;right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:.5rem;min-width:200px;box-shadow:0 8px 24px #00000026;padding:.5rem;z-index:1001;max-height:80vh;overflow-y:auto;overscroll-behavior:contain}html.light .settings-menu{box-shadow:0 8px 24px #00000014}.settings-menu.hidden{display:none}.settings-menu-item{background:none;border:none;cursor:pointer;padding:.75rem 1rem;border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;text-align:left;display:flex;align-items:center;gap:.75rem;width:100%;transition:all var(--transition);min-height:40px}.settings-menu-item:hover{background:#ffffff14;color:var(--accent)}html.light .settings-menu-item:hover{background:#0000000f}.settings-menu-item svg{flex-shrink:0}.settings-menu-item--danger{color:var(--error)!important}.settings-menu-item--danger svg{color:var(--error)}.settings-menu-item--danger:hover{background:#ef53501a!important;color:var(--error)!important}html.light .settings-menu-item--danger:hover{background:#d32f2f14!important}.settings-menu-divider{height:1px;background:var(--border);margin:.4rem .5rem}.header{position:fixed;top:0;left:0;right:0;z-index:100;background:#1a1a2ed9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}html.light .header{background:#f5f5f5e0}.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;height:60px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text-primary);font-size:1.2rem;font-weight:600;letter-spacing:.02em}.logo-icon{height:48px;width:auto;flex-shrink:0;filter:invert(1)}html.light .logo-icon{filter:invert(0)}.connection-status{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--error);transition:background var(--transition)}.status-dot.connected{background:var(--success);box-shadow:0 0 8px #4caf5080}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:var(--accent);color:var(--bg-primary)}.btn--primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 20px var(--accent-glow)}.btn--outline{background:transparent;color:var(--accent);border:1px solid var(--accent)}.btn--outline:hover:not(:disabled){background:var(--accent-glow)}.btn--ghost{background:transparent;color:var(--text-secondary)}.btn--ghost:hover:not(:disabled){color:var(--text-primary);background:#ffffff0d}.btn--large{padding:.85rem 2rem;font-size:1.05rem;border-radius:var(--radius-md)}.btn--small{padding:.4rem .9rem;font-size:.82rem}.btn-icon{width:20px;height:20px}.screen{padding-top:60px}.hidden{display:none!important}.screen--landing{min-height:100vh;display:flex;align-items:center;justify-content:center}.landing-content{text-align:center;padding:2rem 1.5rem;max-width:480px;width:100%}.landing-hero{margin-bottom:2.5rem}.landing-logo{width:400px;max-width:90vw;height:auto;margin-bottom:1rem;filter:invert(1) drop-shadow(0 0 20px var(--accent-glow))}html.light .landing-logo{filter:invert(0) drop-shadow(0 0 20px var(--accent-glow))}.landing-hero h1{font-size:2.4rem;font-weight:700;letter-spacing:.03em;margin-bottom:.3rem}.landing-subtitle{color:var(--text-secondary);font-size:1.05rem}.connect-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;margin-bottom:2rem;box-shadow:var(--shadow-sm);transition:all var(--transition)}.connect-card:hover{box-shadow:var(--shadow);border-color:var(--border-hover)}.connect-description{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem;line-height:1.7}.connect-hint{margin-top:1rem;font-size:.82rem;color:var(--text-muted);min-height:1.2em}.connect-hint.error{color:var(--error)}.browser-support{color:var(--text-muted);font-size:.78rem}.device-bar{position:fixed;top:60px;left:0;right:0;z-index:90;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}@media(max-width:700px){.device-bar-inner,.device-actions{flex-wrap:nowrap!important;gap:.3rem}.device-actions button,.device-actions .btn,.device-actions .btn--small{font-size:.78rem!important;padding:.35rem .6rem!important;min-width:32px!important;min-height:32px!important;max-width:100%}.device-bar-inner{padding:.4rem .5rem}.device-info{gap:.5rem}}@media(max-width:480px){.device-bar-inner{gap:.15rem;padding:.2rem}.device-actions{gap:.15rem}.device-actions button,.device-actions .btn,.device-actions .btn--small{font-size:.7rem!important;padding:.22rem .4rem!important;min-width:26px!important;min-height:26px!important}.device-info{gap:.2rem}}.device-bar.collapsed{height:40px}.device-bar.collapsed .device-bar-inner{display:none}.device-bar__toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text-secondary);transition:all var(--transition);min-width:40px;min-height:40px;align-items:center;justify-content:center;flex-shrink:0;position:absolute;left:50%;transform:translate(-50%);bottom:-20px}.device-bar.collapsed .device-bar__toggle{bottom:auto;top:50%;transform:translate(-50%) translateY(-50%)}.device-bar__toggle:hover{color:var(--accent);background:#ffffff0d}.device-bar__toggle svg{width:18px;height:18px;transition:transform var(--transition);transform:rotate(-90deg)}.device-bar.collapsed .device-bar__toggle svg{transform:rotate(90deg)}.device-bar-inner{max-width:var(--max-width);margin:0 auto;padding:.6rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;flex:1;width:100%}@media(max-width:700px){.device-bar-inner,.device-info{flex-wrap:nowrap!important;gap:.3rem;font-size:.88rem}.device-info-column{gap:.1rem}.device-name,.device-detail,.device-serial,.device-bar span,.device-bar div{font-size:.88rem!important}}@media(max-width:480px){.device-bar-inner{gap:.12rem;padding:.15rem;font-size:.75rem}.device-info{gap:.12rem;font-size:.75rem}.device-info-column{gap:.05rem}.device-name,.device-detail,.device-serial,.device-bar span,.device-bar div{font-size:.75rem!important}}.device-info{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.device-info-column{display:flex;flex-direction:column;gap:.2rem}.device-name{font-weight:600;font-size:.95rem}.device-serial{font-size:.7rem;color:var(--text-muted);font-family:Courier New,monospace;letter-spacing:.02em}.device-detail{font-size:.8rem;color:var(--text-secondary);padding:.2rem .6rem;background:#ffffff0d;border-radius:var(--radius-sm)}.device-actions{display:flex;gap:.5rem;flex-wrap:wrap}.screen--dashboard,.screen--dashboard.device-bar-collapsed{padding-top:60px}.dashboard-layout{display:flex;flex-direction:row;align-items:flex-start;gap:2rem;max-width:var(--max-width);margin:0 auto;padding:5.5rem 1.5rem 3rem;overflow-x:hidden;transition:padding-top var(--transition)}.screen--dashboard.device-bar-collapsed .dashboard-layout{padding-top:2.5rem}.dashboard-content{flex:1 1 0;min-width:0}.ble-console{position:sticky;top:80px;right:0;width:340px;min-width:260px;max-height:70vh;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-left:1rem;box-shadow:var(--shadow);z-index:100;display:flex;flex-direction:column;overflow:hidden;transition:all var(--transition)}.ble-console__body{flex:1 1 0;overflow-y:auto;padding:1rem}.ble-console__log{font-family:monospace;font-size:.92rem;color:var(--text-secondary);line-height:1.5}@media(max-width:1024px){.dashboard-layout{gap:1.5rem}.ble-console{position:sticky;top:auto;max-height:300px;margin-left:0}}@media(max-width:768px){.dashboard-layout{flex-direction:column;gap:1rem;padding-left:0;padding-right:0}.dashboard-content{padding:0 1.5rem}.ble-console{width:100%;min-width:0;max-height:240px;margin-left:0;margin-top:1rem;position:static;border-radius:var(--radius-md);margin-right:0}}@media(max-width:600px){.dashboard-layout{padding-top:5.5rem;padding-bottom:3rem;flex-direction:column;gap:1rem;padding-left:0;padding-right:0;max-width:100%}.dashboard-content{width:100%;padding:0}}.config-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1.25rem;overflow:hidden;transition:all var(--transition);box-shadow:var(--shadow-sm)}.config-section:hover{border-color:var(--border-hover);box-shadow:0 2px 12px #00000026}.config-section__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition)}.config-section__header:hover{background:#ffffff05}.config-section__title{font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.6rem;line-height:1}.config-section__title span:first-child{display:inline-flex;align-items:center;justify-content:center;line-height:1;font-size:1.2em;width:1.4ch}.config-section__chevron{width:20px;height:20px;color:var(--text-muted);transition:transform var(--transition)}.config-section.open .config-section__chevron{transform:rotate(180deg)}.tone-sim-help-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid rgba(79,195,247,.3);border-radius:50%;background:#4fc3f714;color:var(--accent);cursor:pointer;transition:all var(--transition);margin-right:.8rem;flex-shrink:0}.tone-sim-help-btn:hover{background:#4fc3f726;border-color:var(--accent);box-shadow:0 0 8px #4fc3f733}.tone-sim-help-btn:active{transform:scale(.95)}.tone-sim-help-btn svg{width:16px;height:16px}html.light .tone-sim-help-btn{border-color:#0288d14d;background:#0288d114;color:#0288d1}html.light .tone-sim-help-btn:hover{background:#0288d126;border-color:#0288d1;box-shadow:0 0 8px #0288d133}.tone-points-table .tone-points-row{height:16px;line-height:1;max-height:16px;overflow:hidden}.tone-points-table td{height:16px;max-height:16px;overflow:hidden}.tone-points-table input[type=number]{display:block;height:16px;max-height:16px;padding:0 .15rem;font-size:.72rem;line-height:1;box-sizing:border-box}@media(max-width:600px){.tone-points-table{font-size:.62rem!important}.tone-points-table th{padding:.05rem .1rem!important;line-height:1!important}.tone-points-table .tone-points-row{height:15px!important;max-height:15px!important}.tone-points-table td{height:15px!important;max-height:15px!important;padding:0!important;line-height:1!important}.tone-points-table input[type=number]{padding:0 .05rem!important;font-size:.62rem!important;height:15px!important;max-height:15px!important}}.config-section__body{display:none;padding:0 1.5rem 1.5rem;border-top:1px solid var(--border)}.config-section.open .config-section__body{display:block}.config-field{display:grid;grid-template-columns:1fr auto;align-items:center;padding:1rem 0;border-bottom:1px solid var(--border);gap:1rem}.config-field:last-child{border-bottom:none}.config-field__info{grid-column:1;min-width:0}.config-field__label{font-size:.9rem;color:var(--text-primary)}.config-field__description{font-size:.75rem;color:var(--text-muted);margin-top:.15rem}.config-field__input{grid-column:2;grid-row:1 / 3;flex-shrink:0;display:flex;align-items:center}input[type=number],input[type=text],select{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:.45rem .7rem;font-size:.88rem;font-family:var(--font);width:120px;transition:all var(--transition)}input[type=number]:hover,input[type=text]:hover,select:hover{border-color:var(--border-hover)}input[type=number]:focus,input[type=text]:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}input[type=number]:focus-visible,input[type=text]:focus-visible,select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}select{cursor:pointer;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 d='M3 4.5L6 7.5L9 4.5' stroke='%23a0a8b8' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center;padding-right:2rem}.toggle{position:relative;width:44px;height:24px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle__slider{position:absolute;inset:0;background:#ffffff1a;border-radius:12px;cursor:pointer;transition:background var(--transition)}.toggle__slider:before{content:"";position:absolute;left:3px;top:3px;width:18px;height:18px;background:var(--text-secondary);border-radius:50%;transition:all var(--transition)}.toggle input:checked+.toggle__slider{background:var(--accent)}.toggle input:checked+.toggle__slider:before{transform:translate(20px);background:var(--bg-primary)}.ble-console{position:fixed;top:60px;right:0;bottom:0;width:360px;background:var(--bg-card);border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:90;transition:transform .3s ease}.ble-console.collapsed{transform:translate(calc(100% - 40px))}.ble-console__header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border);flex-shrink:0}.ble-console__title{font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.ble-console__actions{display:flex;align-items:center;gap:.4rem}.btn--tiny{font-size:.72rem;padding:.15rem .45rem}.ble-console__toggle{display:flex;align-items:center;justify-content:center;padding:.2rem!important;transition:transform .2s ease}.ble-console.collapsed .ble-console__toggle{transform:rotate(180deg)}.ble-console.collapsed .ble-console__header{writing-mode:vertical-rl;text-orientation:mixed;padding:.8rem .5rem;border-bottom:none;border-left:none;flex-direction:column-reverse;align-items:center;gap:.6rem;height:100%}.ble-console.collapsed .ble-console__actions{flex-direction:column}.ble-console.collapsed .ble-console__title{font-size:.8rem}.ble-console__body{flex:1;overflow:hidden;display:flex;flex-direction:column}.ble-console.collapsed .ble-console__body{display:none}.ble-console__log{font-family:Consolas,Monaco,Courier New,monospace;font-size:.78rem;line-height:1.5;padding:.5rem .75rem;flex:1;overflow-y:auto;background:var(--bg-secondary)}.ble-console__log:empty:before{content:"No activity yet...";color:var(--text-muted);font-style:italic}.ble-log-entry{display:flex;gap:.4rem;padding:1px 0}.ble-log-entry__time{color:var(--text-muted);flex-shrink:0;font-size:.72rem}.ble-log-entry__dir{flex-shrink:0;font-weight:700;min-width:2em;font-size:.72rem}.ble-log-entry__dir--tx{color:var(--accent)}.ble-log-entry__dir--rx{color:var(--success)}.ble-log-entry__dir--info{color:var(--text-muted)}.ble-log-entry__dir--error{color:var(--error)}.ble-log-entry__msg{color:var(--text-primary);word-break:break-all;font-size:.75rem}.ble-log-entry__msg--error{color:var(--error)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:200;display:flex;flex-direction:column;gap:.5rem}.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:.8rem 1.2rem;font-size:.88rem;color:var(--text-primary);box-shadow:var(--shadow);animation:toast-in .3s ease;max-width:340px}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--error)}.toast.info{border-left:3px solid var(--accent)}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.2);border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fw-update-btn{position:relative}.fw-update-dot{position:absolute;top:-3px;right:-3px;width:9px;height:9px;background:var(--error);border-radius:50%;border:2px solid var(--bg-secondary);box-shadow:0 0 6px #ef535099}.modal-overlay{position:fixed;inset:0;z-index:300;background:#0009;display:flex;align-items:flex-start;justify-content:center;padding:1.5rem;overflow-y:auto;padding-top:max(1.5rem,env(safe-area-inset-top));padding-bottom:max(1.5rem,env(safe-area-inset-bottom))}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:480px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0006;animation:modal-in .2s ease;margin:auto 0}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal__header h3{font-size:1.05rem;font-weight:600}.modal__close{background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:all var(--transition);line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.modal__close:hover{color:var(--text-primary);background:#ffffff14}html.light .modal__close:hover{background:#0000000f}.modal__body{padding:1.5rem;font-size:.92rem;line-height:1.7;color:var(--text-secondary);overflow-y:auto;flex:1;overscroll-behavior:contain}.fw-bl-update-banner{display:flex;align-items:center;gap:.5rem;background:#ff98001f;border:1px solid rgba(255,152,0,.4);border-radius:6px;padding:.55rem .75rem;margin-bottom:.6rem;color:#ff9800;font-size:.88rem}.fw-bl-update-banner strong{font-weight:700}.fw-bl-update-icon{font-size:1rem;flex-shrink:0}.fw-version-row{display:flex;justify-content:space-between;padding:0;border-bottom:1px solid var(--border);margin-top:0}.fw-version-row:last-child{border-bottom:none}.fw-version-label{color:var(--text-muted)}.fw-version-value{color:var(--text-primary);font-weight:500}.fw-beta-toggle{display:flex;align-items:center;gap:.2rem;margin:0;font-size:.9rem;color:var(--text-primary);padding:0}.fw-beta-toggle input[type=checkbox]{cursor:pointer;width:18px;height:18px;min-width:18px;min-height:18px;accent-color:var(--accent)}.fw-beta-toggle label{cursor:pointer;-webkit-user-select:none;user-select:none;padding:.05rem .1rem}@media(max-width:600px){.fw-beta-toggle{padding:.75rem 0;gap:.75rem}.fw-beta-toggle input[type=checkbox]{width:20px;height:20px;min-width:20px;min-height:20px}.fw-beta-toggle label{padding:.4rem;font-size:1rem}.fw-selection-item{padding:.75rem;min-height:50px}.fw-selection-item input[type=radio]{width:18px;height:18px;min-width:18px;min-height:18px;margin-top:.25rem}.fw-sel-version{font-size:.95rem}.fw-sel-filename{font-size:.8rem}}.fw-beta-tag{display:inline-block;background:#ff980033;color:#ff9800;padding:.2rem .5rem;border-radius:3px;font-size:.7rem;font-weight:600;text-transform:uppercase;margin-left:.3rem}.fw-current-tag{display:inline-block;background:#4caf5033;color:#4caf50;padding:.2rem .5rem;border-radius:3px;font-size:.7rem;font-weight:600;text-transform:uppercase;margin-left:.3rem}.fw-selection-section{margin-top:.1rem;padding:0}.fw-selection-label{display:block;font-size:.9rem;font-weight:500;color:var(--text-primary);margin-bottom:.6rem}.fw-selection-list{display:flex;flex-direction:column;gap:.5rem;max-height:10.5rem;overflow-y:auto}.fw-selection-item{display:flex;align-items:flex-start;gap:.5rem;padding:1.5rem .9rem;min-height:4.5rem;background:#4fc3f70a;border:1px solid rgba(79,195,247,.1);border-radius:4px;cursor:pointer;transition:all .2s ease}.fw-selection-item:hover{background:#4fc3f714;border-color:#4fc3f733}.fw-selection-item input[type=radio]{margin-top:.15rem;cursor:pointer;width:16px;height:16px;accent-color:var(--accent);flex-shrink:0}.fw-selection-item label{display:flex;flex-direction:column;gap:.2rem;cursor:pointer;flex:1;-webkit-user-select:none;user-select:none}.fw-sel-version{font-size:.9rem;font-weight:500;color:var(--text-primary)}.fw-sel-filename{font-size:.75rem;color:var(--text-secondary);font-family:monospace}.fw-update-available{margin-top:1rem;padding:.8rem 1rem;background:#4fc3f714;border:1px solid rgba(79,195,247,.2);border-radius:var(--radius-md);color:var(--text-primary);font-size:.85rem}.fw-no-update{margin-top:1rem;padding:.8rem 1rem;background:#4caf5014;border:1px solid rgba(76,175,80,.2);border-radius:var(--radius-md);color:var(--success);font-size:.85rem}.fw-progress{margin-top:1rem;padding:.8rem 1rem;background:#4fc3f714;border:1px solid rgba(79,195,247,.2);border-radius:var(--radius-md)}.fw-progress-bar{width:100%;height:6px;background:#4fc3f71a;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.fw-progress-fill{height:100%;background:var(--accent);transition:width .3s ease}.fw-status{font-size:.85rem;color:var(--text-secondary);text-align:center}.fw-status.fw-success{color:var(--success);font-weight:500}.fw-status.fw-error{color:var(--error);font-weight:500}.fw-real-update-btn{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;padding:.95rem 1.5rem;margin-top:1rem;border:none;border-radius:var(--radius-md);background:var(--accent);color:var(--bg-primary);font-family:var(--font);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 12px #4fc3f733;position:relative;overflow:hidden;z-index:1}.fw-real-update-btn.progressing{color:#fff}.fw-real-update-btn.progressing:before{content:"";position:absolute;top:0;left:0;height:100%;width:var(--fw-progress, 0%);background:linear-gradient(90deg,#156fa1 60%,#0d3550);opacity:.85;z-index:0;transition:width .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.fw-real-update-btn .fw-btn-icon,.fw-real-update-btn span,.fw-real-update-btn svg,.fw-real-update-btn strong{position:relative;z-index:1}.fw-real-update-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:#fff3;transition:left var(--transition)}.fw-real-update-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 6px 20px var(--accent-glow);transform:translateY(-2px)}.fw-real-update-btn:hover:not(:disabled):before{left:100%}.fw-real-update-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px var(--accent-glow)}.fw-real-update-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:0 2px 8px #0000001a}.fw-btn-icon{flex-shrink:0;transition:transform .3s ease}.fw-real-update-btn:hover:not(:disabled) .fw-btn-icon{transform:translateY(-2px)}.fw-real-update-btn.loading .fw-btn-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fw-changelog{margin-top:.5rem;padding:.5rem;background:#4fc3f70f;border:1px solid rgba(79,195,247,.15);border-radius:var(--radius-md);max-height:200px;overflow-y:auto}.fw-changelog-title{font-size:.8rem;font-weight:600;color:var(--text-primary);margin-bottom:.3rem;display:flex;align-items:center;gap:.5rem}.fw-changelog-list{list-style:none;padding:0;margin:0;font-size:.75rem;color:var(--text-secondary);line-height:1.2}.fw-changelog-list li{padding:.15rem 0 .15rem 1rem;position:relative}.fw-changelog-list li:before{content:"•";position:absolute;left:.4rem;color:var(--accent);font-weight:700}html.light .fw-changelog{background:#0288d10a;border-color:#0288d11f}html.light .fw-real-update-btn{box-shadow:0 4px 12px #0288d126}html.light .fw-real-update-btn:hover:not(:disabled){box-shadow:0 6px 20px #0288d140}html.light .config-section__header:hover{background:#00000008}html.light .toggle__slider{background:#0000001f}html.light .toggle__slider:before{background:var(--text-muted)}html.light .toggle input:checked+.toggle__slider:before{background:#fff}html.light .btn--ghost:hover:not(:disabled){background:#0000000d}html.light .device-detail{background:#0000000d}html.light .spinner{border-color:#00000026;border-top-color:currentColor}@media(min-width:769px){.device-bar__toggle{display:none!important}.device-bar.collapsed{height:auto!important}.device-bar.collapsed .device-bar-inner{display:flex!important}.device-bar.collapsed .device-bar__toggle svg{transform:none!important}}@media(max-width:768px){.device-bar-inner{flex-direction:column;align-items:flex-start;padding:.8rem 1rem}.device-actions{width:100%;flex-wrap:wrap}.modal{max-width:calc(100vw - 3rem);max-height:90vh}.device-bar__toggle{display:flex}}@media(max-width:600px){.header-inner{padding:0 1rem}.landing-hero h1{font-size:1.8rem}.connect-card{padding:1.5rem}.dashboard-content{padding:6.5rem 1rem 2rem}.config-field{flex-direction:column;align-items:flex-start}.config-field__input{width:100%}input[type=number],input[type=text],select{width:100%;min-height:44px;font-size:16px}.btn{min-height:44px;min-width:44px}.btn--small{min-height:40px;padding:.6rem 1rem}.btn--primary,.btn--outline{min-height:48px}.modal{max-width:calc(100vw - 1rem);max-height:calc(100vh - 2rem);border-radius:var(--radius-md)}.modal__header{padding:1rem 1.25rem}.modal__body{padding:1.25rem;font-size:.9rem}.fw-real-update-btn{min-height:48px;font-size:1rem}.ble-console{inset:auto 0 0;width:100%;height:220px;border-left:none;border-top:1px solid var(--border)}.ble-console.collapsed{transform:translateY(calc(100% - 36px))}.ble-console.collapsed .ble-console__header{writing-mode:horizontal-tb;text-orientation:initial;flex-direction:row;padding:.5rem 1rem;height:auto}.ble-console.collapsed .ble-console__actions{flex-direction:row}.ble-console.collapsed .ble-console__toggle{transform:rotate(90deg)}.ble-console:not(.collapsed) .ble-console__toggle svg{transform:rotate(90deg)}}@media(max-width:480px){.modal{max-width:100%;max-height:calc(100vh - 1rem)}.modal__header{padding:.9rem 1rem}.modal__header h3{font-size:.95rem}.modal__body{padding:1rem;font-size:.85rem}.fw-selection-list{max-height:10.5rem}.fw-changelog{max-height:180px}.device-bar-inner{gap:.5rem}.device-actions{gap:.4rem}.btn--small{padding:.5rem .8rem;font-size:.8rem}}@media(max-width:768px){div[style*="aspect-ratio:2.2"]{aspect-ratio:1.3!important}}@media(max-width:600px){div[style*="aspect-ratio:2.2"]{aspect-ratio:.9!important;width:100vw!important;max-width:100vw!important;position:relative!important;left:50%!important;right:50%!important;margin-left:-50vw!important;margin-right:-50vw!important;overflow:hidden!important}div[style*="aspect-ratio:2.2"] canvas{width:100%!important;height:100%!important;display:block!important}.config-section{margin:0;border-radius:0;width:100vw;max-width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;overflow:hidden}.config-section__header{padding:.75rem 1.5rem}.config-section__body{padding-left:1.5rem;padding-right:1.5rem;padding-bottom:1.5rem;padding-top:0;overflow:visible}#toneSimulatorSection .config-section__header{padding-left:0;padding-right:0;margin-left:1.5rem;margin-right:1.5rem}#toneSimulatorSection .config-section__body{padding:0}#toneSimulatorSection .config-section__body>div{padding-left:0;padding-right:0;padding-top:.75rem;padding-bottom:.75rem}#toneSimulatorSection .config-section__body>table{margin:0;width:100%}#toneSimulatorSection select,#toneSimulatorSection input[type=range],#toneSimulatorSection button{margin-left:1.5rem;margin-right:1.5rem}}@media(max-width:400px){.config-section{margin:0;width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw}.config-section__header{padding:.75rem 1.5rem}.config-section__body{padding-left:1.5rem;padding-right:1.5rem;padding-bottom:1.5rem;padding-top:0}#toneSimulatorSection .config-section__header{padding-left:0;padding-right:0;margin-left:1.5rem;margin-right:1.5rem}#toneSimulatorSection .config-section__body{padding:0}#toneSimulatorSection .config-section__body>div{padding-left:0;padding-right:0;padding-top:.75rem;padding-bottom:.75rem}#toneSimulatorSection .config-section__body>table{margin:0;width:100%}#toneSimulatorSection select,#toneSimulatorSection input[type=range],#toneSimulatorSection button{margin-left:1.5rem;margin-right:1.5rem}div[style*="aspect-ratio:2.2"]{aspect-ratio:.8!important;width:100vw!important;position:relative!important;left:50%!important;right:50%!important;margin-left:-50vw!important;margin-right:-50vw!important}}body.recovery-mode{--bg-primary: #2d0d0d;--bg-secondary: #3d1010;--bg-card: #4a1515;--bg-card-hover: #5a1c1c;--border: rgba(239, 83, 80, .18);--border-hover: rgba(239, 83, 80, .3)}body.recovery-mode .header{background:#460a0ae0!important;border-bottom-color:#ef535040!important}html.light body.recovery-mode{--bg-primary: #fff2f2;--bg-secondary: #ffe0e0;--bg-card: #fff8f8;--bg-card-hover: #ffecec;--border: rgba(211, 47, 47, .18);--border-hover: rgba(211, 47, 47, .3)}html.light body.recovery-mode .header{background:#fff0f0e6!important;border-bottom-color:#d32f2f33!important}.modal--recovery{border-color:#ef535059;max-height:90vh}.modal__header--recovery{background:#ef535014;border-bottom-color:#ef535033;flex-shrink:0}.modal__header--recovery h3{color:var(--error);display:flex;align-items:center;gap:.5rem}html.light .modal__header--recovery{background:#d32f2f0f;border-bottom-color:#d32f2f26}.fw-recovery-warning{display:flex;align-items:flex-start;gap:.6rem;padding:.75rem 1rem;background:#ef53501f;border:1px solid rgba(239,83,80,.35);border-radius:var(--radius-md);color:#ef5350;font-size:.87rem;font-weight:500;margin-bottom:1rem;line-height:1.5}html.light .fw-recovery-warning{background:#d32f2f12;border-color:#d32f2f4d;color:#c62828}.fw-recovery-product-select{display:flex;align-items:center;gap:.75rem;margin:.5rem 0 .25rem;font-size:.9rem}.fw-recovery-product-select label{color:var(--text-primary);white-space:nowrap;flex-shrink:0}.fw-recovery-product-select select{flex:1;width:auto}.fw-recovery-btn{background:var(--error)!important;box-shadow:0 4px 12px #ef53504d!important}.fw-recovery-btn:hover:not(:disabled){background:#e53935!important;box-shadow:0 6px 20px #ef535073!important}.fw-recovery-btn:active:not(:disabled){background:#c62828!important;box-shadow:0 2px 8px #ef53504d!important}html.light .fw-recovery-btn{box-shadow:0 4px 12px #d32f2f40!important}html.light .fw-recovery-btn:hover:not(:disabled){box-shadow:0 6px 20px #d32f2f66!important}.fw-recovery-howto-row{display:flex;align-items:center;gap:.5rem;margin:.5rem 0}.fw-recovery-help-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:1.5px solid rgba(239,83,80,.35);background:#ef535014;color:var(--error);cursor:pointer;flex-shrink:0;transition:background .15s,border-color .15s,box-shadow .15s}.fw-recovery-help-btn:hover{background:#ef53502e;border-color:var(--error);box-shadow:0 0 8px #ef535033}.fw-recovery-help-btn:active{transform:scale(.95)}.fw-recovery-help-btn svg{width:16px;height:16px}.fw-recovery-help-btn--active{background:#ef535038;border-color:var(--error)}.fw-recovery-howto-label{font-size:.82rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.fw-recovery-steps{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:.75rem .9rem;margin-bottom:.75rem}.fw-recovery-step-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}.fw-recovery-step-list li{display:flex;align-items:flex-start;gap:.6rem;font-size:.85rem;color:var(--text-primary);line-height:1.4}.fw-recovery-step-num{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:50%;background:var(--error);color:#fff;font-size:.72rem;font-weight:700;flex-shrink:0;margin-top:.1rem}
