/* ═══════════════════════════════════════════════════════════════════════════
   BS QA Platform — Corporate Design System
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
  --bg: #09090b;
  --surface: #111114;
  --card: #18181b;
  --card-hover: #1f1f23;
  --border: #27272a;
  --border2: #3f3f46;
  --accent: #6366f1;
  --accent-hover: #818cf8;
  --accent-muted: #6366f120;
  --success: #22c55e;
  --success-muted: #22c55e18;
  --error: #ef4444;
  --error-muted: #ef444418;
  --warning: #eab308;
  --warning-muted: #eab30818;
  --text: #e4e4e7;
  --text2: #a1a1aa;
  --text3: #52525b;
  --radius: 8px;
  --radius-sm: 6px;
  --radius-lg: 12px;
  --shadow: 0 1px 3px rgba(0,0,0,.3);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.5);
  --transition: .15s ease;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono: 'JetBrains Mono', 'SF Mono', 'Fira Code', monospace;
  --sidebar-w: 240px;
  --sidebar-collapsed: 56px;
  --topbar-h: 56px;
}

.light {
  --bg: #fafafa; --surface: #f4f4f5; --card: #ffffff; --card-hover: #f8f8fa;
  --border: #e4e4e7; --border2: #d4d4d8;
  --text: #18181b; --text2: #52525b; --text3: #a1a1aa;
  --shadow: 0 1px 3px rgba(0,0,0,.08); --shadow-lg: 0 8px 32px rgba(0,0,0,.12);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { font-size:14px; }
body { font-family:var(--font); background:var(--bg); color:var(--text); min-height:100vh; display:flex; overflow:hidden; -webkit-font-smoothing:antialiased; }

/* ─── Scrollbar ───────────────────────────────────────────────────────────── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border2); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--text3); }

/* ─── Sidebar ─────────────────────────────────────────────────────────────── */
.sidebar { width:var(--sidebar-w); height:100vh; background:var(--surface); border-right:1px solid var(--border); display:flex; flex-direction:column; position:fixed; left:0; top:0; z-index:100; transition:width var(--transition); overflow:hidden; }
.sidebar.collapsed { width:var(--sidebar-collapsed); }
.sidebar.collapsed .brand-text,
.sidebar.collapsed .nav-item span,
.sidebar.collapsed .nav-group-label,
.sidebar.collapsed .nav-ext-icon,
.sidebar.collapsed .status-text,
.sidebar.collapsed .sidebar-collapse-btn { display:none; }
.sidebar.collapsed .nav-item { justify-content:center; padding:10px; }
.sidebar.collapsed .sidebar-brand { justify-content:center; padding:16px 0; }
.sidebar.collapsed .lang-toggle { font-size:10px; padding:4px; }

.sidebar-brand { display:flex; align-items:center; gap:10px; padding:16px 18px; border-bottom:1px solid var(--border); }
.brand-icon { color:var(--accent); }
.brand-icon svg, .brand-svg { width:22px; height:22px; }
.brand-text { font-size:15px; font-weight:700; color:var(--text); letter-spacing:-.3px; }
.sidebar-collapse-btn { margin-left:auto; background:none; border:none; color:var(--text3); cursor:pointer; padding:4px; border-radius:4px; }
.sidebar-collapse-btn:hover { color:var(--text); background:var(--card); }
.sidebar-collapse-btn svg { width:16px; height:16px; }

.sidebar-nav { flex:1; overflow-y:auto; padding:8px 8px; }
.nav-group-label { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:.8px; color:var(--text3); padding:16px 10px 6px; }
.nav-item { display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:var(--radius-sm); color:var(--text2); text-decoration:none; font-size:13px; font-weight:500; transition:var(--transition); cursor:pointer; position:relative; }
.nav-item:hover { color:var(--text); background:var(--card); }
.nav-item.active { color:var(--accent); background:var(--accent-muted); }
.nav-item svg { width:18px; height:18px; flex-shrink:0; stroke-width:1.75; }
.nav-ext-icon { margin-left:auto; width:12px !important; height:12px !important; opacity:.4; }
.nav-divider { height:1px; background:var(--border); margin:8px 4px; }
.nav-external { position:relative; }

