/* ── Radar Chart ────────────────────────────── */
.radar-container { display:flex; justify-content:center; align-items:center; padding:10px; }
.radar-label { font:500 11px var(--mono); fill:var(--text2); }
.radar-value { font:700 11px var(--mono); }

/* ── BCS Bar ────────────────────────────────── */
.bcs-bar { height:6px; background:var(--bg3); border-radius:3px; overflow:hidden; width:100%; }
.bcs-fill { height:100%; border-radius:3px; transition:width 0.6s ease; }

/* ── Phase 16: Sparkline ───────────────────── */
.sparkline { display:inline-block; vertical-align:middle; margin-left:6px; }

/* ── Phase 16: Compliance Ring ─────────────── */
.compliance-ring { position:relative; display:inline-flex; align-items:center; justify-content:center; }
.compliance-ring-text { position:absolute; font:700 11px var(--mono); }

/* ── Dimension Progress Bars ─────── */
.dim-progress { height:6px; background:var(--bg); border-radius:3px; overflow:hidden; flex:1; }
.dim-progress-fill { height:100%; border-radius:3px; transition:width 0.8s cubic-bezier(0.4,0,0.2,1); }

/* ── Heatmap ───────────────────── */
.heatmap-scroll { max-height:480px; overflow-y:auto; border-radius:8px; border:1px solid var(--border); scrollbar-gutter:stable; }
.heatmap-table { width:100%; border-collapse:separate; border-spacing:4px; }
.heatmap-table thead th { font:600 11px var(--mono); color:var(--text2); letter-spacing:1px; padding:6px 8px; text-align:center; position:sticky; top:0; background:var(--bg2); z-index:10; }
.heatmap-table thead th.hm-sortable { cursor:pointer; user-select:none; transition:color 0.2s; }
.heatmap-table thead th.hm-sortable:hover { color:var(--cyan); }
.heatmap-table thead th.hm-sorted { color:var(--cyan); }
.heatmap-table td { text-align:center; padding:8px 10px; border-radius:6px; font:600 11px var(--mono); cursor:pointer; transition:all 0.2s; }
.heatmap-table td:hover { filter:brightness(1.15); transform:scale(1.02); }
.heatmap-table td.dep-name { text-align:left; color:var(--text); font-weight:500; cursor:pointer; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:220px; }
.heatmap-table tr.hm-selected { background:rgba(6,182,212,0.06); }
.heatmap-table tr.hm-selected td.dep-name { color:var(--cyan); }
.heatmap-table tr.hm-selected td:first-child { box-shadow:inset 3px 0 0 var(--cyan); }

