/* ═══════════════════════════════════════════════════════════════════════════
   panels.css — Tab visibility rules, outages, networks, endpoints,
                projects, reports tabs
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Tab visibility — hide all Clients-only UI unless on clients tab ── */
body:not(.nrt-tab-clients) .page-hdr,
body:not(.nrt-tab-clients) #stats-grid,
body:not(.nrt-tab-clients) #filter-bar,
body:not(.nrt-tab-clients) #view-toggle-bar,
body:not(.nrt-tab-clients) .tbl-hdr-wrap,
body:not(.nrt-tab-clients) #attention-bar,
body:not(.nrt-tab-clients) #client-list,
body:not(.nrt-tab-clients) .stat-cfg-btn,
body:not(.nrt-tab-clients) #dot-legend-inline{display:none!important}

/* ── Clients tab — explicit show ─────────────────────────────────── */
body.nrt-tab-clients .page-hdr{display:flex!important;align-items:center!important}
body.nrt-tab-clients #stats-grid{display:grid!important}
body.nrt-tab-clients #filter-bar{display:flex!important}
body.nrt-tab-clients #view-toggle-bar{display:flex!important}
body.nrt-tab-clients .tbl-hdr-wrap{display:block!important}
body.nrt-tab-clients #attention-bar{display:block!important}
body.nrt-tab-clients #client-list{display:block!important}
body.nrt-tab-clients .stat-cfg-btn{display:block!important}
body.nrt-tab-clients #dot-legend-inline{display:flex!important}

/* ── Tab content panels — default hidden ──────────────────────────── */
#outages-view,#endpoints-view,#networks-view,#projects-view,#reports-view,#alerts-view{display:none!important}
body.nrt-tab-outages   #outages-view  {display:block!important}
body.nrt-tab-networks  #networks-view {display:block!important}
body.nrt-tab-endpoints #endpoints-view{display:block!important}
body.nrt-tab-reports   #reports-view  {display:block!important}
body.nrt-tab-projects  #projects-view {display:block!important}
body.nrt-tab-alerts    #alerts-view   {display:block!important}

/* ════════════════════════════════════════════════════════════════════
   ALERTS TAB — email triage panel
   ════════════════════════════════════════════════════════════════════ */
.alrt-wrap{padding:0 0 80px}

