body { font:400 15px/1.6 var(--sans); letter-spacing:0.01em; background:var(--bg); color:var(--text2); min-height:100vh; display:flex; flex-direction:column; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
::-webkit-scrollbar { width:4px; } ::-webkit-scrollbar-track { background:transparent; } ::-webkit-scrollbar-thumb { background:var(--border2); border-radius:4px; }

/* ── Header ─────────────────────────────────── */
.header { background:var(--surface); border-bottom:1px solid var(--border); padding:0 24px; height:48px; display:flex; align-items:center; justify-content:space-between; flex-shrink:0; }
.brand-block { display:flex; align-items:center; flex-shrink:0; }
.brand-accent-line { display:none; }
.logo-shield { flex-shrink:0; margin-right:10px; }
.logo { font:700 18px 'IBM Plex Mono',monospace; letter-spacing:3px; color:#F1F5F9; white-space:nowrap; }
.logo span { color:#06B6D4; }
.logo-sub { font:400 10px var(--mono); color:var(--muted); letter-spacing:2px; margin-left:14px; padding-left:14px; border-left:1px solid var(--border); opacity:0.7; white-space:nowrap; }
.header-center { display:flex; align-items:center; justify-content:center; flex:1; min-width:0; }
.header-right { display:flex; align-items:center; gap:12px; flex-shrink:0; }

/* User menu dropdown */
.hdr-user-menu { position:relative; }
.hdr-user-avatar { width:30px; height:30px; border-radius:50%; background:var(--bg3); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font:700 12px var(--mono); color:var(--cyan); cursor:pointer; transition:all 0.2s; user-select:none; }
.hdr-user-avatar:hover { border-color:var(--cyan); }
.hdr-user-dd { display:none; position:absolute; top:calc(100% + 8px); right:0; background:var(--surface); border:1px solid var(--border); border-radius:8px; min-width:200px; box-shadow:0 12px 40px rgba(0,0,0,0.4); z-index:3000; overflow:hidden; }
.hdr-user-dd.open { display:block; animation:hdrDdIn 0.15s ease-out; }
@keyframes hdrDdIn { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:translateY(0); } }
.hdr-dd-info { padding:12px 14px; }
.hdr-dd-sep { height:1px; background:var(--border); }
.hdr-dd-item { display:flex; align-items:center; justify-content:space-between; padding:8px 14px; font:400 12px var(--sans); color:var(--text2); cursor:pointer; transition:background 0.15s; text-decoration:none; }
.hdr-dd-item:hover { background:var(--bg3); color:var(--text); }
.hdr-dd-logout { color:var(--red); }
.hdr-dd-logout:hover { background:rgba(239,68,68,0.08); }

/* Status line */
.hdr-status-line { display:flex; align-items:center; justify-content:center; gap:0; background:var(--bg1); border-bottom:1px solid var(--border); padding:0 24px; height:22px; font:400 10px var(--mono); color:var(--muted); flex-shrink:0; }
.sl-item { letter-spacing:0.5px; }
.sl-clickable { cursor:pointer; border-radius:3px; padding:1px 4px; margin:-1px -4px; transition:background 0.15s,color 0.15s; }
.sl-clickable:hover { background:rgba(6,182,212,0.12); color:var(--cyan); }
.sl-sep { margin:0 8px; opacity:0.4; }

/* Legacy badge styles (still used by JS) */
.provider-badge { font:500 10px var(--mono); padding:2px 8px; border-radius:20px; letter-spacing:1px; white-space:nowrap; flex-shrink:0; }
.provider-live { background:var(--green-dim); color:var(--green); border:1px solid rgba(0,230,138,0.2); }
.provider-sim { background:var(--amber-dim); color:var(--amber); border:1px solid rgba(255,179,71,0.2); }
.mode-badge { font:600 10px var(--mono); padding:2px 8px; border-radius:20px; letter-spacing:1px; background:var(--brand-primary-dim); color:var(--brand-primary); border:1px solid rgba(var(--accent-rgb),0.2); white-space:nowrap; flex-shrink:0; }
.lockdown-badge { background:var(--red-dim); color:var(--red); border:1px solid rgba(255,71,87,0.2); }
.user-badge { font:400 10px var(--mono); color:var(--muted); white-space:nowrap; flex-shrink:1; overflow:hidden; text-overflow:ellipsis; }
.role-badge { font:600 10px var(--mono); padding:2px 8px; border-radius:20px; letter-spacing:1px; white-space:nowrap; flex-shrink:1; overflow:hidden; text-overflow:ellipsis; }
.viewer-badge { background:var(--amber-dim); color:var(--amber); border:1px solid rgba(255,179,71,0.2); }
.sandbox-badge { background:var(--amber-dim); color:var(--amber); border:1px solid rgba(255,179,71,0.2); }
.tier-badge { font:700 10px var(--mono); padding:2px 8px; border-radius:20px; letter-spacing:1px; cursor:default; white-space:nowrap; flex-shrink:1; overflow:hidden; text-overflow:ellipsis; }
.tier-starter, .tier-certified { background:var(--cyan-dim); color:var(--cyan); border:1px solid rgba(6,182,212,0.3); }
.tier-professional, .tier-plus { background:rgba(165,228,255,0.12); color:#A5E4FF; border:1px solid rgba(165,228,255,0.3); }
.tier-enterprise, .tier-elite { background:rgba(212,165,6,0.12); color:#D4A506; border:1px solid rgba(212,165,6,0.3); animation:tierShimmer 3s ease-in-out infinite; }
@keyframes tierShimmer { 0%,100%{opacity:1} 50%{opacity:.8;text-shadow:0 0 6px rgba(255,215,0,0.4)} }
.header-badges { display:none; }
.header-actions { display:none; }
.docs-link { font:600 10px var(--mono);color:var(--text3);text-decoration:none;letter-spacing:1px;padding:2px 8px;border:1px solid var(--border);border-radius:20px;transition:all .2s;white-space:nowrap;flex-shrink:0; }
.docs-link:hover { color:var(--cyan); border-color:var(--cyan); }
.tab-locked { position:relative; opacity:.55; }
.tab-locked::after { content:'\1F512'; font-size:9px; margin-left:3px; }
.upgrade-overlay { position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;background:var(--bg);backdrop-filter:blur(8px);border-radius:8px; }
.quota-bar { height:6px;border-radius:3px;background:rgba(255,255,255,0.08);overflow:hidden;margin-top:8px; }
.quota-fill { height:100%;border-radius:3px;transition:width .3s; }
.sandbox-banner {
  background:var(--amber-dim); border-bottom:1px solid rgba(255,179,71,0.15);
  padding:6px 24px; font:400 11px var(--mono); color:var(--amber);
  text-align:center; letter-spacing:0.5px; flex-shrink:0;
}

/* ── Layout ─────────────────────────────────── */
.main { flex:1; display:flex; flex-direction:column; overflow:hidden; }
.tabs { background:var(--surface); border-bottom:1px solid var(--border); display:flex; padding:0 24px; gap:0; flex-shrink:0; position:relative; align-items:flex-end; }
.nav-group { display:flex; align-items:flex-end; position:relative; }
.nav-group-label { position:absolute; top:2px; left:18px; font:600 9px var(--sans); letter-spacing:2px; color:var(--muted); text-transform:uppercase; pointer-events:none; }
.nav-sep { width:1px; height:20px; background:var(--border2); margin:0 4px; align-self:center; flex-shrink:0; opacity:0.5; }
.tab { font:500 11px var(--sans); padding:12px 18px; color:var(--text3); cursor:pointer; border-bottom:2px solid transparent; transition:color 0.2s ease, border-color 0.2s ease; letter-spacing:0.3px; white-space:nowrap; text-transform:uppercase; }
.tab:hover { color:var(--text2); }
.tab.active { color:var(--text); border-bottom-color:var(--brand-primary); }
.tab-more { position:relative; font:500 11px var(--sans); padding:12px 18px; color:var(--text3); cursor:pointer; border-bottom:2px solid transparent; transition:color 0.2s ease, border-color 0.2s ease; letter-spacing:0.3px; white-space:nowrap; text-transform:uppercase; user-select:none; }
.tab-more:hover { color:var(--text2); }
.tab-more.has-active { color:var(--brand-primary); border-bottom-color:var(--brand-primary); }
.more-dropdown { display:none; position:absolute; top:100%; left:0; min-width:180px; background:var(--surface); border:1px solid var(--border); border-radius:0 0 8px 8px; box-shadow:0 8px 24px rgba(0,0,0,0.3); z-index:100; padding:4px 0; }
.more-dropdown.open { display:block; }
.more-dropdown .tab { display:block; padding:10px 18px; border-bottom:none; white-space:nowrap; }
.more-dropdown .tab:hover { background:var(--bg3); color:var(--text); }
.more-dropdown .tab.active { color:var(--brand-primary); background:var(--bg3); border-bottom:none; }
.content { flex:1; overflow-y:auto; padding:20px 24px; }

/* ── Login ──────────────────────────────────── */
.login-overlay { position:fixed; inset:0; background:var(--bg); display:flex; align-items:center; justify-content:center; z-index:1000; }
.login-box { background:var(--bg2); border:1px solid var(--border); border-radius:16px; padding:40px; width:380px; text-align:center; }
.login-box h1 { font:700 18px 'IBM Plex Mono',monospace; letter-spacing:3px; color:#F1F5F9; margin-bottom:4px; }
.login-box h1 span { color:#06B6D4; }
.login-box p { font:400 11px var(--mono); color:var(--muted); margin-bottom:24px; letter-spacing:1px; }
.login-box input { width:100%; background:var(--bg3); border:1px solid var(--border); border-radius:8px; padding:12px 16px; color:var(--text); font:400 12px var(--sans); margin-bottom:12px; outline:none; }
.login-box input:focus { border-color:var(--brand-primary); }
.login-box .btn { width:100%; padding:12px; margin-top:8px; }
.login-error { color:var(--red); font:400 11px var(--mono); margin-top:8px; }

/* ── Footer ─────────────────────────────────── */
.footer { background:var(--surface); border-top:1px solid var(--border); padding:6px 24px; display:flex; justify-content:space-between; align-items:center; flex-shrink:0; }
.footer span { font:400 10px var(--mono); color:var(--muted); letter-spacing:0.5px; }

/* ── Responsive ─────────────────────────────── */
@media(min-width:1920px) { .kpi-grid { grid-template-columns:repeat(7,1fr); } .grid-2 { gap:16px; } }
@media(max-width:1440px) and (min-width:1201px) { .kpi-grid { grid-template-columns:repeat(7,1fr); gap:10px; } .content { padding:16px 20px; } }
@media(max-width:1200px) { .kpi-grid { grid-template-columns:repeat(3,1fr); } }
@media(max-width:768px) { .kpi-grid { grid-template-columns:repeat(2,1fr); } .grid-2,.grid-3 { grid-template-columns:1fr; } }

/* ── Responsive Tablet (1024px) ────────────── */
@media(max-width:1024px) {
  .header { padding:8px 12px; }
  .header-badges { gap:4px; }
  .header-actions { gap:6px; }
  .tabs { flex-wrap:wrap; gap:2px; padding:4px 12px; }
  .tab { font-size:11px; padding:8px 10px; }
  .kpi-grid { grid-template-columns:repeat(3,1fr); gap:8px; }
  .kpi-value { font:300 32px var(--mono); }
  .grid-2 { grid-template-columns:1fr; }
  .grid-3 { grid-template-columns:1fr 1fr; }
  .panel { margin-bottom:12px; }
  .heatmap-table { font-size:11px; }
  .posture-grid { grid-template-columns:1fr; }
  .cmd-box { width:90vw; }
  .nc-panel { width:100vw; }
  .cert-detail-panel { width:100% !important; }
}

/* ── Tab transitions ───────────────────────── */
.tab-content { transition:opacity 0.15s ease-out; position:relative; z-index:1; isolation:isolate; }

/* ── Print stylesheet ────────────────────── */
@media print {
  /* ── Base: white background, exact colors ── */
  body { margin:0 !important; padding:0 !important; background:#fff !important; color:#000 !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  * { box-shadow:none !important; text-shadow:none !important; -webkit-print-color-adjust:exact !important; print-color-adjust:exact !important; }

  /* ── HIDE ALL APP CHROME — only .print-active content shows ── */
  .header, #appHeader,
  .tabs, #appTabs,
  .mode-bar, #modeBar,
  .sub-nav, #subNav,
  .configure-sidebar, #configSidebar,
  .sandbox-banner, #sandboxBanner,
  .vp-lead-banner, #vpLeadBanner,
  .lead-notif-badge, #vpLeadHeaderWrap,
  .notif-bell, #notifBell,
  .nc-panel, #ncPanel,
  .theme-toggle,
  #loginOverlay, #onboardModal, #keyboardHelp,
  .export-wrap, .cross-links, .context-bar, .help-tip,
  .tut-hud, #tutHud, .tut-chapter-menu, .tut-spotlight,
  [class*="journey-hud"], [id*="journeyHud"],
  .role-badge, .tier-badge,
  .toast, .toast-container { display:none !important; }

  /* ── Show only the print-active tab ── */
  .content { overflow:visible !important; padding:10px !important; }
  .tab-content { display:none !important; }
  .tab-content.print-active { display:block !important; overflow:visible !important; }

  /* ── Within compliance tab: hide controls, show only content ── */
  .tab-content.print-active .st-launcher { display:none !important; }
  .tab-content.print-active .tab-subtitle { display:none !important; }
  .tab-content.print-active .cg-galaxy-header select { display:none !important; }
  .main { overflow:visible !important; }

  /* ── Card layout: never split across pages ── */
  .panel { break-inside:avoid; border:1px solid #ddd !important; }
  .cg-constellation-card { page-break-inside:avoid !important; break-inside:avoid !important; margin-bottom:8px; overflow:visible !important; border:1px solid #ccc !important; background:#fff !important; }
  .cg-star-field { page-break-before:auto; grid-template-columns:1fr 1fr !important; padding-bottom:40px; }
  /* Orphaned last card (odd count): center it */
  .cg-constellation-card:last-child:nth-child(odd) { grid-column:1 / -1; max-width:48%; margin:0 auto; }

  /* ── Card text: print-safe colors ── */
  .cg-card-name { color:#000 !important; font-size:12px !important; }
  .cg-card-posture { color:#000 !important; font-size:20px !important; }
  .cg-card-reg { color:#333 !important; }
  .cg-card-stats { color:#555 !important; }
  .cg-card-bar { border:1px solid #ccc !important; }

  /* ── SVG constellations: preserve colors ── */
  .cg-card-svg svg { display:block; margin:0 auto; }
  .cg-card-svg svg circle, .cg-card-svg svg line { -webkit-print-color-adjust:exact; print-color-adjust:exact; }

  /* ── Stress test: table + recommendations flush alignment ── */
  .st-results, .st-rec-card { width:100% !important; max-width:100% !important; margin-left:0 !important; margin-right:0 !important; box-sizing:border-box !important; overflow:visible !important; background:#fff !important; border:1px solid #ccc !important; }
  .st-results { border-radius:6px 6px 0 0 !important; margin-bottom:0 !important; border-bottom:none !important; }
  .st-rec-card { border-radius:0 0 6px 6px !important; margin-top:0 !important; padding:16px 20px !important; }
  .st-results-header { padding:16px 20px !important; }
  .st-table-header, .st-row { padding:10px 20px !important; }
  .st-row-expanded { padding-left:20px !important; padding-right:20px !important; }
  .st-rec-card, .st-results { page-break-inside:avoid !important; break-inside:avoid !important; }
  .st-results-header, .st-results-title, .st-results-meta { color:#000 !important; }
  .st-score-val { color:#000 !important; }
  .st-table-header { color:#555 !important; }
  .st-row { color:#222 !important; border-bottom:1px solid #ddd !important; }
  .st-rec-title { color:#B45309 !important; }
  .st-rec-item { border-bottom:1px solid #ddd !important; }
  .st-rec-item:last-child { border-bottom:none !important; }
  .st-rec-action { color:#333 !important; }
  .st-rec-action .cross-link { display:none !important; }

  /* ── Footer: below content, never overlap ── */
  .footer { position:relative !important; display:block !important; clear:both; margin-top:24px; padding-top:16px; border-top:1px solid #ccc !important; page-break-inside:avoid; page-break-before:auto; }
  .footer span, .footer a { color:#333 !important; }

  /* ── KPIs & badges ── */
  .kpi { border:1px solid #ddd !important; }
  .kpi-value { font-size:32px !important; }
  .badge { border:1px solid currentColor !important; }
  a { text-decoration:underline; }
}

/* ── Mode Navigation Bar ──────────────────────── */
.mode-bar { display:flex; align-items:center; background:var(--surface); border-bottom:1px solid var(--border); padding:0 24px; gap:0; flex-shrink:0; }
.mode-btn { font:600 13px var(--sans); padding:12px 24px; color:var(--text3); cursor:pointer; border:none; background:none; border-bottom:3px solid transparent; transition:color 0.2s, border-color 0.2s; letter-spacing:1.5px; text-transform:uppercase; user-select:none; }
.mode-btn:hover { color:var(--text2); }
.mode-btn.active { color:var(--text); border-bottom-color:var(--brand-primary); }
.mode-sep { width:1px; height:20px; background:var(--border2); margin:0 2px; opacity:0.4; }

/* ── Sub-nav (horizontal, for Monitor + Investigate) ── */
.sub-nav { display:flex; align-items:center; background:var(--bg); border-bottom:1px solid var(--border); padding:0 24px; gap:0; flex-shrink:0; overflow-x:auto; }
.sub-nav:empty { display:none; }
.sub-nav-dot { color:var(--muted); font-size:10px; padding:0 6px; user-select:none; }
.sub-nav-item { font:500 11px var(--sans); padding:8px 14px; color:var(--text3); cursor:pointer; border:none; background:none; border-bottom:2px solid transparent; transition:color 0.15s, border-color 0.15s; letter-spacing:0.3px; white-space:nowrap; }
.sub-nav-item:hover { color:var(--text2); }
.sub-nav-item.active { color:var(--text); border-bottom-color:var(--brand-primary); }

/* ── Configure Sidebar ───────────────────────── */
.configure-layout { flex-direction:row !important; min-height:0 !important; flex:1 !important; }
.configure-layout > .configure-sidebar { flex:0 0 220px !important; overflow-y:auto !important; }
.configure-layout > .content { flex:1 1 auto !important; min-width:0 !important; min-height:0 !important; overflow-y:auto !important; }
.configure-sidebar { background:var(--bg); border-right:1px solid var(--border); display:none; flex-direction:column; }
.configure-sidebar.visible { display:flex; }
.cfg-sidebar-header { padding:16px; border-bottom:1px solid var(--border); flex-shrink:0; }
.cfg-sidebar-title { font:700 11px var(--mono); letter-spacing:2px; color:var(--text); margin-bottom:4px; }
.cfg-sidebar-sub { font:400 11px var(--mono); color:var(--text3); }
.cfg-section-label { font:600 9px var(--sans); letter-spacing:2px; color:var(--muted); text-transform:uppercase; padding:14px 16px 6px; }
.cfg-section-label:first-child { padding-top:12px; }
.cfg-nav-item { display:flex; align-items:center; gap:10px; padding:10px 16px; cursor:pointer; border-left:3px solid transparent; transition:all 0.2s; font:400 12px var(--sans); color:var(--text3); letter-spacing:0.2px; }
.cfg-nav-item:hover { background:var(--bg2); color:var(--text); }
.cfg-nav-item.active { background:var(--bg2); border-left-color:var(--cyan); color:var(--text); font-weight:500; }
.cfg-nav-icon { font-size:14px; width:18px; text-align:center; opacity:0.7; }

/* ── Command Center — Mission Control fullscreen ── */
.cc-fullscreen { position:fixed!important; inset:0!important; z-index:999!important; background:var(--bg)!important; overflow-y:auto!important; padding:12px!important; margin:0!important; max-width:none!important; }
.cc-fullscreen .cc-grid { height:calc(100vh - 24px); }
body.cc-fs-active .sidebar, body.cc-fs-active .header, body.cc-fs-active .top-bar { display:none!important; }
body.cc-fs-active .main { margin:0!important; padding:0!important; }
