Renderer/Assets/Style.ps1

function Get-AerStyleCss {
    return @'
:root[data-theme="dark"] {
  --bg:#0a0f1e;--bg2:#0d1526;--surface:#162033;--surface2:#1e293b;
  --border:#1e3352;--text:#e2e8f0;--muted:#64748b;
  --accent:#0ea5e9;--accent2:#38bdf8;
  --good:#22c55e;--warn:#f59e0b;--bad:#ef4444;--purple:#a78bfa;
  --sidebar-bg:#0b1120;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--text);font-family:'Segoe UI',Inter,system-ui,Arial,sans-serif;display:flex;min-height:100vh;transition:background .2s,color .2s}

/* ── Sidebar ─────────────────────────────────────────────────────────── */
.sidebar{width:220px;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto;border-right:1px solid rgba(255,255,255,.06);transition:width .2s ease}
.sidebar-brand{padding:18px 16px;display:flex;align-items:center;gap:11px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.06)}
.brand-name{font-size:14px;font-weight:700;color:#fff;letter-spacing:-.2px;line-height:1.2}
.brand-sub{font-size:10px;color:rgba(255,255,255,.4);margin-top:2px}
.sidebar-search{padding:12px 14px;flex-shrink:0;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,.06)}
.sidebar-search-box{position:relative;flex:1;min-width:0}
.sidebar-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:11px;opacity:.4;pointer-events:none}
.sidebar-search input{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:7px 10px 7px 28px;font-size:12px;color:#fff;outline:none;transition:border-color .15s}
.sidebar-toggle{flex-shrink:0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.6);cursor:pointer;font-size:14px;line-height:1;padding:7px 10px;border-radius:8px;transition:all .15s}
.sidebar-toggle:hover{color:#fff;border-color:var(--accent);background:rgba(14,165,233,.12)}
.sidebar-search input::placeholder{color:rgba(255,255,255,.3)}
.sidebar-search input:focus{border-color:var(--accent)}
.nav-empty{padding:14px 16px;font-size:11.5px;color:rgba(255,255,255,.3);text-align:center}
.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}
.nav-section{display:flex;align-items:center;gap:6px;width:100%;padding:14px 16px 5px;font-size:9.5px;font-weight:600;letter-spacing:1.8px;color:rgba(255,255,255,.25);text-transform:uppercase;background:none;border:none;cursor:pointer;font-family:inherit;transition:color .15s}
.nav-section:hover{color:rgba(255,255,255,.45)}
.nav-section-label{flex:1;text-align:left}
.nav-section-chevron{font-size:8px;opacity:.6;transition:transform .2s}
.nav-group.collapsed .nav-section-chevron{transform:rotate(-90deg)}
.nav-group-items{overflow:hidden;max-height:600px;transition:max-height .25s ease}
.nav-group.collapsed .nav-group-items{max-height:0}
.sidebar-nav.searching .nav-group-items{max-height:600px}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 16px;color:rgba(255,255,255,.45);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .15s;border-left:2px solid transparent;text-decoration:none}
.nav-item:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.05)}
.nav-item.active{color:#fff;background:rgba(14,165,233,.15);border-left-color:var(--accent)}
.nav-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0}
.nav-label{flex:1}
.nav-badge{font-size:9.5px;font-weight:700;padding:1px 6px;border-radius:10px;display:none}
.nav-badge.bad{background:rgba(239,68,68,.25);color:#fca5a5;display:inline}
.nav-badge.warn{background:rgba(245,158,11,.2);color:#fde68a;display:inline}
.nav-divider{height:1px;background:rgba(255,255,255,.06);margin:6px 10px}
.sidebar-footer{padding:14px 16px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}
.sidebar-tenant-label{font-size:9.5px;color:rgba(255,255,255,.25);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.sidebar-tenant-val{font-size:11px;color:rgba(255,255,255,.5);word-break:break-all;line-height:1.5}
.sidebar-version{font-size:10px;color:rgba(255,255,255,.2);margin-top:8px}

/* ── Sidebar collapse (icon rail) ────────────────────────────────────── */
body.sidebar-collapsed .sidebar{width:64px}
body.sidebar-collapsed .page-wrapper{margin-left:64px}
body.sidebar-collapsed .sidebar-brand{justify-content:center;padding:18px 0}
body.sidebar-collapsed .sidebar-brand-text,
body.sidebar-collapsed .sidebar-search-box,
body.sidebar-collapsed .sidebar-footer,
body.sidebar-collapsed .nav-label,
body.sidebar-collapsed .nav-section-label,
body.sidebar-collapsed .nav-section-chevron{display:none}
body.sidebar-collapsed .sidebar-search{justify-content:center;padding:12px 0}
body.sidebar-collapsed .nav-section{display:none}
body.sidebar-collapsed .nav-group + .nav-group{margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.06)}
body.sidebar-collapsed .nav-item{justify-content:center;padding:10px 0;position:relative}
body.sidebar-collapsed .nav-group-items{max-height:none!important}
body.sidebar-collapsed .nav-badge{position:absolute;top:5px;right:13px;min-width:0;width:7px;height:7px;padding:0;font-size:0;border-radius:50%}

/* ── Page wrapper ────────────────────────────────────────────────────── */
.page-wrapper{margin-left:220px;flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .2s ease}

/* ── Topbar ──────────────────────────────────────────────────────────── */
.topbar{background:var(--bg);border-bottom:1px solid var(--border);padding:11px 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
[data-theme="dark"] .topbar{background:rgba(10,15,30,.9);backdrop-filter:blur(10px)}
.topbar-left{display:flex;align-items:center;gap:14px;min-width:0}
.topbar-title{font-size:14px;font-weight:700;color:var(--text)}
.topbar-right{display:flex;align-items:center;gap:14px}
.topbar-meta{font-size:11.5px;color:var(--muted)}
.topbar-meta strong{color:var(--text)}
.topbar-actions{display:flex;align-items:center;gap:8px;padding-right:14px;border-right:1px solid var(--border)}
.topbar-action-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}
.export-btn{display:inline-flex;align-items:center;gap:7px;min-height:32px;padding:7px 11px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);text-decoration:none;font-size:11.5px;font-weight:800;letter-spacing:.4px;transition:border-color .15s,background .15s,transform .15s}
.export-btn:hover{transform:translateY(-1px);background:var(--surface2);border-color:var(--accent);color:var(--accent2)}
.export-btn.excel{border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.09)}
.export-btn.excel:hover{border-color:var(--good);color:#86efac}
.export-btn.pdf{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.08)}
.export-btn.pdf:hover{border-color:var(--bad);color:#fca5a5}
.export-btn-icon{font-size:14px;line-height:1}
@media (max-width:820px){.topbar{align-items:flex-start;gap:10px;flex-direction:column}.topbar-right{width:100%;justify-content:space-between}.topbar-actions{padding-right:10px}.topbar-action-label{display:none}}
@media (max-width:520px){.topbar-right{align-items:flex-start;flex-direction:column}.topbar-actions{border-right:none;padding-right:0;flex-wrap:wrap}.export-btn{min-height:30px;padding:6px 10px}}
.export-panel{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:22px;padding:16px 18px;border:1px solid rgba(14,165,233,.32);border-radius:10px;background:linear-gradient(135deg,rgba(14,165,233,.12),rgba(34,197,94,.07));box-shadow:0 8px 26px rgba(0,0,0,.14)}
.export-panel-copy{min-width:0}
.export-panel-kicker{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1.4px;color:var(--accent2);margin-bottom:4px}
.export-panel-title{font-size:15px;font-weight:800;color:var(--text);line-height:1.2}
.export-panel-sub{font-size:11.5px;color:var(--muted);margin-top:4px;line-height:1.45}
.export-panel-actions{display:flex;align-items:center;gap:9px;flex-shrink:0}
@media (max-width:700px){.export-panel{align-items:flex-start;flex-direction:column}.export-panel-actions{width:100%;flex-wrap:wrap}}

/* ── Page content ────────────────────────────────────────────────────── */
.page-content{flex:1;padding:24px 28px}
.page{display:none}
.page.active{display:block;animation:fadein .18s ease}
@keyframes fadein{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* ── Section title ───────────────────────────────────────────────────── */
.section-title{font-size:10px;font-weight:600;letter-spacing:1.6px;color:var(--muted);text-transform:uppercase;margin-bottom:14px;margin-top:0;display:flex;align-items:center;gap:8px}
.section-title::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── Page header (detail pages) ─────────────────────────────────────── */
.page-header{display:flex;align-items:center;gap:14px;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--border)}
.page-header-icon{font-size:30px;line-height:1}
.page-header-title{font-size:20px;font-weight:700;color:var(--text)}
.page-header-sub{font-size:12px;color:var(--muted);margin-top:3px}
.page-header-chips{margin-left:auto;display:flex;gap:8px;align-items:center}
.chip{padding:4px 12px;border-radius:20px;font-size:11.5px;font-weight:600}
.chip.bad{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.3);color:#f87171}
.chip.warn{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.3);color:#fbbf24}
.chip.blue{background:rgba(14,165,233,.12);border:1px solid rgba(14,165,233,.3);color:var(--accent2)}
.chip.good{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);color:#4ade80}

/* ── KPI grid ────────────────────────────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:26px}
.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px 20px;position:relative;overflow:hidden;transition:border-color .2s}
.kpi-card:hover{border-color:var(--accent)}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.kpi-card.purple::before{background:linear-gradient(90deg,#a78bfa,#6366f1)}
.kpi-card.blue::before{background:linear-gradient(90deg,#0ea5e9,#6366f1)}
.kpi-card.cyan::before{background:linear-gradient(90deg,#22d3ee,#0ea5e9)}
.kpi-card.sky::before{background:linear-gradient(90deg,#38bdf8,#22d3ee)}
.kpi-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}
.kpi-value{font-size:28px;font-weight:800;line-height:1;margin-bottom:5px}
.kpi-card.purple .kpi-value{color:#c4b5fd}
.kpi-card.blue .kpi-value{color:#38bdf8}
.kpi-card.cyan .kpi-value{color:#67e8f9}
.kpi-card.sky .kpi-value{color:#7dd3fc}
.kpi-hint{font-size:11px;color:var(--muted)}
.kpi-icon{position:absolute;right:16px;top:16px;font-size:24px;opacity:.1}

/* ── Stat tiles (compute summary) ────────────────────────────────────── */
.stat-tiles{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:24px}
@media (max-width:1200px){.stat-tiles{grid-template-columns:repeat(3,1fr)}}
@media (max-width:640px){.stat-tiles{grid-template-columns:repeat(2,1fr)}}
.stat-tile{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:7px;transition:border-color .2s}
.stat-tile:hover{border-color:var(--accent)}
.stat-tile-label{font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);display:flex;align-items:center;gap:6px}
.stat-tile-value{font-size:22px;font-weight:800;color:var(--text);line-height:1}
.stat-tile-unit{font-size:12px;font-weight:600;color:var(--muted);margin-left:4px}
.stat-tile-sub{font-size:11px;color:var(--muted);margin-top:-2px}
.cat-pill{display:inline-block;font-size:11px;line-height:1.6;padding:1px 8px;border-radius:10px;margin:2px 4px 2px 0;border:1px solid var(--border);white-space:nowrap}
.cat-pill.on{color:#86efac;border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.10)}
.cat-pill.off{color:var(--muted);background:var(--bg2)}
.diag-setting{border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin-bottom:8px;background:var(--bg2)}
.diag-setting-name{font-weight:600;font-size:13px;margin-bottom:8px}
.diag-cats{display:flex;align-items:baseline;gap:8px;margin-top:6px;flex-wrap:wrap}
.diag-cats-label{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);min-width:56px}