/* Summary bar */
.alrt-summary-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:10px 24px 8px;border-bottom:1px solid var(--border2)}
.alrt-sum-chip{border-radius:20px;padding:3px 12px;font-size:12px;font-weight:500;white-space:nowrap}
.alrt-sum-crit{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.3);color:#f87171}
.alrt-sum-warn{background:rgba(245,158,11,.10);border:1px solid rgba(245,158,11,.28);color:#fbbf24}
.alrt-sum-info{background:rgba(59,130,246,.10);border:1px solid rgba(59,130,246,.25);color:#93c5fd}
.alrt-sum-res {background:rgba(34,197,94,.09) ;border:1px solid rgba(34,197,94,.22) ;color:#86efac}
.alrt-sum-sep{flex:1}

/* Filter bar */
.alrt-filter-bar{display:flex;flex-wrap:wrap;gap:6px;padding:10px 24px}

/* Alert groups */
.alrt-group{margin:0 24px 20px;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.alrt-group-hdr{padding:8px 16px;font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.alrt-gh-critical{background:rgba(239,68,68,.10);color:#f87171;border-bottom:1px solid rgba(239,68,68,.2)}
.alrt-gh-warning {background:rgba(245,158,11,.08);color:#fbbf24;border-bottom:1px solid rgba(245,158,11,.18)}
.alrt-gh-info    {background:rgba(59,130,246,.08);color:#93c5fd;border-bottom:1px solid rgba(59,130,246,.15)}
.alrt-gh-resolved{background:rgba(34,197,94,.07) ;color:#86efac;border-bottom:1px solid rgba(34,197,94,.15)}
.alrt-gh-cnt{background:rgba(255,255,255,.08);border-radius:10px;padding:1px 8px;font-size:11px}

/* Alert rows */
.alrt-row{display:flex;align-items:stretch;border-bottom:1px solid var(--border2);transition:background .1s}
.alrt-row:last-child{border-bottom:none}
.alrt-row:hover{background:var(--row-hover)}
.alrt-sev-strip{width:4px;flex-shrink:0}
.alrt-sev-critical .alrt-sev-strip{background:#ef4444}
.alrt-sev-warning  .alrt-sev-strip{background:#f59e0b}
.alrt-sev-info     .alrt-sev-strip{background:#3b82f6}
.alrt-sev-resolved .alrt-sev-strip{background:#22c55e}
.alrt-st-acknowledged{opacity:.7}
.alrt-st-suppressed{opacity:.45}
.alrt-body{padding:12px 16px;flex:1;min-width:0}
.alrt-top{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}
.alrt-client-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.alrt-source{font-size:11px;color:var(--text4);font-weight:500}
.alrt-bull{color:var(--text4);font-size:11px}
.alrt-client{font-size:12px;color:var(--text2);font-weight:600}
.alrt-age{font-size:11px;color:var(--text4);margin-left:auto}
.alrt-title{font-size:13px;font-weight:600;color:var(--text1);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.alrt-summary{font-size:11px;color:var(--text4);margin-bottom:6px;line-height:1.5;max-width:72ch}

/* State tag */
.alrt-state-tag{font-size:10px;padding:1px 7px;border-radius:10px;font-weight:500;white-space:nowrap}
.alrt-state-new        {background:rgba(99,102,241,.15);color:#a5b4fc;border:1px solid rgba(99,102,241,.25)}
.alrt-state-ticketed   {background:rgba(59,130,246,.12);color:#93c5fd;border:1px solid rgba(59,130,246,.22)}
.alrt-state-acknowledged{background:rgba(107,114,128,.12);color:#9ca3af;border:1px solid rgba(107,114,128,.22)}
.alrt-state-resolved   {background:rgba(34,197,94,.10);color:#86efac;border:1px solid rgba(34,197,94,.2)}
.alrt-state-suppressed {background:rgba(107,114,128,.08);color:#6b7280;border:1px solid rgba(107,114,128,.15)}

/* Action buttons */
.alrt-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.alrt-act-btn{background:var(--bg3);border:1px solid var(--border);border-radius:5px;color:var(--text2);font-size:11px;padding:3px 10px;cursor:pointer;transition:background .15s}
.alrt-act-btn:hover{background:var(--row-hover);color:var(--text1)}
.alrt-sup-btn{opacity:.5}
.alrt-sup-btn:hover{opacity:1;color:#ef4444;border-color:#ef4444}

/* Empty state */
.alrt-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;gap:12px;color:var(--text4);text-align:center}
.alrt-empty p{font-size:13px;margin:0}

/* Spin keyframe (for refresh button) */
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

/* ── Outage map ──────────────────────────────────────────────────── */
.outage-map-section{margin:0 12px 16px;border:1px solid var(--border);border-radius:10px;overflow:visible}
.outage-map-hdr{padding:10px 14px;background:var(--card-bg);border-bottom:1px solid var(--border);font-size:11px;color:var(--text4);text-transform:uppercase;letter-spacing:.08em;display:flex;justify-content:space-between;align-items:center}
#outage-map{width:auto;height:auto;border-radius:8px;overflow:visible;background:#0a1628;position:relative}
.svg-map{width:100%;height:100%}
.map-marker{cursor:pointer;transition:transform .15s}
.map-marker:hover{transform:scale(1.4)}
.map-label{font-size:9px;fill:var(--text3);pointer-events:none;font-family:var(--font)}
.map-marker-dot{transition:all .2s}

/* ── Outages tab ─────────────────────────────────────────────────── */
#outages-view{display:none;padding:0 0 32px}
#outages-view.active{display:block}
.outage-section{padding:16px 24px 0}
.outage-section-title{font-size:11px;color:var(--text4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.outage-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-bottom:8px}
.outage-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;position:relative;overflow:hidden;transition:border-color .15s}
.outage-card.ok{border-left:3px solid var(--live)}
.outage-card.degraded{border-left:3px solid var(--pend)}
.outage-card.down{border-left:3px solid #ef4444}
.outage-card.manual{border-left:3px solid #8b5cf6}
.outage-card.unknown{border-left:3px solid var(--border)}
.oc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.oc-name{font-size:13px;font-weight:600;color:var(--text)}
.oc-badge{border-radius:10px;padding:2px 9px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.oc-badge.ok{background:rgba(34,197,94,.15);color:var(--live)}
.oc-badge.degraded{background:rgba(245,158,11,.15);color:var(--pend)}
.oc-badge.down{background:rgba(239,68,68,.15);color:#f87171}
.oc-badge.manual{background:rgba(139,92,246,.15);color:#c084fc}
.oc-badge.unknown{background:var(--border);color:var(--text4)}
.oc-meta{font-size:11px;color:var(--text4);margin-bottom:6px}
.oc-affected{font-size:11px;color:var(--text3)}
.oc-affected strong{color:var(--pend)}
.oc-affected.all-ok{color:var(--text4)}
.oc-actions{display:flex;gap:6px;margin-top:10px}
.outage-setup-banner{margin:16px 24px;padding:16px 20px;background:rgba(139,92,246,.08);border:1px solid rgba(139,92,246,.25);border-radius:10px;font-size:13px;color:#c084fc;display:flex;gap:14px;align-items:flex-start}
.outage-setup-banner svg{flex-shrink:0;margin-top:1px}
.setup-steps{margin-top:8px;font-size:12px;color:var(--text3);line-height:1.8}
.setup-steps strong{color:var(--text2)}
.outage-log{margin:0 24px;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.outage-log-header{padding:10px 14px;background:var(--card-bg);border-bottom:1px solid var(--border);font-size:11px;color:var(--text4);text-transform:uppercase;letter-spacing:.08em;display:flex;justify-content:space-between}
.outage-log-row{display:grid;grid-template-columns:90px 130px 80px 1fr;gap:12px;padding:9px 14px;border-bottom:1px solid var(--border2);font-size:12px;align-items:center}
.outage-log-row:last-child{border-bottom:none}
.outage-log-row:hover{background:var(--row-hover)}
.ol-time{color:var(--text4)}
.ol-provider{color:var(--text2);font-weight:500}
.ol-status{text-align:center}
.ol-clients{color:var(--text3)}
.outage-report-btn{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border);border-radius:8px;padding:7px 14px;font-size:12px;color:var(--text3);cursor:pointer;transition:all .15s;margin:0 24px 16px}
.outage-report-btn:hover{border-color:var(--accent);color:var(--accent)}

/* Report outage modal */
.outage-form-row{margin-bottom:14px}
.outage-form-label{font-size:12px;color:var(--text4);margin-bottom:6px}
.outage-form-select,.outage-form-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text2);font-size:13px;outline:none}
.outage-form-select:focus,.outage-form-input:focus{border-color:var(--accent)}
.outage-form-select option{background:var(--bg2)}
.outage-form-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text2);font-size:13px;resize:vertical;min-height:70px;outline:none;font-family:inherit}
.outage-form-textarea:focus{border-color:var(--accent)}

/* ── Endpoints tab ───────────────────────────────────────────────── */
#endpoints-view{display:none;padding:0 0 32px}
.ep-summary{display:flex;gap:12px;padding:16px 24px 8px;flex-wrap:wrap}
.ep-stat{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:12px 16px;min-width:110px}
.ep-stat-num{font-size:22px;font-weight:700;color:var(--text)}
.ep-stat-lbl{font-size:11px;color:var(--text4);margin-top:2px}
.ep-ok{color:var(--live)}.ep-warn{color:var(--pend)}.ep-err{color:#f87171}.ep-na{color:var(--text4)}
.ep-wf-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}
.ep-wf-card{display:flex;align-items:center;gap:12px;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:12px 16px}
.ep-wf-icon{font-size:20px;width:32px;text-align:center;flex-shrink:0}
.ep-wf-body{flex:1}
.ep-wf-name{font-size:13px;font-weight:600;color:var(--text2)}
.ep-wf-desc{font-size:11px;color:var(--text4);margin-top:2px}
.ep-wf-badge{font-size:10px;padding:3px 9px;border-radius:10px;font-weight:600;flex-shrink:0}
.ep-badge-ok{background:rgba(34,197,94,.15);color:var(--live)}
.ep-badge-pend{background:rgba(245,158,11,.12);color:var(--pend)}
.ep-table{margin:0 24px;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.ep-row{display:grid;grid-template-columns:1fr 130px 70px 70px 70px 80px;gap:8px;padding:9px 14px;border-bottom:1px solid var(--border2);font-size:12px;align-items:center}
.ep-row:last-child{border-bottom:none}
.ep-row:hover{background:var(--row-hover)}
.ep-hdr{background:var(--card-bg);font-size:10px;color:var(--text4);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.ep-hdr:hover{background:var(--card-bg)}
.ep-section{padding:0 24px}

/* ── Networks tab ────────────────────────────────────────────────── */
.net-setup-banner{margin:16px 24px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;font-size:12px;color:var(--text2);display:flex;gap:12px;align-items:flex-start}
.net-setup-banner svg{flex-shrink:0;margin-top:2px;color:var(--accent)}
.net-setup-banner code{background:var(--bg3);padding:1px 5px;border-radius:4px;font-size:11px}
.net-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(310px,100%),1fr));gap:16px;padding:0 24px 24px;margin-top:8px}
.net-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.net-card-hdr{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg2);border-bottom:1px solid var(--border)}
.net-card-abbr{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;flex-shrink:0}
.net-card-name{flex:1;font-weight:600;color:var(--text);font-size:13px;line-height:1.3}
.net-refresh-btn{background:none;border:none;cursor:pointer;color:var(--text3);font-size:16px;padding:4px;border-radius:4px;transition:color .15s}
.net-refresh-btn:hover{color:var(--accent)}
.net-section-label{font-size:9px;font-weight:700;letter-spacing:.08em;color:var(--text4);padding:8px 14px 4px;text-transform:uppercase}
.net-wan-row{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--border)}
.net-wan-block{padding:8px 14px;border-right:1px solid var(--border)}
.net-wan-block:last-child{border-right:none}
.net-wan-active{background:rgba(34,197,94,.04)}
.net-wan-label{font-size:10px;font-weight:700;color:var(--text3);margin-bottom:4px;display:flex;align-items:center;gap:5px;flex-wrap:wrap;line-height:1.5}
.net-active-pip{background:var(--live);color:#fff;font-size:8px;padding:1px 5px;border-radius:99px;font-weight:700}
.net-starlink-badge{background:rgba(14,165,233,.15);color:#38bdf8;font-size:8px;padding:1px 5px;border-radius:99px;font-weight:700}
.net-wan-ip{font-family:ui-monospace,monospace;font-size:12px;color:var(--text);font-weight:600}
.net-hw-list{padding:4px 14px 10px;border-bottom:1px solid var(--border)}
.net-hw-row{display:flex;align-items:center;gap:8px;padding:3px 0;border-bottom:1px solid var(--border)}
.net-hw-row:last-child{border:none}
.net-hw-model{font-family:ui-monospace,monospace;font-size:11px;color:var(--text);min-width:80px;font-weight:600}
.net-tools-row{display:flex;gap:6px;padding:8px 14px}
.net-tool-btn{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:5px 4px;font-size:11px;color:var(--text2);cursor:pointer;transition:background .15s,color .15s}
.net-tool-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.net-tool-result{margin:0 14px 10px;background:var(--bg3);border-radius:6px;padding:8px 10px;font-size:11px;color:var(--text2);font-family:ui-monospace,monospace;border:1px solid var(--border)}
.net-cfg-panel{margin:12px 24px 0;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.net-cfg-hdr{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg2);cursor:pointer;font-size:12px;font-weight:600;color:var(--text);user-select:none}
.net-cfg-hdr:hover{background:var(--bg3)}
.net-cfg-status{font-size:10px;padding:2px 8px;border-radius:99px;font-weight:700}
.net-cfg-ok{background:rgba(34,197,94,.15);color:#22c55e}
.net-cfg-warn{background:rgba(245,158,11,.15);color:#f59e0b}
.net-cfg-body{display:none;padding:14px 16px;flex-direction:column;gap:8px;background:var(--card-bg)}
.net-cfg-body.open{display:flex}
.net-cfg-row{display:flex;align-items:center;gap:10px}
.net-cfg-label{font-size:11px;color:var(--text3);min-width:80px;flex-shrink:0}
.net-cfg-input{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:11px;color:var(--text);outline:none}
.net-cfg-input:focus{border-color:var(--accent)}
.net-cfg-org-input{max-width:200px;flex:none}
.net-cfg-section-hdr{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text4);padding-top:6px;border-top:1px solid var(--border)}
.net-cfg-actions{display:flex;gap:8px;padding-top:8px;border-top:1px solid var(--border)}
.net-cfg-note{font-size:10px;color:var(--text3);line-height:1.7;padding-top:8px;border-top:1px solid var(--border)}
.net-cfg-note code{background:var(--bg3);padding:1px 4px;border-radius:3px;font-size:9px}
.net-updated{display:block;font-size:9px;color:var(--text4);font-weight:400;margin-top:1px}

/* ── Projects tab ────────────────────────────────────────────────── */
#projects-view{overflow-y:auto;max-height:calc(100vh - 90px)}
.proj-wrap{padding:0 24px 24px}
.proj-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 0 12px}
.proj-hdr span{font-size:14px;font-weight:700;color:var(--text)}
.proj-open-btn{font-size:11px;color:var(--accent);cursor:pointer;padding:5px 10px;border:1px solid var(--accent);border-radius:6px;background:none;transition:background .15s}
.proj-open-btn:hover{background:var(--accent);color:#fff}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.proj-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.proj-card-hdr{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg2);border-bottom:1px solid var(--border)}
.proj-card-info{flex:1;min-width:0}
.proj-card-name{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.proj-card-company{font-size:11px;color:var(--text3);margin-top:1px}
.proj-status-pill{font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px;white-space:nowrap;flex-shrink:0}
.proj-card-body{padding:10px 14px}
.proj-progress-bar{height:6px;background:var(--bg3);border-radius:99px;overflow:hidden;margin-bottom:6px}
.proj-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--text3)}
.proj-loading,.proj-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;text-align:center;color:var(--text3);font-size:13px}
.proj-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Reports tab ─────────────────────────────────────────────────── */
#reports-view{overflow-y:auto;max-height:calc(100vh - 90px)}
.rpt-wrap{padding:0 24px 32px}
.rpt-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 0 10px}
.rpt-hdr span:first-child{font-size:14px;font-weight:700;color:var(--text)}
.rpt-summary{display:flex;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.rpt-stat{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:10px 16px;min-width:100px;flex:1}
.rpt-stat-num{font-size:20px;font-weight:700;color:var(--text)}
.rpt-stat-lbl{font-size:11px;color:var(--text4);margin-top:1px}
.rpt-stat-err .rpt-stat-num{color:#ef4444}
.rpt-stat-warn .rpt-stat-num{color:#f59e0b}
.rpt-stat-ok .rpt-stat-num{color:var(--live)}
.rpt-table{width:100%;border-collapse:collapse;font-size:12px}
.rpt-table th{text-align:left;padding:7px 12px;background:var(--bg2);color:var(--text3);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap}
.rpt-table td{padding:7px 12px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}
.rpt-row:hover td{background:rgba(255,255,255,.02)}
.rpt-cat{font-size:10px;font-weight:700;padding:2px 7px;border-radius:99px}
.rpt-cat-net{background:rgba(6,182,212,.15);color:#06b6d4}
.rpt-cat-ep{background:rgba(168,85,247,.15);color:#a855f7}
.rpt-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px;white-space:nowrap}

/* ── Reports landing page ────────────────────────────────────────── */
.rpt-landing-hdr{display:flex;align-items:center;gap:8px;padding:18px 0 14px;font-size:15px;font-weight:700;color:var(--text);border-bottom:1px solid var(--border);margin-bottom:20px}
.rpt-card-grid{display:flex;flex-direction:column;gap:10px}
.rpt-card{display:flex;align-items:center;gap:14px;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:16px 18px;transition:border-color .15s,background .15s}
.rpt-card:hover{border-color:var(--accent);background:rgba(14,165,233,.04)}
.rpt-card-soon{opacity:.55;cursor:default}
.rpt-card-icon{font-size:24px;width:36px;text-align:center;flex-shrink:0}
.rpt-card-body{flex:1;min-width:0}
.rpt-card-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:3px;display:flex;align-items:center;gap:7px}
.rpt-card-desc{font-size:11px;color:var(--text3);line-height:1.55}
.rpt-card-action{font-size:12px;font-weight:600;color:var(--accent);white-space:nowrap;flex-shrink:0}
.rpt-card-action-dim{color:var(--text4)}
.rpt-soon-badge{font-size:9px;font-weight:700;letter-spacing:.08em;background:rgba(99,102,241,.18);color:#818cf8;padding:2px 6px;border-radius:99px;text-transform:uppercase}

/* ── Report section header ───────────────────────────────────────── */
.rpt-section-hdr{display:flex;align-items:center;gap:12px;padding:14px 0 12px;border-bottom:1px solid var(--border);margin-bottom:16px;font-size:13px;font-weight:700;color:var(--text)}
.rpt-section-hdr span{flex:1}
.rpt-back-btn{background:none;border:1px solid var(--border);color:var(--text3);border-radius:6px;padding:4px 10px;font-size:11px;cursor:pointer;transition:border-color .15s,color .15s}
.rpt-back-btn:hover{border-color:var(--accent);color:var(--accent)}
.rpt-export-btn{background:var(--accent);border:none;color:#fff;border-radius:6px;padding:5px 12px;font-size:11px;font-weight:600;cursor:pointer;transition:opacity .15s}
.rpt-export-btn:hover{opacity:.85}

/* ── Client picker ───────────────────────────────────────────────── */
.rpt-picker-list{display:flex;flex-direction:column;gap:6px}
.rpt-pick-row{display:flex;align-items:center;gap:12px;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:10px 14px;cursor:pointer;transition:border-color .15s}
.rpt-pick-row:hover{border-color:var(--accent)}
.rpt-pick-name{font-size:12px;font-weight:600;color:var(--text);min-width:140px}
.rpt-pick-bar{flex:1;height:5px;background:var(--bg3);border-radius:99px;overflow:hidden}
.rpt-pick-fill{height:100%;background:var(--live);border-radius:99px;transition:width .4s}
.rpt-pick-pct{font-size:11px;font-weight:700;color:var(--text3);min-width:32px;text-align:right}

/* ── Coverage matrix ─────────────────────────────────────────────── */
.rpt-coverage-wrap{overflow-x:auto;border-radius:8px;border:1px solid var(--border)}
.rpt-coverage-table{width:100%;border-collapse:collapse;font-size:11px}
.rpt-coverage-table thead th,.rpt-cov-client-hdr{background:var(--bg2);color:var(--text3);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:8px 6px;border-bottom:1px solid var(--border);white-space:nowrap}
.rpt-coverage-table tbody tr:hover td{background:rgba(255,255,255,.025)}
.rpt-coverage-table td{padding:6px;border-bottom:1px solid rgba(255,255,255,.04);text-align:center;font-weight:600;font-size:11px}
.rpt-cov-client,.rpt-cov-client-hdr{text-align:left!important;padding-left:12px!important;min-width:120px;font-weight:600;color:var(--text2)}
.rpt-cov-th{min-width:72px;max-width:96px}
.rpt-cov-th-lbl{display:block;overflow:hidden;text-overflow:ellipsis;max-width:88px;writing-mode:horizontal-tb}
.rpt-live{color:var(--live)!important;background:rgba(34,197,94,.08)}
.rpt-pend{color:#f59e0b!important;background:rgba(245,158,11,.07)}
.rpt-none{color:var(--text4)!important}
.rpt-cov-foot td,.rpt-cov-foot-lbl{background:var(--bg2)!important;font-size:11px;font-weight:700;padding:7px 6px;border-top:1px solid var(--border)}
.rpt-cov-foot-lbl{text-align:left!important;padding-left:12px!important;color:var(--text3)}

/* ── Client report (printable) ───────────────────────────────────── */
.rpt-client-report{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:24px;margin-top:4px}
.rpt-cr-hdr{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.rpt-cr-logo{width:44px;height:44px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:900;letter-spacing:.05em;flex-shrink:0}
.rpt-cr-title{font-size:16px;font-weight:700;color:var(--text)}
.rpt-cr-sub{font-size:12px;color:var(--text3);margin-top:2px}
.rpt-cr-stats{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.rpt-cr-stat{flex:1;min-width:80px;background:var(--bg2);border-radius:8px;padding:10px 14px;text-align:center;font-size:11px;color:var(--text3)}
.rpt-cr-stat-val{font-size:22px;font-weight:700;margin-bottom:2px}
.rpt-cr-stat.rpt-live .rpt-cr-stat-val{color:var(--live)}
.rpt-cr-stat.rpt-pend .rpt-cr-stat-val{color:#f59e0b}
.rpt-cr-stat.rpt-none .rpt-cr-stat-val{color:var(--text4)}
.rpt-cr-section{margin-bottom:20px}
.rpt-cr-sec-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--border)}
.rpt-cr-table{width:100%;border-collapse:collapse;font-size:12px}
.rpt-cr-table th{text-align:left;padding:7px 10px;background:var(--bg3);color:var(--text3);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}
.rpt-cr-table td{padding:7px 10px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}
.rpt-cr-table td.rpt-live{color:var(--live);font-weight:700}
.rpt-cr-table td.rpt-pend{color:#f59e0b;font-weight:700}
.rpt-cr-table td.rpt-none{color:var(--text4)}
.rpt-cr-footer{margin-top:20px;padding-top:12px;border-top:1px solid var(--border);font-size:10px;color:var(--text4);text-align:center}

/* ── Print styles ────────────────────────────────────────────────── */
@media print{
  .hdr,.tabs,.ghud,.ghud-bottom-bar,.rpt-section-hdr.no-print{display:none!important}
  body{background:#fff;color:#111}
  .rpt-wrap{padding:0}
  .rpt-client-report{border:none;box-shadow:none;background:#fff;color:#111;padding:0}
  .rpt-cr-logo{background:#1d4ed8}
  .rpt-cr-hdr,.rpt-cr-section,.rpt-cr-stats{border-color:#e5e7eb}
  .rpt-cr-table th,.rpt-cr-table td{border-color:#e5e7eb;background:#f9fafb;color:#111}
  .rpt-cr-footer{color:#6b7280}
}
