:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#e8e8e8;background-color:#1a1a2e;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}:root{--bg: #1a1a2e;--surface: #16213e;--surface-hover: #1a2745;--border: #2a3a5c;--text: #e8e8e8;--text-muted: #8899aa;--accent: #4a9eff;--accent-hover: #3a8eef;--danger: #ff4a6a;--success: #4aff8a;--radius: 8px}.app{max-width:560px;margin:0 auto;padding:24px 20px;min-height:100dvh;display:flex;flex-direction:column}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.app-title{display:flex;align-items:center;gap:10px}.app-logo{width:32px;height:32px;border-radius:7px}.app-header h1{font-size:24px;font-weight:700;color:var(--text);margin:0;letter-spacing:-.5px}.step-indicator{display:flex;gap:8px;justify-content:center;margin-bottom:32px}.dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .2s}.dot.active{background:var(--accent);transform:scale(1.25)}.dot.done{background:var(--accent);opacity:.5}.wizard{flex:1;display:flex;flex-direction:column}.step{display:flex;flex-direction:column;gap:16px;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.step h2{font-size:28px;font-weight:600;color:var(--text);margin:0}.step-header{display:flex;align-items:center}.step-input{width:100%;padding:14px 16px;font-size:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;transition:border-color .15s;box-sizing:border-box}.step-input:focus{border-color:var(--accent)}.step-input::placeholder{color:var(--text-muted)}.input-hint{font-size:14px;color:var(--text-muted);margin:-8px 0 0}.btn{padding:10px 20px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:15px;cursor:pointer;transition:all .15s;font-family:inherit}.btn:hover:not(:disabled){background:var(--surface-hover)}.btn:disabled{opacity:.4;cursor:default}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--surface);border-color:var(--border)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-back{background:none;border:none;color:var(--text-muted);padding:4px 0;font-size:14px}.btn-back:hover:not(:disabled){color:var(--text);background:none}.btn-icon{background:none;border:none;font-size:40px;padding:4px 8px;color:var(--text-muted)}.btn-icon:hover{color:var(--text);background:none}.btn-small{padding:6px 12px;font-size:14px}.step-actions{display:flex;justify-content:center;gap:10px;margin-top:8px}.confirm-actions{flex-direction:column}.preview-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.preview-box p{margin:0;color:var(--text)}.preview-delay{color:var(--text-muted)!important;font-size:14px;margin-top:6px!important}.toggle-group{display:flex;flex-direction:column;gap:8px}.toggle{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text);cursor:pointer}.toggle input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.send-progress{display:flex;flex-direction:column;gap:10px;align-items:center}.send-progress p{margin:0;color:var(--text-muted);font-size:14px}.progress-bar{width:100%;height:6px;background:var(--surface);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);transition:width .2s ease-out;border-radius:3px}.settings-panel{animation:fadeIn .15s ease-out}.settings-panel h3{font-size:20px;font-weight:600;color:var(--text);margin:0 0 20px}.setting-group{margin-bottom:20px}.setting-group>label:first-child{display:block;font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.setting-group input[type=number],.setting-group input[type=text],.setting-group select{width:100%;padding:10px 12px;font-size:15px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;box-sizing:border-box;font-family:inherit}.setting-group input:focus,.setting-group select:focus{border-color:var(--accent)}.setting-hint{display:block;font-size:12px;color:var(--text-muted);margin-top:4px}.midi-destination-row{display:flex;gap:8px}.midi-destination-row select{flex:1}.midi-error{color:var(--danger);font-size:12px;font-weight:400;text-transform:none;letter-spacing:0}.midi-status{display:inline-flex;align-items:center;font-size:12px;margin-top:6px}.midi-status.connected{color:var(--success)}.app-footer{margin-top:auto;padding-top:48px;display:flex;flex-direction:column;gap:20px;align-items:center;text-align:center}.footer-banner p{margin:0;font-size:14px;color:var(--text-muted);line-height:1.5}.footer-app-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%}.footer-app-card{display:flex;flex-direction:column;align-items:center;gap:4px;text-decoration:none;color:var(--text-muted);font-size:11px;transition:color .15s}.footer-app-card:hover{color:var(--text)}.footer-app-desc{font-size:13px;text-align:center}.footer-app-icon{width:48px;height:48px;border-radius:10px;transition:transform .15s}.footer-app-card:hover .footer-app-icon{transform:scale(1.08)}.footer-links{display:flex;gap:24px}.footer-links a{color:var(--text-muted);text-decoration:none;font-size:13px;opacity:.8;transition:opacity .15s}.footer-links a:hover{opacity:1;color:var(--text)}.footer-copyright{margin:0;font-size:12px;color:var(--text-muted);opacity:.6}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:14px 20px;display:flex;align-items:center;justify-content:center;gap:16px;z-index:100;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cookie-banner p{margin:0;font-size:13px;color:var(--text-muted)}.cookie-actions{display:flex;gap:8px;flex-shrink:0}