.sidebar-footer { padding:12px 16px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.run-status { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--text3); }
.status-dot { width:6px; height:6px; border-radius:50%; background:var(--text3); }
.status-dot.running { background:var(--accent); animation:pulse-dot 1s infinite; }
.status-dot.passed { background:var(--success); }
.status-dot.failed { background:var(--error); }
.lang-toggle { background:var(--card); border:1px solid var(--border); color:var(--text2); padding:4px 8px; border-radius:4px; font-size:11px; font-weight:600; cursor:pointer; letter-spacing:.5px; }
.lang-toggle:hover { border-color:var(--accent); color:var(--accent); }

/* ─── Main Wrapper ────────────────────────────────────────────────────────── */
.main-wrapper { margin-left:var(--sidebar-w); flex:1; display:flex; flex-direction:column; min-height:100vh; transition:margin-left var(--transition); }
.sidebar.collapsed ~ .main-wrapper { margin-left:var(--sidebar-collapsed); }

/* ─── Topbar ──────────────────────────────────────────────────────────────── */
.topbar { height:var(--topbar-h); display:flex; align-items:center; justify-content:space-between; padding:0 24px; border-bottom:1px solid var(--border); background:var(--surface); position:sticky; top:0; z-index:50; }
.topbar-left { display:flex; align-items:center; gap:12px; }
.page-title { font-size:16px; font-weight:600; color:var(--text); }
.breadcrumb { font-size:12px; color:var(--text3); }
.topbar-right { display:flex; align-items:center; gap:8px; }
.live-badge { display:flex; align-items:center; gap:6px; font-size:11px; font-weight:600; color:var(--accent); background:var(--accent-muted); padding:4px 12px; border-radius:20px; }
.pulse { width:6px; height:6px; border-radius:50%; background:var(--accent); animation:pulse-dot 1s infinite; }

/* ─── Content ─────────────────────────────────────────────────────────────── */
.content { flex:1; padding:24px; overflow-y:auto; height:calc(100vh - var(--topbar-h)); animation:fadeIn .2s ease; }

/* ─── Buttons ─────────────────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:6px; padding:8px 16px; border-radius:var(--radius-sm); font-size:13px; font-weight:500; font-family:var(--font); border:1px solid transparent; cursor:pointer; transition:var(--transition); white-space:nowrap; }
.btn svg { width:15px; height:15px; }
.btn-primary { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-primary:hover { background:var(--accent-hover); }
.btn-ghost { background:transparent; color:var(--text2); border-color:var(--border); }
.btn-ghost:hover { background:var(--card); color:var(--text); border-color:var(--border2); }
.btn-success { background:var(--success); color:#fff; }
.btn-sm { padding:5px 10px; font-size:12px; }
.btn-sm svg { width:13px; height:13px; }
.btn-icon { padding:8px; min-width:auto; }
.btn-icon svg { width:16px; height:16px; }

/* ─── Cards & Stat Cards ──────────────────────────────────────────────────── */
.card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px; }
.card-title { font-size:13px; font-weight:600; color:var(--text2); margin-bottom:12px; display:flex; align-items:center; gap:6px; }
.card-title svg { width:15px; height:15px; }
.stats-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:12px; }
.stat-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; transition:var(--transition); }
.stat-card:hover { border-color:var(--border2); transform:translateY(-1px); }
.stat-icon { font-size:18px; margin-bottom:8px; display:block; }
.stat-icon svg { width:20px; height:20px; color:var(--text3); }
.stat-value { font-size:28px; font-weight:700; color:var(--text); line-height:1; margin-bottom:4px; }
.stat-label { font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:.5px; }
.c-pass .stat-value { color:var(--success); }
.c-fail .stat-value { color:var(--error); }
.c-rate .stat-value { color:var(--accent); }

