/* ═══ NAV ═════════════════════════════════════ */
.nav{
  display:flex;align-items:center;gap:20px;
  padding:10px 20px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}/* ═══ PAGE HEAD ════════════════════════════════ */
.page-head{
  padding:18px 28px 16px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  display:flex;align-items:flex-start;justify-content:space-between;gap:20px;
  flex-wrap:wrap;flex-shrink:0;
}
.page-head-left{flex:1;min-width:280px;display:flex;flex-direction:column;gap:8px}
.breadcrumb{
  display:flex;align-items:center;gap:8px;font-family:var(--font-mono);
  font-size:11.5px;color:var(--muted);
}
.breadcrumb a:hover{color:var(--fg)}
.breadcrumb .sep{color:var(--subtle)}
.breadcrumb svg{width:12px;height:12px}

.page-title-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.page-title{font-size:21px;font-weight:600;letter-spacing:-0.025em;margin:0}
.failed-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:5px;
  background:var(--danger-soft);color:var(--danger);
  font-size:11px;font-family:var(--font-mono);font-weight:600;
  text-transform:uppercase;letter-spacing:0.04em;
}
.failed-pill.success{background:var(--success-soft);color:var(--success)}
.failed-pill.warn{background:var(--warn-soft);color:var(--warn)}
.failed-pill.info{background:var(--accent-soft);color:var(--accent)}
.failed-pill.success .dot{background:var(--success);animation:none}
.failed-pill.warn .dot{background:var(--warn);animation:none}
.failed-pill.info .dot{background:var(--accent);animation:none}
.failed-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--danger);animation:pulse 1.4s infinite}.page-meta{
  display:flex;gap:18px;font-family:var(--font-mono);font-size:11.5px;color:var(--muted);
  flex-wrap:wrap;
}
.page-meta strong{color:var(--fg);font-weight:500}/* ═══ ALERT BANNER ═════════════════════════════ */
.alert{
  margin:14px 28px;padding:16px 18px;
  border:1px solid var(--danger);background:var(--danger-soft);
  border-radius:10px;
  display:flex;align-items:flex-start;gap:14px;
}
.alert.is-collapsed{align-items:center}
.alert.success{border-color:var(--success);background:var(--success-soft)}
.alert.success .alert-icon{background:var(--success)}
.alert.success .alert-title{color:var(--success)}
.alert.neutral{border-color:var(--border);background:var(--surface)}
.alert.neutral .alert-icon{background:var(--surface-3);color:var(--fg)}
.alert.neutral .alert-title{color:var(--fg)}
.alert-icon{
  width:32px;height:32px;border-radius:8px;background:var(--danger);color:white;
  display:grid;place-items:center;flex-shrink:0;
}
.alert-icon svg{width:16px;height:16px}
.alert-body{flex:1;min-width:0}
.alert-summary{display:flex;align-items:center;justify-content:space-between;gap:14px;min-width:0}
.alert-title{
  font-size:14px;font-weight:600;letter-spacing:-0.01em;color:var(--danger);
  margin-bottom:4px;
}
.alert-summary .alert-title{margin-bottom:0;min-width:0}
.alert-toggle{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 9px;border-radius:6px;border:1px solid color-mix(in oklch, var(--success) 30%, var(--border));
  background:var(--surface);color:var(--muted);
  font:inherit;font-family:var(--font-mono);font-size:11px;
  cursor:pointer;transition:background .12s,color .12s,border-color .12s;
  white-space:nowrap;flex-shrink:0;
}
.alert-toggle:hover{background:var(--surface-2);color:var(--fg);border-color:var(--accent)}
.alert-toggle svg{width:13px;height:13px;transition:transform .12s}
.alert-toggle[aria-expanded="true"] svg{transform:rotate(180deg)}
.alert-details{margin-top:10px}
[data-theme="dark"] .alert-title{color:oklch(85% 0.18 25)}
.alert-msg{font-size:13px;color:var(--fg);line-height:1.55;margin-bottom:10px}
.alert-msg code{
  font-family:var(--font-mono);font-size:12px;
  background:var(--surface);padding:1px 6px;border-radius:4px;border:1px solid var(--border);
}
.alert-suggestions{
  display:flex;flex-direction:column;gap:6px;margin-top:8px;
}
.suggestion{
  display:flex;align-items:flex-start;gap:10px;
  padding:9px 12px;border-radius:7px;background:var(--surface);
  border:1px solid var(--border);
  font-size:12.5px;
  transition:all .12s;cursor:pointer;
}
.suggestion:hover{border-color:var(--accent);background:var(--accent-soft)}
.suggestion-num{
  width:18px;height:18px;border-radius:5px;background:var(--accent);color:var(--accent-fg);
  display:grid;place-items:center;font-size:10px;font-weight:700;flex-shrink:0;
  font-family:var(--font-mono);margin-top:1px;
}
.suggestion-text{flex:1;color:var(--fg);line-height:1.5}
.suggestion-text strong{font-weight:600}
.suggestion-text code{font-family:var(--font-mono);font-size:11.5px;background:var(--surface-2);padding:1px 5px;border-radius:3px}
.suggestion svg.arrow{
  width:14px;height:14px;color:var(--subtle);flex-shrink:0;margin-top:2px;
  transition:transform .12s, color .12s;
}
.suggestion:hover svg.arrow{color:var(--accent);transform:translateX(2px)}

