@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Unbounded:wght@400;600;700&family=Atkinson+Hyperlegible:wght@400;700&display=swap";html{height:var(--app-height, 100dvh);overflow:hidden;overscroll-behavior:none}:root{font-family:Space Grotesk,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-1: #0c1116;--bg-2: #101820;--text: #f4f7f9;--muted: #8d98a5;--accent: #38f2a2;--accent-cool: #4cc9ff;--error: #ff6b6b}*,*:before,*:after{box-sizing:border-box}body{margin:0;position:fixed;inset:0;width:100%;height:var(--app-height, 100dvh);overflow:hidden;overscroll-behavior:none;background:radial-gradient(ellipse 1400px 1000px at 25% 85%,rgba(168,192,255,.08),transparent 60%),radial-gradient(ellipse 1200px 900px at 75% 15%,rgba(196,181,253,.06),transparent 65%),radial-gradient(ellipse 1000px 800px at 50% 50%,rgba(245,199,247,.04),transparent 70%),#0a0c12;color:var(--text);-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}#root{height:100%;width:100%;overflow:hidden;position:relative}button{font-family:inherit;color:inherit;border:none;background:none;padding:0}.app{--app-pad-x: clamp(16px, 6vw, 80px);--app-pad-y: clamp(18px, 4vw, 40px);min-height:100svh;min-height:var(--app-height, 100dvh);height:var(--app-height, 100dvh);width:100%;display:flex;flex-direction:column;align-items:center;gap:clamp(12px,3vw,24px);padding:calc(var(--app-pad-y) + env(safe-area-inset-top,0px)) var(--app-pad-x) calc(var(--app-pad-y) + env(safe-area-inset-bottom,0px));position:relative;overflow:hidden;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.app.mode-listen.listen-focused{--app-pad-y: clamp(12px, 3vw, 28px);gap:clamp(8px,2vw,16px);padding:calc(clamp(12px,3vw,28px) + env(safe-area-inset-top,0px)) var(--app-pad-x) calc(clamp(12px,3vw,28px) + env(safe-area-inset-bottom,0px))}.app.mode-listen.listen-focused .stage{gap:clamp(8px,2vw,14px)}.app.mode-listen.listen-focused .letter{font-size:clamp(64px,18vw,160px)}.top-bar{width:min(960px,100%);display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:start;gap:clamp(8px,2vw,16px);z-index:2}.logo{display:flex;align-items:center;justify-self:start}.logo-button{padding:0;border:0;background:transparent;cursor:pointer;display:flex;align-items:center}.logo-button:focus-visible{outline:3px solid rgba(255,255,255,.65);outline-offset:6px;border-radius:16px}.logo img{width:clamp(44px,6vw,72px);height:auto;display:block;filter:drop-shadow(0 10px 24px rgba(0,0,0,.35));opacity:.5;transition:opacity .16s ease,transform .6s cubic-bezier(.34,1.56,.64,1)}.logo-button:hover img{opacity:1;transform:rotate(15deg)}.legal-overlay{position:absolute;inset:0;display:grid;place-items:center;padding:clamp(16px,4vw,40px);background:#060a0e99;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:4;animation:legalFade .2s ease}.legal-card{width:min(420px,100%);padding:clamp(18px,4vw,28px);border-radius:20px;border:1px solid rgba(255,255,255,.1);background:#0c121866;-webkit-backdrop-filter:blur(18px) saturate(180%);backdrop-filter:blur(18px) saturate(180%);box-shadow:0 24px 48px #00000073,inset 0 1px #ffffff14;text-align:center;display:flex;flex-direction:column;gap:14px;animation:aboutPop .24s ease}.about-overlay{position:absolute;inset:0;display:grid;place-items:center;padding:clamp(16px,4vw,40px);background:#060a0e4d;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:4;animation:aboutFade .2s ease}.about-card{width:min(420px,100%);padding:clamp(18px,4vw,28px);border-radius:20px;border:1px solid rgba(255,255,255,.18);background:#0c12189e;backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);box-shadow:0 16px 36px #00000073,inset 0 1px #ffffff1f,inset 0 -1px #0006,inset 0 0 18px 6px #ffffff14;text-align:center;display:flex;flex-direction:column;gap:14px;animation:aboutPop .24s ease;position:relative;overflow:hidden}.about-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent)}.about-card:after{content:"";position:absolute;top:0;left:0;width:1px;height:100%;background:linear-gradient(180deg,rgba(255,255,255,.3),transparent,rgba(255,255,255,.2))}.about-title{margin:0;font-size:.9rem;letter-spacing:.4em;text-transform:uppercase;color:var(--text)}.about-instruction{margin:0;font-size:.9rem;line-height:1.5;letter-spacing:.01em;text-align:left;color:#ffffffe0}.about-instruction-secondary{font-size:.85rem;line-height:1.5;letter-spacing:.01em;color:#ffffffb3}.about-links{display:flex;justify-content:center;gap:14px;padding-top:20px;margin-top:14px;border-top:1px solid rgba(255,255,255,.1);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:#ffffff73}.about-links a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:color .16s ease,border-color .16s ease}.about-links a:hover{color:#ffffffbf;border-color:#ffffff59}.about-links a:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:3px}.about-close{align-self:center;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#ffffffbf;text-transform:uppercase;font-size:.65rem;letter-spacing:.2em;padding:10px 18px;cursor:pointer;transition:all .16s ease}.about-close:hover{color:var(--text);border-color:#ffffff59;background:#ffffff1f}.about-close:focus-visible{outline:2px solid rgba(255,255,255,.65);outline-offset:3px}@keyframes aboutFade{0%{opacity:0}to{opacity:1}}@keyframes aboutPop{0%{transform:translateY(6px) scale(.98)}to{transform:translateY(0) scale(1)}}.settings{position:relative;display:flex;flex-direction:column;align-items:flex-end;gap:10px;justify-self:end;z-index:3}.auth{display:flex;align-items:center;justify-content:flex-start;gap:10px;flex-wrap:wrap;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.auth-avatar{width:28px;height:28px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:#0c1218b3;display:grid;place-items:center;color:var(--text);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;object-fit:cover}.auth-name{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-button{border-radius:12px;padding:10px 16px;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%);box-shadow:0 4px 12px #0003,inset 0 1px #ffffff1a;color:#ffffffbf;cursor:pointer;width:100%;transition:all .16s ease}.auth-button:hover{color:var(--text);border-color:#ffffff59;background:#ffffff1a;box-shadow:0 8px 20px #0000004d,inset 0 1px #ffffff26;transform:translateY(-1px)}.auth-button:focus-visible{outline:2px solid rgba(255,255,255,.7);outline-offset:3px}.auth-button:disabled{cursor:not-allowed;opacity:.6}.mode-select,.panel-select{appearance:none;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:#ffffff0a;-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%);box-shadow:0 4px 12px #0003,inset 0 1px #ffffff14;color:var(--text);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,rgba(255,255,255,.6) 50%),linear-gradient(135deg,rgba(255,255,255,.6) 50%,transparent 50%);background-position:calc(100% - 14px) 55%,calc(100% - 9px) 55%;background-size:5px 5px;background-repeat:no-repeat}.mode-select{justify-self:center;padding:8px 26px 8px 12px;font-size:.72rem}.panel-select{padding:8px 30px 8px 14px;font-size:.72rem;font-weight:500;transition:border .16s ease,background .16s ease}.panel-select:hover{border-color:#ffffff40;background:#ffffff14}:is(.mode-select,.settings-button):focus-visible{outline:3px solid rgba(255,255,255,.7);outline-offset:3px}.settings-button{width:40px;height:40px;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:#0a101466;-webkit-backdrop-filter:blur(10px) saturate(150%);backdrop-filter:blur(10px) saturate(150%);display:grid;place-items:center;color:var(--text);box-shadow:0 8px 18px #0000004d,inset 0 1px #ffffff1a;transition:transform .14s ease,border .2s ease,filter .2s ease,box-shadow .2s ease}.settings-button:hover{filter:brightness(1.2);box-shadow:0 10px 24px #00000073}.settings-button:hover svg{animation:settingsGearSpin .6s ease-in-out}.settings-button[aria-expanded=true]{border-color:#ffffff59;box-shadow:0 0 20px #4cc9ff33}@keyframes settingsGearSpin{0%{transform:rotate(0)}to{transform:rotate(90deg)}}.settings-button svg{width:18px;height:18px}.settings-panel{position:absolute;top:calc(100% + 10px);right:0;min-width:240px;padding:20px 18px;border-radius:16px;border:1px solid rgba(255,255,255,.15);background:#101820bf;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);box-shadow:0 8px 32px #0006,inset 0 1px #ffffff1a;display:flex;flex-direction:column;gap:18px;animation:panelSlideIn .2s ease}@keyframes panelSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.panel-group{display:flex;flex-direction:column;gap:12px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}.panel-hint{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:#ffffff80;font-style:italic}:is(.panel-button,.modal-close,.hint-button){border-radius:12px;color:var(--muted);text-transform:uppercase;cursor:pointer;transition:border .16s ease,color .16s ease,background .16s ease,transform .12s ease}.panel-button,.modal-close{padding:10px 16px;font-size:.68rem;letter-spacing:.18em;font-weight:500}.panel-button,.hint-button{border:1px solid rgba(255,255,255,.2);background:#ffffff0d;-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%);box-shadow:0 4px 12px #0003,inset 0 1px #ffffff1a}.panel-button{width:100%;text-align:center}:is(.panel-button,.modal-close,.hint-button):hover{color:var(--text);border-color:#ffffff59;background:#ffffff1a;box-shadow:0 8px 20px #0000004d,inset 0 1px #ffffff26;transform:translateY(-1px)}:is(.panel-select,.panel-button,.modal-close,.hint-button):focus-visible{outline:2px solid rgba(255,255,255,.7);outline-offset:3px}.toggle{display:flex;align-items:center;justify-content:space-between;gap:20px;font-size:.85rem;color:var(--text)}.toggle-label{text-transform:uppercase;letter-spacing:.14em;font-size:.75rem;font-weight:500;color:#fffc}.toggle-input{appearance:none;width:48px;height:26px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:#090e12cc;position:relative;cursor:pointer;transition:background .2s ease,border .2s ease,box-shadow .2s ease}.toggle-input:hover{border-color:#fff6}.toggle-input:after{content:"";width:20px;height:20px;border-radius:999px;background:#ffffffd9;position:absolute;top:2px;left:2px;transition:transform .2s cubic-bezier(.4,0,.2,1),background .2s ease;box-shadow:0 2px 4px #0000004d}.toggle-input:checked{background:#38f2a2e6;border-color:#38f2a2e6;box-shadow:0 0 12px #38f2a24d}.toggle-input:checked:after{transform:translate(22px);background:#0c1418f2}.toggle-input:focus-visible{outline:2px solid rgba(255,255,255,.7);outline-offset:3px}.stage{flex:1;min-height:0;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(12px,2vw,18px);z-index:1}.letter{font-family:Atkinson Hyperlegible,Space Grotesk,sans-serif;font-size:clamp(96px,24vw,200px);line-height:.9;letter-spacing:.12em;font-weight:500;text-transform:uppercase;color:var(--text);text-shadow:0 20px 60px rgba(0,0,0,.55);animation:letterRise .52s ease}.word-display{font-family:Atkinson Hyperlegible,Space Grotesk,sans-serif;font-size:clamp(52px,14vw,160px);line-height:.95;letter-spacing:.12em;font-weight:500;text-transform:uppercase;color:var(--text);text-shadow:0 20px 60px rgba(0,0,0,.55);display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(4px,1.2vw,12px);animation:letterRise .52s ease}.word-letter{opacity:.28;transition:color .18s ease,opacity .18s ease,transform .18s ease}.word-letter.done{opacity:.6;color:var(--accent)}.word-letter.active{opacity:1;color:var(--accent-cool);transform:translateY(-4px)}.status-success .word-letter.active{color:var(--accent)}.status-error .word-letter.active{color:var(--error)}.letter-placeholder{min-height:.9em;opacity:.2}.progress{display:flex;align-items:center;gap:12px;min-height:22px}.pip{display:inline-block;border-radius:999px;background:var(--accent-cool);box-shadow:0 0 16px #4cc9ff4d;transition:transform .14s ease,background .2s ease,opacity .2s ease}.pip.dot{width:12px;height:12px}.pip.dah{width:34px;height:12px}.pip.expected{opacity:.3;filter:saturate(.6)}.pip.hit{opacity:1;transform:translateY(-1px)}.progress-hidden{opacity:0}.status-text{margin:0;font-size:.9rem;line-height:1.2;min-height:1.2em;letter-spacing:.12em;color:var(--muted)}.status-success .status-text{color:var(--accent)}.status-error .status-text{color:var(--error)}.status-success .letter{color:var(--accent)}.status-error .letter{color:var(--error);animation:letterShake .4s ease}.status-success .pip{background:var(--accent);box-shadow:0 0 16px #38f2a259}.status-error .pip{background:var(--error);box-shadow:0 0 14px #ff5a6059}.controls{width:min(560px,100%);display:flex;flex-direction:column;align-items:center;gap:24px;z-index:1}.listen-controls{width:min(560px,100%);display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px}.listen-controls-custom{width:min(640px,100%);flex-direction:column;flex-wrap:nowrap;gap:14px}.keyboard-key{font-family:Unbounded,Space Grotesk,sans-serif;text-transform:uppercase}.listen-keyboard{width:min(640px,100%);display:flex;flex-direction:column;gap:clamp(6px,1.6vw,10px)}.keyboard-row{display:flex;justify-content:center;gap:clamp(4px,1.2vw,8px)}.keyboard-key{flex:1 1 0;max-width:56px;height:clamp(36px,9vw,48px);border-radius:12px;border:1px solid rgba(255,255,255,.15);background:#ffffff0a;-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%);box-shadow:0 4px 12px #0003,inset 0 1px #ffffff14;color:var(--text);font-size:clamp(.75rem,2.8vw,.95rem);letter-spacing:.12em;cursor:pointer;transition:all .12s ease;touch-action:manipulation}.keyboard-key:active{transform:translateY(1px) scale(.98);background:#ffffff14;border-color:#ffffff40}.keyboard-key:disabled{opacity:.5;cursor:default}.modal-overlay{position:fixed;inset:0;background:#060a0eb8;display:grid;place-items:center;padding:clamp(16px,4vw,40px);z-index:5;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal{width:min(720px,100%);max-height:min(82vh,680px);background:#0c1218d9;border-radius:20px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(24px) saturate(180%);backdrop-filter:blur(24px) saturate(180%);box-shadow:0 24px 48px #00000080,inset 0 1px #ffffff14;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px 12px;border-bottom:1px solid rgba(255,255,255,.08)}.modal-actions{display:flex;align-items:center;gap:8px}.modal-title{font-size:.75rem;letter-spacing:.28em;text-transform:uppercase;color:var(--text)}.modal-close{border:1px solid rgba(255,255,255,.2);background:#ffffff0d;-webkit-backdrop-filter:blur(10px) saturate(180%);backdrop-filter:blur(10px) saturate(180%);box-shadow:0 4px 12px #0003,inset 0 1px #ffffff1a}.modal-close.modal-reset{color:var(--error);border-color:#ff5a6059}.modal-close.modal-reset:hover{color:var(--error);border-color:#ff5a6099}.reference-grid,.reference-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(78px,1fr));gap:12px}.reference-grid{padding:16px 20px 20px;overflow:auto}.reference-row{grid-column:1 / -1;margin-top:6px}.reference-card{padding:12px 10px;border-radius:12px;background:linear-gradient(0deg,rgba(var(--score-tint, 0, 0, 0),var(--score-alpha, 0)),rgba(var(--score-tint, 0, 0, 0),var(--score-alpha, 0))),#080c1066;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 1px #ffffff0d;display:flex;flex-direction:column;align-items:center;gap:6px}.reference-head{position:relative;width:100%;min-height:1.4rem;display:grid;place-items:center}.reference-letter,.reference-score{position:absolute;inset:0;display:grid;place-items:center;transition:opacity .16s ease;font-family:Unbounded,Space Grotesk,sans-serif;text-transform:uppercase;color:var(--text)}.reference-letter{font-size:1.2rem;letter-spacing:.18em;opacity:1}.reference-score{font-size:1rem;letter-spacing:.16em;opacity:0}.reference-score.score-positive{color:var(--accent)}.reference-score.score-negative{color:var(--error)}.reference-card:hover .reference-letter{opacity:0}.reference-card:hover .reference-score{opacity:1}.reference-code{display:flex;gap:4px;font-size:.9rem;letter-spacing:.16em;color:var(--muted)}.reference-symbol{font-weight:600}.hint-button{padding:8px 16px;font-size:.65rem;letter-spacing:.18em}.hint-button:disabled{opacity:.6;cursor:default}.freestyle-status{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}.button-content{position:relative;display:flex;align-items:center;gap:16px;z-index:1}.signal{display:inline-block;background:#0000004d;border:none;box-shadow:none}.signal.dot{width:14px;height:14px;border-radius:999px}.signal.dah{width:40px;height:14px;border-radius:999px}@keyframes letterRise{0%{opacity:.4;transform:translateY(14px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes letterShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@media(max-width:600px){.status-text{font-size:.8rem;letter-spacing:.1em}.settings-button{width:36px;height:36px}.auth-name{display:none}.letter{letter-spacing:.08em}.button-content{gap:12px}.signal.dah{width:32px}}.morse-button-wrap{width:min(480px,100%);display:grid;place-items:center}.morse-button{position:relative;width:100%;height:clamp(64px,14vw,96px);border-radius:999px;border:none;background:transparent;display:grid;place-items:center;cursor:pointer;isolation:isolate;transform:translateZ(0);overflow:visible;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .3s ease;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:none;-webkit-tap-highlight-color:transparent;z-index:1}.morse-button:before{content:"";position:absolute;inset:0;border-radius:999px;padding:2px;opacity:.5;mix-blend-mode:hard-light;background:conic-gradient(from 125deg,#000000bf,#00000080 25deg,#00000059 45deg,#0000,#fff0 135deg,#fffffff2 180deg 200deg,#fff0 225deg,#0000,#00000073 315deg,#00000080 350deg,#000000bf 360deg);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;z-index:10}.fluid-container{position:absolute;inset:0;border-radius:999px;overflow:hidden;z-index:-2}.fluid-paint{position:absolute;inset:-20px;background:linear-gradient(125deg,transparent 20%,rgba(200,220,255,.85) 25%,transparent 30%),linear-gradient(65deg,transparent 35%,rgba(160,200,255,.9) 40%,transparent 50%),linear-gradient(170deg,transparent 10%,rgba(255,180,200,.85) 20%,transparent 35%),linear-gradient(95deg,transparent 50%,rgba(180,170,240,.85) 60%,transparent 70%),linear-gradient(140deg,transparent 60%,rgba(150,200,255,.9) 70%,transparent 80%),linear-gradient(45deg,transparent 15%,rgba(255,190,210,.8) 25%,transparent 40%),linear-gradient(200deg,transparent 40%,rgba(190,180,240,.85) 55%,transparent 65%),linear-gradient(135deg,#a8d0ff,#d0c0f0,#ffccd8,#b8d8ff,#f0d0e8);background-size:200% 200%;filter:url(#fluid) saturate(1.15) contrast(1.02);transition:background-size .6s cubic-bezier(.34,1.26,.64,1),filter .3s ease;animation:liquidSwirl 16s ease-in-out infinite}.morse-button.pressing .fluid-paint{background-size:120% 170%;filter:url(#fluidActive) saturate(2) contrast(1.15) brightness(1.05)}@keyframes liquidSwirl{0%,to{background-position:80% 20%;transform:scale(1.03) rotate(2deg)}14%{background-position:30% 10%;transform:scale(1.02) rotate(-2deg)}28%{background-position:10% 50%;transform:scale(1.04) rotate(1deg)}42%{background-position:25% 85%;transform:scale(1.02) rotate(-1deg)}57%{background-position:70% 90%;transform:scale(1.03) rotate(2deg)}71%{background-position:95% 60%;transform:scale(1.02) rotate(-2deg)}85%{background-position:90% 30%;transform:scale(1.04) rotate(1deg)}}.fluid-glow{position:absolute;inset:-2px;border-radius:999px;z-index:-3;pointer-events:none;background:radial-gradient(120% 140% at 15% 70%,rgba(147,197,253,.5),transparent 60%),radial-gradient(110% 120% at 85% 30%,rgba(252,165,202,.45),transparent 65%),radial-gradient(140% 140% at 55% 55%,rgba(196,181,253,.4),transparent 60%);filter:blur(8px);opacity:.55;transition:opacity .3s ease}.fluid-glass{position:absolute;inset:0;border-radius:999px;z-index:1;pointer-events:none;background:linear-gradient(160deg,rgba(255,255,255,.2) 0%,rgba(255,255,255,.08) 20%,transparent 50%,rgba(0,0,0,.05) 80%,rgba(0,0,0,.1) 100%);box-shadow:inset 0 2px 3px #ffffff40,inset 0 -2px 3px #00000026,inset 2px 0 3px #ffffff14,inset -2px 0 3px #00000014}.fluid-glass:before{content:"";position:absolute;inset:2px;border-radius:999px;border:1px solid rgba(255,255,255,.08);pointer-events:none}.fluid-glass:after{content:"";position:absolute;top:4px;left:10%;right:10%;height:30%;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,.12),transparent);filter:blur(2px);pointer-events:none}.morse-button:hover .fluid-glow{opacity:.8}.morse-button.pressing{transform:scale(.98);box-shadow:inset 0 2px 4px #0003,inset 0 -1px 1px #ffffff1a,0 0 0 1px #0000004d,0 2px 8px #0003}.morse-button.pressing .fluid-glow{opacity:1}.morse-button,.morse-button *,.morse-button *:before,.morse-button *:after{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.morse-button:focus-visible{outline:2px solid rgba(255,255,255,.4);outline-offset:4px}@media(prefers-reduced-motion:reduce){.fluid-paint{filter:url(#fluid) saturate(1.15) contrast(1.02)!important;animation:none!important}}@media(max-width:600px){.morse-button-wrap{margin-bottom:clamp(8px,3vw,14px)}}