/* ─── Form ────────────────────────────────────────────────────────────────── */
.form-input { width:100%; padding:8px 12px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm); color:var(--text); font-size:13px; font-family:var(--font); transition:var(--transition); }
.form-input:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 2px var(--accent-muted); }
.form-input::placeholder { color:var(--text3); }
select.form-input { cursor:pointer; }
textarea.form-input { resize:vertical; min-height:60px; }
.form-input-sm { padding:6px 10px; font-size:12px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-grid .full-width { grid-column:1/-1; }
.form-label { display:flex; flex-direction:column; gap:4px; font-size:12px; font-weight:500; color:var(--text2); }

/* ─── Tables ──────────────────────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; border:1px solid var(--border); border-radius:var(--radius); background:var(--card); }
.data-table { width:100%; border-collapse:collapse; }
.data-table th { text-align:left; padding:10px 14px; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; color:var(--text3); border-bottom:1px solid var(--border); background:var(--surface); }
.data-table td { padding:9px 14px; font-size:13px; border-bottom:1px solid var(--border); color:var(--text2); }
.data-table tr:hover td { background:var(--card-hover); }
.data-table tr:last-child td { border-bottom:none; }

/* ─── Badges & Tags ───────────────────────────────────────────────────────── */
.badge { display:inline-flex; align-items:center; gap:4px; padding:2px 8px; border-radius:4px; font-size:11px; font-weight:600; }
.mini-tag { display:inline-block; padding:2px 7px; border-radius:4px; font-size:10px; font-weight:600; letter-spacing:.2px; }

/* ─── Modal ───────────────────────────────────────────────────────────────── */
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.6); backdrop-filter:blur(4px); z-index:1000; display:none; align-items:center; justify-content:center; }
.modal-overlay.open { display:flex; }
.modal { background:var(--card); border:1px solid var(--border2); border-radius:var(--radius-lg); width:520px; max-width:95vw; max-height:90vh; display:flex; flex-direction:column; box-shadow:var(--shadow-lg); }
.modal:has(.cd) { width:680px; }
.modal-header { display:flex; justify-content:space-between; align-items:center; padding:16px 20px; border-bottom:1px solid var(--border); }
.modal-header h3 { font-size:15px; font-weight:600; }
.modal-close { background:none; border:none; color:var(--text3); cursor:pointer; padding:4px; border-radius:4px; transition:var(--transition); }
.modal-close:hover { color:var(--text); background:var(--surface); }
.modal-close svg { width:18px; height:18px; }
.modal-body { padding:20px; overflow-y:auto; flex:1; }
.modal-footer { padding:12px 20px; border-top:1px solid var(--border); display:flex; justify-content:flex-end; gap:8px; }