/* ═══ TABS ════════════════════════════════════ */
.tab-rail{
  display:flex;gap:0;padding:0 28px;
  background:var(--surface);border-bottom:1px solid var(--border);
  overflow-x:auto;scrollbar-width:none;flex-shrink:0;
}
.tab-rail::-webkit-scrollbar{display:none}
.tab{
  padding:11px 16px;color:var(--muted);font-size:13px;font-weight:500;
  border:0;background:transparent;cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  display:inline-flex;align-items:center;gap:8px;
  white-space:nowrap;transition:color .12s;
}
.tab:hover{color:var(--fg)}
.tab.active{color:var(--fg);border-color:var(--accent)}
.tab svg{width:14px;height:14px}
.tab .ct{
  font-family:var(--font-mono);font-size:10.5px;font-weight:500;
  padding:1px 6px;border-radius:8px;
  background:var(--surface-2);color:var(--muted);
}
.tab.has-err .ct{background:var(--danger-soft);color:var(--danger)}
.tab.has-warn .ct{background:var(--warn-soft);color:var(--warn)}
.tab.active .ct{background:var(--accent-soft);color:var(--accent)}
[data-theme="dark"] .tab.active .ct{color:oklch(85% 0.16 255)}

/* ═══ BODY ════════════════════════════════════ */
.body{
  flex:1;overflow:auto;padding:24px 28px 32px;
  background:var(--bg);
  scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;
}.tab-pane{display:none;flex-direction:column;gap:20px}
.tab-pane.active{display:flex}

.panel{
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  overflow:hidden;
}
.panel-head{
  padding:12px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--surface);
}
.panel-title{
  font-size:13px;font-weight:600;letter-spacing:-0.005em;
  display:flex;align-items:center;gap:10px;
}
.panel-title .pcount{
  font-family:var(--font-mono);font-size:11px;color:var(--muted);
  padding:1px 7px;border-radius:8px;background:var(--surface-2);
  border:1px solid var(--border);font-weight:500;
}
.panel-actions{display:flex;gap:4px;align-items:center}
.panel-action{
  padding:4px 8px;border-radius:5px;border:1px solid var(--border);
  background:var(--surface);color:var(--muted);font:inherit;font-size:11px;
  cursor:pointer;font-family:var(--font-mono);transition:all .12s;
  display:inline-flex;align-items:center;gap:5px;
}
.panel-action:hover{background:var(--surface-2);color:var(--fg)}
.panel-action svg{width:11px;height:11px}
.panel-note{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--muted);
}

