.layout{min-height:100vh;display:flex;flex-direction:column}.navigation{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #00000026;position:sticky;top:0;z-index:100}.nav-container{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.nav-brand h1{color:#fff;font-size:1.5rem;margin:0;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.nav-links{display:flex;gap:1rem}.nav-link{padding:.75rem 1.5rem;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:all .3s;background:#ffffff1a;border:2px solid transparent}.nav-link:hover{background:#fff3;transform:translateY(-2px)}.nav-link.active{background:#fff;color:#667eea;border-color:#fff;box-shadow:0 4px 12px #0003}.main-content{flex:1}@media (max-width: 768px){.nav-container{flex-direction:column;gap:1rem;padding:1rem}.nav-brand h1{font-size:1.2rem}.nav-links{width:100%;justify-content:center;flex-wrap:wrap}.nav-link{padding:.5rem 1rem;font-size:.9rem}}.app{width:100%;max-width:900px;margin:0 auto}.container{background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 6px #0000001a}h1{color:#333;margin-bottom:10px;font-size:2rem}.subtitle{color:#666;margin-bottom:30px;font-size:1.1rem}.status{margin-bottom:30px}.status-message{padding:15px;border-radius:8px;font-weight:500;display:flex;align-items:center;gap:10px}.status-message.loading{background:#e3f2fd;color:#1976d2}.status-message.error{background:#ffebee;color:#c62828}.status-message.success{background:#e8f5e9;color:#2e7d32}.spinner{width:16px;height:16px;border:2px solid #1976d2;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.model-info{background:#f8f9fa;padding:20px;border-radius:8px;margin-bottom:30px}.model-info h3{margin-top:0;margin-bottom:15px;color:#333}.info-grid{display:flex;flex-direction:column;gap:12px}.info-item{display:flex;flex-direction:column;gap:5px}.info-item strong{color:#555;font-size:.9rem}.info-item code{background:#fff;padding:8px 12px;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem;color:#d63384}.inference-section{margin-top:30px}.inference-section h3{margin-bottom:15px;color:#333}textarea{width:100%;padding:12px;border:2px solid #ddd;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;margin-bottom:15px;transition:border-color .3s}textarea:focus{outline:none;border-color:#1976d2}.run-button{background:#1976d2;color:#fff;border:none;padding:12px 30px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}.run-button:hover:not(:disabled){background:#1565c0}.run-button:disabled{background:#bdbdbd;cursor:not-allowed}.result{margin-top:25px;padding:20px;background:#f8f9fa;border-radius:8px;border-left:4px solid #4caf50}.result h4{margin-top:0;margin-bottom:15px;color:#333}.result-content{display:flex;flex-direction:column;gap:10px}.result-content p{margin:0;color:#555}.data-output{background:#fff;padding:15px;border-radius:4px;display:block;overflow-x:auto;font-family:Courier New,monospace;font-size:.85rem;color:#d63384;margin-top:8px}.note{margin-top:30px;padding:15px;background:#fff3cd;border-left:4px solid #ffc107;border-radius:4px;color:#856404;font-size:.9rem}.note strong{display:block;margin-bottom:5px}.config-section{margin-bottom:20px;padding:15px;background:#f0f7ff;border-radius:8px;border:1px solid #bbdefb}.config-section h4{margin-top:0;margin-bottom:15px;color:#1976d2;font-size:1rem}.config-controls{display:flex;flex-direction:column;gap:15px}.config-item{display:flex;flex-direction:column;gap:5px}.config-item label{display:flex;align-items:center;gap:10px;font-size:.95rem;color:#333;font-weight:500}.config-item input[type=range]{flex:1;max-width:200px}.config-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.config-item input[type=number]{padding:5px 10px;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.config-item small{color:#666;font-size:.85rem;margin-left:28px}.sentences-list{margin-top:15px;display:flex;flex-direction:column;gap:10px}.sentence-item{display:flex;gap:10px;padding:10px;background:#fff;border-radius:6px;border-left:3px solid #4caf50}.sentence-number{font-weight:700;color:#4caf50;min-width:30px}.sentence-text{flex:1;color:#333;line-height:1.5}.debug-info{margin-top:15px;padding:10px;background:#fff;border-radius:6px;font-size:.9rem}.debug-info summary{cursor:pointer;color:#1976d2;font-weight:500}.debug-info p{margin:8px 0;color:#666}.chunking-progress{margin-top:15px;padding:15px;background:#e3f2fd;border-radius:8px;border-left:4px solid #1976d2}.chunking-progress p{margin:0 0 10px;color:#1976d2;font-weight:500}.progress-bar{width:100%;height:8px;background:#bbdefb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#1976d2,#42a5f5);transition:width .3s ease;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{opacity:.8}50%{opacity:1}to{opacity:.8}}.streaming-results{margin-top:20px;padding:15px;background:#f1f8e9;border-radius:8px;border-left:4px solid #7cb342}.streaming-results h4{margin:0 0 10px;color:#558b2f;font-size:1rem}.sentence-item.streaming{border-left-color:#7cb342;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.container{padding:20px}h1{font-size:1.5rem}.subtitle{font-size:1rem}}.stst-test-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.page-container{max-width:1200px;margin:0 auto}.page-header{text-align:center;margin-bottom:2rem;color:#fff}.page-header h1{font-size:2.5rem;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.page-header .subtitle{font-size:1.1rem;opacity:.9;color:#fff}.status-section{margin-bottom:2rem}.status-message{padding:1rem 1.5rem;border-radius:8px;display:flex;align-items:center;gap:1rem;font-weight:500;box-shadow:0 2px 8px #0000001a}.status-message.loading{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.status-message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.status-message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.spinner{width:20px;height:20px;border:3px solid rgba(0,0,0,.1);border-top-color:#856404;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.retry-button{padding:.5rem 1rem;background:#fff;border:1px solid #721c24;border-radius:4px;color:#721c24;cursor:pointer;font-weight:500;transition:all .2s}.retry-button:hover{background:#721c24;color:#fff}.config-panel{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 16px #0000001a}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.panel-header h2{margin:0;color:#333;font-size:1.8rem}.export-button{padding:.6rem 1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.export-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.config-section{margin-bottom:2rem}.config-section h3{margin-bottom:1rem;color:#555;font-size:1.2rem}.preset-buttons{display:flex;gap:1rem;flex-wrap:wrap}.preset-button{flex:1;min-width:150px;padding:1rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.preset-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}.strategy-selector{display:flex;gap:2rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:1rem;color:#333}.radio-label input[type=radio]{width:20px;height:20px;cursor:pointer}.parameter-control{margin-bottom:1.5rem}.parameter-control label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.param-label{font-weight:600;color:#333;font-size:1rem}.param-value{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.25rem .75rem;border-radius:12px;font-weight:700;min-width:50px;text-align:center}.slider{width:100%;height:8px;border-radius:5px;background:#ddd;outline:none;-webkit-appearance:none;margin-bottom:.5rem}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer}.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;border:none}.parameter-control small{display:block;color:#666;font-size:.85rem;font-style:italic}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:1rem;color:#333}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.input-section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 16px #0000001a}.input-section h2{margin-bottom:1rem;color:#333;font-size:1.8rem}.input-textarea{width:100%;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .2s;margin-bottom:1rem}.input-textarea:focus{outline:none;border-color:#667eea}.process-button{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s}.process-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.process-button:disabled{opacity:.5;cursor:not-allowed}.metrics-panel{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 16px #0000001a}.metrics-panel h2{margin-bottom:1.5rem;color:#333;font-size:1.8rem}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.metric-item{display:flex;flex-direction:column;padding:1.5rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:8px;text-align:center}.metric-label{font-size:.9rem;color:#666;margin-bottom:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:2rem;font-weight:700;color:#333;margin-bottom:.5rem}.metric-item small{color:#888;font-size:.85rem}.results-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 16px #0000001a}.results-section h2{margin-bottom:1.5rem;color:#333;font-size:1.8rem}.sentences-list{display:flex;flex-direction:column;gap:1rem}.sentence-item{display:flex;gap:1rem;padding:1rem;background:#f8f9fa;border-left:4px solid #667eea;border-radius:4px;transition:transform .2s,box-shadow .2s,background .3s}.sentence-item.latest{background:linear-gradient(135deg,#667eea10,#764ba210);border-left-color:#ff0844;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sentence-item:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.sentence-number{font-weight:700;color:#667eea;min-width:30px}.sentence-text{flex:1;color:#333;line-height:1.6}@media (max-width: 768px){.stst-test-page{padding:1rem}.page-header h1{font-size:1.8rem}.panel-header{flex-direction:column;gap:1rem;align-items:flex-start}.preset-buttons{flex-direction:column}.strategy-selector{flex-direction:column;gap:1rem}.metrics-grid{grid-template-columns:1fr}.microphone-container{flex-direction:column}.pipeline-viz{overflow-x:auto}}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.section-header h2{margin:0;color:#333;font-size:1.8rem}.workflow-badge{padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;display:inline-flex;align-items:center;gap:.5rem}.speech-badge{background:linear-gradient(135deg,#667eea15,#764ba215);color:#667eea;border:2px solid #667eea}.text-badge{background:linear-gradient(135deg,#4caf5015,#8bc34a15);color:#4caf50;border:2px solid #4caf50}.speech-section{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 16px #0000001a}.speech-section h2{margin-bottom:1.5rem;color:#333;font-size:1.8rem}.speech-warning{padding:1rem;background:#fff3cd;color:#856404;border:1px solid #ffeaa7;border-radius:8px;text-align:center}.speech-controls{display:flex;flex-direction:column;gap:1.5rem}.microphone-container{display:flex;align-items:center;gap:2rem;justify-content:center}.microphone-button{width:120px;height:120px;border-radius:50%;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 16px #667eea66;position:relative}.microphone-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 6px 24px #667eea99}.microphone-button:disabled{opacity:.5;cursor:not-allowed}.microphone-button.listening{background:linear-gradient(135deg,#f093fb,#f5576c);animation:pulse 2s ease-in-out infinite}.microphone-button.listening.active{background:linear-gradient(135deg,#ff0844,#ffb199);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 4px 16px #f5576c66}50%{box-shadow:0 8px 32px #f5576ccc}}.microphone-status{text-align:center}.status-text{font-size:1.2rem;font-weight:600;color:#666}.listening-text{color:#f5576c}.interim-transcript{padding:1rem;background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;font-size:1rem;color:#333}.interim-transcript strong{color:#667eea;margin-right:.5rem}.realtime-indicator{padding:.5rem 1rem;background:linear-gradient(135deg,#ff084415,#ffb19915);color:#ff0844;border:2px solid #ff0844;border-radius:20px;font-size:.9rem;font-weight:600;display:inline-flex;align-items:center;gap:.5rem;animation:pulse-border 2s ease-in-out infinite}@keyframes pulse-border{0%,to{border-color:#ff0844;box-shadow:0 0 #ff084466}50%{border-color:#ffb199;box-shadow:0 0 15px #ff084499}}.metrics-section{margin-bottom:2rem}.metrics-section h3{color:#555;font-size:1.3rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #f0f0f0}.metric-item.highlight{background:linear-gradient(135deg,#667eea15,#764ba215);border:2px solid #667eea;position:relative}.metric-item.highlight:before{content:"⭐";position:absolute;top:-10px;right:-10px;font-size:1.5rem}.metric-value.large{font-size:2rem}.pipeline-viz{background:#f8f9fa;padding:1.5rem;border-radius:8px;border:1px solid #e0e0e0}.pipeline-step{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1rem}.step-name{padding:.75rem 1.25rem;background:#fff;border:2px solid #667eea;border-radius:8px;font-weight:600;color:#667eea;white-space:nowrap}.step-arrow{font-size:1.5rem;color:#667eea;font-weight:700}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}#root{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:20px}
