:root{color-scheme:dark;--bg: #020617;--bg-elevated: #020617;--card-bg: #020617;--accent: #0ea5e9;--accent-soft: rgba(56, 189, 248, .2);--accent-2: #22c55e;--border-subtle: #1e293b;--text-main: #e5e7eb;--text-muted: #9ca3af;--error: #f97373;--warning: #f59e0b;font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%}body{background:radial-gradient(circle at top left,#0f172a,#020617 55%);color:var(--text-main)}#app{min-height:100vh;display:flex;align-items:stretch;justify-content:center;padding:24px}.app-shell{max-width:960px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:16px}.app-header{padding-bottom:8px}.app-title-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.app-title{margin:0;font-size:1.9rem;letter-spacing:.03em}.app-tag{font-size:.85rem;padding:2px 8px;border-radius:999px;background:#0f76d233;color:var(--accent)}.app-subtitle{margin:8px 0 0;max-width:640px;color:var(--text-muted);font-size:.95rem}.app-main{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1.1fr);gap:16px}.app-footer{margin-top:4px;font-size:.8rem;color:var(--text-muted)}.card{background:radial-gradient(circle at top left,#020617 0% 70%);border-radius:18px;border:1px solid var(--border-subtle);padding:14px 16px 16px;box-shadow:0 18px 40px #0f172ab3}.card--full{grid-column:1 / -1}.card-title{margin:0 0 10px;font-size:1.05rem}.card-row{margin-top:8px}.card-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.transcript-buttons{display:flex;gap:8px;flex-wrap:wrap}.field-label{display:block;font-size:.86rem;color:var(--text-muted);margin-bottom:4px}.field-help{margin:4px 0 0;font-size:.8rem;color:var(--text-muted)}.select{width:100%;padding:7px 10px;border-radius:10px;border:1px solid var(--border-subtle);background:#020617;color:var(--text-main);font-size:.9rem;outline:none}.select:focus{border-color:var(--accent);box-shadow:0 0 0 1px #38bdf84d}.device-row{margin-top:14px}.device-status{display:flex;align-items:center;gap:10px}.badge{font-size:.78rem;padding:3px 8px;border-radius:999px;border:1px solid transparent}.badge-ok{background:#22c55e2b;border-color:#22c55e80;color:var(--accent-2)}.badge-warn{background:#eab3081a;border-color:#eab30880;color:var(--warning)}.checkbox-label{font-size:.82rem;color:var(--text-muted);display:inline-flex;align-items:center;gap:6px}.upload-area{margin-top:4px;border-radius:14px;border:1px dashed rgba(148,163,184,.8);background:#0f172acc;padding:14px 12px;cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .1s}.upload-area--active{border-color:var(--accent);background:radial-gradient(circle at top left,#0b1120,#020617);transform:translateY(-1px)}.upload-input{display:none}.upload-content{text-align:left}.upload-content p{margin:3px 0;font-size:.9rem}.upload-hint{font-size:.8rem;color:var(--text-muted)}.controls-row{margin-top:10px;display:flex;gap:8px}.btn{border-radius:999px;border:1px solid transparent;padding:6px 14px;font-size:.9rem;cursor:pointer;background:#0f172a;color:var(--text-main);transition:background .14s ease,transform .08s ease,box-shadow .14s ease,border-color .14s ease}.btn-primary{background:linear-gradient(135deg,#0ea5e9,#22c55e);border-color:transparent;box-shadow:0 10px 25px #22c55e66;color:#0b1120}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 30px #22c55e80}.btn-ghost{background:transparent;border-color:var(--border-subtle);color:var(--text-muted)}.btn-ghost:hover:not(:disabled){border-color:#94a3b8e6}.btn-small{padding:5px 12px;font-size:.82rem;border-radius:999px;background:#0f172ae6;border:1px solid rgba(148,163,184,.7);color:var(--text-muted)}.btn-small:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn:disabled{opacity:.5;cursor:default;box-shadow:none;transform:none}.progress-group{display:flex;flex-direction:column;gap:10px}.progress-row{display:flex;flex-direction:column;gap:4px}.progress-header{display:flex;align-items:baseline;justify-content:space-between;font-size:.8rem}.progress-label{color:var(--text-muted)}.progress-bar{position:relative;width:100%;height:6px;border-radius:999px;background:#0f172af2;overflow:hidden;border:1px solid rgba(30,41,59,.8)}.progress-bar-inner{height:100%;width:0;border-radius:inherit;transform-origin:left center;transition:width .12s linear}.progress-bar-inner--model{background:linear-gradient(90deg,#0ea5e9,#38bdf8)}.progress-bar-inner--stt{background:linear-gradient(90deg,#22c55e,#a3e635)}.progress-bar-inner--indeterminate{width:40%;animation:progress-indeterminate 1s infinite linear}.progress-stats{display:flex;gap:12px;margin-top:4px;font-size:.75rem;color:var(--text-muted)}.progress-stat{display:inline-block}.cache-info{margin-top:8px;display:flex;flex-direction:column;gap:6px}.cache-stat-row{display:flex;justify-content:space-between;align-items:center;font-size:.88rem}.cache-stat-label{color:var(--text-muted)}.cache-stat-value{color:var(--text-main);font-weight:500}.cached-models-list{margin-top:10px;display:flex;flex-direction:column;gap:6px;max-height:150px;overflow-y:auto;padding:8px;background:#0f172a80;border-radius:8px;border:1px solid rgba(30,41,59,.6)}.cached-model-item{padding:6px 8px;background:#0f172ab3;border-radius:6px;border:1px solid rgba(30,41,59,.8)}.cached-model-name{font-size:.82rem;color:var(--text-main);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;word-break:break-all}.cached-model-details{font-size:.75rem;color:var(--text-muted);margin-top:2px}.cache-empty-message{margin:10px 0 0;font-size:.85rem;color:var(--text-muted);font-style:italic}@keyframes progress-indeterminate{0%{transform:translate(-40%)}50%{transform:translate(40%)}to{transform:translate(120%)}}.status-text{margin:10px 0 0;font-size:.8rem;color:var(--text-muted)}.status-text--warning{margin-top:4px;color:#fbbf24}.status-text--error{margin-top:6px;color:var(--error)}.transcript-box{margin-top:6px;border-radius:12px;border:1px solid rgba(30,41,59,.9);background:#0f172ae6;padding:10px 12px;min-height:150px;max-height:380px;overflow:auto}.transcript-box pre{margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;white-space:pre-wrap;word-wrap:break-word;font-size:.9rem;line-height:1.45}.transcript-placeholder{margin:0;font-size:.9rem;color:var(--text-muted)}@media (max-width: 840px){.app-main{grid-template-columns:minmax(0,1fr)}}@media (max-width: 600px){#app{padding:16px}.card{padding:12px 12px 14px}.app-title{font-size:1.6rem}.app-subtitle{font-size:.86rem}}