/* ═══ TIMELINE / WATERFALL ═════════════════════ */
.timeline-bar{
  padding:18px 22px;border-bottom:1px solid var(--border);
  display:flex;flex-direction:column;gap:8px;
}
.timeline-row{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:11.5px;color:var(--muted);
}
.timeline-track{
  position:relative;height:24px;background:var(--surface-2);border-radius:5px;
  overflow:hidden;
}
.timeline-stage{
  position:absolute;top:0;bottom:0;
  display:flex;align-items:center;padding:0 8px;
  font-family:var(--font-mono);font-size:10px;color:white;font-weight:500;
  white-space:nowrap;overflow:hidden;
}
.timeline-stage.ok{background:var(--success)}
.timeline-stage.info{background:var(--accent)}
.timeline-stage.warn{background:var(--warn)}
.timeline-stage.fail{
  background:repeating-linear-gradient(45deg, var(--danger), var(--danger) 6px, color-mix(in oklch, var(--danger) 70%, black) 6px, color-mix(in oklch, var(--danger) 70%, black) 12px);
}
.timeline-stage[data-w="tiny"]{padding:0 3px;font-size:0}
.timeline-axis{
  display:flex;justify-content:space-between;
  font-family:var(--font-mono);font-size:10px;color:var(--subtle);
  padding-top:2px;
}
.timeline-legend{
  display:flex;gap:14px;font-family:var(--font-mono);font-size:11px;color:var(--muted);
  flex-wrap:wrap;
}
.legend{display:inline-flex;align-items:center;gap:6px}
.legend .sw{width:10px;height:10px;border-radius:2px}
.legend .sw.ok{background:var(--success)}
.legend .sw.info{background:var(--accent)}
.legend .sw.warn{background:var(--warn)}
.legend .sw.fail{background:var(--danger)}

.snapshot-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.snapshot-card{
  min-width:0;
  padding:12px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--surface);
}
.snapshot-card.ok{border-color:color-mix(in oklch, var(--success) 35%, var(--border))}
.snapshot-card.info{border-color:color-mix(in oklch, var(--accent) 35%, var(--border))}
.snapshot-card.warn{border-color:color-mix(in oklch, var(--warn) 45%, var(--border))}
.snapshot-card.fail{border-color:color-mix(in oklch, var(--danger) 45%, var(--border))}
.snapshot-card-top{
  display:flex;
  align-items:center;
  gap:7px;
  margin-bottom:8px;
  min-width:0;
}
.snapshot-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
  flex:0 0 auto;
}
.snapshot-card.ok .snapshot-dot{background:var(--success)}
.snapshot-card.warn .snapshot-dot{background:var(--warn)}
.snapshot-card.fail .snapshot-dot{background:var(--danger)}
.snapshot-label{
  color:var(--muted);
  font-family:var(--font-mono);
  font-size:10.5px;
  text-transform:uppercase;
  letter-spacing:0.06em;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.snapshot-value{
  color:var(--fg);
  font-size:13px;
  font-weight:600;
  margin-bottom:3px;
}
.snapshot-detail{
  color:var(--muted);
  font-family:var(--font-mono);
  font-size:11px;
  line-height:1.45;
  overflow-wrap:anywhere;
}
.snapshot-note{
  color:var(--muted);
  font-size:12px;
  line-height:1.55;
  max-width:980px;
}
.snapshot-note code{
  font-family:var(--font-mono);
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:4px;
  padding:1px 5px;
}

/* ═══ OVERVIEW GRID ═════════════════════════════ */
.overview-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:20px;
}
.overview-col{display:flex;flex-direction:column;gap:20px}

/* stages list */
.stage-list{padding:14px 18px;display:flex;flex-direction:column;gap:6px}
.stage{
  display:grid;grid-template-columns:auto 1fr 70px 60px;
  gap:12px;align-items:center;
  padding:9px 4px;border-bottom:1px dashed var(--border);
  font-family:var(--font-mono);font-size:12px;
}
.stage:last-child{border-bottom:0}
.stage-status{
  width:18px;height:18px;border-radius:50%;
  display:grid;place-items:center;font-weight:700;
  flex-shrink:0;
  font-size:7px;font-family:var(--font-mono);
}
.stage-status.ok{background:var(--success-soft);color:var(--success)}
.stage-status.fail{background:var(--danger-soft);color:var(--danger)}
.stage-status.info{background:var(--accent-soft);color:var(--accent)}
.stage-status.warn{background:var(--warn-soft);color:var(--warn)}
[data-theme="dark"] .stage-status.info{color:oklch(85% 0.16 255)}
.stage-status svg{width:10px;height:10px}
.stage-name{color:var(--fg);font-family:var(--font-sans);font-size:12.5px}
.stage-name .sub{color:var(--muted);font-family:var(--font-mono);font-size:11px;display:block;margin-top:1px}
.stage-dur{text-align:right;color:var(--muted)}
.stage-pct{text-align:right;color:var(--subtle);font-size:10.5px}