/* ── Heatmap Gradient Fills ───────────────── */
.hm-green { background:linear-gradient(135deg,rgba(16,185,129,0.12),rgba(16,185,129,0.22)); color:var(--green); }
.hm-green-muted { background:linear-gradient(135deg,rgba(16,185,129,0.08),rgba(16,185,129,0.15)); color:rgba(16,185,129,0.7); }
.hm-yellow { background:linear-gradient(135deg,rgba(245,158,11,0.12),rgba(245,158,11,0.22)); color:var(--amber); }
.hm-orange { background:linear-gradient(135deg,rgba(249,115,22,0.15),rgba(249,115,22,0.28)); color:#F97316; }
.hm-red { background:linear-gradient(135deg,rgba(239,68,68,0.18),rgba(239,68,68,0.32)); color:var(--red); font-weight:700; }

/* ── Heatmap Detail Panel ───────────────── */
.hm-detail { margin-top:12px; animation:hmDetailIn 0.2s ease-out; }
@keyframes hmDetailIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
.hm-detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.hm-detail-dim { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:14px; }
.hm-detail-dim-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.hm-detail-dim-name { font:600 11px var(--mono); letter-spacing:1px; color:var(--text3); text-transform:uppercase; }
.hm-detail-dim-score { font:700 16px var(--mono); }
.hm-detail-bar { height:4px; background:var(--bg3); border-radius:2px; overflow:hidden; }
.hm-detail-bar-fill { height:100%; border-radius:2px; transition:width 0.6s cubic-bezier(0.4,0,0.2,1); }
.hm-detail-certs { margin-top:12px; }
.hm-detail-cert-row { display:flex; align-items:center; gap:10px; padding:6px 0; border-bottom:1px solid var(--border); font:400 11px var(--mono); }
.hm-detail-cert-row:last-child { border-bottom:none; }
.hm-detail-placeholder { padding:40px; text-align:center; font:400 12px var(--mono); color:var(--text3); }

/* ── Posture Gauge Arc ─────────────── */
.posture-gauge-arc { transition:stroke-dashoffset 1.2s cubic-bezier(0.4,0,0.2,1); }

/* ── Cert Flow Container ──────────── */
.cert-flow-container { position:relative; overflow:hidden; height:120px; background:var(--bg3); border-radius:var(--radius); border:1px solid var(--border); margin-bottom:16px; }
.cert-flow-dot { position:absolute; border-radius:50%; transition:none; pointer-events:none; }

/* ── Anomaly Dot ───────────────────── */
.anomaly-dot { cursor:pointer; transition:filter 0.15s; }
.anomaly-dot:hover { filter:brightness(1.4); }

/* ── Taxonomy Cell ─────────────────── */
.taxonomy-cell { text-align:center; border-radius:4px; cursor:pointer; transition:transform 0.15s; font:600 11px var(--mono); padding:4px 6px; }
.taxonomy-cell:hover { transform:scale(1.1); }

/* ── Workflow Node/Edge ────────────── */
.workflow-node { cursor:pointer; transition:filter 0.2s; }
.workflow-node:hover { filter:brightness(1.3); }
.workflow-edge { stroke:var(--border2); stroke-width:2; fill:none; }

/* ── Overview Gauge ─────────────────── */
.ov-gauge svg { display:block; margin:0 auto; }
@keyframes ovGaugeDraw { from { stroke-dashoffset: var(--ov-gauge-full); } to { stroke-dashoffset: var(--ov-gauge-target); } }

/* ── Overview Heatmap ──────────────── */
.ov-heatmap { margin-bottom:16px; }
.ov-hm-grid { display:grid; gap:0; }
.ov-hm-cell { width:100%; height:36px; border:1px solid #1E293B; transition:background 0.2s; cursor:default; min-width:0; display:flex; align-items:center; justify-content:center; font:500 11px var(--sans); color:rgba(255,255,255,0.92); letter-spacing:0.02em; }
.ov-hm-cell:hover { box-shadow:inset 0 0 0 1px var(--cyan); z-index:1; }
.ov-hm-clickable { cursor:pointer; }
.ov-hm-clickable:hover { box-shadow:inset 0 0 0 1px var(--cyan); z-index:1; }
.ov-hm-header { font:600 10px var(--mono); color:var(--muted); text-align:center; letter-spacing:1px; height:28px; display:flex; align-items:center; justify-content:center; }
.ov-hm-row-label { font:400 11px var(--mono); color:var(--text3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:flex; align-items:center; height:36px; padding-right:8px; }

/* ── Heatmap Popover ─────────────────── */
.ov-hm-popover { position:fixed; z-index:9000; width:310px; background:var(--bg2); border:1px solid var(--border2); border-radius:10px; padding:16px; box-shadow:0 8px 32px rgba(0,0,0,0.5); animation:ovPopIn 0.15s ease-out; }
@keyframes ovPopIn { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:translateY(0); } }
.ov-hm-pop-header { font:600 13px var(--sans); color:var(--text); margin-bottom:12px; line-height:1.4; }
.ov-hm-pop-row { display:flex; justify-content:space-between; align-items:center; padding:4px 0; }
.ov-hm-pop-label { font:400 12px var(--sans); color:var(--text3); }
.ov-hm-pop-val { font:600 12px var(--mono); color:var(--text); }
.ov-hm-pop-actions { display:flex; gap:12px; margin-top:12px; padding-top:10px; border-top:1px solid var(--border); }
.ov-hm-pop-link { font:500 11px var(--mono); color:var(--cyan); cursor:pointer; transition:color 0.2s; }
.ov-hm-pop-link:hover { color:var(--brand-accentHover); text-decoration:underline; }

/* ── Clickable Compliance Bars ───────── */
.ov-comp-clickable { cursor:pointer; transition:background 0.2s; border-radius:4px; padding:8px 4px !important; margin:0 -4px; }
.ov-comp-clickable:hover { background:rgba(var(--accent-rgb),0.06); }

/* ── Overview Seismograph ──────────── */
.ov-seismo { height:60px; margin-top:12px; }
.ov-seismo svg { display:block; width:100%; }

/* ── Incident Response Seismograph ─── */
.ir-seismo-wrap { position:relative; height:120px; overflow:hidden; }

/* ── Analytics Charts ──────────────── */
.an-chart { position:relative; width:100%; overflow:hidden; }
.an-chart svg { display:block; width:100%; height:100%; }
.an-tooltip { position:fixed; z-index:9999; background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:10px 14px; font:400 11px var(--mono); color:var(--text2); pointer-events:none; opacity:0; transition:opacity 0.15s; box-shadow:0 8px 24px rgba(0,0,0,0.4); max-width:280px; }
.an-tooltip.visible { opacity:1; }
.an-tooltip-title { font:600 11px var(--mono); color:var(--text); margin-bottom:4px; }
.an-tooltip-row { display:flex; justify-content:space-between; gap:12px; padding:1px 0; }
.an-tooltip-label { color:var(--text3); }
.an-tooltip-val { color:var(--text); font-weight:600; }
.an-heatmap-cell { transition:opacity 0.15s; cursor:pointer; }
.an-heatmap-cell:hover { opacity:1 !important; stroke:var(--cyan); stroke-width:1; }
.an-dist-bar, .an-vol-bar, .an-fail-bar, .an-lat-bar { cursor:pointer; transition:opacity 0.15s; }
.an-dist-bar:hover, .an-vol-bar:hover, .an-fail-bar:hover, .an-lat-bar:hover { opacity:1 !important; filter:brightness(1.2); }
.an-comp-vol-bar, .an-comp-fail-bar { cursor:pointer; transition:opacity 0.15s; }
.an-comp-vol-bar:hover, .an-comp-fail-bar:hover { opacity:1 !important; filter:brightness(1.2); }
.an-radar-shape { transition:fill-opacity 0.15s, stroke-width 0.15s; }
.an-radar-shape:hover { fill-opacity:0.25 !important; stroke-width:2.5; }
.an-radar-axis { transition:fill 0.15s; }
.an-radar-axis:hover { fill:var(--cyan) !important; }
.an-trend-line:hover + path { stroke-width:2.5; }
.an-clickable { cursor:pointer; transition:color 0.15s; }
.an-clickable:hover { color:var(--cyan) !important; text-decoration:underline; }
.an-table tr[onclick] { cursor:pointer; }
.an-table td[onclick] { cursor:pointer; }
.an-legend { display:flex; gap:16px; margin-top:8px; flex-wrap:wrap; }
.an-legend-item { display:flex; align-items:center; gap:4px; font:400 11px var(--mono); color:var(--text3); }
.an-legend-dot { width:8px; height:8px; border-radius:2px; }

/* ── Model Fingerprints DNA Bars ───── */
.fp-dna { display:flex; gap:2px; height:32px; align-items:flex-end; margin:10px 0; }
.fp-dna-bar { flex:1; border-radius:2px 2px 0 0; transition:height 0.4s ease; min-width:4px; }
.fp-dim-bar { flex:1; height:3px; background:var(--bg3); border-radius:2px; margin:0 8px; overflow:hidden; }
.fp-dim-bar-fill { height:100%; border-radius:2px; }
.fp-drift-annotation { position:absolute; font:600 11px var(--mono); color:var(--amber); background:rgba(245,158,11,0.15); padding:2px 6px; border-radius:3px; border:1px solid rgba(245,158,11,0.3); pointer-events:none; white-space:nowrap; }

/* ── Deployment Dossier Timeline ───── */
.dd-timeline-wrap { background:var(--bg2); border:1px solid var(--border); border-radius:10px; padding:16px; overflow:hidden; }
.dd-timeline-scroll { overflow-x:auto; scrollbar-gutter:stable; padding-bottom:8px; }
.dd-timeline-track { position:relative; height:100px; min-width:100%; }
.dd-timeline-axis { position:absolute; bottom:20px; left:0; right:0; height:1px; background:var(--border); }
.dd-timeline-dot { position:absolute; width:8px; height:8px; border-radius:50%; cursor:pointer; transition:all 0.15s; transform:translate(-50%,-50%); z-index:1; }
.dd-timeline-dot:hover { transform:translate(-50%,-50%) scale(1.8); z-index:2; box-shadow:0 0 8px currentColor; }
.dd-timeline-dot.certified { background:var(--green); color:var(--green); }
.dd-timeline-dot.flagged { background:var(--amber); color:var(--amber); }
.dd-timeline-dot.failed { background:var(--red); color:var(--red); }
.dd-timeline-label { position:absolute; bottom:0; font:400 11px var(--mono); color:var(--muted); transform:translateX(-50%); }
.dd-timeline-tip { position:fixed; z-index:9999; background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:10px 14px; font:400 11px var(--mono); color:var(--text2); pointer-events:none; opacity:0; transition:opacity 0.15s; box-shadow:0 8px 24px rgba(0,0,0,0.4); max-width:300px; }
.dd-timeline-tip.visible { opacity:1; }

/* ── Deployment Dossier Dim Histogram ─ */
.dd-dim-hist { display:flex; gap:1px; height:32px; align-items:flex-end; margin-top:8px; }
.dd-dim-hist-bar { flex:1; background:var(--cyan); border-radius:2px 2px 0 0; min-height:1px; opacity:0.7; transition:opacity 0.2s; }
.dd-dim-hist-bar:hover { opacity:1; }

/* ── Orchestration Hub Orbital ──────── */
.oh-orbital-wrap { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:20px; margin-bottom:20px; position:relative; overflow:hidden; }
.oh-orbital-wrap::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 50% 50%,rgba(var(--accent-rgb),0.03),transparent 70%); pointer-events:none; }
.oh-orbital-svg { display:block; margin:0 auto; }
.oh-orbital-tip { position:fixed; z-index:9999; background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:10px 14px; font:400 11px var(--mono); color:var(--text2); pointer-events:none; opacity:0; transition:opacity 0.15s; box-shadow:0 8px 24px rgba(0,0,0,0.4); max-width:260px; }
.oh-orbital-tip.visible { opacity:1; }
@keyframes ohPulseGlow { 0%,100% { opacity:0.5; } 50% { opacity:1; } }
@keyframes ohParticle { 0% { offset-distance:0%; opacity:0.8; } 100% { offset-distance:100%; opacity:0; } }
@keyframes ohRingRotate { 0% { transform:rotate(0deg); } 100% { transform:rotate(360deg); } }

/* ── Orchestration Hub Bar Chart ────── */
.oh-bar-chart { display:flex; flex-direction:column; gap:6px; }
.oh-bar-row { display:flex; align-items:center; gap:8px; }
.oh-bar-label { font:400 11px var(--mono); color:var(--text3); width:80px; text-align:right; flex-shrink:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.oh-bar-track { flex:1; height:16px; background:var(--bg3); border-radius:3px; overflow:hidden; }
.oh-bar-fill { height:100%; border-radius:3px; transition:width 0.6s; }
.oh-bar-val { font:600 11px var(--mono); color:var(--text2); width:40px; }

/* ── Orchestration Hub Arc Chart ──── */
.oh-chart-wrap { display:flex; align-items:center; gap:16px; }
.oh-chart-legend { font:400 11px var(--mono); }
.oh-chart-legend-item { display:flex; align-items:center; gap:6px; margin-bottom:4px; }
.oh-chart-legend-dot { width:8px; height:8px; border-radius:2px; flex-shrink:0; }

/* ── Governance Arc Chart ──────────── */
.gov-chart-wrap { display:flex; align-items:center; gap:20px; margin-top:12px; }
.gov-legend { font:400 11px var(--mono); }
.gov-legend-item { display:flex; align-items:center; gap:6px; margin-bottom:4px; }
.gov-legend-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }

/* ── Governance Flowchart ──────────── */
.gov-flow-wrap { background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:16px; overflow:auto; }
@keyframes govPulse { from { stroke-dashoffset:12; } to { stroke-dashoffset:0; } }

/* ── EI Deployment Health ─────────── */
.ei-health-container { position:relative; width:100%; min-height:380px; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.ei-health-detail { position:absolute; top:0; right:0; width:260px; height:100%; background:#0d1117; border-left:1px solid #ffb347; padding:18px 16px; font:400 11px var(--mono); color:var(--text); overflow-y:auto; z-index:10; transform:translateX(100%); opacity:0; transition:transform 0.3s ease, opacity 0.25s ease; pointer-events:none; scrollbar-gutter:stable; }
.ei-health-detail.visible { transform:translateX(0); opacity:1; pointer-events:auto; }
.od-name { font:700 16px var(--mono); color:var(--text); margin-bottom:10px; line-height:1.3; }
.od-bcs { font:200 28px var(--mono); letter-spacing:-1px; line-height:1.2; }
.od-grade { font:600 12px var(--mono); margin-left:8px; opacity:0.7; }
.od-trend-arrow { font-size:13px; margin-left:6px; }
.od-spark { margin:10px 0 12px; }
.od-divider { height:1px; background:var(--border); margin:10px 0; opacity:0.4; }
.od-row { display:flex; justify-content:space-between; align-items:center; padding:3px 0; font-size:11px; color:var(--text2); }
.od-row-label { opacity:0.6; }
.od-row-value { font-weight:600; color:var(--text); }
.od-section { font:600 10px var(--mono); letter-spacing:1.5px; color:var(--text3); margin:12px 0 6px; text-transform:uppercase; }
.od-comp-row { display:flex; align-items:center; gap:8px; margin-bottom:5px; font-size:10px; }
.od-comp-name { width:72px; color:var(--text3); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.od-comp-bar { flex:1; height:4px; background:var(--bg3); border-radius:2px; overflow:hidden; }
.od-comp-fill { height:100%; border-radius:2px; transition:width 0.4s ease; }
.od-comp-val { width:28px; text-align:right; font-weight:600; font-size:9px; }

/* ── EI Hero Gauge ─────────────────── */
.ei-hero-gauge { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:24px 18px 18px; min-height:320px; }
.ei-hero-gauge .ei-gauge-score { font:200 64px var(--mono); letter-spacing:-2px; line-height:1; }
.ei-hero-gauge .ei-gauge-label { font:500 11px var(--mono); letter-spacing:2px; color:var(--text3); margin-top:8px; }
.ei-hero-gauge .ei-gauge-trend { display:flex; align-items:center; gap:10px; margin-top:12px; }
.ei-hero-gauge .ei-gauge-delta { font:600 12px var(--mono); display:flex; align-items:center; gap:4px; }

/* ── EI ROI Waterfall ──────────────── */
.ei-roi-waterfall { margin-top:16px; }

/* ── Compliance Galaxy Ring Panel ──── */
.cg-ring-panel { background:#111827; border:1px solid var(--border); border-radius:12px; padding:16px; display:flex; flex-direction:column; align-items:center; justify-content:center; width:300px; min-width:300px; flex-shrink:0; align-self:flex-start; z-index:10; }
.cg-ring-title { font:600 11px var(--mono); letter-spacing:2px; color:var(--text3); margin-bottom:8px; }
.cg-card-svg { display:block; margin:0 auto 8px; }
.cg-card-bar { height:3px; background:var(--bg3); border-radius:2px; margin-top:6px; overflow:hidden; }
.cg-card-bar-fill { height:100%; border-radius:2px; transition:width 0.8s ease; }

/* ── Compliance Galaxy Star Groups ─── */
.cg-star-group { transition:transform 0.2s ease, filter 0.2s ease; transform-origin:center; cursor:pointer; }
.cg-star-group.cg-star-active { transform:scale(1.5); filter:drop-shadow(0 0 6px rgba(var(--accent-rgb),0.7)); }

/* ── Mission Control Map ──────────── */
.cc-map { grid-column:1/3; min-height:340px; position:relative; overflow:hidden; }
.cc-map-wrap { position:relative; width:100%; height:100%; }
.cc-map-wrap svg { width:100%; height:100%; display:block; }
.cc-map .country { fill:#111827; stroke:#1E293B; stroke-width:0.5px; }
.cc-map .graticule { fill:none; stroke:#1E293B; stroke-width:0.3px; opacity:0.3; }
.cc-map .ocean { fill:#0E1117; }

/* Skeleton loader */
.cc-map-skeleton { width:100%; height:280px; background:#111827; border-radius:8px; position:relative; overflow:hidden; }
.cc-map-skeleton-shimmer { position:absolute; inset:0; background:linear-gradient(90deg, transparent 0%, rgba(6,182,212,0.04) 50%, transparent 100%); animation:ccMapShimmer 1.8s ease-in-out infinite; }
@keyframes ccMapShimmer { 0% { transform:translateX(-100%); } 100% { transform:translateX(100%); } }

/* Deployment pins */
.cc-map-pin { cursor:pointer; }
.cc-map-pin-core { transition:r 0.2s, opacity 0.2s; }
.cc-map-pin-ring { animation:ccPinPulse 2.5s ease-out infinite; }
@keyframes ccPinPulse { 0% { r:6; opacity:0.5; } 100% { r:22; opacity:0; } }
.cc-map-pin-ring2 { animation:ccPinPulse 2.5s ease-out 0.8s infinite; }
.cc-map-pin:hover .cc-map-pin-core { r:8; }
.cc-map-pin-label { font-family:'IBM Plex Mono',monospace; font-size:9px; fill:#F1F5F9; pointer-events:none; }

/* Connection lines */
.cc-map-connection { fill:none; stroke:#06B6D4; stroke-width:1; opacity:0.4; stroke-dasharray:6,4; animation:ccConnFlow 2s linear infinite; }
@keyframes ccConnFlow { 0% { stroke-dashoffset:0; } 100% { stroke-dashoffset:-20; } }

/* HQ marker */
.cc-map-hq-ring { animation:ccHqPulse 3s ease-in-out infinite; }
@keyframes ccHqPulse { 0%,100% { r:10; opacity:0.1; } 50% { r:14; opacity:0.2; } }

/* Tooltip */
.cc-map-tooltip { position:absolute; background:#111827; border:1px solid #1E293B; border-radius:6px; padding:8px 12px; pointer-events:none; opacity:0; transition:opacity 0.15s; z-index:20; box-shadow:0 4px 16px rgba(0,0,0,0.4); white-space:nowrap; }
.cc-map-tooltip-name { font:600 11px 'IBM Plex Mono',monospace; color:#06B6D4; margin-bottom:2px; }
.cc-map-tooltip-bcs { font:700 13px 'IBM Plex Mono',monospace; }

/* Hover overlay */
.cc-map-wrap.dimmed::before { content:''; position:absolute; inset:0; background:rgba(0,0,0,0.1); z-index:5; pointer-events:none; border-radius:8px; }

/* Detail slide-in panel */
.cc-map-detail { position:absolute; top:0; right:0; bottom:0; width:280px; background:#111827; border-left:1px solid #1E293B; z-index:30; transform:translateX(100%); transition:transform 0.3s ease-out; display:flex; flex-direction:column; overflow-y:auto; }
.cc-map-detail.open { transform:translateX(0); }
.cc-map-detail-close { position:absolute; top:8px; right:10px; background:none; border:none; color:#F1F5F9; font-size:20px; cursor:pointer; z-index:31; padding:4px 8px; opacity:0.6; transition:opacity 0.2s; }
.cc-map-detail-close:hover { opacity:1; }
.cc-map-detail-header { font:700 13px 'IBM Plex Mono',monospace; color:#06B6D4; padding:16px 16px 4px; }
.cc-map-detail-bcs { font:700 36px 'IBM Plex Mono',monospace; padding:0 16px; line-height:1.2; }
.cc-map-detail-bcs-label { font:400 10px 'IBM Plex Mono',monospace; color:#64748B; padding:0 16px 12px; letter-spacing:1px; text-transform:uppercase; }
.cc-map-detail-section { padding:0 16px 12px; }
.cc-map-detail-section-title { font:600 9px 'IBM Plex Mono',monospace; color:#64748B; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:6px; }
.cc-map-detail-donut { display:flex; justify-content:center; padding:4px 0; }
.cc-map-detail-timeline { display:flex; flex-direction:column; gap:4px; }
.cc-map-detail-timeline-item { display:flex; align-items:center; gap:8px; font:400 10px 'IBM Plex Mono',monospace; color:#94A3B8; }
.cc-map-detail-timeline-badge { font:600 8px 'IBM Plex Mono',monospace; letter-spacing:0.5px; padding:2px 6px; border-radius:3px; text-transform:uppercase; }
.cc-map-detail-badges { display:flex; flex-wrap:wrap; gap:4px; }
.cc-map-detail-badge { font:500 8px 'IBM Plex Mono',monospace; letter-spacing:0.5px; color:#06B6D4; background:rgba(6,182,212,0.08); border:1px solid rgba(6,182,212,0.2); padding:2px 6px; border-radius:3px; }
.cc-map-detail-link { display:block; font:600 11px 'IBM Plex Mono',monospace; color:#06B6D4; padding:12px 16px; border-top:1px solid #1E293B; margin-top:auto; cursor:pointer; transition:background 0.2s; }
.cc-map-detail-link:hover { background:rgba(6,182,212,0.05); }

@media(max-width:900px) {
  .cc-map-detail { width:100%; }
}

/* ── Risk Intelligence Charts ──────── */
.ri-gauge-card { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:20px; }
.ri-gauge-svg text { font-family:var(--mono); }
.ri-factor-bar { flex:1; height:6px; border-radius:3px; background:var(--bg3); overflow:hidden; }
.ri-factor-bar-fill { height:100%; border-radius:3px; transition:width 0.6s; }
.ri-calendar { display:grid; grid-template-columns:repeat(13,1fr); gap:3px; }
.ri-cal-cell { aspect-ratio:1; border-radius:3px; min-width:10px; cursor:default; transition:all 0.2s; position:relative; }
.ri-cal-cell:hover { box-shadow:0 0 0 2px var(--cyan); z-index:1; }
.ri-cal-label { font:400 11px var(--mono); color:var(--text3); display:flex; align-items:center; justify-content:center; }
.ri-chart-wrap { overflow:hidden; }
.ri-chart-wrap svg text { font-family:var(--mono); }

/* ── Evidence Vault Calendar Heatmap ── */
.ev-calendar { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:16px; margin-bottom:20px; }
.ev-cal-grid { display:flex; gap:2px; flex-wrap:nowrap; overflow-x:auto; }
.ev-cal-col { display:flex; flex-direction:column; gap:2px; }
.ev-cal-cell { width:12px; height:12px; border-radius:2px; cursor:pointer; transition:all 0.15s; }
.ev-cal-cell:hover { box-shadow:0 0 0 2px var(--cyan); z-index:1; }
.ev-cal-label { font:400 9px var(--mono); color:var(--muted); width:24px; display:flex; align-items:center; }
.ev-cal-month { font:400 9px var(--mono); color:var(--muted); text-align:center; }

/* ── Connected Universe Hub SVG ────── */
.cu-hub-svg { width:100%; max-width:500px; margin:0 auto; display:block; }
.cu-hub-node { cursor:pointer; }

/* ── Benchmarking Radar SVG ────────── */
.bm-radar-svg { display:block; margin:0 auto; }

/* ── Benchmarking Percentile Bars ──── */
.bm-pct-bar { display:flex; align-items:center; gap:8px; margin:6px 0; }
.bm-pct-label { width:22px; font:600 11px var(--mono); color:var(--text3); text-align:right; flex-shrink:0; }
.bm-pct-track { flex:1; height:10px; background:var(--bg3); border-radius:5px; overflow:hidden; position:relative; }
.bm-pct-fill { height:100%; border-radius:5px; transition:width 0.8s ease; }
.bm-pct-val { width:52px; font:600 11px var(--mono); text-align:right; flex-shrink:0; }

/* ── Deployment Dossier Gauge ──────── */
.dd-gauge-wrap { position:relative; }
.dd-gauge-grade { position:absolute; bottom:6px; left:50%; transform:translateX(-50%); font:700 14px var(--mono); }

/* ── Certification Forensics Dimension Bar ── */
.cf-dim-bar{height:8px;border-radius:4px;background:var(--surface);overflow:hidden;position:relative}
.cf-dim-bar-fill{height:100%;border-radius:4px;transition:width .6s}
.cf-dim-floor{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--text3);z-index:1}
.cf-confidence-bar{height:6px;border-radius:3px;background:var(--surface);overflow:hidden}
.cf-confidence-fill{height:100%;border-radius:3px}
.cf-legend{display:flex;gap:16px;flex-wrap:wrap;padding:10px 0;font:400 11px var(--mono);color:var(--text3)}
.cf-legend-item{display:flex;align-items:center;gap:5px}
.cf-legend-swatch{width:12px;height:4px;border-radius:2px}

/* ── Radar Draw Animation ──────────── */
@keyframes radarDraw { from { stroke-dashoffset:var(--dash-total); } to { stroke-dashoffset:0; } }

/* ── SLA Bar Chart ─────────────────── */
.sla-bar-row{display:flex;align-items:center;gap:10px;padding:6px 0}
.sla-bar-label{font:400 11px var(--mono);color:var(--text2);min-width:50px;text-align:right}
.sla-bar-track{flex:1;height:8px;background:var(--surface);border-radius:4px;overflow:hidden}
.sla-bar-fill{height:100%;border-radius:4px;transition:width .6s}
.sla-bar-value{font:600 11px var(--mono);min-width:50px}

/* ── Risk Intelligence Sim Result ──── */
.ri-sim-result { min-width:200px; display:flex; flex-direction:column; align-items:center; justify-content:center; background:var(--bg2); border:1px solid var(--border); padding:24px; border-radius:12px; }

/* ── EI Chart Animations ───────────── */
@keyframes eiPulse { 0%,100%{opacity:0.6;transform:scale(1)} 50%{opacity:1;transform:scale(1.05)} }
@keyframes eiCountUp { from{opacity:0} to{opacity:1} }

/* ── Compliance Galaxy Chart Animations ── */
@keyframes cgPulse { 0%,100%{opacity:0.6} 50%{opacity:1} }

/* ── MC Pulse Glow ─────────────────── */
@keyframes mcPulseGlow { 0%,100% { opacity:0.3; } 50% { opacity:1; } }

/* ── Risk Intelligence responsive ──── */
@media(max-width:900px) {
  .ri-calendar { grid-template-columns:repeat(7,1fr); }
}

/* ═══ REPORTS CENTER ═══════════════════════════ */
.rc-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:24px; gap:20px; flex-wrap:wrap; }
.rc-title { font:700 20px var(--mono); color:var(--cyan); letter-spacing:2px; }
.rc-subtitle { font:400 13px var(--sans); color:var(--text3); margin-top:4px; }
.rc-search-wrap { flex-shrink:0; }
.rc-search { background:var(--bg3); border:1px solid var(--border); border-radius:8px; padding:8px 14px; font:400 13px var(--sans); color:var(--text); width:260px; outline:none; transition:border-color 0.2s; }
.rc-search:focus { border-color:var(--cyan); }
.rc-search::placeholder { color:var(--text3); }

.rc-category { margin-bottom:28px; }
.rc-category-header { display:flex; align-items:center; gap:10px; font:700 12px var(--mono); color:var(--text2); letter-spacing:2px; text-transform:uppercase; margin-bottom:14px; padding-bottom:8px; border-bottom:1px solid var(--border); }
.rc-category-header svg { color:var(--cyan); flex-shrink:0; }

.rc-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media(max-width:1100px) { .rc-cards { grid-template-columns:repeat(2,1fr); } }
@media(max-width:700px) { .rc-cards { grid-template-columns:1fr; } }

.rc-card { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:20px; display:flex; flex-direction:column; min-height:210px; transition:border-color 0.2s, box-shadow 0.2s; }
.rc-card:hover { border-color:var(--cyan); box-shadow:0 0 0 1px rgba(6,182,212,0.15); }

.rc-card-icon { color:var(--cyan); margin-bottom:12px; opacity:0.7; }
.rc-card-title { font:600 14px var(--sans); color:var(--text); margin-bottom:8px; }
.rc-card-desc { font:400 12px var(--sans); color:var(--text3); line-height:1.5; flex:1; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.rc-card-meta { display:flex; align-items:center; gap:8px; margin-top:12px; }
.rc-card-pages { font:400 10px var(--mono); color:var(--text3); }

.rc-badge { display:inline-block; padding:2px 8px; border-radius:4px; font:700 9px var(--mono); color:var(--bg); letter-spacing:1px; }

.rc-card-action { margin-top:14px; }

.rc-btn { display:inline-block; background:transparent; border:1px solid var(--cyan); color:var(--cyan); font:700 11px var(--mono); letter-spacing:2px; padding:8px 20px; border-radius:6px; cursor:pointer; transition:all 0.2s; text-transform:uppercase; width:100%; text-align:center; }
.rc-btn:hover { background:var(--cyan); color:var(--bg); }
.rc-btn:disabled { opacity:0.5; cursor:not-allowed; }
.rc-btn.rc-generating { animation:rcPulse 1.2s ease-in-out infinite; border-color:var(--amber); color:var(--amber); }
.rc-btn.rc-done { border-color:var(--green); color:var(--green); }
@keyframes rcPulse { 0%,100% { opacity:1; } 50% { opacity:0.5; } }

.rc-param-row { display:flex; gap:8px; margin-bottom:8px; }
.rc-select { flex:1; background:var(--bg3); border:1px solid var(--border); border-radius:6px; padding:6px 10px; font:400 12px var(--sans); color:var(--text); outline:none; }
.rc-select:focus { border-color:var(--cyan); }
.rc-btn-go { width:auto; padding:6px 16px; }

.rc-recent-section { margin-top:32px; }
.rc-recent-row { display:flex; align-items:center; gap:12px; padding:10px 14px; border-bottom:1px solid var(--border); }
.rc-recent-row:last-child { border-bottom:none; }
.rc-recent-title { font:500 13px var(--sans); color:var(--text); flex:1; }
.rc-recent-time { font:400 11px var(--mono); color:var(--text3); }
.rc-recent-btn { background:none; border:none; color:var(--cyan); font:400 11px var(--mono); cursor:pointer; padding:4px 8px; }
.rc-recent-btn:hover { text-decoration:underline; }
.rc-recent-empty { font:400 13px var(--sans); color:var(--text3); padding:16px 0; text-align:center; }

/* ── Live Certification Feed ─────────────────── */
.lf-section { background:var(--bg2); border:1px solid var(--border); border-radius:10px; margin-bottom:20px; overflow:hidden; }
.lf-header { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid var(--border); }
.lf-header-left { display:flex; align-items:center; gap:10px; }
.lf-dot { width:8px; height:8px; border-radius:50%; background:#64748B; }
.lf-dot.live { background:var(--green); animation:simPulse 2s ease-in-out infinite; }
.lf-title { font:700 12px var(--mono); letter-spacing:1.5px; color:var(--text); }
.lf-count { font:400 11px var(--mono); color:var(--text3); }
.lf-header-right { display:flex; align-items:center; gap:8px; }
.lf-filter { font:400 11px var(--mono); background:var(--bg3); color:var(--text2); border:1px solid var(--border); border-radius:4px; padding:4px 8px; cursor:pointer; }
.lf-pause-btn { font:600 11px var(--mono); background:transparent; color:var(--text3); border:1px solid var(--border); border-radius:4px; padding:3px 8px; cursor:pointer; transition:all 0.2s; }
.lf-pause-btn:hover { border-color:var(--text3); color:var(--text2); }
.lf-pause-btn.paused { color:var(--cyan); border-color:rgba(var(--accent-rgb),0.3); }
.lf-feed { max-height:320px; overflow-y:auto; scrollbar-gutter:stable; }
.lf-empty { font:400 12px var(--sans); color:var(--text3); padding:32px 16px; text-align:center; }
.lf-row { display:grid; grid-template-columns:140px 180px 80px 60px 1fr; align-items:center; gap:8px; padding:8px 16px; border-bottom:1px solid var(--border); font:400 12px var(--mono); color:var(--text2); animation:lfSlideIn 0.3s ease-out; }
.lf-row:hover { background:rgba(var(--accent-rgb),0.03); }
.lf-row .lf-ts { color:var(--text3); font-size:11px; }
.lf-row .lf-dep { color:var(--text); font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.lf-row .lf-verdict { font:700 10px var(--mono); letter-spacing:1px; padding:2px 8px; border-radius:3px; text-align:center; }
.lf-verdict.certified { background:rgba(16,137,129,0.15); color:var(--green); }
.lf-verdict.flagged { background:rgba(245,158,11,0.15); color:var(--amber); }
.lf-verdict.failed { background:rgba(239,68,68,0.15); color:var(--red); }
.lf-row .lf-bcs { font:600 12px var(--mono); }
.lf-row .lf-desc { font:400 11px var(--sans); color:var(--text3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
@keyframes lfSlideIn { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:translateY(0); } }
@media (max-width:900px) { .lf-row { grid-template-columns:100px 120px 70px 50px 1fr; font-size:11px; } }
@media (max-width:600px) { .lf-row { grid-template-columns:80px 1fr 70px 50px; } .lf-row .lf-desc { display:none; } }

/* ── Simulation Toggle ──────────────────────── */
.sim-toggle { display:flex; align-items:center; gap:8px; padding:4px 12px; border:1px solid var(--border); border-radius:6px; background:var(--bg2); }
.sim-dot { width:8px; height:8px; border-radius:50%; background:#64748B; transition:background 0.3s; }
.sim-dot.active { background:var(--cyan); animation:simPulse 2s ease-in-out infinite; }
.sim-label { font:600 10px var(--mono); letter-spacing:1.5px; color:#64748B; transition:color 0.3s; }
.sim-label.active { color:var(--cyan); }
.sim-btn { font:600 9px var(--mono); letter-spacing:1px; padding:2px 8px; border:1px solid var(--border); border-radius:3px; background:transparent; color:var(--text3); cursor:pointer; transition:all 0.2s; }
.sim-btn.active { background:var(--cyan-dim); color:var(--cyan); border-color:rgba(var(--accent-rgb),0.3); }
.sim-btn:hover:not(.active) { border-color:var(--text3); color:var(--text2); }
.sim-status { font:400 9px var(--mono); color:var(--cyan); letter-spacing:0.5px; margin-left:2px; }
@keyframes simPulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }

/* ── Interactive Standard ─────────────────────── */
.ov-hero-card.vp-click { cursor:pointer; transition:border-color 0.2s, transform 0.15s, box-shadow 0.2s; }
.ov-hero-card.vp-click:hover { border-color:var(--cyan); transform:translateY(-2px); box-shadow:0 4px 20px rgba(6,182,212,0.08); }
.ov-hero-card.vp-click:active { transform:translateY(0); }
.ov-hero-card.vp-click .vp-drill { position:absolute; bottom:10px; right:14px; font:400 9px var(--mono); color:var(--muted); letter-spacing:0.5px; opacity:0; transition:opacity 0.2s; pointer-events:none; }
.ov-hero-card.vp-click:hover .vp-drill { opacity:1; }

/* ── Live Feed Row Enhancements ────────────────── */
.lf-row { cursor:pointer; border-left:3px solid transparent; transition:background 0.15s, border-left-color 0.15s; }
.lf-row:hover { background:rgba(var(--accent-rgb),0.04); }
.lf-row:hover .lf-verdict.certified { box-shadow:0 0 0 1px var(--green); }
.lf-row:hover .lf-verdict.flagged { box-shadow:0 0 0 1px var(--amber); }
.lf-row:hover .lf-verdict.failed { box-shadow:0 0 0 1px var(--red); }
.lf-row:hover.lf-row-certified { border-left-color:var(--green); }
.lf-row:hover.lf-row-flagged { border-left-color:var(--amber); }
.lf-row:hover.lf-row-failed { border-left-color:var(--red); }

/* ═══ LIVE CERTIFICATION EXPERIENCE — "PROVE IT" ═══ */
.lc-hero { display:flex; justify-content:space-between; align-items:center; padding:20px 0 16px; gap:20px; border-bottom:1px solid var(--border); margin-bottom:20px; }
.lc-hero-title { font:700 16px var(--mono); color:var(--cyan); letter-spacing:0.5px; }
.lc-hero-sub { font:400 12px var(--mono); color:var(--text3); margin-top:4px; max-width:600px; }
.lc-hero-right { display:flex; gap:8px; align-items:center; flex-shrink:0; }
.lc-select { background:var(--bg3); border:1px solid var(--border); color:var(--text); font:400 11px var(--mono); padding:6px 10px; border-radius:6px; cursor:pointer; }
.lc-select:focus { border-color:var(--cyan); outline:none; }

.lc-main { display:grid; grid-template-columns:1fr 280px; gap:24px; }
@media (max-width:900px) { .lc-main { grid-template-columns:1fr; } }

/* Left column */
.lc-left { display:flex; flex-direction:column; gap:16px; min-width:0; }
.lc-label { font:600 10px var(--mono); color:var(--muted); letter-spacing:1px; margin-bottom:6px; }
.lc-input-section { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:16px; }
.lc-textarea { width:100%; background:var(--bg3); border:1px solid var(--border); color:var(--text); font:400 12px var(--mono); padding:10px 12px; border-radius:6px; resize:vertical; min-height:60px; box-sizing:border-box; }
.lc-textarea:focus { border-color:var(--cyan); outline:none; box-shadow:0 0 0 2px rgba(6,182,212,0.15); }
.lc-textarea::placeholder { color:var(--muted); }
.lc-input-actions { display:flex; align-items:center; gap:12px; margin-top:10px; }
.lc-submit-btn { background:var(--cyan); color:#000; font:700 11px var(--mono); padding:8px 24px; border:none; border-radius:6px; cursor:pointer; letter-spacing:0.5px; transition:all 0.15s; }
.lc-submit-btn:hover { background:#22d3ee; transform:translateY(-1px); }
.lc-submit-btn:disabled { opacity:0.5; cursor:not-allowed; transform:none; }
.lc-input-hint { font:400 10px var(--mono); color:var(--muted); }

.lc-prompt-display { background:var(--bg3); border-left:3px solid var(--cyan); padding:10px 14px; border-radius:4px; font:400 12px var(--mono); color:var(--text3); white-space:pre-wrap; word-break:break-word; }

.lc-response-section { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:16px; }
.lc-response-box { max-height:300px; overflow-y:auto; scrollbar-gutter:stable; }
.lc-response-text { font:400 12px/1.6 var(--mono); color:var(--text); white-space:pre-wrap; word-break:break-word; margin:0; }

.lc-error { background:rgba(255,71,87,0.08); border:1px solid var(--red); color:var(--red); font:400 11px var(--mono); padding:10px 14px; border-radius:6px; }

/* Dimension Grid */
.lc-dim-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(200px, 1fr)); gap:10px; }
.lc-dim-card { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:12px; transition:border-color 0.2s; cursor:pointer; }
.lc-dim-card:hover { border-color:var(--cyan); background:rgba(6,182,212,0.03); }
.lc-dim-header { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.lc-dim-abbrev { font:700 10px var(--mono); color:var(--cyan); background:rgba(6,182,212,0.1); padding:2px 6px; border-radius:4px; }
.lc-dim-name { font:500 11px var(--mono); color:var(--text3); flex:1; }
.lc-dim-score { font:700 13px var(--mono); }
.lc-dim-bar { height:4px; background:var(--bg3); border-radius:2px; overflow:hidden; }
.lc-dim-bar-fill { height:100%; border-radius:2px; transition:width 0.6s ease-out; }
.lc-dim-flags { display:flex; flex-wrap:wrap; gap:4px; margin-top:6px; }
.lc-dim-flag { font:500 9px var(--mono); background:rgba(255,71,87,0.1); color:var(--red); padding:1px 6px; border-radius:8px; cursor:pointer; transition:background 0.15s; }
.lc-dim-flag:hover { background:rgba(255,71,87,0.25); }

/* Final Verdict */
.lc-final-verdict { display:flex; flex-wrap:wrap; align-items:center; gap:16px; background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:16px; animation:lcSlideIn 0.3s ease-out; }
@keyframes lcSlideIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
.lc-verdict-badge { font:700 14px var(--mono); color:#fff; padding:6px 16px; border-radius:6px; letter-spacing:1px; cursor:pointer; transition:filter 0.15s; }
.lc-verdict-badge:hover { filter:brightness(1.2); }
.lc-verdict-bcs { display:flex; align-items:center; gap:8px; }
.lc-verdict-meta { display:flex; flex-direction:column; gap:2px; font:400 10px var(--mono); }
.lc-verdict-flags { display:flex; flex-wrap:wrap; gap:4px; width:100%; margin-top:4px; }
.lc-flag-pill { font:500 10px var(--mono); background:rgba(245,158,11,0.1); color:var(--amber); padding:2px 8px; border-radius:8px; }

/* Performance */
.lc-perf { display:flex; flex-wrap:wrap; gap:8px 16px; font:400 10px var(--mono); color:var(--muted); padding:8px 0; }
.lc-perf-item b { color:var(--text3); }

/* VCAS Artifact */
.lc-vcas { background:var(--bg2); border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.lc-vcas-header { display:flex; align-items:center; gap:10px; padding:10px 14px; background:var(--bg3); border-bottom:1px solid var(--border); }
.lc-vcas-title { font:700 10px var(--mono); color:var(--cyan); letter-spacing:1px; }
.lc-vcas-version { font:400 9px var(--mono); color:var(--muted); }
.lc-vcas-btn { margin-left:auto; background:transparent; border:1px solid var(--border); color:var(--text3); font:600 9px var(--mono); padding:3px 10px; border-radius:4px; cursor:pointer; letter-spacing:0.5px; transition:all 0.15s; }
.lc-vcas-btn:hover { border-color:var(--cyan); color:var(--cyan); }
.lc-vcas-btn + .lc-vcas-btn { margin-left:6px; }
.lc-vcas-code { font:400 10px/1.5 var(--mono); color:var(--text3); padding:14px; margin:0; max-height:300px; overflow:auto; scrollbar-gutter:stable; white-space:pre-wrap; word-break:break-all; }

/* Right column */
.lc-right { display:flex; flex-direction:column; gap:16px; }

/* Pipeline phases */
.lc-pipeline { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:14px; }
.lc-pipeline-title { font:600 10px var(--mono); color:var(--muted); letter-spacing:1px; margin-bottom:12px; }
.lc-phase { display:flex; align-items:center; gap:8px; padding:6px 0; font:400 11px var(--mono); color:var(--text3); position:relative; cursor:pointer; transition:background 0.15s; border-radius:4px; }
.lc-phase:hover { background:rgba(6,182,212,0.04); }
.lc-phase + .lc-phase { border-top:1px solid rgba(255,255,255,0.03); }
.lc-phase-dot { width:8px; height:8px; border-radius:50%; background:var(--border); flex-shrink:0; transition:all 0.3s; }
.lc-phase-label { flex:1; }
.lc-phase-time { font:600 10px var(--mono); color:var(--muted); }

.lc-phase-active .lc-phase-dot { background:var(--cyan); box-shadow:0 0 8px var(--cyan); animation:lcPulse 1s infinite; }
.lc-phase-active .lc-phase-label { color:var(--cyan); }
@keyframes lcPulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }

.lc-phase-done .lc-phase-dot { background:var(--green); }
.lc-phase-done .lc-phase-label { color:var(--green); }
.lc-phase-done .lc-phase-time { color:var(--green); }

.lc-phase-error .lc-phase-dot { background:var(--red); }
.lc-phase-error .lc-phase-label { color:var(--red); }

/* Quick-fire prompts */
.lc-quickfire { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:14px; }
.lc-qf-section { margin-bottom:10px; }
.lc-qf-section:last-child { margin-bottom:0; }
.lc-qf-label { font:600 9px var(--mono); color:var(--muted); letter-spacing:0.5px; margin-bottom:6px; }
.lc-qf-btn { display:block; width:100%; text-align:left; background:var(--bg3); border:1px solid var(--border); color:var(--text3); font:400 10px var(--mono); padding:5px 8px; border-radius:4px; cursor:pointer; margin-bottom:4px; transition:all 0.15s; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.lc-qf-btn:hover { border-color:var(--cyan); color:var(--text); }
.lc-qf-safe:hover { border-color:var(--green); }
.lc-qf-adv:hover { border-color:var(--red); }
.lc-qf-adv { border-left:2px solid rgba(255,71,87,0.3); }

/* History */
.lc-history-section { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:14px; max-height:300px; overflow-y:auto; scrollbar-gutter:stable; }
.lc-history-empty { font:400 10px var(--mono); color:var(--muted); text-align:center; padding:12px; }
.lc-history-row { display:flex; align-items:center; gap:6px; padding:5px 0; cursor:pointer; transition:background 0.15s; border-radius:4px; }
.lc-history-row:hover { background:var(--bg3); }
.lc-history-row + .lc-history-row { border-top:1px solid rgba(255,255,255,0.03); }

/* Root Cause Analysis */
.lc-rca { background:var(--bg2); border:1px solid var(--border); border-left:3px solid var(--amber); border-radius:8px; padding:16px; animation:lcSlideIn 0.3s ease-out; }

/* Progressive Scoring */
.lc-initial-label { font:500 10px var(--mono); color:var(--amber); letter-spacing:0.5px; animation:lcPulse 1.5s infinite; }
.lc-refined-label { font:500 10px var(--mono); color:var(--green); letter-spacing:0.5px; }
.lc-refine-glow { animation:lcRefineGlow 1.2s ease-out; }
@keyframes lcRefineGlow {
  0% { box-shadow:0 0 0 0 rgba(6,182,212,0.4); }
  30% { box-shadow:0 0 20px 4px rgba(6,182,212,0.3); }
  100% { box-shadow:none; }
}

/* ── Policy Wizard ─────────────────────────── */
.wiz-progress { display:flex; align-items:center; justify-content:center; gap:0; margin-bottom:24px; padding:16px 0; }
.wiz-step-dot { width:28px; height:28px; border-radius:50%; background:var(--bg3); border:2px solid var(--border); display:flex; align-items:center; justify-content:center; font:700 11px var(--mono); color:var(--muted); transition:all 0.3s; }
.wiz-step-active { background:var(--cyan); border-color:var(--cyan); color:#000; }
.wiz-step-done { background:var(--green); border-color:var(--green); color:#000; }
.wiz-step-line { width:60px; height:2px; background:var(--border); }

.wiz-choose-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; max-width:720px; margin:0 auto; }
@media (max-width:700px) { .wiz-choose-grid { grid-template-columns:1fr; } }
.wiz-choose-card { background:var(--bg2); border:1px solid var(--border); border-radius:10px; padding:24px 20px; text-align:center; cursor:pointer; transition:all 0.2s; }
.wiz-choose-card:hover { border-color:var(--cyan); transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,0.3); }
.wiz-choose-icon { font-size:28px; margin-bottom:12px; color:var(--cyan); }
.wiz-choose-title { font:700 12px var(--mono); color:var(--text); letter-spacing:1px; margin-bottom:8px; }
.wiz-choose-desc { font:400 11px var(--sans); color:var(--text3); line-height:1.5; }

.wiz-section-label { font:600 10px var(--mono); color:var(--cyan); letter-spacing:1.5px; margin-bottom:8px; text-transform:uppercase; }
.wiz-textarea { width:100%; box-sizing:border-box; background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:14px 16px; color:var(--text); font:400 12px var(--sans); resize:vertical; line-height:1.6; transition:border-color 0.2s; }
.wiz-textarea:focus { border-color:var(--cyan); outline:none; box-shadow:0 0 0 2px rgba(6,182,212,0.15); }
.wiz-textarea::placeholder { color:var(--muted); }

.wiz-drop-zone { border:2px dashed var(--border); border-radius:10px; padding:40px 20px; text-align:center; transition:all 0.2s; cursor:pointer; }
.wiz-drop-zone:hover, .wiz-drop-hover { border-color:var(--cyan); background:rgba(6,182,212,0.04); }

.wiz-template-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
@media (max-width:600px) { .wiz-template-grid { grid-template-columns:1fr; } }
.wiz-template-card { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:16px; cursor:pointer; transition:all 0.2s; }
.wiz-template-card:hover { border-color:var(--cyan); transform:translateY(-1px); }
.wiz-template-icon { font-size:20px; margin-bottom:8px; }
.wiz-template-name { font:700 12px var(--mono); color:var(--text); margin-bottom:4px; }
.wiz-template-desc { font:400 10px var(--sans); color:var(--text3); line-height:1.5; margin-bottom:8px; }
.wiz-template-tags { display:flex; flex-wrap:wrap; gap:4px; }
.wiz-template-tags span { font:600 9px var(--mono); background:var(--cyan-dim); color:var(--cyan); padding:2px 6px; border-radius:4px; }

.wiz-review-panel { background:var(--bg2); border:1px solid var(--border); border-radius:10px; padding:24px; }

.wiz-field-label { font:400 10px var(--mono); color:var(--muted); letter-spacing:0.5px; display:block; margin-bottom:4px; }
.wiz-field-input { width:100%; box-sizing:border-box; background:var(--bg3); border:1px solid var(--border); border-radius:6px; padding:8px 12px; color:var(--text); font:500 12px var(--mono); transition:border-color 0.2s; }
.wiz-field-input:focus { border-color:var(--cyan); outline:none; }
.wiz-field-value { font:500 12px var(--mono); color:var(--text2); text-transform:capitalize; }

.wiz-dim-grid { display:grid; gap:6px; }
.wiz-dim-row { display:flex; align-items:center; gap:10px; padding:4px 0; }
.wiz-dim-name { font:400 11px var(--mono); color:var(--text3); min-width:140px; }
.wiz-dim-slider { flex:1; accent-color:var(--cyan); }
.wiz-dim-val { font:700 11px var(--mono); min-width:36px; text-align:right; }

.wiz-editable-list { display:flex; flex-direction:column; gap:4px; }
.wiz-list-item { display:flex; align-items:center; gap:6px; }
.wiz-list-x { font:400 16px var(--mono); color:var(--red); cursor:pointer; width:18px; text-align:center; flex-shrink:0; opacity:0.6; transition:opacity 0.2s; }
.wiz-list-x:hover { opacity:1; }
.wiz-list-input { flex:1; background:var(--bg3); border:1px solid var(--border); border-radius:4px; padding:6px 10px; color:var(--text2); font:400 11px var(--sans); transition:border-color 0.2s; }
.wiz-list-input:focus { border-color:var(--cyan); outline:none; }

.wiz-frameworks { display:grid; grid-template-columns:repeat(4,1fr); gap:4px 12px; }
@media (max-width:600px) { .wiz-frameworks { grid-template-columns:repeat(2,1fr); } }
.wiz-fw-label { font:400 11px var(--mono); color:var(--text2); display:flex; align-items:center; gap:6px; cursor:pointer; }

.wiz-spinner { width:24px; height:24px; border:3px solid var(--border); border-top-color:var(--cyan); border-radius:50%; animation:wizSpin 0.8s linear infinite; margin:0 auto; }
@keyframes wizSpin { to { transform:rotate(360deg); } }

/* ── Adversarial Probe Generator ──────────────── */
.probe-header { display:flex; align-items:center; justify-content:space-between; padding:0 0 16px; border-bottom:1px solid var(--border); margin-bottom:20px; }
.probe-launch-panel { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:24px; }
@media (max-width:800px) { .probe-launch-panel { grid-template-columns:1fr; } }
.probe-form { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:20px; }
.probe-label { display:block; font:600 10px var(--mono); color:var(--muted); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:6px; }
.probe-select { width:100%; background:var(--bg); border:1px solid var(--border); border-radius:4px; padding:8px 10px; font:400 12px var(--mono); color:var(--text); }
.probe-count-row { display:flex; align-items:center; gap:12px; }
.probe-slider { flex:1; -webkit-appearance:none; height:4px; background:var(--border); border-radius:2px; outline:none; }
.probe-slider::-webkit-slider-thumb { -webkit-appearance:none; width:16px; height:16px; border-radius:50%; background:var(--cyan); cursor:pointer; }
.probe-count-val { font:700 16px var(--mono); color:var(--cyan); min-width:28px; text-align:center; }
.probe-run-btn { width:100%; margin-top:16px; padding:12px; background:var(--cyan); color:#000; border:none; border-radius:6px; font:700 12px var(--mono); letter-spacing:1px; cursor:pointer; transition:all 0.2s; }
.probe-run-btn:hover { background:var(--cyanHover); transform:translateY(-1px); }
.probe-run-btn:disabled, .probe-run-btn.running { opacity:0.6; cursor:wait; }
.probe-info-card { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:20px; }
.probe-info-title { font:700 11px var(--mono); color:var(--text); margin-bottom:16px; text-transform:uppercase; letter-spacing:0.5px; }
.probe-info-step { display:flex; align-items:flex-start; gap:10px; margin-bottom:12px; font:400 11px var(--mono); color:var(--muted); line-height:1.5; }
.probe-step-num { flex-shrink:0; width:22px; height:22px; border-radius:50%; background:var(--cyan); color:#000; display:flex; align-items:center; justify-content:center; font:700 10px var(--mono); }

/* Progress */
.probe-progress-bar { height:4px; background:var(--border); border-radius:2px; overflow:hidden; margin-bottom:8px; }
.probe-progress-fill { height:100%; background:var(--cyan); border-radius:2px; transition:width 0.3s; width:0; }
.probe-progress-text { font:400 11px var(--mono); color:var(--muted); text-align:center; }

/* Report */
.probe-report-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.probe-report-title { font:700 13px var(--mono); color:var(--text); margin:0; }
.probe-report-time { font:400 10px var(--mono); color:var(--muted); }
.probe-summary-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:20px; }
@media (max-width:700px) { .probe-summary-grid { grid-template-columns:repeat(2,1fr); } }
.probe-summary-card { background:var(--bg2); border:1px solid var(--border); border-radius:8px; padding:16px; text-align:center; }
.probe-sum-label { font:600 9px var(--mono); color:var(--muted); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:6px; }
.probe-sum-value { font:700 24px var(--mono); }

/* Vulnerabilities */
.probe-vuln-section { background:rgba(255,68,68,0.05); border:1px solid rgba(255,68,68,0.2); border-radius:8px; padding:16px; margin-bottom:20px; }
.probe-vuln-title { font:700 11px var(--mono); color:var(--red); margin:0 0 12px; }
.probe-vuln-row { display:flex; gap:10px; padding:10px 0; border-bottom:1px solid rgba(255,255,255,0.05); }
.probe-vuln-row:last-child { border-bottom:none; }
.probe-vuln-detail { flex:1; min-width:0; }
.probe-vuln-prompt { font:400 11px var(--mono); color:var(--text); margin-bottom:4px; word-break:break-word; }
.probe-vuln-meta { font:400 9px var(--mono); color:var(--muted); display:flex; gap:6px; flex-wrap:wrap; }

/* Severity badges */
.probe-sev-badge { display:inline-block; padding:2px 6px; border-radius:3px; font:700 8px var(--mono); text-transform:uppercase; letter-spacing:0.5px; }
.probe-sev-low { background:rgba(var(--accent-rgb,6,182,212),0.15); color:var(--cyan); }
.probe-sev-medium { background:rgba(245,158,11,0.15); color:var(--amber); }
.probe-sev-high { background:rgba(239,68,68,0.15); color:var(--red); }
.probe-sev-critical { background:rgba(255,0,0,0.2); color:#ff4444; }

/* Category breakdown */
.probe-breakdown-section { margin-bottom:20px; }
.probe-breakdown-title { font:700 11px var(--mono); color:var(--text); margin:0 0 12px; }
.probe-breakdown-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:10px; }
.probe-cat-card { background:var(--bg2); border:1px solid var(--border); border-radius:6px; padding:12px; }
.probe-cat-name { font:700 9px var(--mono); color:var(--muted); text-transform:uppercase; margin-bottom:8px; }
.probe-cat-bar { height:4px; background:var(--border); border-radius:2px; overflow:hidden; margin-bottom:6px; }
.probe-cat-fill { height:100%; border-radius:2px; transition:width 0.5s; }
.probe-cat-stats { font:400 10px var(--mono); color:var(--muted); }

/* Results table */
.probe-results-section { margin-bottom:20px; }
.probe-results-title { font:700 11px var(--mono); color:var(--text); margin:0 0 12px; }
.probe-results-table { background:var(--bg2); border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.probe-table-header { display:flex; gap:8px; padding:10px 12px; background:var(--bg3); border-bottom:1px solid var(--border); }
.probe-th { font:700 9px var(--mono); color:var(--muted); text-transform:uppercase; }
.probe-table-row { display:flex; gap:8px; padding:8px 12px; border-bottom:1px solid rgba(255,255,255,0.03); font:400 10px var(--mono); color:var(--text); align-items:center; }
.probe-table-row:hover { background:rgba(255,255,255,0.02); }
.probe-td { }
.probe-verdict { padding:2px 6px; border-radius:3px; font:700 8px var(--mono); text-transform:uppercase; }
.probe-verdict-certified { background:rgba(var(--accent-rgb,6,182,212),0.15); color:var(--cyan); }
.probe-verdict-flagged { background:rgba(245,158,11,0.15); color:var(--amber); }
.probe-verdict-failed { background:rgba(239,68,68,0.15); color:var(--red); }

/* Risk badges */
.probe-risk-badge { display:inline-block; padding:2px 8px; border-radius:3px; font:700 9px var(--mono); text-transform:uppercase; }
.probe-risk-low { background:rgba(34,197,94,0.15); color:var(--green); }
.probe-risk-medium { background:rgba(245,158,11,0.15); color:var(--amber); }
.probe-risk-high { background:rgba(239,68,68,0.15); color:var(--red); }
.probe-risk-critical { background:rgba(255,0,0,0.2); color:#ff4444; }

/* History */
.probe-history { margin-top:24px; }
.probe-history-title { font:700 11px var(--mono); color:var(--text); margin:0 0 12px; }
.probe-history-list { background:var(--bg2); border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.probe-history-row { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid rgba(255,255,255,0.03); cursor:pointer; transition:background 0.15s; }
.probe-history-row:hover { background:rgba(255,255,255,0.02); }
.probe-history-row:last-child { border-bottom:none; }
.probe-hist-left { display:flex; align-items:center; gap:10px; }
.probe-hist-name { font:500 11px var(--mono); color:var(--text); }
.probe-hist-rate { font:400 10px var(--mono); color:var(--muted); }
.probe-hist-right { display:flex; align-items:center; gap:12px; }
.probe-hist-stats { font:400 10px var(--mono); }
.probe-hist-date { font:400 10px var(--mono); color:var(--muted); }