/* ─── Console ─────────────────────────────────────────────────────────────── */
.console-wrap { border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; background:var(--bg); }
.console-header { display:flex; align-items:center; gap:8px; padding:10px 14px; background:var(--surface); border-bottom:1px solid var(--border); }
.console-dots { display:flex; gap:5px; }
.console-dots span { width:10px; height:10px; border-radius:50%; }
.console-dots span:nth-child(1) { background:#ef4444; }
.console-dots span:nth-child(2) { background:#eab308; }
.console-dots span:nth-child(3) { background:#22c55e; }
.console-title { font-size:11px; color:var(--text3); font-family:var(--mono); }
.console-body { padding:12px 14px; max-height:400px; overflow-y:auto; font-family:var(--mono); font-size:12px; line-height:1.7; }
.console-line { white-space:pre-wrap; word-break:break-all; }
.console-line.success { color:var(--success); }
.console-line.error { color:var(--error); }
.console-line.warning { color:var(--warning); }
.console-line.running { color:var(--accent); }
.console-line.info { color:var(--text3); }

/* ─── Toast ───────────────────────────────────────────────────────────────── */
.toast-container { position:fixed; bottom:20px; right:20px; z-index:2000; display:flex; flex-direction:column-reverse; gap:8px; }
.toast { padding:10px 16px; border-radius:var(--radius-sm); font-size:13px; color:var(--text); background:var(--card); border:1px solid var(--border); box-shadow:var(--shadow-lg); animation:slideIn .3s ease; max-width:360px; }
.toast.success { border-left:3px solid var(--success); }
.toast.error { border-left:3px solid var(--error); }
.toast.info { border-left:3px solid var(--accent); }
.toast.warning { border-left:3px solid var(--warning); }

/* ─── Utility ─────────────────────────────────────────────────────────────── */
.mb-8 { margin-bottom:8px; }
.mb-12 { margin-bottom:12px; }
.mb-16 { margin-bottom:16px; }
.mb-24 { margin-bottom:24px; }
.text-muted { color:var(--text3); }
.text-white { color:var(--text); }
.text-green { color:var(--success); }
.text-red { color:var(--error); }
.text-sm { font-size:12px; }
.flex-between { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.flex-row { display:flex; align-items:center; }
.gap-8 { gap:8px; }
.gap-12 { gap:12px; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.section-title { font-size:14px; font-weight:600; color:var(--text); display:flex; align-items:center; gap:6px; }

.empty-state { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:48px 20px; text-align:center; }
.empty-state .icon { font-size:40px; margin-bottom:12px; opacity:.5; }
.empty-state .icon svg { width:48px; height:48px; color:var(--text3); }
.empty-state p { color:var(--text3); font-size:14px; }

.loading-screen { display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:50vh; }
.spinner { width:28px; height:28px; border:2px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:spin .6s linear infinite; margin-bottom:12px; }

/* ─── Chart ───────────────────────────────────────────────────────────────── */
.chart-wrap { display:flex; align-items:flex-end; gap:4px; height:80px; padding:12px 0; }
.chart-bar-col { display:flex; flex-direction:column; align-items:center; flex:1; gap:2px; }
.chart-bar { border-radius:2px 2px 0 0; min-height:2px; width:100%; }
.chart-bar.pass { background:var(--success); }
.chart-bar.fail { background:var(--error); }
.chart-label { font-size:9px; color:var(--text3); margin-top:4px; }

/* ─── Test Row ────────────────────────────────────────────────────────────── */
.test-row { display:flex; align-items:center; gap:12px; padding:10px 14px; border:1px solid var(--border); border-radius:var(--radius-sm); margin-bottom:6px; background:var(--card); transition:var(--transition); }
.test-row:hover { border-color:var(--border2); }
.test-info { flex:1; min-width:0; }
.test-name { font-size:13px; font-weight:500; color:var(--text); }
.test-path { font-size:11px; color:var(--text3); font-family:var(--mono); }
.test-meta { display:flex; gap:4px; margin-top:4px; }
.test-actions { display:flex; gap:4px; flex-shrink:0; }

/* ─── Tag selector ────────────────────────────────────────────────────────── */
.tag-btn { display:inline-flex; align-items:center; padding:5px 12px; border-radius:20px; font-size:12px; font-weight:500; cursor:pointer; border:1px solid var(--border); background:transparent; color:var(--text2); transition:var(--transition); }
.tag-btn:hover { border-color:var(--accent); color:var(--accent); }
.tag-btn.selected { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ─── Editor ──────────────────────────────────────────────────────────────── */
.editor-overlay { position:fixed; inset:0; background:var(--bg); z-index:800; display:flex; flex-direction:column; }
.editor-header { display:flex; align-items:center; justify-content:space-between; padding:12px 20px; border-bottom:1px solid var(--border); background:var(--surface); }
.editor-textarea { flex:1; width:100%; padding:16px 20px; background:var(--bg); color:var(--text); font-family:var(--mono); font-size:13px; line-height:1.6; border:none; outline:none; resize:none; tab-size:2; }

/* ─── Case Detail Card ────────────────────────────────────────────────────── */
.case-row { cursor:pointer; }
.case-row:hover td { background:var(--card-hover); }

.cd { max-height:72vh; overflow-y:auto; padding-right:4px; }
.cd-header { padding:14px 18px; background:var(--surface); border-radius:var(--radius); margin-bottom:14px; }
.cd-key { display:inline-block; font-size:11px; font-weight:700; letter-spacing:.5px; color:var(--accent); margin-bottom:4px; font-family:var(--mono); }
.cd-title { font-size:16px; font-weight:600; color:var(--text); line-height:1.4; margin:0; }
.cd-pills { display:flex; flex-wrap:wrap; gap:6px; align-items:center; margin-bottom:14px; }
.cd-pill { display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:20px; font-size:11px; font-weight:600; }
.cd-pill-icon { font-size:12px; }
.cd-pill-outline { background:transparent; border:1px solid var(--border); color:var(--text2); }
.cd-tag { display:inline-block; padding:2px 8px; border-radius:4px; font-size:10px; font-weight:600; }
.cd-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:14px; }
.cd-grid-item { background:var(--surface); border-radius:var(--radius-sm); padding:8px 12px; }
.cd-grid-label { display:block; font-size:10px; text-transform:uppercase; letter-spacing:.5px; color:var(--text3); margin-bottom:2px; }
.cd-grid-value { font-size:12px; color:var(--text2); word-break:break-all; }
.cd-grid-value code { font-size:11px; color:var(--accent); }
.cd-block { margin-bottom:12px; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.cd-block-header { display:flex; align-items:center; gap:6px; padding:8px 12px; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; color:var(--text2); background:var(--surface); border-bottom:1px solid var(--border); }
.cd-block-icon { font-size:13px; }
.cd-count { display:inline-flex; align-items:center; justify-content:center; min-width:18px; height:18px; border-radius:9px; background:var(--accent-muted); color:var(--accent); font-size:10px; font-weight:700; padding:0 5px; margin-left:4px; }
.cd-block-body { padding:10px 14px; font-size:13px; color:var(--text2); line-height:1.6; white-space:pre-wrap; word-break:break-word; }
.cd-block-precond { border-left:3px solid var(--warning); background:var(--warning-muted); }
.cd-block-expected { border-left:3px solid var(--success); background:var(--success-muted); }
.cd-steps { max-height:300px; overflow-y:auto; }
.cd-step { display:flex; align-items:flex-start; gap:10px; padding:8px 14px; font-size:13px; color:var(--text); line-height:1.5; border-bottom:1px solid var(--border); }
.cd-step:last-child { border-bottom:none; }
.cd-step:nth-child(even) { background:var(--surface); }
.cd-step-num { flex-shrink:0; display:flex; align-items:center; justify-content:center; width:22px; height:22px; border-radius:50%; background:var(--accent-muted); color:var(--accent); font-size:11px; font-weight:700; margin-top:1px; }
.cd-step-text { flex:1; }

/* ─── Ticket Detail ───────────────────────────────────────────────────────── */
.ticket-detail p { color:var(--text); line-height:1.6; }
.error-pre { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-sm); padding:12px; font-family:var(--mono); font-size:12px; color:var(--text2); white-space:pre-wrap; word-break:break-all; max-height:300px; overflow:auto; }
.mono { font-family:var(--mono); font-size:12px; }

/* ─── Collections ─────────────────────────────────────────────────────────── */
.col-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(320px, 1fr)); gap:12px; }
.col-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; cursor:pointer; transition:var(--transition); }
.col-card:hover { border-color:var(--accent); transform:translateY(-1px); }
.col-card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.col-card-name { font-size:14px; font-weight:600; color:var(--text); }
.col-card-count { font-size:11px; color:var(--text3); background:var(--surface); padding:2px 8px; border-radius:10px; }
.col-card-desc { font-size:12px; color:var(--text2); margin:0 0 8px; line-height:1.4; }
.col-card-actions { display:flex; gap:4px; }

/* ─── Help Page ───────────────────────────────────────────────────────────── */
.help-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(340px, 1fr)); gap:14px; }
.help-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius); padding:18px; transition:var(--transition); }
.help-card:hover { border-color:var(--accent); }
.help-card-header { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.help-card-icon { width:36px; height:36px; border-radius:var(--radius-sm); background:var(--accent-muted); display:flex; align-items:center; justify-content:center; color:var(--accent); }
.help-card-icon svg { width:18px; height:18px; }
.help-card-title { font-size:14px; font-weight:600; color:var(--text); }
.help-card-body { font-size:13px; color:var(--text2); line-height:1.6; }
.help-card-body ol, .help-card-body ul { padding-left:18px; margin:6px 0; }
.help-card-body li { margin-bottom:4px; }
.help-card-body strong { color:var(--text); }

/* ─── Step Row (form) ─────────────────────────────────────────────────────── */
.step-row { display:flex; align-items:center; gap:8px; margin-bottom:4px; }
.step-num { color:var(--text3); font-size:12px; min-width:20px; }
.steps-list { max-height:200px; overflow-y:auto; }
.steps-view { padding-left:20px; margin:0; }
.steps-view li { padding:6px 0; color:var(--text); font-size:13px; line-height:1.5; border-bottom:1px solid var(--border); }
.steps-view li:last-child { border-bottom:none; }

/* ─── Animations ──────────────────────────────────────────────────────────── */
@keyframes pulse-dot { 0%,100% { opacity:1; } 50% { opacity:.4; } }
@keyframes spin { to { transform:rotate(360deg); } }
@keyframes slideIn { from { transform:translateX(20px); opacity:0; } to { transform:translateX(0); opacity:1; } }
@keyframes fadeIn { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }

/* ─── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .stats-grid { grid-template-columns:1fr 1fr; }
  .grid-2 { grid-template-columns:1fr; }
  .help-grid { grid-template-columns:1fr; }
  .form-grid { grid-template-columns:1fr; }
  .content { padding:16px; }
}