/* env panel */
.env-grid{padding:14px 18px;display:grid;grid-template-columns:1fr 1fr;gap:10px 18px}
.env-row{display:flex;flex-direction:column;gap:2px;padding:6px 0;border-bottom:1px dashed var(--border)}
.env-row:nth-last-child(-n+2){border-bottom:0}
.env-key{font-size:10.5px;color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.06em}
.env-val{font-size:12px;color:var(--fg);font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.env-val.success{color:var(--success)}
.env-val.fail{color:var(--danger)}
.env-val.warn{color:var(--warn)}

/* validation list */
.validation-list{padding:6px 0}
.vrow{
  display:flex;align-items:flex-start;gap:12px;
  padding:10px 18px;border-bottom:1px solid var(--border);
}
.vrow:last-child{border-bottom:0}
.vicon{
  width:24px;height:24px;border-radius:6px;display:grid;place-items:center;flex-shrink:0;
  font-family:var(--font-mono);font-size:8px;font-weight:700;
}
.vicon.ok{background:var(--success-soft);color:var(--success)}
.vicon.warn{background:var(--warn-soft);color:var(--warn)}
.vicon.fail{background:var(--danger-soft);color:var(--danger)}
.vicon svg{width:12px;height:12px}
.vbody{flex:1;min-width:0}
.vtitle{font-size:13px;font-weight:500;letter-spacing:-0.005em}
.vdesc{font-size:11.5px;color:var(--muted);font-family:var(--font-mono);margin-top:2px;line-height:1.55}
.vdesc code{background:var(--surface-2);padding:1px 5px;border-radius:3px;border:1px solid var(--border)}
.vtag{
  font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.04em;
  padding:2px 7px;border-radius:4px;font-weight:600;flex-shrink:0;
}
.vtag.ok{background:var(--success-soft);color:var(--success)}
.vtag.warn{background:var(--warn-soft);color:var(--warn)}
.vtag.fail{background:var(--danger-soft);color:var(--danger)}

.diagnostics-empty{
  padding:36px 18px;
  color:var(--muted);
  font-size:13px;
  line-height:1.55;
  text-align:center;
  max-width:760px;
  margin:0 auto;
  white-space:normal;
  overflow-wrap:anywhere;
}
.diagnostics-empty-title{
  color:var(--fg);
  font-weight:600;
  margin-bottom:6px;
}
.diagnostics-empty-copy + .diagnostics-empty-copy{margin-top:6px}
.diagnostics-json{
  margin:0;
  padding:16px 18px;
  white-space:pre-wrap;
  word-break:break-word;
  font-size:12px;
  line-height:1.65;
  font-family:var(--font-mono);
  color:var(--fg);
  background:var(--code-bg);
  border-top:1px solid var(--border);
  max-height:620px;
  overflow:auto;
}

.snackbar-host{
  position:fixed;left:50%;bottom:80px;transform:translateX(-50%);
  display:flex;flex-direction:column;gap:8px;
  z-index:9999;pointer-events:none;
}
.snackbar{
  pointer-events:auto;min-width:260px;max-width:480px;
  padding:12px 16px;border-radius:8px;
  background:oklch(22% 0.02 250);color:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,0.18);
  font-size:13px;line-height:1.45;
  display:flex;align-items:flex-start;gap:10px;
  opacity:0;transform:translateY(8px);
  transition:opacity .22s ease,transform .22s ease;
}
.snackbar.show{opacity:1;transform:translateY(0)}
.snackbar.warn{background:oklch(45% 0.13 60)}
.snackbar.err{background:oklch(45% 0.18 25)}
.snackbar.ok{background:oklch(40% 0.13 150)}
.snackbar .snackbar-icon{flex:0 0 auto;margin-top:1px}
.snackbar .snackbar-icon svg{width:16px;height:16px;display:block}
.snackbar .snackbar-msg{flex:1 1 auto}
.snackbar .snackbar-close{
  flex:0 0 auto;background:transparent;border:0;color:inherit;
  opacity:.7;cursor:pointer;padding:0;margin-left:6px;
  display:grid;place-items:center;
}
.snackbar .snackbar-close:hover{opacity:1}