/* ── Summary cards (overview) ────────────────────────────────────────── */
.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:8px}
.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s;text-decoration:none;display:flex;align-items:center;gap:16px}
.summary-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.summary-card.security:hover{border-color:var(--bad);box-shadow:0 6px 20px rgba(239,68,68,.12)}
.summary-card.cost:hover{border-color:var(--warn);box-shadow:0 6px 20px rgba(245,158,11,.12)}
.summary-card.advisor:hover{border-color:var(--accent);box-shadow:0 6px 20px rgba(14,165,233,.12)}
.summary-icon-wrap{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.summary-card.security .summary-icon-wrap{background:rgba(239,68,68,.12)}
.summary-card.cost .summary-icon-wrap{background:rgba(245,158,11,.1)}
.summary-card.advisor .summary-icon-wrap{background:rgba(14,165,233,.1)}
.summary-value{font-size:26px;font-weight:800;line-height:1;margin-bottom:3px}
.summary-card.security .summary-value{color:var(--bad)}
.summary-card.cost .summary-value{color:var(--warn)}
.summary-card.advisor .summary-value{color:var(--accent2)}
.summary-label{font-size:12px;font-weight:600;color:var(--text)}
.summary-hint{font-size:11px;color:var(--muted);margin-top:2px}
.summary-arrow{margin-left:auto;color:var(--muted);font-size:16px;flex-shrink:0;opacity:.5}

/* ── Cards ───────────────────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:16px}
.card:last-child{margin-bottom:0}
.card h3{font-size:13px;font-weight:600;color:var(--text);margin-bottom:16px}
.charts-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:16px}

/* ── Donut ────────────────────────────────────────────────────────────── */
.donut-wrap{display:flex;align-items:center;gap:18px}
.legend-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:7px;font-size:12px}
.legend-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px}
.legend-label{color:var(--muted);flex:1;min-width:0;white-space:normal;word-break:break-word;line-height:1.35}
.legend-val{color:var(--text);font-weight:600;font-size:12px;flex-shrink:0;margin-left:4px}

