:root{color-scheme:dark;--background:#0d1117;--surface-1:#151b23;--surface-2:#1c2430;--surface-3:#242d3a;--border:#303a48;--border-subtle:#252e3a;--text-primary:#f0f3f6;--text-secondary:#9da7b3;--text-muted:#6e7885;--accent:#4da3ff;--accent-hover:#74b7ff;--success:#3fb950;--warning:#d29922;--danger:#f85149;--info:#58a6ff;--radius:8px;--radius-sm:6px;--shadow:0 12px 40px rgba(0,0,0,0.35);--font-sans:Inter,Geist,"IBM Plex Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:ui-monospace,SFMono-Regular,SF Mono,Menlo,Monaco,Consolas,"Liberation Mono",monospace}[data-theme=light]{color-scheme:light;--background:#f6f8fb;--surface-1:#ffffff;--surface-2:#eef2f7;--surface-3:#dde4ee;--border:#cad4e1;--border-subtle:#dde4ee;--text-primary:#101828;--text-secondary:#475467;--text-muted:#667085;--shadow:0 12px 30px rgba(16,24,40,0.08)}*{box-sizing:border-box}body,html{margin:0;min-height:100%;background:radial-gradient(circle at top left,rgba(77,163,255,.08),transparent 32%),radial-gradient(circle at 90% 10%,rgba(63,185,80,.08),transparent 28%),var(--background);color:var(--text-primary);font-family:var(--font-sans)}body{line-height:1.5}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}::selection{background:rgba(77,163,255,.25)}.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}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px minmax(0,1fr)}.sidebar{position:-webkit-sticky;position:sticky;top:0;height:100vh;padding:20px 16px;border-right:1px solid var(--border-subtle);background:rgba(10,14,19,.92);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}[data-theme=light] .sidebar{background:rgba(255,255,255,.88)}.brand{display:flex;align-items:center;gap:12px;padding:10px 10px 18px}.brand-mark{min-width:32px;width:auto;height:32px;padding:0 7px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),#1e7fe6);color:white;font-weight:700;font-size:12px;box-shadow:var(--shadow)}.brand-title{font-size:15px;font-weight:700}.brand-subtitle{font-size:12px;color:var(--text-muted)}.nav-group{display:grid;grid-gap:6px;gap:6px}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid transparent}.nav-link:hover,.nav-link[aria-current=page]{background:var(--surface-2);border-color:var(--border);color:var(--text-primary)}.sidebar-footer{margin-top:auto;padding-top:16px;display:grid;grid-gap:12px;gap:12px}.topbar-user{display:flex;align-items:center;gap:12px}.topbar-user-meta{display:grid;justify-items:end;grid-gap:2px;gap:2px;text-align:right}.topbar-user-role{font-size:10px;color:var(--text-muted);text-transform:lowercase}.logout-button-wrap{display:flex;align-items:flex-start}.button-secondary-compact{padding:7px 10px;font-size:12px}.button-secondary-compact svg{width:14px;height:14px}.button svg,.button-danger svg,.button-secondary svg{width:16px;height:16px}.main-column{min-width:0;display:grid;grid-template-rows:auto 1fr}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 24px;border-bottom:1px solid var(--border-subtle);background:rgba(9,13,18,.72);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:-webkit-sticky;position:sticky;top:0;z-index:20}[data-theme=light] .topbar{background:rgba(255,255,255,.8)}.content{padding:24px;display:grid;grid-gap:30px;gap:30px;align-content:start;grid-auto-rows:max-content}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;align-self:start}.page-title{margin:0;font-size:26px;line-height:1.1}.page-description{margin:4px 0 0;color:var(--text-secondary);max-width:72ch}.button,.button-danger,.button-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-primary);background:var(--surface-2)}.button{background:linear-gradient(180deg,#2684ff,#1b6fd8);border-color:#266ccf}.button-danger{background:rgba(248,81,73,.12);border-color:rgba(248,81,73,.35);color:#ffb7b3}.button-danger:hover,.button-secondary:hover{background:var(--surface-3)}.icon-actions{display:flex;gap:8px;flex-wrap:nowrap}.actions-column{min-width:96px;width:112px}.kpi-results-carousel{display:grid;grid-gap:16px;gap:16px}.kpi-results-carousel-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.kpi-results-carousel-header h2{margin:0 0 6px}.kpi-results-scroller{display:flex;gap:12px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;padding-bottom:4px}.kpi-result-card{min-width:min(280px,82vw);scroll-snap-align:start;display:grid;grid-gap:10px;gap:10px;padding:18px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2)}.kpi-result-score{font-size:clamp(2rem,4vw,3.25rem);font-weight:700;letter-spacing:0}.kpi-change-down,.kpi-change-up{display:inline-flex;align-items:center;gap:4px;font-size:.92rem;font-weight:700}.kpi-change-down svg,.kpi-change-up svg{width:16px;height:16px}.kpi-change-up{color:#3fb950}.kpi-change-down{color:#f85149}.icon-button{width:34px;height:34px;display:inline-grid;place-items:center;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-primary)}.icon-button svg{width:16px;height:16px}.icon-button:hover{background:var(--surface-3)}.icon-button-danger{color:#ffb7b3}.button-danger:disabled,.button-secondary:disabled,.button:disabled,.icon-button:disabled{cursor:not-allowed;opacity:.6}.link-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;padding:0;background:transparent;color:var(--accent);cursor:pointer;text-align:left;text-decoration:underline}.results-kpi-carousel,.results-kpi-stack{display:grid;grid-gap:16px;gap:16px}.results-kpi-carousel-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.results-kpi-carousel-header h2{margin:0 0 6px}.results-kpi-scroller{display:flex;gap:16px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;padding-bottom:4px}.results-kpi-card{min-width:calc((100% - 16px) / 2);min-height:410px;scroll-snap-align:start;position:relative;display:grid;grid-template-rows:auto 1fr;grid-gap:12px;gap:12px;padding:16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2)}.results-kpi-chart{position:relative;width:100%;height:320px}.results-kpi-empty-state{width:100%;height:320px;display:grid;place-items:center;text-align:center}.results-kpi-tooltip{position:absolute;z-index:5;min-width:180px;display:grid;grid-gap:6px;gap:6px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-1);box-shadow:var(--shadow)}.auth-card,.card,.panel,.table-shell{background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--surface-1);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:var(--shadow)}.card{padding:16px}.overview-section{display:grid;grid-gap:16px;gap:16px}.overview-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.overview-section-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:14px;gap:14px}.metric-label{color:var(--text-secondary);font-size:12px}.metric-value{margin-top:8px;font-size:26px;font-weight:700}.metric-meta{margin-top:6px;color:var(--text-muted);font-size:12px}.status-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;font-size:12px;border:1px solid transparent}.status-chip.ok{color:#8de6a7;background:rgba(63,185,80,.12);border-color:rgba(63,185,80,.25)}.status-chip.warning{color:#ffd27a;background:rgba(210,153,34,.12);border-color:rgba(210,153,34,.25)}.status-chip.danger{color:#ffb1ad;background:rgba(248,81,73,.12);border-color:rgba(248,81,73,.25)}.status-chip.info{color:#a9d6ff;background:rgba(88,166,255,.12);border-color:rgba(88,166,255,.25)}.status-chip.muted{color:var(--text-secondary);background:rgba(110,120,133,.12);border-color:rgba(110,120,133,.25)}.table-shell{overflow:hidden}.table-toolbar{display:flex;gap:12px;padding:14px;border-bottom:1px solid var(--border-subtle);flex-wrap:wrap}.test-case-table-toolbar label{display:grid;grid-gap:6px;gap:6px;min-width:min(260px,100%);font-size:12px;color:var(--text-secondary)}.table-sort-button{display:inline-flex;align-items:center;gap:6px;padding:0;border:0;background:transparent;color:var(--text-secondary);font:inherit;font-weight:600;cursor:pointer}.table-sort-button svg{width:14px;height:14px}.table-scroller{overflow:auto}table{width:100%;border-collapse:collapse}td,th{padding:12px 14px;border-bottom:1px solid var(--border-subtle);text-align:left;vertical-align:top;font-size:13px}th{position:-webkit-sticky;position:sticky;top:0;z-index:1;background:var(--surface-1);color:var(--text-secondary);font-weight:600}tr:hover td{background:rgba(77,163,255,.04)}.mono{font-family:var(--font-mono);font-size:12px}.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:min(520px,100%);padding:28px}.field{display:grid;grid-gap:8px;gap:8px;margin-top:14px}.checkbox-label,.field label{font-size:13px;color:var(--text-secondary)}.checkbox-label{display:inline-flex;align-items:center;gap:8px;margin-top:14px}.input,.select,.textarea{width:100%;padding:11px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-primary)}.input-invalid{border-color:#f85149;box-shadow:0 0 0 1px rgba(248,81,73,.3)}.textarea{min-height:112px;resize:vertical}.form-actions{display:flex;gap:12px;align-items:center;margin-top:18px;flex-wrap:wrap}.test-case-actions-column{min-width:120px;width:132px}.test-case-pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-top:1px solid var(--border-subtle);flex-wrap:wrap}.pipeline-actions-column{min-width:156px;width:168px}.pipeline-progress-inline{margin-left:6px;color:var(--text-muted);font-size:10px}.pipeline-progress{display:flex;align-items:center;gap:10px;min-width:180px}.pipeline-progress-track{width:min(260px,100%);height:6px;overflow:hidden;border-radius:999px;background:var(--surface-3)}.pipeline-progress-track span{display:block;height:100%;background:var(--accent);transition:width .4s ease}.test-case-event-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.test-case-event-toggle{display:inline-flex;align-items:center;gap:8px;min-width:0;padding:0;border:0;background:transparent;color:var(--text-primary);font-size:16px;font-weight:700;cursor:pointer}.test-case-event-toggle svg{width:18px;height:18px;transition:transform .16s ease}.test-case-event-toggle svg.expanded{transform:rotate(180deg)}.test-case-response-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.test-case-time-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:10px;gap:10px}.test-case-time-grid label{display:grid;grid-gap:6px;gap:6px}.test-case-audio-preview{width:min(260px,100%);height:34px}.test-case-image-preview-button{display:inline-flex;align-items:center;max-width:280px;gap:8px;padding:7px 9px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-primary);cursor:pointer}.test-case-image-preview-button svg{width:18px;height:18px;flex:0 0 auto}.test-case-image-preview-button span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.test-case-image-preview-large{display:block;width:100%;max-height:70vh;object-fit:contain;border-radius:var(--radius-sm);background:var(--surface-2)}.recording-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.recording-waveform{display:inline-flex;align-items:center;gap:3px;height:34px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2)}.recording-waveform span{width:3px;height:8px;border-radius:999px;background:#58a6ff;animation:recording-wave .9s ease-in-out infinite;animation-delay:calc(var(--wave-index, 0) * 45ms)}.recording-waveform span:nth-child(2n){--wave-index:2}.recording-waveform span:nth-child(3n){--wave-index:3}.recording-waveform span:nth-child(4n){--wave-index:4}.recording-waveform span:nth-child(5n){--wave-index:5}@keyframes recording-wave{0%,to{height:8px}50%{height:26px}}.empty-state,.error-state,.notice{padding:16px;border-radius:12px;border:1px solid var(--border-subtle);background:var(--surface-1)}.notice{color:var(--text-secondary)}.error-state{color:#ffb1ad;background:rgba(248,81,73,.08)}.drawer{position:fixed;top:0;right:0;width:min(640px,100%);height:100vh;background:var(--background);border-left:1px solid var(--border-subtle);box-shadow:var(--shadow);z-index:40;display:grid;grid-template-rows:auto 1fr}.drawer-header{padding:16px 20px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.drawer-content{padding:18px 20px 24px;overflow:auto}.modal-backdrop{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:24px;background:rgba(3,7,12,.68);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-window{width:min(560px,100%);max-height:min(760px,calc(100vh - 48px));display:grid;grid-template-rows:auto 1fr;overflow:hidden;border:1px solid var(--border-subtle);border-radius:var(--radius);background:var(--surface-1);box-shadow:var(--shadow)}.modal-window-wide{width:min(920px,100%)}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border-subtle)}.modal-header h2{margin:0;font-size:18px}.modal-content{padding:18px;overflow:auto}.separator{height:1px;background:var(--border-subtle);margin:16px 0}.helper-text{color:var(--text-muted);font-size:12px}.kbd{font-family:var(--font-mono);font-size:12px;padding:2px 6px;border-radius:6px;border:1px solid var(--border);background:var(--surface-2)}@media (max-width:1100px){.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.app-shell{grid-template-columns:86px minmax(0,1fr)}}@media (max-width:780px){.results-kpi-card{min-width:min(520px,88vw)}.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.metrics-grid{grid-template-columns:1fr}.page-header,.topbar{flex-direction:column;align-items:stretch}}