/* screenshot panel */
.shot-wrap{padding:18px;display:flex;flex-direction:column;gap:12px}
.shot-frame{
  position:relative;
  background:repeating-conic-gradient(var(--surface-2) 0% 25%, var(--surface-3) 0% 50%) 50% / 12px 12px;
  border:1px solid var(--border);border-radius:8px;overflow:hidden;
  aspect-ratio:1280/900;
}
.shot-img{
  position:absolute;inset:0;
  background:white;
  padding:32px 40px;
  font-family:'Georgia',serif;color:#1a1a1a;
  font-size:9px;line-height:1.5;
}
.shot-img .h{
  display:flex;justify-content:space-between;align-items:flex-start;
  padding-bottom:12px;border-bottom:1.5px solid #1a1a1a;margin-bottom:14px;
}
.shot-img .h h1{margin:0;font-family:'Inter',sans-serif;font-size:18px;letter-spacing:-0.02em;font-weight:600}
.shot-img .h .sub{font-family:'Inter',sans-serif;font-size:8.5px;color:#666;text-transform:uppercase;letter-spacing:0.08em;margin-top:2px}
.shot-img .h .num{font-family:'JetBrains Mono',monospace;font-size:8.5px;color:#666;text-align:right}
.shot-img .h .num strong{display:block;color:#1a1a1a;font-size:12px;margin-top:1px}
.shot-img .meta{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;font-family:'Inter',sans-serif}
.shot-img .meta h4{margin:0 0 3px;font-size:7.5px;color:#888;text-transform:uppercase;letter-spacing:0.08em;font-weight:600}
.shot-img .meta p{margin:0;font-size:9px;color:#333;line-height:1.5}
.shot-img table{width:100%;border-collapse:collapse;font-family:'Inter',sans-serif;font-size:8.5px}
.shot-img th{text-align:left;padding:5px 0;border-bottom:1px solid #1a1a1a;font-size:7.5px;text-transform:uppercase;letter-spacing:0.08em;color:#555;font-weight:600}
.shot-img td{padding:5px 0;border-bottom:1px solid #eee}
.shot-img td.r{text-align:right;font-family:'JetBrains Mono',monospace}
.shot-img .missing-asset{
  position:absolute;left:32px;bottom:64px;width:140px;height:48px;
  background:var(--danger-soft);border:1.5px dashed var(--danger);border-radius:4px;
  display:grid;place-items:center;
  font-family:'JetBrains Mono',monospace;font-size:7.5px;color:var(--danger);
  text-align:center;padding:4px;
}
.shot-overlay-label{
  position:absolute;top:8px;left:8px;
  padding:3px 8px;border-radius:4px;
  background:rgba(0,0,0,0.7);color:white;
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  display:flex;align-items:center;gap:6px;
}
.shot-overlay-label .dot{width:6px;height:6px;border-radius:50%;background:var(--warn)}
.shot-meta{
  display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:11.5px;color:var(--muted);
  padding-top:4px;
}
.shot-meta .val{color:var(--fg)}

/* ═══ NETWORK WATERFALL ════════════════════════ */
.net-head{
  padding:10px 18px;border-bottom:1px solid var(--border);
  background:var(--surface-2);
  display:flex;align-items:center;gap:14px;font-family:var(--font-mono);font-size:11px;color:var(--muted);
  text-transform:uppercase;letter-spacing:0.06em;
}
.net-row{
  display:grid;grid-template-columns:60px 1fr 90px 90px 1.4fr;
  gap:14px;align-items:center;
  padding:9px 18px;border-bottom:1px solid var(--border);
  font-size:12px;
}
.net-row:last-child{border-bottom:0}
.net-row.warn{background:var(--warn-soft)}
.net-row.fail{background:var(--danger-soft)}
.net-status{
  font-family:var(--font-mono);font-size:11.5px;font-weight:600;font-variant-numeric:tabular-nums;
}
.net-status.s2{color:var(--success)}
.net-status.s3{color:var(--info)}
.net-status.s4,.net-status.s5{color:var(--danger)}
[data-theme="dark"] .net-status.s3{color:oklch(80% 0.16 220)}
.net-url{
  font-family:var(--font-mono);font-size:11.5px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  color:var(--fg);
}
.net-url .domain{color:var(--muted)}
.net-url .path{color:var(--fg)}
.net-url .type{color:var(--subtle);margin-left:6px;font-size:10.5px}
.net-time,.net-size{
  font-family:var(--font-mono);font-size:11px;color:var(--muted);
  text-align:right;font-variant-numeric:tabular-nums;
}
.net-bar{position:relative;height:14px}
.net-bar-track{
  position:absolute;top:50%;transform:translateY(-50%);height:6px;
  background:var(--surface-2);border-radius:3px;left:0;right:0;
}
.net-bar-fill{
  position:absolute;top:50%;transform:translateY(-50%);height:6px;border-radius:3px;
  background:var(--accent);
}
.net-bar-fill.ok{background:var(--success)}
.net-bar-fill.warn{background:var(--warn)}
.net-bar-fill.fail{background:var(--danger)}

/* ═══ CONSOLE ════════════════════════════════ */
.console-toolbar{
  padding:8px 14px;border-bottom:1px solid var(--border);
  background:var(--surface-2);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.level-chip{
  padding:4px 10px;border-radius:5px;font-size:11px;
  background:var(--surface);border:1px solid var(--border);color:var(--muted);
  cursor:pointer;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);
  transition:all .12s;
}
.level-chip:hover{color:var(--fg)}
.level-chip.active{background:var(--accent-soft);color:var(--accent);border-color:transparent}
[data-theme="dark"] .level-chip.active{color:oklch(85% 0.16 255)}
.level-chip .ct{font-size:9.5px;color:var(--subtle)}
.console-search{
  flex:1;min-width:140px;max-width:260px;position:relative;
}
.console-search svg{position:absolute;left:8px;top:50%;transform:translateY(-50%);width:11px;height:11px;color:var(--muted)}
.console-search input{
  width:100%;padding:5px 8px 5px 26px;
  background:var(--surface);border:1px solid var(--border);border-radius:5px;
  font:inherit;font-size:11.5px;color:var(--fg);font-family:var(--font-mono);
}
.console-search input:focus{outline:none;border-color:var(--accent)}

.console-stream{
  padding:8px 0;font-family:var(--font-mono);font-size:11.5px;line-height:1.65;
  background:var(--code-bg);max-height:480px;overflow:auto;
  scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;
}
.console-stream::-webkit-scrollbar{width:6px}
.console-stream::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}
.log{
  display:grid;grid-template-columns:78px 38px 1fr;gap:12px;
  padding:3px 18px;align-items:flex-start;
}
.log:hover{background:var(--surface-2)}
.log-time{color:var(--subtle)}
.log-level{font-weight:600;text-transform:uppercase;font-size:9.5px;letter-spacing:0.04em;padding-top:1px}[data-theme="dark"] .log-level.info{color:oklch(82% 0.16 255)}.log-level.debug{color:var(--subtle)}
.log-msg{color:var(--fg);word-break:break-word;font-size:11.5px}
.log-msg .grey{color:var(--muted)}
.log-msg .url{color:var(--info)}
[data-theme="dark"] .log-msg .url{color:oklch(80% 0.16 220)}
.log-source{
  margin-left:8px;color:var(--subtle);font-size:10.5px;float:right;
}

/* ═══ RESPONSIVE ════════════════════════════════ */
@media (max-width:1024px){
  .overview-grid{grid-template-columns:1fr}
  .net-row{grid-template-columns:50px 1fr 70px 1fr;}
  .net-row .net-size{display:none}
  .env-grid{grid-template-columns:1fr}
  .env-row:nth-last-child(-n+2){border-bottom:1px dashed var(--border)}
  .env-row:last-child{border-bottom:0}
}
@media (max-width:768px){
  .nav{padding:10px 14px;gap:10px;flex-wrap:wrap}
  .nav-tabs{order:3;width:100%;overflow-x:auto;scrollbar-width:none}
  .nav-tabs::-webkit-scrollbar{display:none}
  .nav-tab{padding:5px 10px;font-size:12px}
  .page-head{padding:14px 16px}
  .alert{margin:12px 16px;padding:12px}
  .tab-rail{padding:0 16px}
  .body{padding:16px}
  .net-row{grid-template-columns:50px 1fr 70px;font-size:11px}
  .net-row .net-bar,.net-row .net-size{display:none}
  .stage{grid-template-columns:auto 1fr 60px}
  .stage-pct{display:none}
  .log{grid-template-columns:64px 32px 1fr}
}
@media (max-width:480px){
  .page-actions .btn span{display:none}
  .panel-action span{display:none}
}