/* ── Bar charts ──────────────────────────────────────────────────────── */
.bar-item{display:flex;align-items:center;gap:9px;margin-bottom:8px;font-size:12px}
.bar-label{color:var(--muted);width:120px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;background:var(--bg2);border-radius:4px;height:5px}
.bar-fill{height:5px;border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.bar-count{width:32px;text-align:right;font-weight:600;color:var(--accent2);font-size:11.5px}

/* ── Advisor ─────────────────────────────────────────────────────────── */
.advisor-header{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.advisor-header h3{font-size:14px;font-weight:600}
.high-impact-badge{background:rgba(239,68,68,.2);color:#fca5a5;border:1px solid rgba(239,68,68,.3);font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}
.advisor-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.advisor-cat{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;align-items:center;gap:12px;transition:border-color .2s}
.advisor-cat:hover{border-color:var(--accent)}
.advisor-cat-icon{font-size:20px;flex-shrink:0}
.advisor-cat-count{font-size:24px;font-weight:800;line-height:1}
.advisor-cat-label{font-size:11.5px;font-weight:600;color:var(--text);margin-top:2px}
.advisor-cat-sub{font-size:10.5px;color:var(--muted)}
.advisor-cat.security .advisor-cat-count{color:#f87171}
.advisor-cat.reliability .advisor-cat-count{color:#fbbf24}
.advisor-cat.cost .advisor-cat-count{color:#4ade80}
.advisor-cat.performance .advisor-cat-count{color:#818cf8}
.advisor-cat.excellence .advisor-cat-count{color:#38bdf8}

/* ── Issue list ──────────────────────────────────────────────────────── */
.issue-item{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border);font-size:12.5px}
.issue-item:last-child{border-bottom:none}
.badge{padding:2px 8px;border-radius:20px;font-size:9.5px;font-weight:700;letter-spacing:.4px;white-space:nowrap;flex-shrink:0}
.badge.critical{background:rgba(127,29,29,.8);color:#fca5a5}
.badge.high{background:rgba(124,45,18,.8);color:#fdba74}
.badge.medium{background:rgba(133,77,14,.7);color:#fef08a}
.badge.info{background:rgba(30,58,95,.8);color:#93c5fd}
.badge.low{background:rgba(12,74,110,.6);color:#7dd3fc}
.badge.waste{background:rgba(74,29,150,.8);color:#ddd6fe}
.issue-text{flex:1;min-width:0}
.issue-title{color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.issue-sub{color:var(--muted);font-size:11px;margin-top:2px}
.issue-count{color:var(--accent2);font-weight:700;font-size:13px;flex-shrink:0;min-width:32px;text-align:right}

/* ── Bottom row (overview) ───────────────────────────────────────────── */
.bottom-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:8px}

/* ── Cloud structure grid ────────────────────────────────────────────── */
.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
@media (max-width:1100px){.cs-grid{grid-template-columns:1fr}}
.aer-table.simple{min-width:0;table-layout:auto}
.aer-table.simple thead th{padding:9px 12px}
.aer-table.simple tbody td{white-space:normal;word-break:break-word;padding:12px 12px}

/* ── Warn banner ─────────────────────────────────────────────────────── */
.warn-banner{background:rgba(69,26,3,.6);border:1px solid rgba(133,77,14,.5);color:#fef08a;border-radius:8px;padding:10px 14px;margin-bottom:20px;font-size:12.5px}

/* ── Empty state ─────────────────────────────────────────────────────── */
.empty-state{padding:28px 16px;text-align:center;color:var(--muted);font-size:12.5px}

/* ── Pagination ──────────────────────────────────────────────────────── */
.pager{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
.pager-info{font-size:11.5px;color:var(--muted)}
.pager-controls{display:flex;align-items:center;gap:6px}
.pager-btn{background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:5px 11px;font-size:12px;color:var(--text);cursor:pointer;transition:all .15s;min-width:32px}
.pager-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent2)}
.pager-btn:disabled{opacity:.35;cursor:not-allowed}
.pager-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
.pager-ellipsis{color:var(--muted);font-size:12px;padding:0 2px}

/* ── Data table ──────────────────────────────────────────────────────── */
.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.table-search{position:relative;flex:1;max-width:340px}
.table-search input{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:8px 12px 8px 32px;font-size:12.5px;color:var(--text);outline:none;transition:border-color .15s}
.table-search input:focus{border-color:var(--accent)}
.table-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:13px;pointer-events:none}
.table-active-filters{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.table-cols-btn{margin-left:auto;flex-shrink:0;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:7px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.table-cols-btn:hover{border-color:var(--accent);color:var(--accent2)}
.filter-tag{background:rgba(14,165,233,.12);border:1px solid rgba(14,165,233,.3);color:var(--accent2);font-size:10.5px;font-weight:600;padding:3px 8px;border-radius:14px;display:flex;align-items:center;gap:5px}
.filter-tag-x{cursor:pointer;opacity:.7;font-weight:700}
.filter-tag-x:hover{opacity:1}
.filter-clear-all{font-size:11px;color:var(--muted);cursor:pointer;text-decoration:underline;background:none;border:none}
.filter-clear-all:hover{color:var(--text)}

.table-scroll{overflow-x:auto;border:1px solid var(--border);border-radius:10px}
table.aer-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:12px;min-width:900px}
.aer-table thead th{background:var(--bg2);color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:10px;text-align:left;padding:0;position:relative;border-bottom:1px solid var(--border);white-space:nowrap;overflow:hidden}
.th-inner{display:flex;align-items:center;gap:6px;padding:11px 12px}
.th-label{flex:1;overflow:hidden;text-overflow:ellipsis}
.th-filter-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:11px;padding:2px;border-radius:4px;flex-shrink:0;transition:color .15s;line-height:1}
.th-filter-btn:hover{color:var(--accent2)}
.th-filter-btn.has-filter{color:var(--accent2)}
.col-resizer{position:absolute;right:0;top:0;height:100%;width:6px;cursor:col-resize;user-select:none}
.col-resizer:hover,.col-resizer.resizing{background:var(--accent)}
.aer-table tbody td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aer-table tbody tr:last-child td{border-bottom:none}
.aer-table tbody tr:hover td{background:var(--surface2)}
.cell-muted{color:var(--muted)}
.cell-mono{font-family:'Cascadia Code','Consolas',monospace;font-size:11px}
.status-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px}
.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--muted)}
.status-dot.ok{background:var(--good)}
.status-dot.warn{background:var(--warn)}
.status-dot.bad{background:var(--bad)}
.portal-btn{display:inline-flex;align-items:center;gap:5px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:4px 9px;font-size:11px;color:var(--accent2);text-decoration:none;white-space:nowrap;transition:all .15s}
.portal-btn:hover{border-color:var(--accent);background:rgba(14,165,233,.1)}

/* ── Filter dropdown ─────────────────────────────────────────────────── */
.filter-dropdown{position:absolute;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.4);width:240px;display:none;overflow:hidden}
.filter-dropdown.open{display:block}
.filter-dd-search{padding:10px;border-bottom:1px solid var(--border)}
.filter-dd-search input{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:7px;padding:6px 10px;font-size:12px;color:var(--text);outline:none}
.filter-dd-search input:focus{border-color:var(--accent)}
.filter-dd-actions{display:flex;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border)}
.filter-dd-action{background:none;border:none;color:var(--accent2);font-size:11px;cursor:pointer;font-weight:600}
.filter-dd-action:hover{text-decoration:underline}
.filter-dd-list{max-height:240px;overflow-y:auto;padding:6px 0}
.filter-dd-item{display:flex;align-items:center;gap:9px;padding:6px 12px;font-size:12px;color:var(--text);cursor:pointer;transition:background .12s}
.filter-dd-item:hover{background:var(--surface2)}
.filter-dd-item input{cursor:pointer;accent-color:var(--accent);flex-shrink:0}
.filter-dd-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.filter-dd-item-count{color:var(--muted);font-size:10.5px;flex-shrink:0}
.filter-dd-empty{padding:14px;text-align:center;color:var(--muted);font-size:11.5px}

/* ── Table row accordion (resource detail) ───────────────────────────── */
.aer-table tbody tr.data-row{cursor:pointer}
.aer-table tbody tr.data-row .row-chevron{display:inline-block;transition:transform .2s;color:var(--muted);font-size:10px;margin-right:6px}
.aer-table tbody tr.data-row.expanded .row-chevron{transform:rotate(90deg);color:var(--accent2)}
.aer-table tbody tr.data-row.expanded td{background:var(--surface2)}
.detail-row > td{padding:0!important;background:var(--bg2)!important;border-bottom:1px solid var(--border)}
.res-detail{padding:18px 20px;animation:fadein .18s ease}
.res-detail-section{margin-bottom:16px}
.res-detail-section:last-child{margin-bottom:0}
.res-detail-label{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.res-detail-id{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-family:'Cascadia Code','Consolas',monospace;font-size:11.5px;color:var(--text);word-break:break-all;line-height:1.5}
.res-detail-text{font-size:12.5px;color:var(--text);line-height:1.6;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 13px;overflow-wrap:anywhere}
.res-detail-text ol,.res-detail-text ul{margin:6px 0;padding-left:22px}
.res-detail-text li{margin:3px 0}
.res-detail-text a{color:var(--accent2);word-break:break-all}
.res-detail-text p{margin:6px 0}
.res-detail-text code{background:var(--bg2);padding:1px 5px;border-radius:4px;font-size:11.5px}
.copy-btn{flex-shrink:0;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:3px 9px;font-size:10.5px;color:var(--accent2);cursor:pointer;transition:all .15s;white-space:nowrap}
.copy-btn:hover{border-color:var(--accent);background:rgba(14,165,233,.1)}

/* ── Peering / relationship graph ────────────────────────────────────── */
.graph-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.graph-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.graph-filter-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:6px 11px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.graph-filter-btn:hover{border-color:var(--accent);color:var(--accent2)}
.graph-filter-btn.active{border-color:var(--accent);color:var(--accent2);background:rgba(14,165,233,.1)}
.graph-wrap{overflow:auto;max-height:700px;cursor:grab;user-select:none;-webkit-user-select:none;border:1px solid var(--border);border-radius:10px;background:var(--bg2)}
.graph-wrap.panning{cursor:grabbing}
.graph-wrap.panning #vnet-graph-svg{pointer-events:none}
#vnet-graph-svg{display:block;margin:auto}
.graph-legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:12px;font-size:11.5px;color:var(--muted)}
.graph-legend-item{display:flex;align-items:center;gap:7px}
.graph-line{display:inline-block;width:22px;height:0;border-top:1.5px solid #3a4a63}
.graph-line.gw{border-top:2px solid #f59e0b}
.graph-dot{display:inline-block;width:11px;height:11px;border-radius:3px}

/* ── Key/value grid (contextual row details) ─────────────────────────── */
.kv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px 28px;align-items:start}
.kv{display:flex;flex-direction:column;gap:4px;min-width:0;padding-right:12px}
.kv-k{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kv-v{font-size:13px;color:var(--text);font-weight:600;overflow-wrap:anywhere;word-break:break-word;white-space:normal;line-height:1.45}

/* ── Tag pills ───────────────────────────────────────────────────────── */
.res-tags{display:flex;flex-wrap:wrap;gap:7px}
.tag-pill{display:inline-flex;align-items:center;max-width:100%;border-radius:16px;font-size:11px;font-weight:500;overflow:hidden;border:1px solid rgba(14,165,233,.3)}
.tag-key{padding:3px 8px;font-weight:600;letter-spacing:.2px;background:rgba(14,165,233,.15);color:var(--accent2);flex-shrink:0}
.tag-val{padding:3px 9px;background:rgba(255,255,255,.04);color:var(--text);overflow-wrap:anywhere;min-width:0}
.tags-empty{font-size:11.5px;color:var(--muted);font-style:italic}

/* ── Generic pills (cloud structure accordion) ───────────────────────── */
.pill-row{display:flex;flex-wrap:wrap;gap:8px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 13px;border-radius:16px;font-size:11.5px;font-weight:600;border:1px solid}
.pill-yellow{background:rgba(245,158,11,.15);color:#fbbf24;border-color:rgba(245,158,11,.4)}
.pill-blue{background:rgba(14,165,233,.15);color:#38bdf8;border-color:rgba(14,165,233,.4)}
.pill-cyan{background:rgba(34,211,238,.15);color:#67e8f9;border-color:rgba(34,211,238,.4)}
.pill-purple{background:rgba(167,139,250,.15);color:#c4b5fd;border-color:rgba(167,139,250,.4)}
.pill-orange{background:rgba(251,146,60,.15);color:#fdba74;border-color:rgba(251,146,60,.4)}

/* ── Hierarchy tree diagram (inline SVG org-chart) ───────────────────── */
.tree-toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.tree-legend{display:flex;gap:18px;flex-wrap:wrap}
.tree-legend-item{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--muted)}
.tree-dot{width:11px;height:11px;border-radius:3px;border:1px solid}
.tree-dot.root{background:rgba(14,165,233,.25);border-color:var(--accent)}
.tree-dot.mg{background:rgba(167,139,250,.2);border-color:rgba(167,139,250,.5)}
.tree-dot.sub{background:rgba(245,158,11,.2);border-color:rgba(245,158,11,.5)}
.tree-controls{display:flex;align-items:center;gap:6px}
.tree-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:6px 11px;font-size:12px;font-weight:600;cursor:pointer;line-height:1;transition:background .15s,border-color .15s,color .15s}
.tree-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent2)}
.tree-btn:disabled{opacity:.45;cursor:not-allowed}
.tree-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.tree-btn.primary:hover:not(:disabled){filter:brightness(1.08);color:#fff}
.tree-zoom-label{font-size:12px;color:var(--muted);min-width:44px;text-align:center;font-variant-numeric:tabular-nums}
.tree-wrap{overflow:auto;padding:14px 6px 28px;max-height:660px;cursor:grab;user-select:none;-webkit-user-select:none}
.tree-wrap.panning{cursor:grabbing}
.tree-wrap.panning #mg-svg{pointer-events:none}
#mg-svg{display:block}
ul.tree{display:flex;justify-content:center;gap:26px;padding:0;margin:0;min-width:min-content}
ul.tree, .tree ul{list-style:none}
.tree ul{position:relative;padding-top:24px;display:flex;justify-content:center;margin:0}
.tree li{list-style:none;position:relative;padding:24px 12px 0;display:flex;flex-direction:column;align-items:center}
.tree li::before,.tree li::after{content:'';position:absolute;top:0;right:50%;border-top:1px solid var(--border);width:50%;height:24px}
.tree li::after{right:auto;left:50%;border-left:1px solid var(--border)}
.tree li:only-child::before,.tree li:only-child::after{display:none}
.tree li:only-child{padding-top:24px}
.tree li:first-child::before,.tree li:last-child::after{border:0 none}
.tree li:last-child::before{border-right:1px solid var(--border);border-radius:0 6px 0 0}
.tree li:first-child::after{border-radius:6px 0 0 0}
.tree ul::before{content:'';position:absolute;top:0;left:50%;border-left:1px solid var(--border);width:0;height:24px}
ul.tree > li{padding-top:0}
ul.tree > li::before,ul.tree > li::after{display:none}
.tree-node{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--border);border-radius:10px;padding:9px 14px;font-size:12px;font-weight:600;white-space:nowrap;background:var(--surface);max-width:220px;overflow:hidden;text-overflow:ellipsis;transition:transform .15s,box-shadow .15s}
.tree-node:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.25)}
.tree-node.tree-root{border-color:var(--accent);background:rgba(14,165,233,.12);color:var(--accent2);font-weight:700}
.tree-node.tree-mg{border-color:rgba(167,139,250,.5);background:rgba(167,139,250,.1);color:#c4b5fd}
.tree-node.tree-sub{border-color:rgba(245,158,11,.45);background:rgba(245,158,11,.1);color:#fbbf24}

/* ── Footer ──────────────────────────────────────────────────────────── */
.footer{border-top:1px solid var(--border);padding:13px 28px;display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--muted);flex-shrink:0}
'@

}