:root{--bg: #f6f7f9;--card: #ffffff;--border: #e3e6ea;--text: #1f2933;--muted: #6b7785;--accent: #2563eb;--accent-soft: #dbeafe;--danger: #b91c1c;--danger-soft: #fee2e2;--shadow: 0 1px 3px rgba(16, 24, 40, .08), 0 1px 2px rgba(16, 24, 40, .04)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.5}a{color:var(--accent)}.page{max-width:980px;margin:0 auto;padding:24px 20px 64px}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.topbar h1{font-size:20px;margin:0}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow)}.card+.card{margin-top:18px}.controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;align-items:end}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:600;color:var(--muted)}select,input[type=text],input[type=email],input[type=password]{width:100%;padding:9px 10px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:14px;color:var(--text)}input[type=range]{width:100%}.range-value{font-variant-numeric:tabular-nums;font-weight:600}button{cursor:pointer;font-size:14px;font-weight:600;padding:9px 14px;border-radius:8px;border:1px solid var(--accent);background:var(--accent);color:#fff}button.secondary{background:#fff;color:var(--text);border-color:var(--border)}button:disabled{opacity:.55;cursor:not-allowed}.result{margin-top:18px;display:flex;flex-wrap:wrap;gap:24px;align-items:baseline}.result .value{font-size:30px;font-weight:700;font-variant-numeric:tabular-nums}.result .likely{color:var(--muted)}.result .time{background:var(--accent-soft);color:#1e40af;padding:4px 10px;border-radius:999px;font-size:13px;font-weight:600}.muted{color:var(--muted)}.section-title{font-size:15px;font-weight:700;margin:0 0 12px}.chart-wrap{width:100%;height:300px}.charts{display:grid;grid-template-columns:1fr;gap:18px}@media (min-width: 760px){.charts{grid-template-columns:1fr 1fr}}.error{background:var(--danger-soft);color:var(--danger);border:1px solid #fecaca;border-radius:8px;padding:10px 12px;font-size:14px}.loading{color:var(--muted);font-size:14px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:100%;max-width:380px}.login-card h1{margin:0 0 4px;font-size:22px}.login-card p.sub{margin:0 0 20px;color:var(--muted)}.login-card .field{margin-bottom:14px}.login-card button[type=submit]{width:100%;margin-top:4px}.nav{display:flex;align-items:baseline;gap:20px;flex-wrap:wrap}.nav-links{display:flex;gap:14px}.nav-link{text-decoration:none;color:var(--muted);font-weight:600;font-size:14px;padding-bottom:2px;border-bottom:2px solid transparent}.nav-link:hover{color:var(--text)}.nav-link.active{color:var(--accent);border-bottom-color:var(--accent)}.upload-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.upload-row input[type=file]{font-size:14px}code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;background:#f1f3f5;padding:1px 5px;border-radius:5px}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th,.data-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:top}.data-table th{font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);font-weight:700}.data-table td.num,.data-table td.nowrap{white-space:nowrap}.data-table td.num{font-variant-numeric:tabular-nums}.metrics{font-variant-numeric:tabular-nums;color:var(--text)}.error-inline{margin-top:6px;font-size:12px;padding:6px 8px}.predictor-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}.predictor-meta{font-size:14px;color:var(--muted)}.predictor-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;align-items:end;padding:14px;margin-bottom:18px;background:var(--bg);border:1px solid var(--border);border-radius:10px}.predictor-grid{display:grid;grid-template-columns:1fr;gap:18px;align-items:start}.cast-result{display:flex;flex-direction:column;gap:6px}.cast-big{font-size:34px;font-weight:800;line-height:1.1;font-variant-numeric:tabular-nums}.cast-big.is-true{color:#166534}.cast-big.is-false{color:var(--muted)}.cast-sub{color:var(--muted);font-size:13px;font-variant-numeric:tabular-nums}.pill-onoff{display:inline-block;align-self:flex-start;padding:6px 18px;border-radius:999px;font-size:22px;font-weight:800;letter-spacing:.02em;border:1px solid transparent}.pill-on{background:#dcfce7;color:#166534;border-color:#bbf7d0}.pill-off{background:#eef2f6;color:#64748b;border-color:#dbe1e8}.raw-detail{margin-top:14px;padding-top:10px;border-top:1px dashed var(--border);color:var(--muted);font-size:12px;font-variant-numeric:tabular-nums;display:flex;flex-wrap:wrap;align-items:center;gap:4px}@media (min-width: 760px){.predictor-grid{grid-template-columns:1.4fr 1fr}}.predictor-output{border:1px solid var(--border);border-radius:10px;padding:16px;background:var(--bg);min-height:80px}.predictor-empty{opacity:.85}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:700;text-transform:capitalize;border:1px solid transparent}.badge-uploaded{background:#eef2f6;color:#475569;border-color:#dbe1e8}.badge-training{background:var(--accent-soft);color:#1e40af;border-color:#bfdbfe}.badge-trained{background:#dcfce7;color:#166534;border-color:#bbf7d0}.badge-failed{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.train-control{display:flex;align-items:center;gap:8px}.train-control select{width:auto;min-width:140px}.train-control button{white-space:nowrap}.spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--accent-soft);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px;margin-right:2px}@keyframes spin{to{transform:rotate(360deg)}}.wake-meta{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:14px}.badge-wake-empty,.badge-wake-ready{background:#eef2f6;color:#475569;border-color:#dbe1e8}.badge-wake-training{background:var(--accent-soft);color:#1e40af;border-color:#bfdbfe}.badge-wake-trained{background:#dcfce7;color:#166534;border-color:#bbf7d0}.badge-wake-failed{background:var(--danger-soft);color:var(--danger);border-color:#fecaca}.wake-record-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.wake-rec-btn{min-width:180px}.wake-rec-btn.is-recording{background:var(--danger);border-color:var(--danger);color:#fff;animation:wake-pulse 1s ease-in-out infinite}@keyframes wake-pulse{0%,to{box-shadow:0 0 #b91c1c80}50%{box-shadow:0 0 0 8px #b91c1c00}}.wake-train-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px}.wake-meters{display:flex;flex-wrap:wrap;align-items:center;gap:20px;margin-top:8px}.wake-meter{flex:1 1 240px;min-width:200px}.wake-meter-label{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}.wake-meter-track{width:100%;height:14px;background:#eef2f6;border-radius:999px;overflow:hidden;border:1px solid var(--border)}.wake-meter-fill{height:100%;background:linear-gradient(90deg,#22c55e,#2563eb);transition:width .08s linear}.wake-vad{display:flex;align-items:center}.wake-banner{position:sticky;top:0;z-index:50;width:100%;margin:0 0 18px;padding:22px 16px;text-align:center;font-size:clamp(22px,4vw,38px);font-weight:900;letter-spacing:.04em;color:#fff;background:linear-gradient(90deg,#166534,#16a34a);border-radius:12px;box-shadow:0 6px 20px #16653466;animation:wake-flash .5s ease-in-out infinite alternate}@keyframes wake-flash{0%{filter:brightness(1)}to{filter:brightness(1.18)}}.rec-progress{margin:12px 0}.rec-progress-bar{height:10px;border-radius:6px;background:#e6e8ee;overflow:hidden}.rec-progress-fill{height:100%;background:#e2483d;transition:width 60ms linear}.rec-progress-label{display:inline-block;margin-top:6px;font-size:13px;color:#e2483d;font-weight:600}.clip-lists{display:flex;gap:24px;flex-wrap:wrap;margin-top:16px}.clip-col{flex:1;min-width:200px}.clip-col-title{font-weight:600;margin:0 0 8px}.clip-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.clip-item{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:8px;background:#f4f5f8;font-size:14px}.clip-item.clip-positive{border-left:3px solid #2e9e5b}.clip-item.clip-negative{border-left:3px solid #8a93a3}.clip-name{font-weight:600;min-width:28px}.clip-del{margin-left:auto;background:transparent;color:#b4321f;border:1px solid #e0c4bf;border-radius:6px;padding:2px 8px;cursor:pointer;line-height:1.2}.clip-del:hover:not(:disabled){background:#fbeae7}.clip-play{background:transparent;border:1px solid #cdd3df;color:#2b6cb0;border-radius:6px;padding:2px 9px;cursor:pointer;line-height:1.2;font-size:12px}.clip-play:hover{background:#eef3fb}.wake-meter-track{position:relative}.wake-meter-thresh{position:absolute;top:-2px;bottom:-2px;width:2px;background:#1f2733;transform:translate(-1px)}.sensitivity-row{margin-top:14px;max-width:460px}.sensitivity-row label{font-size:14px;font-weight:600}.sensitivity-row input[type=range]{width:100%;margin-top:6px}
