.logo,.main-nav a,.nav-dropdown a{text-decoration:none}.decoder-hero h1 span,.footer-bottom a:hover,.footer-links a:hover,.logo,.main-nav a:hover,.mode-tab.active{color:var(--accent)}.audio-filename,.freq-label,.logo{white-space:nowrap}.footer-links h4,.nav-dropdown-label,.result-label,.settings-title,.signal-timeline h4{text-transform:uppercase}:root{--bg:#080a0e;--bg-card:#0e1118;--bg-panel:#13171f;--border:rgba(255,255,255,.07);--border-glow:rgba(232,184,75,.25);--accent:#e8b84b;--accent-dim:rgba(232,184,75,.3);--accent2:#4be8b8;--danger:#e8534b;--text-main:#f0f2f5;--text-muted:#8a919e;--text-dim:#555d6b;--morse-font:'Share Tech Mono',monospace;--body-font:'Barlow',sans-serif;--radius:10px;--radius-lg:16px;--focus-ring:0 0 0 2px rgba(232,184,75,0.4)}*,::after,::before{box-sizing:border-box;margin:0;padding:0}.container,.header-inner{margin:0 auto;max-width:900px}html{scroll-behavior:smooth}body{font-family:var(--body-font);background:var(--bg);color:var(--text-main);min-height:100vh;font-size:16px;line-height:1.6}:focus-visible{outline:0;box-shadow:var(--focus-ring);border-radius:var(--radius)}.container{padding:0 24px}.site-header{background:rgba(8,10,14,.92);border-bottom:1px solid var(--border);padding:0 24px;position:sticky;top:0;z-index:100;backdrop-filter:blur(12px)}.header-inner{display:flex;align-items:center;gap:24px;height:60px}.logo{font-family:var(--morse-font);font-size:1.1rem;letter-spacing:.05em}.main-nav a,.nav-group-btn{font-size:.9rem;color:var(--text-muted)}.logo .logo-dots{opacity:.7;margin-right:6px}.main-nav{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.main-nav a{transition:color .2s}.nav-group{position:relative}.nav-group-btn{background:0 0;border:none;font-family:var(--body-font);cursor:pointer;padding:.5rem}.nav-dropdown{position:absolute;top:100%;left:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem;min-width:180px;display:none;z-index:1000}.decoder-hero,.upload-zone{position:relative;text-align:center}.decode-progress.visible,.error-box.visible,.nav-group:hover .nav-dropdown,.result-box.visible,.signal-timeline.visible,.waveform-wrap.visible{display:block}.nav-dropdown a{display:block;padding:.5rem;color:var(--text-muted);font-size:.85rem}.nav-dropdown-label{padding:.5rem;color:var(--text-dim);font-size:.75rem;letter-spacing:.05em}.nav-divider{height:1px;background:var(--border);margin:.5rem 0}.nav-toggle{display:none;background:0 0;border:none;color:var(--text-main);font-size:1.5rem;cursor:pointer}.decoder-hero{background:linear-gradient(135deg,#080a0e 0,#0f1420 50%,#080a0e 100%);border-bottom:1px solid var(--border);padding:56px 24px 44px;overflow:hidden}.decoder-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 80%,rgba(232,184,75,.06) 0,transparent 70%);pointer-events:none}.hero-eyebrow{font-family:var(--morse-font);color:var(--accent2);font-size:.85rem;letter-spacing:.25em;margin-bottom:14px;opacity:.8}.decoder-hero h1{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.15;margin-bottom:14px}.decoder-hero p{color:var(--text-muted);max-width:560px;margin:0 auto}.decoder-wrap{max-width:900px;margin:0 auto;padding:40px 24px 64px}.mode-tabs{display:flex;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:6px;margin-bottom:28px}.mode-tab{flex:1;padding:12px;border-radius:10px;border:none;background:0 0;color:var(--text-muted);font-size:.95rem;font-weight:600;font-family:var(--body-font);transition:.2s;cursor:pointer}.audio-filename,.file-badge,.record-timer{font-family:var(--morse-font)}.mode-tab:hover{background:rgba(255,255,255,.05)}.mode-tab.active{background:var(--bg-panel);border:1px solid var(--border-glow)}.upload-zone{border:2px dashed var(--border-glow);border-radius:var(--radius-lg);padding:52px 24px;cursor:pointer;transition:.25s;background:var(--bg-card)}.decode-btn,.rec-btn,.record-btn{transition:.2s;cursor:pointer}.audio-preview,.file-badge{background:var(--bg-panel);border:1px solid var(--border)}.upload-zone.drag-over,.upload-zone:hover{border-color:var(--accent);background:rgba(232,184,75,.04)}.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.upload-icon{font-size:3rem;margin-bottom:14px}.upload-zone h3{font-size:1.2rem;margin-bottom:8px;color:var(--text-main)}.upload-zone p{color:var(--text-muted);font-size:.9rem}.file-types{margin-top:14px;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.file-badge{color:var(--text-dim);font-size:.75rem;padding:3px 10px;border-radius:20px}.audio-preview{border-radius:var(--radius);padding:14px 18px;margin:16px 0;display:none;align-items:center;gap:14px}.audio-preview.visible,.freq-display.visible,.record-btn{display:flex}.audio-preview audio{flex:1;height:36px}.audio-filename{font-size:.8rem;color:var(--accent2);overflow:hidden;text-overflow:ellipsis;max-width:200px}.record-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 24px;text-align:center}.rec-btn,.record-btn,.waveform-wrap,canvas#freqCanvas{background:var(--bg-panel)}.record-btn{width:100px;height:100px;border-radius:50%;border:3px solid var(--border-glow);color:var(--text-main);font-size:2.2rem;align-items:center;justify-content:center;margin:0 auto 20px}.record-btn:hover{border-color:var(--danger);box-shadow:0 0 24px rgba(232,83,75,.3)}.record-btn.recording{border-color:var(--danger);background:rgba(232,83,75,.15);animation:1s infinite pulse-rec}@keyframes pulse-rec{0%,100%{box-shadow:0 0 0 0 rgba(232,83,75,.4)}50%{box-shadow:0 0 0 16px rgba(232,83,75,0)}}.record-timer{font-size:1.4rem;color:var(--accent);margin-bottom:8px;min-height:2rem}.rec-btn,.record-status,.setting-item label{color:var(--text-muted)}.record-status{font-size:.9rem;margin-bottom:20px}.waveform-wrap{margin:20px 0;border:1px solid var(--border);border-radius:var(--radius);padding:10px;display:none}canvas#waveCanvas{width:100%;height:80px;display:block;border-radius:6px}.record-controls{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.rec-btn{padding:10px 22px;border-radius:var(--radius);border:1px solid var(--border);font-size:.9rem;font-weight:600;font-family:var(--body-font)}.freq-val,.setting-val{font-family:var(--morse-font)}.prog-step.active,.rec-btn:hover:not(:disabled),.result-act-btn:hover:not(:disabled){border-color:var(--accent2);color:var(--accent2)}.rec-btn.primary{background:var(--accent);color:#000;border-color:var(--accent)}.rec-btn.primary:hover:not(:disabled){background:#f5cc6a}.rec-btn:disabled{opacity:.35;cursor:not-allowed}.tip-box{background:rgba(75,232,184,.05);border:1px solid rgba(75,232,184,.2);border-radius:var(--radius);padding:14px 18px;color:var(--accent2);font-size:.88rem;margin:16px 0}.decoder-settings{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 24px;margin:20px 0}.settings-title{font-size:.85rem;font-weight:700;color:var(--text-dim);letter-spacing:.12em;margin-bottom:16px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:520px){.settings-grid{grid-template-columns:1fr}}.setting-item label{display:block;font-size:.82rem;margin-bottom:6px}.setting-item input[type=range],.setting-item select{width:100%;background:var(--bg-panel);border:1px solid var(--border);color:var(--text-main);border-radius:var(--radius);padding:8px 10px;font-size:.88rem;font-family:var(--body-font)}.setting-item input:focus,.setting-item select:focus{outline:0;border-color:var(--accent)}.setting-val{color:var(--accent);font-size:.8rem;text-align:right;margin-top:4px}.freq-display{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin:12px 0;display:none;align-items:center;gap:14px}.decode-btn,.sig-bar.on{background:var(--accent)}.freq-label{font-size:.8rem;color:var(--text-muted)}.freq-val{color:var(--accent);font-size:1rem}canvas#freqCanvas{flex:1;height:48px;border-radius:4px}.decode-btn-wrap{text-align:center;margin:24px 0}.decode-btn{padding:16px 48px;color:#000;border:none;border-radius:var(--radius);font-size:1.05rem;font-weight:700;font-family:var(--body-font);letter-spacing:.02em}.result-meta span,.result-morse,.result-text{font-family:var(--morse-font)}.decode-btn:hover:not(:disabled){background:#f5cc6a;transform:translateY(-1px)}.decode-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.decode-progress{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin:16px 0;display:none}.progress-label,.signal-timeline h4{font-size:.85rem;margin-bottom:10px}.progress-label{color:var(--text-muted);display:flex;justify-content:space-between}.progress-bar-bg{background:var(--bg-panel);border-radius:20px;height:8px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent2),var(--accent));border-radius:20px;width:0%;transition:width .3s}.prog-step,.signal-bars{background:var(--bg-panel)}.progress-steps{display:flex;gap:6px;margin-top:14px;flex-wrap:wrap}.prog-step{font-size:.75rem;padding:3px 10px;border-radius:20px;border:1px solid var(--border);color:var(--text-dim);transition:.3s}.prog-step.done{border-color:var(--accent);color:var(--accent)}.signal-timeline{margin:20px 0;display:none}.signal-timeline h4{color:var(--text-dim);letter-spacing:.1em}.signal-bars{display:flex;align-items:flex-end;gap:2px;height:60px;border:1px solid var(--border);border-radius:var(--radius);padding:8px;overflow-x:auto}.sig-bar{width:6px;min-width:6px;border-radius:2px;transition:height .1s}.sig-bar.off{background:var(--border)}.result-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;margin:20px 0;display:none}.result-act-btn,.result-morse,.result-text{background:var(--bg-panel)}.result-label{font-size:.8rem;color:var(--text-dim);letter-spacing:.12em;margin-bottom:10px}.result-morse{font-size:1.05rem;color:var(--accent);word-break:break-all;line-height:1.9;padding:14px;border-radius:var(--radius);margin-bottom:16px;min-height:48px;letter-spacing:.08em}.result-text{font-size:1.5rem;font-weight:700;color:var(--text-main);letter-spacing:.1em;padding:16px;border:1px solid var(--border-glow);border-radius:var(--radius);word-break:break-all;min-height:56px}.result-meta{display:flex;gap:16px;flex-wrap:wrap;margin:12px 0;font-size:.82rem;color:var(--text-muted)}.result-meta span{color:var(--accent2)}.result-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.result-act-btn{padding:9px 18px;border-radius:var(--radius);border:1px solid var(--border);color:var(--text-muted);font-size:.85rem;font-weight:600;font-family:var(--body-font);cursor:pointer;transition:.2s}.error-box{background:rgba(232,83,75,.08);border:1px solid rgba(232,83,75,.3);border-radius:var(--radius);padding:14px 18px;color:#f08080;font-size:.9rem;margin:16px 0;display:none}.memory-warning{background:rgba(232,184,75,.1);border:1px solid rgba(232,184,75,.3);border-radius:var(--radius);padding:12px 16px;color:var(--accent);font-size:.85rem;margin:12px 0;display:none}.footer-brand p,.how-step p,.section-sub{color:var(--text-muted)}.memory-warning.visible{display:flex;align-items:center;gap:10px}.how-section{background:var(--bg-panel);border-top:1px solid var(--border);padding:56px 0}.section-title{font-size:1.8rem;font-weight:700;text-align:center;margin-bottom:8px}.section-sub{text-align:center;margin-bottom:32px}.how-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.how-step{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 20px;text-align:center}.how-num{width:44px;height:44px;border-radius:50%;background:rgba(232,184,75,.12);border:1px solid var(--accent-dim);color:var(--accent);font-family:var(--morse-font);font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}.footer-bottom,.site-footer{border-top:1px solid var(--border)}.how-step h3{font-size:1rem;margin-bottom:8px}.how-step p{font-size:.85rem}.site-footer{background:var(--bg-card);padding:40px 24px 24px}.footer-inner{max-width:900px;margin:0 auto;display:flex;gap:40px;flex-wrap:wrap}.footer-brand{flex:2;min-width:200px}.footer-brand p{font-size:.88rem;margin-top:8px}.footer-bottom,.footer-links h4{color:var(--text-dim);font-size:.8rem}.footer-links{flex:1;min-width:120px}.footer-links h4{letter-spacing:.1em;margin-bottom:12px}.footer-bottom a,.footer-links a{color:var(--text-muted);text-decoration:none}.footer-links a{display:block;font-size:.88rem;margin-bottom:6px;transition:color .2s}.footer-bottom{max-width:900px;margin:24px auto 0;padding-top:16px}@media (max-width:768px){.main-nav{display:none;position:absolute;top:60px;left:0;right:0;background:var(--bg-card);flex-direction:column;padding:1rem}.main-nav.active{display:flex}.nav-group.active .nav-dropdown,.nav-toggle{display:block}.nav-group{width:100%}.nav-dropdown{position:static;display:none;margin-top:.5rem}}