:root{--bg: #f7f6f3;--bg-secondary: #efefeb;--surface: #ffffff;--surface-hover: #f9f9f7;--border: rgba(0, 0, 0, .08);--border-strong: rgba(0, 0, 0, .14);--text-primary: #1a1a18;--text-secondary: #6b6b63;--text-muted: #9b9b93;--accent: #c96442;--accent-subtle: rgba(201, 100, 66, .1);--accent-hover: #b8553a;--wave-color: rgba(0, 0, 0, .2);--wave-progress: #c96442;--male: #4a7fd4;--male-subtle: rgba(74, 127, 212, .18);--neutral: #a787c2;--neutral-subtle: rgba(167, 135, 194, .18);--female: #c25e8f;--female-subtle: rgba(194, 94, 143, .18);--music: #b8972a;--music-subtle: rgba(184, 151, 42, .18);--noise: #7a7a72;--noise-subtle: rgba(122, 122, 114, .18);--noenergy: #aaaaaa;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06), 0 1px 4px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08), 0 1px 3px rgba(0, 0, 0, .05);--radius-sm: 8px;--radius-md: 14px;--radius-lg: 18px;--transition: .18s ease;--block-card-border: rgba(0, 0, 0, .11);--block-card-shadow: 0 1px 2px rgba(0, 0, 0, .04);--bg-glass: rgba(247, 246, 243, .8);--accent-border: rgba(201, 100, 66, .3);--male-dom-bg: rgba(74, 127, 212, .08);--neutral-dom-bg: rgba(167, 135, 194, .08);--female-dom-bg: rgba(194, 94, 143, .08);--noise-dom-bg: rgba(122, 122, 114, .08);--surface-blend: #f8f8f7}[data-theme=dark]{--bg: #141413;--bg-secondary: #1c1c1a;--surface: #222220;--surface-hover: #2a2a27;--border: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .16);--text-primary: #ededea;--text-secondary: #a8a8a0;--text-muted: #8a8a82;--accent: #d4a574;--accent-subtle: rgba(212, 165, 116, .14);--accent-hover: #e0b585;--wave-color: rgba(255, 255, 255, .22);--wave-progress: #d4a574;--male: #7ba4f0;--male-subtle: rgba(123, 164, 240, .2);--neutral: #bba3d0;--neutral-subtle: rgba(187, 163, 208, .2);--female: #e896b7;--female-subtle: rgba(232, 150, 183, .2);--music: #d9be7a;--music-subtle: rgba(217, 190, 122, .2);--noise: #9a9a9c;--noise-subtle: rgba(154, 154, 156, .2);--noenergy: #48484a;--bg-glass: rgba(20, 20, 19, .82);--accent-border: rgba(212, 165, 116, .32);--male-dom-bg: rgba(123, 164, 240, .1);--neutral-dom-bg: rgba(187, 163, 208, .1);--female-dom-bg: rgba(232, 150, 183, .1);--noise-dom-bg: rgba(154, 154, 156, .1);--surface-blend: #1f1f1d;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .45), 0 1px 3px rgba(0, 0, 0, .25);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5), 0 2px 4px rgba(0, 0, 0, .3);--block-card-border: rgba(255, 255, 255, .12);--block-card-shadow: 0 1px 2px rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}[hidden]{display:none!important}html{font-size:15px;-webkit-font-smoothing:antialiased;touch-action:manipulation;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:1rem;line-height:1.6;background:var(--bg);color:var(--text-primary);min-height:100vh;transition:background var(--transition),color var(--transition)}.header{position:sticky;top:0;z-index:100;border-bottom:1px solid var(--border);background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.header-inner{max-width:none;padding:0 20px;height:56px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;color:var(--text-primary);letter-spacing:-.01em;text-decoration:none}.logo:hover{opacity:.75}.header-actions{display:flex;align-items:center;gap:4px}.lang-picker{position:relative;display:inline-flex}.lang-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:132px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:4px;display:flex;flex-direction:column;gap:2px;z-index:50}.lang-menu[hidden]{display:none}.lang-menu-item{background:none;border:none;border-radius:var(--radius-sm);padding:6px 10px;font:inherit;font-size:.85rem;color:var(--text-secondary);text-align:left;cursor:pointer;transition:background var(--transition),color var(--transition)}.lang-menu-item:hover,.lang-menu-item:focus-visible{background:var(--surface-hover);color:var(--text-primary);outline:none}.lang-menu-item.is-active{color:var(--text-primary);font-weight:600;background:var(--surface-hover)}.main{max-width:780px;margin:0 auto;padding:36px 24px 80px;display:flex;flex-direction:column;gap:16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:background var(--transition),border-color var(--transition)}.upload-section{padding:18px;display:flex;flex-direction:column;gap:14px}.input-method-tabs{display:flex;gap:4px;padding:4px;border-radius:10px;background:var(--bg-secondary);border:1px solid var(--border)}.input-method-tab{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 12px;background:transparent;border:0;border-radius:7px;cursor:pointer;color:var(--text-muted);font:inherit;font-size:.85rem;font-weight:500;transition:background var(--transition),color var(--transition),box-shadow var(--transition)}.input-method-tab:hover:not(.is-active){color:var(--text-primary)}.input-method-tab.is-active{background:var(--surface);color:var(--text-primary);box-shadow:0 1px 2px #0000000f}.input-method-tab svg{flex-shrink:0}.input-method-tab[hidden],.input-method-panel[hidden]{display:none}.upload-dropzone{padding:40px 24px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;border:1.5px dashed var(--border-strong);border-radius:10px;background:transparent;transition:border-color var(--transition),background var(--transition),box-shadow var(--transition)}.upload-dropzone:hover,.upload-dropzone.drag-over{border-color:var(--accent);background:var(--accent-subtle);box-shadow:0 0 0 4px var(--accent-subtle)}.upload-dropzone.drag-over{box-shadow:0 0 0 6px var(--accent-subtle)}.upload-icon{margin-bottom:6px}.upload-title{font-weight:500;font-size:1rem;color:var(--text-primary)}.upload-subtitle{font-size:.875rem;color:var(--text-secondary)}.upload-hint{font-size:.78rem;color:var(--text-muted);margin-top:2px}.record-panel-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:6px 0 4px}.recorder-hint{font-size:.78rem;color:var(--text-muted);margin:0;text-align:center}.icon-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;transition:background var(--transition),color var(--transition),border-color var(--transition)}.icon-btn:hover{background:var(--surface-hover);color:var(--text-primary)}[data-theme=dark] .icon-sun{display:none}[data-theme=dark] .icon-moon,[data-theme=light] .icon-sun{display:block}[data-theme=light] .icon-moon{display:none}:root:not([data-theme]) .icon-moon{display:none}.link-btn{background:none;border:none;padding:0;cursor:pointer;color:var(--accent);font:inherit;font-size:inherit;text-decoration:underline;text-underline-offset:2px;transition:color var(--transition)}.link-btn:hover{color:var(--accent-hover)}.link-btn.small{font-size:.78rem}.hint-muted{color:var(--text-muted);font-size:.78rem;font-weight:400}.upload-import-row{display:flex;justify-content:center;margin-top:12px}.btn-secondary{display:inline-flex;align-items:center;gap:6px;background:var(--surface);color:var(--text-primary);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:6px 12px;font:inherit;font-size:.85rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background var(--transition),border-color var(--transition)}.btn-secondary:hover:not(:disabled){background:var(--accent-subtle);border-color:var(--accent-border)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary.small{font-size:.78rem;padding:4px 10px;gap:5px}.export-dialog{border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--surface);color:var(--text-primary);padding:0;max-width:440px;width:calc(100% - 32px);box-shadow:var(--shadow-md);margin:auto}.export-dialog::backdrop{background:#00000059}.export-dialog-form{display:flex;flex-direction:column;gap:16px;padding:20px 22px}.export-dialog-title{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.export-dialog-group{border:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.export-dialog-group legend{font-size:.78rem;font-weight:600;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;padding:0 0 4px}.export-dialog-option{display:flex;align-items:flex-start;gap:8px;font-size:.9rem;color:var(--text-primary);cursor:pointer;padding:4px 6px;border-radius:var(--radius-sm)}.export-dialog-option:hover{background:var(--accent-subtle)}.export-dialog-option input{margin-top:3px;accent-color:var(--accent)}.export-dialog-option .hint-muted{display:inline-block;margin-left:6px}.export-dialog-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.btn-primary{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 16px;font:inherit;font-size:.875rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background var(--transition),opacity var(--transition),transform 80ms ease}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.play-btn{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),transform 80ms ease}.play-btn .icon-play,.play-btn .icon-pause{display:block}.play-btn .icon-pause,.play-btn.is-playing .icon-play{display:none}.play-btn.is-playing .icon-pause{display:block}.play-btn:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.05)}.play-btn:disabled{opacity:.4;cursor:not-allowed}.player-card{padding:20px 20px 16px}.file-info{display:flex;align-items:center;gap:8px;margin-bottom:14px;color:var(--text-secondary);font-size:.875rem}.file-name{flex:1;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.waveform-container{position:relative;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-secondary);height:88px;margin-bottom:14px}#waveform{width:100%;height:100%}.segment-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.waveform-tooltip{position:absolute;top:6px;transform:translate(-50%);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:3px 8px;font-size:.7rem;color:var(--text-secondary);white-space:nowrap;pointer-events:none;box-shadow:var(--shadow-md);opacity:0;transition:opacity .12s ease;z-index:10;font-variant-numeric:tabular-nums}.waveform-tooltip.visible{opacity:1}.scatter-tooltip{position:absolute;left:0;top:0;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:5px 8px;font-size:.7rem;color:var(--text-secondary);line-height:1.35;pointer-events:none;box-shadow:var(--shadow-md);opacity:0;transition:opacity .12s ease;z-index:10;font-variant-numeric:tabular-nums;max-width:220px}.scatter-tooltip.visible{opacity:1}.scatter-tooltip-line{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scatter-tooltip-time{color:var(--text-muted);font-size:.66rem}.scatter-tooltip-name{color:var(--text-primary);font-weight:500}.waveform-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;padding:0 12px;background:var(--bg-secondary)}.skeleton-wave{width:100%;height:40px;background:linear-gradient(90deg,var(--border) 25%,var(--border-strong) 50%,var(--border) 75%);background-size:200% 100%;border-radius:4px;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.controls{display:flex;align-items:center;gap:10px}.time-label{font-size:.78rem;font-variant-numeric:tabular-nums;color:var(--text-secondary);min-width:34px;white-space:nowrap}.seek-bar{flex:1;height:20px;display:flex;align-items:center;cursor:pointer}.seek-track{position:relative;width:100%;height:3px;background:var(--border-strong);border-radius:99px}.seek-progress{position:absolute;left:0;top:0;height:100%;background:var(--accent);border-radius:99px;width:0%;transition:width 80ms linear}.seek-thumb{position:absolute;top:50%;transform:translate(-50%,-50%) scale(0);width:12px;height:12px;border-radius:50%;background:var(--accent);left:0%;transition:transform .12s ease,left 80ms linear}.seek-bar:hover .seek-thumb{transform:translate(-50%,-50%) scale(1)}.spinner{width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.stats-collapsible{margin:14px 14px 0}.stats-caption{font-size:11px;line-height:1.3;color:var(--text-muted)}.stats-grid{display:flex;flex-direction:column;gap:3px}.stat-card{display:grid;grid-template-columns:10px minmax(60px,auto) 56px minmax(80px,220px) 36px;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:.85rem;transition:background var(--transition),border-color var(--transition)}.stat-male.dominant{background:var(--male-dom-bg)}.stat-neutral.dominant{background:var(--neutral-dom-bg)}.stat-female.dominant{background:var(--female-dom-bg)}.stat-other.dominant{background:var(--noise-dom-bg)}.stat-dot{width:10px;height:10px;border-radius:3px}.stat-male .stat-dot{background:var(--male)}.stat-neutral .stat-dot{background:var(--neutral)}.stat-female .stat-dot{background:var(--female)}.stat-other .stat-dot{background:var(--noise)}.stat-label{color:var(--text-primary);font-weight:500;white-space:nowrap}.stat-pct{font-weight:600;letter-spacing:-.01em;color:var(--text-primary);font-variant-numeric:tabular-nums}.stat-bar-wrap{height:4px;background:var(--border-strong);border-radius:99px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:99px;width:0%;transition:width .8s cubic-bezier(.4,0,.2,1)}.stat-male .stat-bar-fill{background:linear-gradient(to right,var(--male-subtle),var(--male))}.stat-neutral .stat-bar-fill{background:linear-gradient(to right,var(--neutral-subtle),var(--neutral))}.stat-female .stat-bar-fill{background:linear-gradient(to right,var(--female-subtle),var(--female))}.stat-other .stat-bar-fill{background:linear-gradient(to right,var(--noise-subtle),var(--noise))}.stat-duration{font-size:.78rem;color:var(--text-muted);font-variant-numeric:tabular-nums;text-align:right}.section-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 0;margin-bottom:12px}.section-title{font-size:.9rem;font-weight:600;color:var(--text-primary)}.badge{font-size:.72rem;font-weight:500;padding:2px 8px;border-radius:99px;background:var(--bg-secondary);color:var(--text-muted);border:1px solid var(--border)}.classify-mode-switcher{display:inline-flex;gap:6px}.scatter-mode-switcher{display:inline-flex;gap:2px;padding:2px;border-radius:8px;background:var(--bg-secondary);border:1px solid var(--border)}.classify-mode-btn,.scatter-mode-btn{font:inherit;font-size:.7rem;font-weight:500;color:var(--text-muted);background:transparent;border:0;padding:3px 9px;border-radius:6px;cursor:pointer;transition:background-color .12s ease,color .12s ease;line-height:1.3}.classify-mode-btn:hover:not(:disabled):not(.is-active),.scatter-mode-btn:hover:not(:disabled):not(.is-active){color:var(--text-primary)}.classify-mode-btn.is-active,.scatter-mode-btn.is-active{background:var(--surface);color:var(--text-primary);box-shadow:0 1px 2px #0000000f}.classify-mode-btn:disabled,.scatter-mode-btn:disabled{opacity:.38;cursor:not-allowed}.classify-mode-btn:focus-visible,.scatter-mode-btn:focus-visible{outline:2px solid var(--accent, #7aa);outline-offset:1px}.scatter-mode-switcher{margin:8px 12px 0;padding:2px}.scatter-mode-switcher .scatter-mode-btn{flex:1;text-align:center}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%) translateY(20px);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:12px 20px;font-size:.875rem;color:var(--text-primary);box-shadow:var(--shadow-md);z-index:999;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;max-width:420px;text-align:center}.toast.show{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.toast.error{border-color:#e05252;color:#e05252}.app-layout{display:grid;grid-template-columns:240px 1fr;grid-template-rows:auto auto;grid-template-areas:"left center" "left right";min-height:calc(100vh - 56px);align-content:start}.panel{overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.panel::-webkit-scrollbar{display:none}html,body{scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar,body::-webkit-scrollbar{display:none}.vga-help-overlay-card{scrollbar-width:none;-ms-overflow-style:none}.vga-help-overlay-card::-webkit-scrollbar{display:none}.panel-left{grid-area:left;border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:56px;left:0;width:240px;height:calc(100vh - 56px);overflow-y:auto}.panel-center{grid-area:center;padding:20px 20px 16px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}.panel-right{grid-area:right;border-top:1px solid var(--border);display:flex;flex-direction:column;overflow-y:visible;position:relative}.dashboard-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.dashboard-icon-btn:hover{background:var(--surface-hover);border-color:var(--border);color:var(--text-secondary)}.dashboard-icon-btn[aria-expanded=true]{background:var(--surface-hover);border-color:var(--border-strong);color:var(--text-primary)}#acoustic-dashboard.grid-stack{background:transparent;padding:6px 10px}.grid-stack-item-content.block-card{background:var(--surface);border:1px solid var(--block-card-border);border-radius:var(--radius-md);box-shadow:var(--block-card-shadow);overflow:hidden;display:flex;flex-direction:column;transition:border-color var(--transition),box-shadow var(--transition)}.grid-stack-item:hover>.grid-stack-item-content.block-card{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.block-header{display:flex;align-items:center;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border);font-size:.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;-webkit-user-select:none;user-select:none;flex-shrink:0}.block-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.block-meta{font-weight:500;font-size:.7rem;text-transform:none;letter-spacing:0;color:var(--text-primary);font-variant-numeric:tabular-nums}.block-drag-handle{display:none;align-items:center;justify-content:center;width:16px;height:16px;font-size:.85rem;line-height:1;color:var(--text-muted);cursor:grab;letter-spacing:-.15em;opacity:.7}.block-drag-handle:active{cursor:grabbing}.grid-stack-item[data-edit-armed=true] .block-drag-handle{display:inline-flex}.grid-stack-item[data-edit-armed=true] .block-drag-handle:hover{opacity:1;color:var(--text-secondary)}.block-hide-btn{display:none;align-items:center;justify-content:center;width:18px;height:18px;padding:0;background:transparent;border:0;border-radius:4px;color:var(--text-muted);font-size:1.05rem;line-height:1;cursor:pointer;opacity:.7;transition:background var(--transition),color var(--transition)}.grid-stack-item[data-edit-armed=true] .block-hide-btn{display:inline-flex}.block-hide-btn:hover{opacity:1;background:var(--surface-hover);color:var(--text-primary)}.block-collapse-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;background:transparent;border:0;border-radius:4px;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.block-collapse-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.block-collapse-btn svg{transition:transform .2s ease}.grid-stack-item[data-collapsed=true] .block-collapse-btn svg{transform:rotate(-180deg)}.grid-stack-item[data-collapsed=true] .block-body{display:none}.grid-stack-item[data-collapsed=true] .block-header{border-bottom:0}.block-body{flex:1;min-height:0;padding:10px 12px 12px;overflow:hidden;display:flex;flex-direction:column;gap:8px}.grid-stack-item[data-block-id=resonance] .block-body{overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.grid-stack-item[data-block-id=resonance] .block-body::-webkit-scrollbar{display:none}.block-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.78rem;text-align:center;line-height:1.5;padding:16px}.block-content{display:flex;flex-direction:column;gap:10px}.grid-stack-item>.ui-resizable-handle{opacity:0;pointer-events:none;transition:opacity var(--transition)}.grid-stack-item[data-edit-armed=true]>.ui-resizable-handle{opacity:.5;pointer-events:auto}.grid-stack-item[data-edit-armed=true]>.ui-resizable-handle:hover{opacity:.9}@keyframes block-arm-jiggle{0%{transform:rotate(-.55deg) translate(0)}50%{transform:rotate(.55deg) translate(0)}to{transform:rotate(-.55deg) translate(0)}}.grid-stack-item[data-edit-armed=true]>.grid-stack-item-content{animation:block-arm-jiggle .45s ease-in-out infinite;transform-origin:center center}.grid-stack-item.ui-draggable-dragging>.grid-stack-item-content,.grid-stack-item.ui-resizable-resizing>.grid-stack-item-content{animation:none}@media (prefers-reduced-motion: reduce){.grid-stack-item[data-edit-armed=true]>.grid-stack-item-content{animation:none;outline:2px dashed var(--accent, var(--text-secondary));outline-offset:-2px}}.grid-stack>.grid-stack-placeholder>.placeholder-content{background:var(--accent-subtle);border:1px dashed var(--accent-border);border-radius:var(--radius-md);color:transparent}.dashboard-popover{position:absolute;top:44px;right:14px;min-width:160px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:4px;z-index:50;display:flex;flex-direction:column;gap:1px;opacity:0;visibility:hidden;transform:translateY(-6px) scale(.98);transform-origin:top right;transition:opacity .16s ease-out,transform .16s ease-out,visibility 0s linear .16s}.dashboard-popover.is-open{opacity:1;visibility:visible;transform:translateY(0) scale(1);transition:opacity .16s ease-out,transform .16s ease-out,visibility 0s linear 0s}.dashboard-popover-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:transparent;border:0;border-radius:6px;color:var(--text-primary);font-size:.82rem;text-align:left;cursor:pointer;transition:background var(--transition)}.dashboard-popover-item:hover{background:var(--surface-hover)}.dashboard-popover-empty{padding:10px 12px;color:var(--text-muted);font-size:.78rem;text-align:center}.page-disclaimer{padding:18px 24px 24px;border-top:1px solid var(--border);background:var(--bg)}.page-disclaimer .mc-disclaimer{max-width:1200px;margin:0 auto;border-top:none;padding-top:0;text-align:center}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);flex-shrink:0;gap:8px}.panel-title{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}.panel-header-actions{display:flex;gap:4px;margin-left:auto}.scatter-wrap{flex:1;position:relative;min-height:0}#scatter-canvas{display:block;width:100%;height:100%}.upload-section{flex-shrink:0}.metrics-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:220px;color:var(--text-muted);font-size:.85rem;text-align:center;line-height:1.6;padding:24px}.resonance-panel{margin:14px 14px 0}.resonance-summary{font-size:.8rem;line-height:1.5;color:var(--text-primary)}.resonance-median-block{display:flex;flex-direction:column;gap:6px;margin-top:2px}.resonance-scale-bar{position:relative;height:10px;border-radius:99px;overflow:visible;background:var(--border-strong);display:flex}.resonance-zone{height:100%}.resonance-zone-male{background:#5b8def33}.resonance-zone-overlap{background:#a078d22e}.resonance-zone-female{background:#e07aaa33}.resonance-range-span{position:absolute;top:50%;transform:translateY(-50%);height:16px;left:0;width:0;background:#ffffff29;backdrop-filter:blur(4px) saturate(1.15);-webkit-backdrop-filter:blur(4px) saturate(1.15);border:1px solid rgba(255,255,255,.32);border-radius:999px;box-shadow:0 1px 3px #00000014,inset 0 1px #ffffff4d;box-sizing:border-box;pointer-events:none;transition:left .5s cubic-bezier(.4,0,.2,1),width .5s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .resonance-range-span{background:#ffffff0f;border-color:#ffffff29;box-shadow:0 1px 3px #00000040,inset 0 1px #ffffff1a}.resonance-scale-labels{display:flex;justify-content:space-between;font-size:.62rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.resonance-history-header{font-size:.72rem;color:var(--text-secondary);font-style:italic;opacity:.9;margin-top:2px}.resonance-divergence-advisory{margin-top:6px;padding:8px 10px;background:color-mix(in srgb,var(--accent) 6%,transparent);border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);border-radius:var(--radius-sm);font-size:.78rem;line-height:1.55;color:var(--text-primary)}.resonance-all-vowels-section{display:flex;flex-direction:column;gap:4px;margin-top:2px}.resonance-section-header{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.resonance-section-title{font-size:.72rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em;text-transform:uppercase}.classify-controls-row{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.resonance-consonants-toggle{display:inline-flex;gap:6px}.resonance-consonants-toggle[hidden]{display:none}.resonance-consonants-btn{font:inherit;font-size:.7rem;font-weight:500;color:var(--text-muted);background:transparent;border:0;padding:3px 9px;border-radius:6px;cursor:pointer;transition:background-color .12s ease,color .12s ease;line-height:1.3;font-variant-numeric:tabular-nums}.resonance-consonants-btn:hover:not(.is-active){color:var(--text-primary)}.resonance-consonants-btn.is-active{background:var(--surface);color:var(--text-primary);box-shadow:0 1px 2px #0000000f}.resonance-consonants-btn:focus-visible{outline:2px solid var(--accent, #7aa);outline-offset:1px}.resonance-all-vowels-list{display:grid;grid-template-columns:1fr;gap:2px 12px}.grid-stack-item.block-w2 .resonance-all-vowels-list{grid-template-columns:1fr}.grid-stack-item.block-w3 .resonance-all-vowels-list{grid-template-columns:1fr 1fr}.grid-stack-item.block-w4 .resonance-all-vowels-list{grid-template-columns:1fr 1fr 1fr}.resonance-vowel-row{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;padding:4px 8px;font-size:.74rem;line-height:1.4;color:var(--text-primary);border-radius:var(--radius-sm);transition:background .18s ease}.resonance-vowel-row:hover{background:color-mix(in srgb,var(--text-secondary) 4%,transparent)}.resonance-vowel-row.is-consonant .resonance-vowel-label{font-style:italic;color:var(--text-muted)}.resonance-vowel-row.is-consonant .resonance-vowel-bar-fill{opacity:.65}.resonance-vowel-row.is-consonant .resonance-vowel-pct{color:var(--text-muted)}.resonance-vowel-label{font-variant-numeric:tabular-nums;color:var(--text-primary);min-width:38px}.resonance-vowel-bar-wrap{height:4px;background:var(--border-strong);border-radius:99px;overflow:hidden;min-width:80px}.resonance-vowel-bar-fill{height:100%;width:0%;border-radius:99px;background:linear-gradient(90deg,var(--accent-subtle),var(--accent));transition:width .7s cubic-bezier(.4,0,.2,1)}.resonance-vowel-pct{font-size:.72rem;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;min-width:38px;text-align:right}.resonance-vowel-n{font-size:.66rem;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;opacity:.75;min-width:38px;text-align:right}@media (prefers-reduced-motion: reduce){.resonance-vowel-bar-fill,.resonance-vowel-row,.resonance-consonants-btn{transition:none}}.disclosure-points{margin:6px 0 0;padding-left:20px;display:flex;flex-direction:column;gap:8px;color:var(--text-primary);font-size:.86rem;line-height:1.55}.disclosure-resources{margin:6px 0 0;padding-left:20px;display:flex;flex-direction:column;gap:6px;font-size:.84rem;line-height:1.5}.disclosure-resources a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.disclosure-resources a:hover,.disclosure-resources a:focus-visible{color:var(--accent-hover)}.disclosure-resource-note{color:var(--text-secondary)}.disclosure-acknowledge{margin-top:18px;width:100%}#metrics-content{padding:14px 14px 32px;display:flex;flex-direction:column;gap:14px}.mc-align-warning{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:10px;background:color-mix(in srgb,var(--accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.76rem;line-height:1.4}.mc-align-warning svg{flex-shrink:0;color:var(--accent)}.mc-cards-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mc-card{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:14px 12px 12px;box-shadow:var(--shadow-sm)}.mc-card-title{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:6px}.mc-card-big{font-size:1.4rem;font-weight:600;letter-spacing:-.03em;color:var(--text-primary);line-height:1.1;font-variant-numeric:tabular-nums}.mc-card-sub{font-size:.75rem;color:var(--text-muted);margin-top:4px;font-variant-numeric:tabular-nums}.mc-res-bar-wrap{height:3px;background:var(--border-strong);border-radius:99px;overflow:hidden;margin-top:8px}.mc-res-bar-fill{height:100%;background:var(--female);border-radius:99px;width:0%;transition:width .7s cubic-bezier(.4,0,.2,1)}.mc-section{display:flex;flex-direction:column;gap:8px}.mc-section-label{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.pitch-range-bar{position:relative;height:10px;border-radius:99px;overflow:visible;background:var(--border-strong);display:flex}.pitch-zone{height:100%}.pitch-zone-male{width:27.083%;background:#5b8def33}.pitch-zone-overlap{width:16.667%;background:#a078d22e}.pitch-zone-female{width:29.167%;background:#e07aaa33}.pitch-indicator{position:absolute;top:50%;transform:translate(-50%,-50%);width:4px;height:20px;left:50%;background:#ffffff80;backdrop-filter:blur(4px) saturate(1.2);-webkit-backdrop-filter:blur(4px) saturate(1.2);border-radius:2px;box-shadow:0 1px 3px #00000024,inset 0 0 0 1px #ffffffb3;transition:left .5s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .pitch-indicator{background:#ffffff2e;box-shadow:0 1px 3px #0006,inset 0 0 0 1px #ffffff52}.pitch-range-span{position:absolute;top:50%;transform:translateY(-50%);height:16px;left:50%;width:0;background:#ffffff29;backdrop-filter:blur(4px) saturate(1.15);-webkit-backdrop-filter:blur(4px) saturate(1.15);border:1px solid rgba(255,255,255,.32);border-radius:999px;box-shadow:0 1px 3px #00000014,inset 0 1px #ffffff4d;box-sizing:border-box;pointer-events:none;transition:left .5s cubic-bezier(.4,0,.2,1),width .5s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .pitch-range-span{background:#ffffff0f;border-color:#ffffff29;box-shadow:0 1px 3px #00000040,inset 0 1px #ffffff1a}.pitch-range-labels{display:flex;justify-content:space-between;font-size:.62rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.pitch-legend{display:none}.legend-male{color:var(--male)}.legend-neutral{color:var(--text-muted)}.legend-female{color:var(--female)}.formants-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 10px}.grid-stack-item.block-w1 .formants-grid{grid-template-columns:1fr}.grid-stack-item.block-w3 .formants-grid,.grid-stack-item.block-w4 .formants-grid{grid-template-columns:repeat(4,1fr)}.grid-stack-item.block-w1 .mc-nn-disclaimer,.grid-stack-item.block-w1 .mc-nn-segment-note{display:none}.formant-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);border-radius:var(--radius-sm);padding:6px 10px;border:1px solid var(--border)}.fn-label{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.fn-val{font-size:.82rem;font-weight:500;color:var(--text-primary);font-variant-numeric:tabular-nums}.gender-score-display{font-size:1.1rem;font-weight:600;color:var(--text-primary);text-align:center;font-variant-numeric:tabular-nums}.gender-ref-score{font-size:.78rem;color:var(--text-muted);text-align:center;margin-top:4px}.certainty-tag{display:block;text-align:center;font-size:1.05rem;font-weight:600;padding:14px 16px;border-radius:12px;background:var(--surface-hover);color:var(--text-primary);border:1px solid var(--border);margin-top:4px;line-height:1.3}.mc-segment-label{font-size:.72rem;color:var(--text-muted);font-variant-numeric:tabular-nums;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mc-disclaimer{font-size:.68rem;color:var(--text-muted);line-height:1.5;border-top:1px solid var(--border);padding-top:12px}.mc-collapsible{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:transparent}.mc-collapsible-header{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none;transition:color var(--transition),background var(--transition)}.mc-collapsible-header:hover{background:var(--surface-hover);color:var(--text-secondary)}.mc-collapsible[open]{background:var(--surface-blend);border-color:var(--border-strong)}.mc-collapsible[open] .mc-collapsible-header{color:var(--text-secondary)}.mc-collapsible-header::-webkit-details-marker{display:none}.mc-collapsible-header::marker{display:none}.mc-collapsible-value{margin-left:auto;margin-right:8px;font-weight:500;font-size:.7rem;text-transform:none;letter-spacing:0;color:var(--text-primary);font-variant-numeric:tabular-nums}.mc-collapsible-header:after{content:"›";font-size:1rem;transform:rotate(90deg);transition:transform var(--transition);display:inline-block;opacity:.5}.mc-collapsible[open] .mc-collapsible-header:after{transform:rotate(270deg)}.mc-collapsible-body{padding:10px 10px 12px;display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--border)}.gender-primary-label{font-size:.65rem;font-weight:500;color:var(--text-muted);letter-spacing:.03em}.gender-ref-row{display:flex;align-items:center;justify-content:space-between;padding:5px 9px;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border)}.gender-ref-label{font-size:.65rem;color:var(--text-muted)}.gender-ref-val{font-size:.8rem;font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums}.gender-ref-ranges{display:flex;gap:5px;flex-wrap:wrap}.ref-range-item{font-size:.63rem;padding:2px 7px;border-radius:99px;border:1px solid transparent;white-space:nowrap}.ref-male{color:var(--male);background:var(--male-subtle);border-color:var(--male-subtle)}.ref-female{color:var(--female);background:var(--female-subtle);border-color:var(--female-subtle)}.ref-neutral{color:var(--text-muted);background:var(--bg-secondary);border-color:var(--border)}@media (max-width: 1000px){.app-layout{grid-template-columns:200px 1fr}}@media (max-width: 780px){.app-layout{grid-template-columns:1fr;grid-template-rows:auto auto auto;grid-template-areas:none;height:auto;overflow:visible}.panel-center{grid-area:auto;order:1;overflow-y:visible;display:block}.grid-stack-item.block-w2 .resonance-all-vowels-list,.grid-stack-item.block-w3 .resonance-all-vowels-list,.grid-stack-item.block-w4 .resonance-all-vowels-list{grid-template-columns:1fr}.vga-timeline__footer-legend--hoisted{position:sticky;top:56px;z-index:5;background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:6px 20px 8px;order:1}.panel-left{grid-area:auto;order:2;height:auto;border-right:none;border-top:1px solid var(--border);position:static;top:auto;left:auto;width:auto}.panel-right{grid-area:auto;order:3;border-top:1px solid var(--border)}.upload-section{padding:14px}.upload-dropzone{padding:30px 18px}.mc-cards-row{grid-template-columns:1fr 1fr}.metrics-placeholder{height:auto;padding:16px;flex-direction:row;gap:8px;min-height:0}.metrics-placeholder svg{width:20px;height:20px;flex-shrink:0}.metrics-placeholder span{font-size:.78rem}.metrics-placeholder span br{display:none}.panel-left .scatter-wrap,.panel-left .scatter-mode-switcher{max-height:0;overflow:hidden;margin-top:0;margin-bottom:0;transition:max-height .3s ease,margin .3s ease,padding .3s ease}.panel-left.panel-expanded .scatter-wrap{max-height:260px;min-height:180px}.panel-left.panel-expanded .scatter-mode-switcher{max-height:32px;margin:8px 12px 0}.panel-left .panel-header{cursor:pointer}.panel-collapse-chevron{display:inline-block;font-size:.8rem;transition:transform .2s ease;color:var(--text-muted);margin-left:4px}.panel-collapse-chevron:after{content:"›"}.panel-left.panel-expanded .panel-collapse-chevron{transform:rotate(90deg)}.panel-left:not(.panel-expanded) .panel-header{border-bottom:none}.panel-left:not(.panel-expanded) .panel-header-actions{display:none}.panel-left:not(.panel-expanded) .scatter-mode-switcher,.panel-left:not(.panel-expanded) .scatter-wrap{display:none}.icon-btn{padding:10px;min-width:44px;min-height:44px;justify-content:center}.play-btn{width:44px;height:44px}.btn-primary{padding:12px 20px}.seek-thumb{width:18px;height:18px}.seek-track{height:6px}.seek-bar{height:28px}.mc-collapsible-header{min-height:44px;padding:10px 12px}.recorder-mic-btn{padding:10px 16px}}.duck-progress{padding:12px 14px 4px;--duck-orange-1: #ffd28a;--duck-orange-2: #ff9a3c;--duck-orange-3: #f26b1f}.duck-track{position:relative;height:6px;background:#ff9a3c26;border-radius:99px;overflow:visible}.duck-fill{height:100%;width:0%;max-width:100%;background:linear-gradient(90deg,var(--duck-orange-1),var(--duck-orange-2),var(--duck-orange-3));border-radius:99px;pointer-events:none;transition:width .12s linear}.duck-emoji{position:absolute;top:50%;left:0%;font-size:20px;line-height:1;transform:translate(-50%,-65%);pointer-events:none;z-index:2;filter:drop-shadow(0 1px 3px rgba(242,107,31,.35));animation:duck-bob .55s ease-in-out infinite alternate;transition:left .12s linear}@keyframes duck-bob{0%{transform:translate(-50%,-55%) rotate(-8deg)}to{transform:translate(-50%,-75%) rotate(6deg)}}.duck-label{display:block;margin-top:10px;font-size:11px;color:var(--text-muted);text-align:center;letter-spacing:.02em}.record-mode-panel{width:100%;max-width:460px;align-self:center;display:flex;flex-direction:column;gap:10px}.record-mode-header{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.record-mode-label{font-size:.78rem;color:var(--text-secondary)}.record-script-panel{padding:12px 14px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm)}.record-script-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.record-script-picker-label{display:flex;width:100%;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.record-script-picker-cap{font-size:.82rem;font-weight:600;color:var(--text-primary)}.record-script-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-color:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:5px 26px 5px 10px;font:inherit;font-size:.82rem;font-weight:600;color:var(--text-primary);cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none' stroke='%23999' stroke-width='1.4' stroke-linecap='round'><path d='M1 1l4 4 4-4'/></svg>");background-repeat:no-repeat;background-position:right 8px center;transition:border-color var(--transition),background-color var(--transition);max-width:100%}.record-script-select:hover{border-color:var(--accent-border)}.record-script-select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.record-script-text{font-size:1rem;line-height:1.65;color:var(--text-primary);margin:0 0 6px;letter-spacing:.02em}.record-script-custom{display:block;width:100%;box-sizing:border-box;font:inherit;font-size:1rem;line-height:1.65;letter-spacing:.02em;color:var(--text-primary);background-color:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:8px 10px;margin:0 0 6px;resize:vertical;min-height:88px;transition:border-color var(--transition),box-shadow var(--transition)}.record-script-custom:hover{border-color:var(--accent-border)}.record-script-custom:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.record-script-hint{font-size:.72rem;color:var(--text-muted);margin:0}.recorder-mic-btn{display:inline-flex;align-items:center;gap:7px;background:none;border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:7px 14px;color:var(--text-secondary);font:inherit;font-size:.82rem;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition)}.recorder-mic-btn:hover{background:var(--accent-subtle);color:var(--accent);border-color:var(--accent-border)}.recorder-mic-btn-large{gap:9px;padding:12px 26px;font-size:.95rem;font-weight:500;border-radius:var(--radius-md);border:1.5px solid var(--accent-border);background:var(--accent-subtle);color:var(--accent)}.recorder-mic-btn-large:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.recorder-idle-ui{display:flex;flex-direction:column;align-items:center;gap:8px}.recorder-active-ui{display:flex;align-items:center;gap:10px;width:100%;max-width:360px}.recorder-waveform{flex:1;height:44px;min-width:80px;display:block;border-radius:6px}.recorder-dot{width:8px;height:8px;border-radius:50%;background:#e05252;flex-shrink:0;animation:rec-pulse 1.2s ease-in-out infinite}@keyframes rec-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.recorder-timer{font-size:.85rem;font-variant-numeric:tabular-nums;color:var(--text-primary);font-weight:500;min-width:2.8ch}.recorder-stop-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:5px 12px;color:var(--text-secondary);font:inherit;font-size:.8rem;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition)}.recorder-stop-btn:hover{background:#e0525214;color:#e05252;border-color:#e052524d}.panel-collapse-chevron{display:none}@media (max-width: 480px){.panel-center{padding:12px 12px 6px}.upload-section{padding:12px}.upload-dropzone{padding:22px 14px}.upload-title{font-size:.9rem}.upload-hint{font-size:.72rem}.controls{flex-wrap:wrap;gap:8px}.controls .btn-primary{order:10;width:100%;justify-content:center;margin-top:4px}.mc-cards-row{grid-template-columns:1fr}.toast{max-width:calc(100vw - 32px);left:16px;right:16px;transform:translateY(20px)}.toast.show{transform:translateY(0)}.header-inner{padding:0 16px}}:root{--dv-0: #3a6b8d;--dv-1: #5b8fb0;--dv-2: #8bb0c9;--dv-3: #bdd3e0;--dv-4: #ede8e4;--dv-5: #e6c8d2;--dv-6: #d9a1b6;--dv-7: #bc738f;--dv-8: #964b69;--cv-0: #00224e;--cv-8: #fde737;--pitch: #e69f00;--pitch-halo: #0b1220;--active: #0072b2;--active-bg: #e3f2fd}[data-theme=dark]{--cv-0: #13386c;--pitch-halo: rgba(0, 0, 0, .6);--active: #56b4e9;--active-bg: #1e3a5f}.vga-timeline{margin-top:0;contain:layout style;min-height:220px}#phone-timeline-root:not([hidden]){min-height:220px;flex-shrink:0}.vga-timeline[data-state=skeleton] .vga-skel{background:var(--bg-secondary);border-radius:var(--radius-sm);animation:vga-skel-pulse 1.5s ease-in-out infinite}.vga-skel--band{height:18px;margin-bottom:8px}.vga-skel--row{height:60px;margin-bottom:12px}@keyframes vga-skel-pulse{0%,to{opacity:.4}50%{opacity:.7}}.vga-timeline__readout-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.vga-timeline__readout-row:empty{display:none}.vga-timeline__readout-row>.vga-transcript-readout{flex:1 1 auto;min-width:0}.vga-timeline__bar-mode{flex:0 0 auto;margin-left:auto}.vga-timeline__rows{position:relative}.vga-timeline__row{display:flex;align-items:center;gap:8px}.vga-timeline__row--pitch{margin-bottom:6px}.vga-timeline__row--resonance{margin-top:6px}.vga-timeline__label{flex:0 0 36px;min-width:0;text-align:left;padding-left:4px;font-size:.72rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none;letter-spacing:.02em}.vga-timeline__row--transcript .vga-timeline__label{min-height:1px}.vga-timeline__band,.vga-timeline__transcript{flex:1 1 auto;min-width:0}.vga-timeline__cursor{position:absolute;top:0;bottom:0;width:1px;background:var(--active);opacity:0;pointer-events:none;transition:opacity .1s linear;z-index:2}.vga-timeline__cursor.visible{opacity:.35}.vga-heatmap{display:block;width:100%;height:18px}.vga-heatmap rect{transition:filter 80ms linear;cursor:pointer}.vga-heatmap rect:focus{outline:none}.vga-heatmap rect:hover{filter:brightness(1.15)}.vga-heatmap rect:focus-visible{filter:brightness(1.15);outline:2px solid var(--active);outline-offset:1px}.vga-heatmap rect.active{stroke:var(--active);stroke-width:2;vector-effect:non-scaling-stroke}.vga-transcript-wrap{position:relative;display:flex;flex-direction:column;gap:8px}.vga-transcript{position:relative;height:40px;margin:6px 0 4px;contain:content;transition:opacity .15s linear}.vga-transcript-readout{display:flex;align-items:baseline;gap:14px;padding:6px 10px;background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-secondary);min-height:28px}.vga-transcript-readout__char{font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,Noto Sans CJK SC,sans-serif;font-size:1.05rem;font-weight:500;color:var(--active);min-width:1.4em;text-align:center}.vga-transcript-readout__phone{font-family:SF Mono,JetBrains Mono,Fira Mono,monospace;font-size:.78rem;color:var(--text-secondary);background:var(--bg-primary);padding:1px 8px;border-radius:999px;letter-spacing:.02em;font-variant-numeric:tabular-nums}.vga-transcript-readout__phone.is-hidden{display:none}.vga-transcript-readout__metric{display:inline-flex;align-items:baseline;gap:4px}.vga-transcript-readout__label{color:var(--text-muted);font-size:.75rem}.vga-transcript-readout__pitch,.vga-transcript-readout__res{font-family:SF Mono,JetBrains Mono,Fira Mono,monospace;color:var(--text-primary);font-variant-numeric:tabular-nums}.vga-sentence-nav{display:flex;align-items:center;justify-content:center;gap:16px;padding:4px 0}.vga-sentence-nav__btn{min-width:44px;min-height:44px;padding:0 14px;border:1px solid var(--border);border-radius:22px;background:var(--surface);color:var(--text-primary);font-size:18px;cursor:pointer;transition:background-color .12s linear,border-color .12s linear}.vga-sentence-nav__btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--active)}.vga-sentence-nav__btn:focus-visible{outline:3px solid var(--active);outline-offset:2px}.vga-sentence-nav__btn:disabled{opacity:.4;cursor:not-allowed}.vga-sentence-nav__counter{font-family:SF Mono,JetBrains Mono,Fira Mono,monospace;font-size:14px;color:var(--text-secondary);min-width:56px;text-align:center}.phone{all:unset;box-sizing:border-box;cursor:pointer;position:absolute;top:0;bottom:0;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:0;border-radius:4px;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,Noto Sans CJK SC,sans-serif;transition:background-color 80ms linear,color 80ms linear}.phone:focus-visible{outline:3px solid var(--active);outline-offset:2px}.phone__char{display:block;font-weight:500;line-height:1.25;text-align:center;white-space:nowrap}.phone[aria-current=true]{background:var(--active-bg);color:var(--active);will-change:background-color,color}.vga-timeline__nav-row{display:flex;justify-content:center;margin-top:10px}.vga-timeline__nav-row:empty{display:none}.vga-band-mode{display:inline-flex;align-items:baseline;gap:14px;padding:6px 10px;background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-secondary);min-height:28px;box-sizing:border-box}.vga-band-mode-btn{border:0;background:transparent;color:var(--text-muted);padding:0;font:inherit;cursor:pointer;transition:color .12s linear}.vga-band-mode-btn:hover{color:var(--text-primary)}.vga-band-mode-btn.is-active{color:var(--active);font-weight:500}.vga-band-mode-btn:focus-visible{outline:2px solid var(--active);outline-offset:2px;border-radius:2px}.vga-timeline__footer{margin-top:10px}.vga-timeline__footer-legend{width:100%}.vga-gender-legend{position:relative}.vga-gender-legend__bar-wrap{position:relative;height:8px;border-radius:4px;border:1px solid var(--border);overflow:hidden}.vga-gender-legend__bar{height:100%}.vga-gender-legend__labels{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;column-gap:8px;padding-top:4px;padding-bottom:6px;font-size:.78rem;color:var(--text-secondary);position:relative}.vga-gender-legend__label--left{grid-column:1;justify-self:start;min-width:0}.vga-gender-legend__label--mid{grid-column:2;justify-self:center;color:var(--text-muted)}.vga-gender-legend__label--right{grid-column:3;justify-self:end;min-width:0}.vga-gender-legend__info{all:unset;box-sizing:border-box;position:absolute;top:-22px;right:0;width:20px;height:20px;border:1px solid var(--border);border-radius:50%;background:var(--surface);text-align:center;line-height:18px;font-size:12px;cursor:pointer;color:var(--text-secondary)}.vga-gender-legend__info:hover,.vga-gender-legend__info:focus-visible{background:var(--bg-secondary);outline:none;border-color:var(--active)}.vga-gender-legend__popover{position:absolute;bottom:calc(100% + 6px);right:0;max-width:360px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:10;font-size:.82rem;line-height:1.6;color:var(--text-secondary)}.vga-gender-legend__popover p{margin:0 0 6px}.vga-gender-legend__popover p:last-child{margin-bottom:0}.vga-gender-legend__note{padding-top:4px;border-top:1px solid var(--border);color:var(--text-muted);font-size:.75rem}.vga-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.vga-fallback{padding:24px 20px;border:1px dashed var(--border-strong);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-secondary);font-size:.875rem;line-height:1.7}.vga-fallback h3{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.vga-fallback h4{font-size:.82rem;font-weight:600;color:var(--text-secondary);margin-top:12px;margin-bottom:4px}.vga-fallback ul,.vga-fallback ol{padding-left:20px;margin-bottom:8px}.vga-fallback__actions{margin-top:16px;display:flex;gap:8px}.vga-low-phone-banner{padding:8px 12px;border-radius:var(--radius-sm);background:var(--accent-subtle);color:var(--text-secondary);font-size:.82rem;margin-bottom:8px}.vga-return-btn{position:sticky;bottom:8px;margin-left:auto;margin-right:auto;display:none;padding:4px 12px;border-radius:16px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:.75rem;cursor:pointer;box-shadow:var(--shadow-sm);z-index:2}.vga-return-btn.show{display:block}@media (max-width: 767px){.vga-heatmap{height:14px}.vga-timeline__label{flex:0 0 28px;min-width:0;font-size:.68rem}.vga-timeline__row{gap:6px}.vga-transcript{height:32px}.vga-transcript-readout{font-size:.78rem;gap:10px;padding:4px 8px}.vga-transcript-readout__char{font-size:.95rem}.vga-sentence-nav__btn{min-width:44px;min-height:44px;padding:0 12px}}.mc-nn-segment-note{font-size:.7rem;color:var(--text-muted);line-height:1.55;margin:8px 0 0;padding:0 2px}.mc-nn-disclaimer{font-size:.78rem;color:var(--text-muted);line-height:1.6;margin-bottom:10px;padding:6px 8px;background:var(--bg-secondary);border-radius:var(--radius-sm)}@media (prefers-reduced-motion: reduce){.phone,.vga-transcript,.vga-sentence-nav__btn,.vga-timeline__cursor{transition:none}.vga-skel{animation:none;opacity:.5}.vga-return-btn{animation:none}}@media (max-width: 780px){.vga-timeline{min-height:0}#phone-timeline-root:not([hidden]){min-height:0}.vga-timeline__nav-row,.vga-timeline__footer{margin-top:4px}}.grid-stack{position:relative}.grid-stack-rtl{direction:ltr}.grid-stack-rtl>.grid-stack-item{direction:rtl}.grid-stack-placeholder>.placeholder-content{background-color:#0000001a;margin:0;position:absolute;width:auto;z-index:0!important}.grid-stack>.grid-stack-item{position:absolute;padding:0}.grid-stack>.grid-stack-item>.grid-stack-item-content{margin:0;position:absolute;width:auto;overflow-x:hidden;overflow-y:auto}.grid-stack>.grid-stack-item.size-to-content:not(.size-to-content-max)>.grid-stack-item-content{overflow-y:hidden}.grid-stack-item>.ui-resizable-handle{position:absolute;font-size:.1px;display:block;-ms-touch-action:none;touch-action:none}.grid-stack-item.ui-resizable-autohide>.ui-resizable-handle,.grid-stack-item.ui-resizable-disabled>.ui-resizable-handle{display:none}.grid-stack-item>.ui-resizable-ne,.grid-stack-item>.ui-resizable-nw,.grid-stack-item>.ui-resizable-se,.grid-stack-item>.ui-resizable-sw{background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="none" stroke="%23666" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" viewBox="0 0 20 20"><path d="m10 3 2 2H8l2-2v14l-2-2h4l-2 2"/></svg>');background-repeat:no-repeat;background-position:center}.grid-stack-item>.ui-resizable-ne{transform:rotate(45deg)}.grid-stack-item>.ui-resizable-sw{transform:rotate(45deg)}.grid-stack-item>.ui-resizable-nw{transform:rotate(-45deg)}.grid-stack-item>.ui-resizable-se{transform:rotate(-45deg)}.grid-stack-item>.ui-resizable-nw{cursor:nw-resize;width:20px;height:20px;top:0}.grid-stack-item>.ui-resizable-n{cursor:n-resize;height:10px;top:0;left:25px;right:25px}.grid-stack-item>.ui-resizable-ne{cursor:ne-resize;width:20px;height:20px;top:0}.grid-stack-item>.ui-resizable-e{cursor:e-resize;width:10px;top:15px;bottom:15px}.grid-stack-item>.ui-resizable-se{cursor:se-resize;width:20px;height:20px}.grid-stack-item>.ui-resizable-s{cursor:s-resize;height:10px;left:25px;bottom:0;right:25px}.grid-stack-item>.ui-resizable-sw{cursor:sw-resize;width:20px;height:20px}.grid-stack-item>.ui-resizable-w{cursor:w-resize;width:10px;top:15px;bottom:15px}.grid-stack-item.ui-draggable-dragging>.ui-resizable-handle{display:none!important}.grid-stack-item.ui-draggable-dragging{will-change:left,top;cursor:move}.grid-stack-item.ui-resizable-resizing{will-change:width,height}.ui-draggable-dragging,.ui-resizable-resizing{z-index:10000}.ui-draggable-dragging>.grid-stack-item-content,.ui-resizable-resizing>.grid-stack-item-content{box-shadow:1px 4px 6px #0003;opacity:.8}.grid-stack-animate,.grid-stack-animate .grid-stack-item{transition:left .3s,top .3s,height .3s,width .3s}.grid-stack-animate .grid-stack-item.grid-stack-placeholder,.grid-stack-animate .grid-stack-item.ui-draggable-dragging,.grid-stack-animate .grid-stack-item.ui-resizable-resizing{transition:left 0s,top 0s,height 0s,width 0s}.grid-stack>.grid-stack-item[gs-y="0"]{top:0}.grid-stack>.grid-stack-item[gs-x="0"]{left:0}.gs-12>.grid-stack-item{width:8.333%}.gs-12>.grid-stack-item[gs-x="1"]{left:8.333%}.gs-12>.grid-stack-item[gs-w="2"]{width:16.667%}.gs-12>.grid-stack-item[gs-x="2"]{left:16.667%}.gs-12>.grid-stack-item[gs-w="3"]{width:25%}.gs-12>.grid-stack-item[gs-x="3"]{left:25%}.gs-12>.grid-stack-item[gs-w="4"]{width:33.333%}.gs-12>.grid-stack-item[gs-x="4"]{left:33.333%}.gs-12>.grid-stack-item[gs-w="5"]{width:41.667%}.gs-12>.grid-stack-item[gs-x="5"]{left:41.667%}.gs-12>.grid-stack-item[gs-w="6"]{width:50%}.gs-12>.grid-stack-item[gs-x="6"]{left:50%}.gs-12>.grid-stack-item[gs-w="7"]{width:58.333%}.gs-12>.grid-stack-item[gs-x="7"]{left:58.333%}.gs-12>.grid-stack-item[gs-w="8"]{width:66.667%}.gs-12>.grid-stack-item[gs-x="8"]{left:66.667%}.gs-12>.grid-stack-item[gs-w="9"]{width:75%}.gs-12>.grid-stack-item[gs-x="9"]{left:75%}.gs-12>.grid-stack-item[gs-w="10"]{width:83.333%}.gs-12>.grid-stack-item[gs-x="10"]{left:83.333%}.gs-12>.grid-stack-item[gs-w="11"]{width:91.667%}.gs-12>.grid-stack-item[gs-x="11"]{left:91.667%}.gs-12>.grid-stack-item[gs-w="12"]{width:100%}.gs-1>.grid-stack-item{width:100%}
