*,*:before,*:after{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:transparent}a{color:var(--accent-1);text-decoration:none}a:hover{text-decoration:underline}:root{--bg-start: #0a0614;--bg-end: #040208;--surface: rgba(18, 8, 38, .68);--surface-strong: rgba(18, 8, 38, .88);--panel: rgba(28, 14, 58, .82);--panel-light: rgba(38, 20, 72, .9);--panel-border: rgba(120, 70, 220, .28);--text: #e8e0ff;--muted: #8a7ab8;--ink: #1a0e30;--accent-1: #b066ff;--accent-2: #22d4ee;--accent: color-mix(in oklab, var(--accent-1) 55%, var(--accent-2) 45%);--ring: #9955ee;--border: rgba(100, 55, 200, .35);--female: #ff3cac;--male: #3c85ff;--band-gray: rgba(22, 12, 44, 1);--band-blue: rgba(10, 38, 110, 1);--band-pink: rgba(100, 10, 88, 1);--band-lilac: rgba(50, 10, 130, 1);--stream-ink: #00f5ea}.bg{position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse at 20% 15%,rgba(80,20,140,.22) 0%,transparent 60%),radial-gradient(ellipse at 80% 85%,rgba(10,60,130,.18) 0%,transparent 55%),linear-gradient(160deg,var(--bg-start) 0%,var(--bg-end) 100%)}.container{width:min(980px,92%);margin:0 auto}main.container{padding-bottom:80px}.site-banner{text-align:center;padding:1.5rem 1rem .25rem}.site-banner__title{display:block;font-size:clamp(1.1rem,3vw,1.35rem);font-weight:900;letter-spacing:-.02em;background:linear-gradient(90deg,#c8f,#22d4ee);-webkit-background-clip:text;background-clip:text;color:transparent;text-decoration:none}.site-banner__title:hover{text-decoration:none}.site-banner__sub{display:block;font-size:.7rem;color:var(--muted);margin-top:2px;letter-spacing:.01em}.hero{padding:16px 0}.hero-title{margin:16px 0 6px;font-size:clamp(26px,5.5vw,52px);line-height:1.06;font-weight:900;background:linear-gradient(90deg,#c8f,#22d4ee);-webkit-background-clip:text;background-clip:text;color:transparent}.sub{margin:0 0 4px;color:var(--muted);font-size:14px;line-height:1.55}.start-wrap{display:flex;align-items:stretch;gap:14px;margin-top:8px;flex-wrap:wrap}.record-btn{flex:0 0 auto;appearance:none;border:0;cursor:pointer;padding:16px 26px;border-radius:16px;min-height:56px;font-weight:900;letter-spacing:.5px;font-size:17px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);background:linear-gradient(180deg,#ffffff2e,#fff0) padding-box,linear-gradient(135deg,#93f,#22d4ee) border-box;border:1.5px solid transparent;box-shadow:0 18px 40px #641edc66,0 6px 14px #00000040;transition:transform .12s ease,filter .14s ease,box-shadow .14s ease}.record-btn:hover{filter:brightness(1.08) saturate(1.1);transform:translateY(-2px)}.record-btn:active{transform:translateY(0)}.record-btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}.record-btn .rec,body.recording .record-btn .idle{display:none}body.recording .record-btn .rec{display:inline}body.recording .record-btn{background:linear-gradient(180deg,#ffffff2e,#fff0) padding-box,linear-gradient(135deg,#ff3cac,#f83) border-box;box-shadow:0 18px 40px #ff3cac66,0 6px 14px #00000040}.status-bar{flex:1 1 240px;display:flex;align-items:center;gap:12px;min-height:56px;padding:14px 20px;border-radius:16px;border:1px solid var(--panel-border);background:linear-gradient(135deg,var(--surface) 0%,var(--surface-strong) 100%);backdrop-filter:blur(16px);box-shadow:0 16px 40px #0000004d;font-size:14px;font-weight:600;color:var(--text)}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;background:#8c64ff66;transition:background .25s ease}body.recording .status-dot{background:var(--accent-1);box-shadow:0 0 10px var(--accent-1);animation:dotPulse .7s ease-in-out infinite alternate}body.recording.silent .status-dot{background:#ffb84d;box-shadow:0 0 8px #ffb84d80;animation:none}@keyframes dotPulse{0%{transform:scale(.75);opacity:.7}to{transform:scale(1.3);opacity:1}}.interval-control{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);flex-basis:100%;margin-top:2px}.interval-control input[type=range]{width:130px;accent-color:var(--accent-1)}.interval-control input[type=range]:disabled{opacity:.35}.checkbox-label{display:flex;align-items:center;gap:5px;cursor:pointer;user-select:none}.meter{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0 14px}.meter.hidden{display:none}.bar{--p: 0;--meter-h: 10px;padding:14px 16px 16px;border-radius:14px;background:var(--panel);border:1px solid var(--panel-border);display:flex;flex-direction:column;gap:10px;box-shadow:0 12px 30px #00000059,inset 0 1px #c8a0ff14}.bar-header{display:flex;align-items:flex-end;justify-content:space-between;gap:10px}.bar .label{font-size:11.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted)}.bar .value{font-weight:900;font-size:22px;line-height:1;color:var(--text)}.bar.female .value{color:var(--female);text-shadow:0 0 14px rgba(255,60,172,.5)}.bar.male .value{color:var(--male);text-shadow:0 0 14px rgba(60,133,255,.5)}.bar-track{position:relative;height:var(--meter-h);border-radius:999px;background:#ffffff12;overflow:hidden}.bar-track:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 39.5%,rgba(255,255,255,.12) 39.5% 40.5%,transparent 40.5% 59.5%,rgba(255,255,255,.12) 59.5% 60.5%,transparent 60.5%);pointer-events:none;z-index:2}.bar-track:after{content:"";position:absolute;inset:0;width:calc(var(--p) * 100%);border-radius:inherit;transition:width .5s ease}.bar.female .bar-track:after{background:linear-gradient(90deg,rgba(255,60,172,.25) 0%,var(--female) 100%);box-shadow:0 0 12px #ff3cac99}.bar.male .bar-track:after{background:linear-gradient(90deg,rgba(60,133,255,.25) 0%,var(--male) 100%);box-shadow:0 0 12px #3c85ff99}.bar-scale{position:relative;height:14px;font-size:10px;font-variant-numeric:tabular-nums;color:#aa96dc80;pointer-events:none}.bar-scale__label{position:absolute;top:0;transform:translate(-50%)}.bar-scale__label--zero{left:0;transform:none}.bar-scale__label--forty{left:40%}.bar-scale__label--sixty{left:60%}.bar-scale__label--full{left:100%;transform:translate(-100%)}.pitch-wrap{margin-top:6px;padding:12px 12px 10px;border-radius:16px;border:1px solid var(--panel-border);background:var(--panel);box-shadow:0 14px 36px #00000061}.pitch-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;flex-wrap:wrap;gap:8px}.pitch-now{display:flex;align-items:center;gap:8px}#pitchNow{font-weight:900;font-size:22px;color:var(--stream-ink);text-shadow:0 0 14px rgba(0,245,234,.5);font-variant-numeric:tabular-nums;min-width:90px}.band-tag{padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700;background:#00f5ea1f;border:1px solid rgba(0,245,234,.25);color:var(--stream-ink)}#volNow{font-size:13px;font-weight:600;color:var(--muted);font-variant-numeric:tabular-nums}#pitchCanvas{display:block;width:100%;height:220px;border-radius:10px;background:#070310}.pitch-legend{margin-top:5px;font-size:11.5px;color:#8c78be8c}.formant-graph-wrap{margin-bottom:12px}.formant-graph-head{display:flex;align-items:center;gap:20px;margin-bottom:8px;flex-wrap:wrap}.fleg{font-size:12px;font-weight:700;letter-spacing:.3px;color:var(--muted);display:flex;align-items:center;gap:5px}.fleg span[id]{font-size:15px;font-weight:900;font-variant-numeric:tabular-nums}.fleg--f1 span[id]{color:#e06bff;text-shadow:0 0 10px rgba(224,107,255,.4)}.fleg--f2 span[id]{color:#22d4ee;text-shadow:0 0 10px rgba(34,212,238,.4)}.fleg--f3 span[id]{color:#b8ff6b;text-shadow:0 0 10px rgba(184,255,107,.3)}.fleg--breath span[id]{color:#ffb84d;text-shadow:0 0 10px rgba(255,184,77,.3)}#formantCanvas{display:block;width:100%;height:160px;border-radius:10px;background:#070310}.formant-legend{margin-top:5px;font-size:11.5px;color:#8c78be8c}.fc--f1{color:#e06bff}.fc--f2{color:#22d4ee}.fc--f3{color:#b8ff6b}.formant-wrap{margin-top:12px;padding:14px;border-radius:16px;border:1px solid var(--panel-border);background:var(--panel);box-shadow:0 14px 36px #00000059}.formant-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:12px}.formant-head h2{margin:0;font-size:16px;font-weight:800;color:var(--text)}.formant-note{margin:0;font-size:12px;color:var(--muted)}.resonance-panel{margin-top:12px;border-radius:12px;padding:10px 12px;border:1px dashed rgba(100,60,200,.3);background:#160a3280;display:flex;flex-direction:column;gap:8px}.resonance-panel .label{font-size:11px;font-weight:700;letter-spacing:.35px;text-transform:uppercase;color:var(--muted)}.resonance-bar{display:flex;width:100%;height:30px;border-radius:999px;overflow:hidden;border:1px solid rgba(100,60,200,.25)}.res-part{display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#ffffffd9;text-shadow:0 1px 3px rgba(0,0,0,.5);min-width:0;transition:flex .25s ease;white-space:nowrap;overflow:hidden}.res-part+.res-part{box-shadow:inset 2px 0 #ffffff14}.res-part.chest{background:linear-gradient(135deg,#b43c3cbf,#c8505099)}.res-part.mask{background:linear-gradient(135deg,#503cb4bf,#6450c899)}.res-part.head{background:linear-gradient(135deg,#1e82a0bf,#28b4c899)}.gender-graph-section{margin-top:6px;padding:12px 12px 10px;border-radius:16px;border:1px solid var(--panel-border);background:var(--panel);box-shadow:0 14px 36px #00000061}.gender-graph-head{display:flex;align-items:center;gap:20px;margin-bottom:8px;flex-wrap:wrap}.fleg--gender-f span[id]{color:var(--female);text-shadow:0 0 10px rgba(255,60,172,.4)}.fleg--gender-m span[id]{color:var(--male);text-shadow:0 0 10px rgba(60,133,255,.4)}#genderCanvas{display:block;width:100%;height:120px;border-radius:10px;background:#070310}.gender-legend{margin-top:5px;font-size:11.5px;color:#8c78be8c}.gc--f{color:var(--female)}.gc--m{color:var(--male)}.about-section{margin-top:48px;padding-bottom:12px}.section-heading{margin:0 0 16px;font-size:clamp(15px,2.8vw,19px);font-weight:800;background:linear-gradient(90deg,#c8f,#22d4ee);-webkit-background-clip:text;background-clip:text;color:transparent}.feature-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}.feature-card{padding:18px 20px;border-radius:16px;border:1px solid var(--panel-border);background:var(--panel);box-shadow:0 14px 36px #00000059,inset 0 1px #c8a0ff0f}.feature-card__icon{font-size:22px;margin-bottom:10px;line-height:1}.feature-card__title{font-size:11px;font-weight:700;letter-spacing:.45px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.feature-card__body{margin:0;font-size:13.5px;color:var(--text);line-height:1.65}.score-callout{padding:20px 24px;border-radius:14px;border:1px dashed rgba(176,102,255,.5);background:#3c126e61;backdrop-filter:blur(8px)}.score-callout p{margin:0 0 14px;font-size:14px;color:var(--text);line-height:1.7}.score-callout strong{color:var(--accent-1)}@media(max-width:600px){.feature-cards{grid-template-columns:1fr}}.footer{padding:28px 0 20px;text-align:center;color:#8c78be73;font-size:12px}.hidden{display:none!important}@media(max-width:600px){.meter{grid-template-columns:1fr}.hero{padding:22px 0 10px}.start-wrap{gap:10px}.record-btn{width:100%}.status-bar{flex-basis:100%}}@media(max-width:720px){.status-bar{flex-basis:100%}}@media(prefers-reduced-motion:reduce){.record-btn,.bar-track:after,.res-part{transition:none}body.recording .status-dot{animation:none}}.site-nav{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;padding:.75rem 1rem 0}.site-nav a{font-size:.78rem;font-weight:500;letter-spacing:.02em;color:var(--muted);text-decoration:none;padding:4px 12px;border-radius:20px;background:var(--panel);border:1px solid var(--panel-border);transition:color .15s,border-color .15s,box-shadow .15s}.site-nav a:hover{color:var(--text);border-color:#b066ff66;text-decoration:none}.site-nav a[aria-current=page]{color:var(--accent-1);border-color:var(--accent-1);box-shadow:0 0 8px #b066ff40}.nav-beta{font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-2);border:1px solid currentColor;border-radius:3px;padding:1px 4px;margin-left:5px;vertical-align:middle;opacity:.75;pointer-events:none}.tool-canvas{display:block;width:100%;border-radius:10px;background:#070310}.reset-btn{background:transparent;border:1px solid var(--panel-border);color:var(--muted);border-radius:8px;padding:6px 14px;font-size:.82rem;cursor:pointer;transition:color .15s,border-color .15s}.reset-btn:hover{color:var(--text);border-color:#b066ff66}.note-display{text-align:center;padding:2rem 1.5rem 1.5rem;background:var(--panel);border:1px solid var(--panel-border);border-radius:14px;margin:1.5rem 0}.note-main{line-height:1;font-weight:700;letter-spacing:-.03em;background:linear-gradient(135deg,var(--accent-1),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block;font-size:clamp(5rem,20vw,9rem)}.note-octave{font-size:.38em;font-weight:500;opacity:.75}.note-hz{font-size:1.05rem;color:var(--muted);margin:.35rem 0 1.5rem;min-height:1.4em}.cents-wrap{max-width:420px;margin:0 auto 1.25rem}.cents-track{position:relative;height:12px;background:var(--surface-strong);border-radius:6px;margin-bottom:5px}.cents-center-line{position:absolute;left:50%;top:-4px;bottom:-4px;width:2px;background:#ffffff2e;transform:translate(-50%)}.cents-marker{position:absolute;top:50%;width:18px;height:18px;border-radius:50%;background:var(--accent-1);transform:translate(-50%,-50%);transition:left .08s linear,background .15s;box-shadow:0 0 8px currentColor}.cents-labels{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted)}#centsLabel{font-size:.9rem;color:var(--muted);margin-top:.4rem;display:block}.note-vol{font-size:.82rem;color:var(--muted);margin-top:.5rem}.vowel-canvas-wrap{margin:1.5rem 0}.vowel-axis-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--muted);margin-bottom:4px;padding:0 2px}#rangeWrap{margin:1.5rem 0}.range-readout{display:flex;justify-content:space-between;margin-top:1rem;padding:0 .25rem}.range-endpoint{text-align:center}.range-label{font-size:.75rem;color:var(--muted);margin-bottom:2px}.range-note{font-size:1.6rem;font-weight:700;color:var(--accent-1);line-height:1.1}.range-hz{font-size:.78rem;color:var(--muted)}.age-meter{text-align:center;padding:2rem 1.5rem 1.5rem;background:var(--panel);border:1px solid var(--panel-border);border-radius:14px;margin:1.5rem 0}.age-display{display:flex;align-items:baseline;justify-content:center;gap:8px}.age-number{font-size:clamp(4rem,18vw,8rem);font-weight:700;line-height:1;background:linear-gradient(135deg,var(--accent-1),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.age-unit{font-size:1.4rem;color:var(--muted);font-weight:500}.age-confidence{font-size:.85rem;color:var(--muted);margin:.25rem 0 .5rem}.age-legend{font-size:.75rem;color:var(--muted);margin-top:6px}#emotionMeter{margin:1.5rem 0;padding:1.25rem 1.5rem;background:var(--panel);border:1px solid var(--panel-border);border-radius:14px}.emotion-top{font-size:clamp(1.6rem,5vw,2.5rem);font-weight:700;text-align:center;margin-bottom:1.25rem}.emotion-bars{display:flex;flex-direction:column;gap:8px}.emotion-row{display:flex;align-items:center;gap:10px}.emotion-label{width:80px;font-size:.82rem;color:var(--muted);flex-shrink:0}.emotion-bar-track{flex:1;height:10px;border-radius:5px;background:var(--surface-strong);overflow:hidden;position:relative}.emotion-bar-fill{height:100%;border-radius:5px;transition:width .3s ease}.emotion-pct{width:44px;text-align:right;font-size:.78rem;color:var(--muted);flex-shrink:0}#spectroWrap{margin:1.5rem 0}.spectro-labels{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted);margin-bottom:4px;padding:0 2px}.spectro-time-label{font-size:.72rem;color:var(--muted);margin-top:4px;text-align:right}.vibrato-display{margin:1.5rem 0}.vibrato-stats{display:flex;justify-content:space-around;gap:1rem;padding:1.25rem;background:var(--panel);border:1px solid var(--panel-border);border-radius:14px;margin-bottom:0;flex-wrap:wrap}.vibrato-stat{text-align:center;min-width:100px}.vibrato-value{font-size:2rem;font-weight:700;color:var(--accent-2);line-height:1.1}.vibrato-label{font-size:.75rem;color:var(--muted);margin-top:2px}
