:root{--black:#000;--near-black:#17171c;--green-deep:#003c33;--canvas:#fff;--stone:#eeece7;--card-border:#f2f2f2;--ink:#212121;--muted:#93939f;--slate:#75758a;--hairline:#d9d9dd;--border-light:#e5e7eb;--focus-violet:#9b60aa;--error:#b30000;--error-soft:#f8e3e3;--radius-xs:4px;--radius-sm:8px;--radius-md:16px;--radius-lg:22px;--radius-xl:30px;--radius-pill:32px;--radius-full:9999px;--font-display:"Space Grotesk", "Pretendard Variable", "Inter", "Noto Sans KR", system-ui, sans-serif;--font-body:"Inter", "Pretendard Variable", "Noto Sans KR", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace}*{box-sizing:border-box}[hidden]{display:none!important}html,body{background:var(--canvas);color:var(--ink);font-family:var(--font-body);font-feature-settings:"ss01", "cv11";-webkit-font-smoothing:antialiased;margin:0;padding:0;font-size:16px;line-height:1.5}a{color:var(--ink);text-underline-offset:3px}.app-header{border-bottom:1px solid var(--hairline);padding:56px 32px 40px}.app-header-inner{flex-direction:column;gap:12px;max-width:880px;margin:0 auto;display:flex}.app-header h1{font-family:var(--font-display);letter-spacing:-.02em;color:var(--ink);margin:0;font-size:56px;font-weight:500;line-height:1}.app-header .subtitle{color:var(--slate);max-width:640px;margin:0;font-size:18px;line-height:1.4}.mono-label{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:12px}.app-main{flex-direction:column;gap:24px;max-width:880px;margin:0 auto;padding:32px;display:flex}.app-footer{border-top:1px solid var(--hairline);text-align:center;color:var(--muted);padding:24px 32px;font-size:12px}.panel{background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--radius-sm);padding:28px 32px}.panel h2{font-family:var(--font-display);letter-spacing:-.01em;color:var(--ink);margin:0 0 20px;font-size:22px;font-weight:500;line-height:1.2}.panel h2.is-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;display:flex}.panel h2.is-toggle:before{content:"";opacity:.65;border-top:5px solid #0000;border-bottom:5px solid #0000;border-left:6px solid;flex:none;width:0;height:0;transition:transform .18s;display:inline-block;transform:rotate(90deg)}.panel.is-collapsed h2.is-toggle:before{transform:rotate(0)}.panel.is-collapsed h2.is-toggle{margin-bottom:0}.panel.is-collapsed>:not(h2):not(.panel-header){display:none!important}.panel.is-collapsed .panel-header{margin-bottom:0}.panel.is-collapsed .panel-header>:not(h2){display:none!important}.panel-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.panel-header h2{margin:0}.input-row{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:12px;display:flex}.input-row:last-child{margin-bottom:0}.input-row label{min-width:120px;color:var(--slate);font-size:14px}.input-row input[type=number],.input-row input[type=password]{background:var(--canvas);border:1px solid var(--hairline);color:var(--ink);border-radius:var(--radius-xs);padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .12s}.input-row input[type=number]:focus,.input-row input[type=password]:focus{border-color:var(--focus-violet);outline:none}.input-row input[type=number]{width:92px}.input-row input[type=password]{flex:1;min-width:240px}.input-row input[type=range]{max-width:320px;accent-color:var(--near-black);flex:1}.hint{color:var(--muted);font-size:13px}#output-slider{font-family:var(--font-mono);text-align:center;min-width:28px;color:var(--ink);font-size:14px;font-weight:500;display:inline-block}button{border:1px solid var(--hairline);color:var(--ink);border-radius:var(--radius-pill);cursor:pointer;background:0 0;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;line-height:1.2;transition:background .12s,border-color .12s,color .12s,opacity .12s}button:hover:not(:disabled){border-color:var(--ink)}button:focus-visible{outline:2px solid var(--near-black);outline-offset:2px}button:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--near-black);border-color:var(--near-black);color:#fff;padding:12px 24px}.btn-primary:hover:not(:disabled){background:var(--black);border-color:var(--black)}.btn-primary:disabled{background:var(--near-black);border-color:var(--near-black);color:#fff}.btn-secondary{color:var(--ink);text-underline-offset:4px;background:0 0;border:none;border-radius:0;padding:8px 4px;text-decoration:underline;text-decoration-thickness:1px}.btn-secondary:hover:not(:disabled){color:var(--near-black);border-color:#0000}.btn-danger{color:var(--error);border-radius:var(--radius-pill);background:0 0;border:1px solid #0000;padding:6px 12px;font-size:13px}.btn-danger:hover:not(:disabled){background:var(--error-soft);border-color:var(--error-soft)}.dropzone{transition:border-color .15s,background .15s}.dropzone-active{border-color:var(--ink);background:var(--stone)}.dropzone-body{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.dropzone-hint{color:var(--muted);max-width:480px;font-size:13px}.file-info{background:var(--stone);border-radius:var(--radius-sm);color:var(--ink);grid-template-columns:max-content 1fr;gap:6px 20px;margin-top:16px;padding:14px 18px;font-size:14px;display:grid}.file-info-row{display:contents}.file-info-key{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--slate);align-self:center;font-size:11px}.file-info-value{color:var(--ink);word-break:break-all}.cache-prompt{background:var(--canvas);border:1px solid var(--hairline);border-left:3px solid var(--ink);border-radius:var(--radius-sm);flex-direction:column;gap:12px;margin-top:16px;padding:16px 20px;display:flex}.cache-prompt-header{color:var(--ink);font-size:14px}.cache-prompt-actions{flex-wrap:wrap;gap:12px;display:flex}.genre-tags{flex-wrap:wrap;gap:8px;display:flex}.genre-tags button{background:var(--canvas);border:1px solid var(--hairline);color:var(--slate);border-radius:var(--radius-xl);padding:8px 16px;font-size:14px;font-weight:500}.genre-tags button:hover:not(.active){background:var(--stone);border-color:var(--hairline);color:var(--ink)}.genre-tags button.active{background:var(--near-black);border-color:var(--near-black);color:#fff}.status{color:var(--slate);font-family:var(--font-mono);word-break:break-word;min-height:1.6em;margin-top:14px;font-size:13px;line-height:1.6}.debug-summary{background:var(--stone);border-radius:var(--radius-sm);font-family:var(--font-mono);color:var(--ink);word-break:break-all;letter-spacing:.01em;margin-bottom:16px;padding:10px 14px;font-size:12px}.debug-segments{border-top:1px solid var(--hairline);flex-direction:column;max-height:360px;font-size:13px;display:flex;overflow-y:auto}.segment-row{border-bottom:1px solid var(--hairline);grid-template-columns:120px 80px 1fr;gap:12px;padding:8px 4px;display:grid}.segment-row:hover{background:var(--stone)}.segment-ts{color:var(--slate);font-family:var(--font-mono);font-size:12px}.segment-speaker{color:var(--slate);font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.segment-text{color:var(--ink);word-break:break-word}.candidates-list{border-top:1px solid var(--hairline);flex-direction:column;display:flex}.candidate-row{border-bottom:1px solid var(--hairline);grid-template-columns:110px 1fr;align-items:center;gap:16px;padding:14px 4px;display:grid}.candidate-ts{border:1px solid var(--hairline);color:var(--ink);border-radius:var(--radius-xl);font-family:var(--font-mono);letter-spacing:.05em;cursor:pointer;background:0 0;justify-self:start;padding:6px 12px;font-size:12px;font-weight:500}.candidate-ts:hover{background:var(--near-black);color:#fff;border-color:var(--near-black)}.candidate-reason{color:var(--ink);word-break:break-word;font-size:14px;line-height:1.5}.results-list{border-top:1px solid var(--hairline);flex-direction:column;margin-bottom:16px;display:flex}.result-row{border-bottom:1px solid var(--hairline);grid-template-columns:110px 1fr;align-items:start;gap:16px;padding:16px 4px;display:grid}.result-row .candidate-ts{border-color:var(--ink);color:var(--ink);align-self:start}.result-row .candidate-ts:hover{background:var(--ink);color:#fff}.result-meta{flex-direction:column;gap:6px;min-width:0;display:flex}.result-top{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.result-tag{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--radius-full);background:var(--stone);color:var(--slate);padding:3px 10px;font-size:11px}.result-in_silence .result-tag,.result-between_segments .result-tag,.result-in_silence-tag,.result-between_segments-tag{background:var(--stone);color:var(--green-deep)}.result-snapped_to_silence .result-tag,.result-snapped_to_boundary .result-tag,.result-snapped_to_silence-tag,.result-snapped_to_boundary-tag{background:var(--stone);color:var(--slate)}.result-no_snap_available .result-tag,.result-no_snap_available-tag{background:var(--stone);color:var(--ink)}.result-tag-wrap{align-items:center;gap:6px;display:inline-flex;position:relative}.result-tag-info{border:1px solid var(--hairline);width:18px;height:18px;color:var(--slate);border-radius:var(--radius-full);font-family:var(--font-body);cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:0;font-size:11px;font-style:italic;font-weight:600;line-height:1;display:inline-flex}.result-tag-info:hover,.result-tag-info[aria-expanded=true]{border-color:var(--ink);color:var(--ink)}.result-tag-popover{z-index:50;background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--radius-sm);min-width:220px;max-width:320px;color:var(--ink);white-space:normal;word-break:keep-all;padding:10px 12px;font-size:13px;line-height:1.5;position:absolute;top:calc(100% + 8px);left:0;box-shadow:0 6px 20px #00000014}.snap-legend{border:1px solid var(--hairline);border-radius:var(--radius-sm);background:var(--canvas);margin:0 0 16px;padding:0}.snap-legend>summary{cursor:pointer;color:var(--slate);align-items:center;gap:8px;padding:10px 14px;font-size:13px;list-style:none;display:flex}.snap-legend>summary::-webkit-details-marker{display:none}.snap-legend>summary:before{content:"▸";color:var(--muted);font-size:10px;transition:transform .12s}.snap-legend[open]>summary:before{transform:rotate(90deg)}.snap-legend-body{padding:0 14px 14px}.snap-pipeline{color:var(--ink);margin:4px 0 12px;padding-left:22px;font-size:13px;line-height:1.6}.snap-pipeline li{word-break:keep-all;margin:4px 0}.snap-pipeline strong{color:var(--ink);font-weight:600}.snap-legend-note{background:var(--stone);border-radius:var(--radius-xs);color:var(--slate);word-break:keep-all;margin:0 0 12px;padding:8px 10px;font-size:12px}.snap-legend dl{grid-template-columns:max-content 1fr;gap:10px 14px;margin:0;display:grid}.snap-legend dt{align-self:start;margin:0}.snap-legend dd{color:var(--ink);word-break:keep-all;margin:0;font-size:13px;line-height:1.5}.result-delta{color:var(--slate);font-size:12px;font-family:var(--font-mono)}.result-reason{color:var(--ink);word-break:break-word;font-size:14px;line-height:1.5}.video-timeline{height:40px;margin:4px 0 20px;padding:0 6px;position:relative}.timeline-bar{background:var(--hairline);height:1px;position:absolute;top:50%;left:6px;right:6px;transform:translateY(-50%)}.timeline-marker{background:var(--ink);border:2px solid var(--canvas);border-radius:var(--radius-full);cursor:pointer;width:10px;height:10px;box-shadow:0 0 0 1px var(--ink);padding:0;transition:transform .12s,box-shadow .12s;position:absolute;top:50%;transform:translate(-50%,-50%)}.timeline-marker:hover{transform:translate(-50%,-50%)scale(1.3)}.timeline-marker:after{content:attr(data-label);font-family:var(--font-mono);color:var(--slate);white-space:nowrap;opacity:0;font-size:10px;transition:opacity .12s;position:absolute;top:-22px;left:50%;transform:translate(-50%)}.timeline-marker:hover:after{opacity:1}.timeline-snapped_to_silence,.timeline-snapped_to_boundary{background:var(--ink);box-shadow:0 0 0 1px var(--ink)}.timeline-in_silence,.timeline-between_segments{background:var(--green-deep);box-shadow:0 0 0 1px var(--green-deep)}.timeline-no_snap_available{background:var(--slate);box-shadow:0 0 0 1px var(--slate)}.results-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.history-empty{color:var(--muted);padding:12px 4px;font-size:14px}.history-list{border-top:1px solid var(--hairline);flex-direction:column;display:flex}.history-row{border-bottom:1px solid var(--hairline);grid-template-columns:1fr auto;align-items:center;gap:20px;padding:18px 4px;display:grid}.history-meta{flex-direction:column;gap:4px;min-width:0;display:flex}.history-when{color:var(--muted);font-size:11px;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase}.history-file{color:var(--ink);word-break:break-all;font-size:15px;font-weight:500;line-height:1.4}.history-params,.history-result{color:var(--slate);font-size:12px;font-family:var(--font-mono)}.history-actions{align-items:center;gap:8px;display:flex}.history-actions button{white-space:nowrap;padding:6px 12px;font-size:13px}.history-actions .btn-primary{padding:8px 16px}.toast-container{z-index:1000;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius-sm);background:var(--canvas);max-width:360px;color:var(--ink);border:1px solid var(--hairline);border-left-width:3px;padding:12px 16px;font-size:14px;animation:.18s ease-out toast-in}.toast-info{border-left-color:var(--ink)}.toast-error{border-left-color:var(--error);background:var(--error-soft)}.toast-success{border-left-color:var(--green-deep);background:var(--canvas)}.toast-warn{border-left-color:var(--slate);background:var(--stone)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.app-header{padding:40px 20px 28px}.app-header h1{font-size:40px}.app-header .subtitle{font-size:16px}.app-main{gap:16px;padding:20px}.panel{padding:20px 18px}.panel h2{font-size:20px}.input-row{flex-direction:column;align-items:stretch;gap:8px}.input-row label{min-width:0}.history-row{grid-template-columns:1fr}.history-actions{flex-wrap:wrap}.segment-row{grid-template-columns:100px 1fr}.segment-speaker{display:none}}
