/* Bambu OS — Admin Console stylesheet (PORTAL_UI_STANDARD.md conformant).
   Layered ON TOP of ../internal/assets/app.css (the shared portal shell).
   Part 1: console shell (views, router chrome, sidebar sections, overview, tabs) — admin-nav.js
   Part 2: section components (matrices, chips, role cards, team rows) — admin-shell.js
   Adding a portal? The matrices + role checkboxes are driven by ALL_PORTALS /
   ROLE_PORTAL_LIST in admin-shell.js + the two static theads in index.html.
   The Overview "registry health" panel cross-checks chooser ↔ admin automatically. */

/* ───────────────────────── 1 · CONSOLE SHELL ───────────────────────── */

/* Sidebar: sectioned nav per the portal standard */
.nav__sec{font:700 10px var(--mont);letter-spacing:.14em;text-transform:uppercase;
  color:#8A93F0;padding:18px 14px 7px;user-select:none}
.nav__sec:first-child{padding-top:6px}
.nav__item .count{margin-left:auto;font:700 10px var(--mont);color:#C5CAF8;
  background:rgba(138,147,240,.16);border:1px solid rgba(138,147,240,.3);
  border-radius:100px;padding:1px 8px;line-height:1.5}
.nav__item.active .count{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.35);color:#fff}

/* Views (hash-routed) */
.adm-view{display:none;animation:admViewIn .18s ease}
.adm-view.is-active{display:block}
@keyframes admViewIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* Every admin section sits in a white panel per the standard */
.adm-section{background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:22px 24px 24px;margin-bottom:22px;box-shadow:0 1px 2px rgba(14,21,66,.04)}
.adm-section h2{font-family:var(--mont);font-weight:800;font-size:17px;color:var(--ink);margin:0 0 4px}
.adm-section .sub{font-size:13px;color:var(--muted);margin-bottom:18px;display:block;line-height:1.55;max-width:880px}

/* Underlined sub-tab row (allowed by the standard for in-page sub-views) */
.adm-tabs{display:flex;gap:2px;border-bottom:2px solid var(--line);margin:0 0 22px}
.adm-tab{appearance:none;border:none;background:none;cursor:pointer;position:relative;
  font:600 13.5px var(--inter);color:var(--muted);padding:10px 16px 12px;white-space:nowrap;
  transition:color .14s}
.adm-tab:hover{color:var(--ink)}
.adm-tab.is-active{color:var(--royal)}
.adm-tab.is-active::after{content:"";position:absolute;left:10px;right:10px;bottom:-2px;
  height:2.5px;border-radius:3px;background:var(--royal)}
.adm-tab .count{margin-left:7px;font:700 10px var(--mont);color:var(--muted);
  background:var(--canvas);border:1px solid var(--line);border-radius:100px;padding:1px 7px}
.adm-tabpane{display:none}
.adm-tabpane.is-active{display:block}

/* ───────────────────────── 2 · OVERVIEW ───────────────────────── */

.adm-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:22px}
.adm-stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;
  cursor:pointer;transition:.15s;display:block;text-decoration:none;color:inherit;
  box-shadow:0 1px 2px rgba(14,21,66,.04)}
.adm-stat:hover{border-color:rgba(31,46,214,.45);transform:translateY(-2px);
  box-shadow:0 10px 24px -14px rgba(14,21,66,.25)}
.adm-stat .n{font:800 26px var(--mont);color:var(--ink);line-height:1.1}
.adm-stat .l{font:700 10.5px var(--mont);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:5px}
.adm-stat .d{font-size:11.5px;color:var(--muted-2);margin-top:3px}

.adm-ov-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:22px;align-items:start}
@media(max-width:1100px){.adm-ov-grid{grid-template-columns:1fr}}

/* Registry health table */
.adm-reg-table{width:100%;border-collapse:collapse;font-size:13px}
.adm-reg-table th{font:700 10.5px var(--mont);letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
.adm-reg-table td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.adm-reg-table tr:last-child td{border-bottom:none}
.adm-reg-table .pk{font:600 12px monospace;color:var(--muted)}
.adm-pill{display:inline-flex;align-items:center;gap:5px;font:700 10px var(--mont);
  letter-spacing:.05em;text-transform:uppercase;border-radius:100px;padding:3px 10px;white-space:nowrap}
.adm-pill--ok{color:#1a6b40;background:#EEF9F3;border:1px solid #A8D8BC}
.adm-pill--warn{color:#7a5a16;background:#FBF4E4;border:1px solid #EBD9B0}
.adm-pill--danger{color:#8c2f37;background:#FCEEF0;border:1px solid #F0BFC6}
.adm-pill--muted{color:var(--muted);background:var(--canvas);border:1px solid var(--line)}

/* System / integration cards */
.adm-sys{display:flex;flex-direction:column;gap:12px}
.adm-sys-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:15px 17px;
  box-shadow:0 1px 2px rgba(14,21,66,.04)}
.adm-sys-card b{font:700 13px var(--mont);color:var(--ink);display:flex;align-items:center;gap:8px;margin-bottom:5px}
.adm-sys-card p{font-size:12.5px;color:var(--muted);line-height:1.55;margin:0}
.adm-sys-card a{color:var(--royal);font-weight:600;text-decoration:none}
.adm-sys-card a:hover{text-decoration:underline}
.adm-sys-card .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.adm-sys-card .dot--ok{background:var(--ok);box-shadow:0 0 6px rgba(31,157,91,.5)}
.adm-sys-card .dot--info{background:var(--royal);box-shadow:0 0 6px rgba(31,46,214,.4)}

/* ───────────────────── 3 · SECTION COMPONENTS (admin-shell.js) ───────────────────── */

/* portal grants matrices */
.adm-grants-wrap{overflow-x:auto;margin-bottom:20px;border-radius:12px;border:1px solid var(--line)}
.adm-grants-table{width:100%;border-collapse:collapse;font-size:13px;min-width:600px}
.adm-grants-table thead th{
  font-family:var(--mont);font-weight:700;font-size:11px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--muted);background:var(--canvas);
  padding:10px 14px;text-align:center;border-bottom:1px solid var(--line);white-space:nowrap}
.adm-grants-table thead th:first-child{text-align:left;padding-left:18px}
.adm-grants-table thead th:last-child{width:40px}
.adm-grants-table tbody tr{border-bottom:1px solid var(--line);transition:background .12s}
.adm-grants-table tbody tr:last-child{border-bottom:none}
.adm-grants-table tbody tr:hover{background:rgba(31,46,214,.03)}
.adm-domain-cell{padding:12px 14px 12px 18px;text-align:left;min-width:160px}
.adm-domain-name{font-family:var(--mont);font-weight:700;font-size:13px;color:var(--royal)}
.adm-grant-cell{text-align:center;padding:10px 8px;line-height:17px}
/* top-align every body cell so all checkboxes line up on one horizontal row; fund dropdowns hang below */
.adm-grants-table tbody td{vertical-align:top}
.adm-grant-cell input[type="checkbox"]{
  width:17px;height:17px;cursor:pointer;accent-color:var(--royal);
  border-radius:4px;border:1.5px solid var(--line);vertical-align:top}
.adm-remove-cell{text-align:center;padding:8px 12px;width:44px}
.adm-th-always{color:var(--ok) !important;opacity:.8}
.adm-th-locked{color:var(--danger, #c0392b) !important;opacity:.7}
.adm-cell-always{color:var(--ok);font-weight:700;font-size:15px;opacity:.75;cursor:default}
.adm-cell-locked{color:var(--muted-2);font-weight:700;font-size:15px;cursor:default}
.adm-remove-btn{
  width:24px;height:24px;border-radius:50%;background:rgba(255,77,77,.1);
  border:none;cursor:pointer;display:inline-flex;align-items:center;
  justify-content:center;font-size:15px;color:#c0392b;font-weight:700;
  transition:.13s;line-height:1}
.adm-remove-btn:hover{background:rgba(255,77,77,.22);color:#a93226}
.adm-empty-row{padding:22px 18px;text-align:center;color:var(--muted-2);font-size:13px;font-style:italic}

/* add rows */
.adm-add{display:flex;gap:10px;align-items:center;margin-bottom:18px}
.adm-add input{
  font:500 13.5px Inter,sans-serif;padding:9px 13px;
  border:1px solid var(--line);border-radius:10px;
  background:#fff;color:var(--ink);flex:1;max-width:320px}
.adm-add input:focus{outline:none;border-color:var(--royal)}
.adm-add input::placeholder{color:var(--muted-2)}

/* CF note + setup */
.adm-note{
  background:#FBF7EC;border:1px solid #E8D8A0;border-left:3px solid var(--gold);
  border-radius:10px;padding:12px 15px;font-size:12.5px;color:#6b5a2e;
  line-height:1.55;margin-bottom:20px;max-width:880px}
.adm-note b{font-weight:700;color:#4a3a1a}
.adm-note a{color:#4a3a1a;font-weight:600}
.adm-note code{font-family:monospace;font-size:11.5px;background:rgba(0,0,0,.06);border-radius:4px;padding:1px 5px}
.adm-note--ok{background:#EEF9F3;border-color:#9FD4B4;border-left-color:var(--ok);color:#1a4d32}
.adm-note--ok b{color:#0e3320}
.adm-setup{
  background:var(--canvas);border:1px solid var(--line);border-radius:10px;
  padding:14px 16px;font-size:12.5px;color:var(--muted);line-height:1.6;margin-bottom:20px}
.adm-setup b{font-weight:700;color:var(--ink);display:block;margin-bottom:6px;font-family:var(--mont)}
.adm-setup ol{margin:8px 0 0 18px;padding:0}
.adm-setup li{margin-bottom:5px}
.adm-setup code{font-family:monospace;font-size:11.5px;background:rgba(0,0,0,.06);border-radius:4px;padding:1px 5px}

/* saved chip */
.adm-saved{
  display:none;font-family:var(--mont);font-weight:700;font-size:12px;
  color:var(--ok);background:var(--ok-bg);border:1px solid #BFE6CE;
  border-radius:100px;padding:4px 13px;margin-left:10px}
.adm-saved.show{display:inline-flex;align-items:center;gap:5px}

/* coming-soon block */
.adm-coming{
  background:var(--canvas);border:1px dashed var(--line);border-radius:12px;
  padding:22px 20px;font-size:13px;color:var(--muted-2);text-align:center}
.adm-coming b{display:block;font-family:var(--mont);font-weight:700;font-size:14px;color:var(--muted);margin-bottom:6px}

/* access-denied overlay */
.adm-denied{
  display:none;position:fixed;inset:0;z-index:100;background:var(--canvas);
  flex-direction:column;align-items:center;justify-content:center;
  gap:16px;text-align:center;padding:40px}
.adm-denied.show{display:flex}
.adm-denied h2{font-family:var(--mont);font-weight:800;font-size:24px;color:var(--ink);margin:0}
.adm-denied p{font-size:14px;color:var(--muted);max-width:380px;line-height:1.6;margin:0}

.content{max-width:min(1440px,94vw)}

/* portal admins chips */
.adm-chips-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;min-height:36px;align-items:center}
.adm-chip{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-family:Inter,sans-serif;font-weight:500;color:var(--ink);
  background:#EEF9F3;border:1px solid #A8D8BC;border-radius:100px;
  padding:5px 10px 5px 13px}
.adm-chip__x{
  width:18px;height:18px;border-radius:50%;
  background:rgba(0,0,0,.08);border:none;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;color:var(--muted);font-weight:700;line-height:1;
  padding:0;transition:.12s}
.adm-chip__x:hover{background:rgba(255,77,77,.18);color:#c0392b}
.adm-empty{font-size:13px;color:var(--muted-2);font-style:italic}
.adm-admin-add{display:flex;gap:10px;align-items:center;margin-bottom:14px}
.adm-admin-add input{
  font:500 13.5px Inter,sans-serif;padding:9px 13px;
  border:1px solid var(--line);border-radius:10px;
  background:#fff;color:var(--ink);flex:1;max-width:300px}
.adm-admin-add input:focus{outline:none;border-color:var(--royal)}
.adm-admin-add input::placeholder{color:var(--muted-2)}
#adm-admin-err{font-size:12.5px;color:var(--danger);margin-top:6px}

/* fund-access selector */
.adm-fund-sel{
  display:block;margin-top:5px;width:100%;max-width:84px;
  font:500 11px Inter,sans-serif;padding:3px 5px;
  border:1px solid var(--line);border-radius:6px;
  background:#fff;color:var(--ink);cursor:pointer;line-height:1.4}
.adm-fund-sel:focus{outline:none;border-color:var(--royal)}

/* 🔒 Emails button */
.adm-restrict-btn{border:1px solid var(--line);background:transparent;cursor:pointer;border-radius:6px;
  font:500 11px var(--inter);color:var(--muted);padding:3px 9px;margin-left:8px;transition:.14s;white-space:nowrap}
.adm-restrict-btn:hover,.adm-restrict-btn.is-open{border-color:var(--royal);color:var(--royal);background:rgba(31,46,214,.05)}
.adm-restrict-btn.has-locks{color:#1a4d32;border-color:#9FD4B4;background:#EEF9F3}
.adm-restrict-btn.has-locks:hover,.adm-restrict-btn.has-locks.is-open{border-color:var(--royal);color:var(--royal);background:rgba(31,46,214,.05)}

/* email restriction sub-row + chip editor */
.adm-email-row>td{padding:0;background:rgba(31,46,214,.025)}
.adm-ec-cell{padding:0}
.adm-email-card{border-top:2px solid var(--royal);padding:16px 18px 20px}
.adm-ec-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.adm-ec-hd b{font:700 13px var(--mont);color:var(--ink)}
.adm-ec-sub{font-size:12px;color:var(--muted);margin-top:3px;max-width:640px;line-height:1.5}
.adm-email-done{border:1px solid var(--line);background:#fff;cursor:pointer;border-radius:8px;
  font:500 12px var(--inter);color:var(--muted);padding:6px 16px;white-space:nowrap;transition:.14s;flex-shrink:0}
.adm-email-done:hover{border-color:var(--royal);color:var(--royal)}
.adm-portals-grid{display:flex;flex-wrap:wrap;gap:14px 24px}
.adm-portal-lock{display:flex;flex-direction:column;gap:5px;min-width:180px}
.adm-portal-lock__lbl{font:700 10px var(--mont);letter-spacing:.09em;text-transform:uppercase;color:var(--muted);padding:0 2px}
.adm-chips{display:flex;flex-wrap:wrap;gap:5px;align-items:center;padding:6px 8px;
  border:1px solid var(--line);border-radius:10px;background:#fff;min-height:38px;cursor:text;min-width:200px}
.adm-chips:focus-within{border-color:var(--royal)}
.adm-chip{display:inline-flex;align-items:center;gap:3px;background:rgba(31,46,214,.10);
  border:1px solid rgba(31,46,214,.24);border-radius:100px;padding:3px 6px 3px 10px;
  font:500 12.5px var(--inter);color:var(--royal)}
.adm-chip-del{border:none;background:none;cursor:pointer;color:var(--royal);opacity:.55;
  padding:0 2px;font-size:14px;line-height:1;transition:.1s}
.adm-chip-del:hover{opacity:1}
.adm-chip-input{border:none;outline:none;font:400 13px var(--inter);color:var(--ink);
  background:transparent;min-width:90px;flex:1;padding:1px 2px}
.adm-chip-input::placeholder{color:var(--muted-2)}
.adm-domain-sfx{font-size:12px;color:var(--muted-2);white-space:nowrap}
.adm-ec-empty{font-size:12.5px;color:var(--muted);font-style:italic;padding:4px 0}

/* Team & Deal Owners */
.adm-team-list{display:flex;flex-direction:column;gap:8px;margin-bottom:6px}
.adm-team-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.adm-team-row .sw{width:26px;height:26px;border-radius:50%;flex-shrink:0;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);color:#fff;display:inline-flex;align-items:center;justify-content:center;font:700 9.5px var(--mont)}
.adm-team-row input{font:500 13px Inter,sans-serif;padding:7px 11px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}
.adm-team-row input.nm{font-weight:700;max-width:180px}
.adm-team-row input.em{max-width:250px}
.adm-team-row input.tt{max-width:160px}
.adm-team-row input:focus{outline:none;border-color:var(--royal)}
.adm-team-row select.clr{font:500 12px Inter,sans-serif;padding:7px 8px;border:1px solid var(--line);border-radius:9px;background:#fff;cursor:pointer;max-width:110px}
.adm-crm-owners{margin-bottom:12px}
.adm-crm-row{display:flex;align-items:center;gap:11px;padding:9px 4px;border-bottom:1px solid var(--line);font-size:13px}
.adm-crm-row:last-child{border-bottom:0}
.adm-crm-row .sw{width:24px;height:24px;border-radius:50%;flex-shrink:0;color:#fff;display:inline-flex;align-items:center;justify-content:center;font:700 9px var(--mont)}
.adm-crm-row b{font-family:var(--mont);min-width:150px}
.adm-crm-row .cnt{color:var(--muted)}
.adm-crm-row .warn-chip{font:700 10px var(--mont);letter-spacing:.04em;text-transform:uppercase;color:var(--warn);background:var(--warn-bg);border:1px solid #EBD9B0;border-radius:100px;padding:2px 9px}
.adm-crm-meta{font-size:12px;color:var(--muted-2);margin-top:8px}

/* Companies & Roles */
.adm-sub-h{font:700 12px var(--mont);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:24px 0 10px}
.adm-tabpane .adm-sub-h:first-child{margin-top:0}
.adm-co-list{display:flex;flex-direction:column;gap:8px;margin-bottom:6px}
.adm-co-company{display:flex;align-items:center;gap:10px}
.adm-co-company .dom{font:600 12px monospace;color:var(--muted);min-width:170px}
.adm-co-company input{font:600 13.5px Inter,sans-serif;padding:7px 11px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink);max-width:240px}
.adm-co-company input:focus{outline:none;border-color:var(--royal)}
.adm-co-select{font:500 12.5px Inter,sans-serif;padding:7px 10px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink);cursor:pointer}
.adm-co-select:focus{outline:none;border-color:var(--royal)}
.adm-co-group{margin-bottom:16px}
.adm-co-group__hd{font:800 13px var(--mont);color:var(--royal);margin:0 0 9px;display:flex;align-items:center;gap:8px}
.adm-co-group__hd .pill{font:700 9.5px var(--mont);letter-spacing:.05em;text-transform:uppercase;color:var(--muted);background:var(--canvas);border:1px solid var(--line);border-radius:100px;padding:2px 9px}
.adm-role-card{border:1px solid var(--line);border-radius:12px;padding:13px 15px;margin-bottom:10px;background:#fff}
.adm-role-row1{display:flex;flex-wrap:wrap;gap:9px;align-items:center;margin-bottom:11px}
.adm-role-card input{border:1px solid var(--line);border-radius:9px;padding:7px 11px;color:var(--ink);background:#fff}
.adm-role-card input.lbl{font:700 13.5px var(--mont);max-width:190px}
.adm-role-card input.pn{font:500 13px Inter,sans-serif;max-width:160px}
.adm-role-card input.pe{font:500 13px Inter,sans-serif;max-width:230px}
.adm-role-card input:focus{outline:none;border-color:var(--royal)}
.adm-role-card .spacer{flex:1}
.adm-role-portals{display:flex;flex-wrap:wrap;gap:7px 15px;border-top:1px dashed var(--line);padding-top:11px}
.adm-pp{display:inline-flex;align-items:center;gap:5px;font:500 12px Inter,sans-serif;color:var(--ink);cursor:pointer;white-space:nowrap}
.adm-pp input{width:15px;height:15px;accent-color:var(--royal);cursor:pointer;margin:0}
.adm-co-add{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:8px 0 4px}
.adm-co-add input{font:500 13.5px Inter,sans-serif;padding:9px 13px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);max-width:240px}
.adm-co-add input:focus{outline:none;border-color:var(--royal)}

/* ───────────────────── 4 · TWO-LAYER ACCESS MODEL (Overview explainer) ───────────────────── */
.adm-layer-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:900px){.adm-layer-grid{grid-template-columns:1fr}}
.adm-layer{border:1px solid var(--line);border-radius:12px;padding:15px 17px 13px;background:var(--canvas)}
.adm-layer--os{border-left:3px solid var(--royal)}
.adm-layer--portal{border-left:3px solid var(--gold)}
.adm-layer b{font:700 13px var(--mont);color:var(--ink);display:block;margin-bottom:6px}
.adm-layer p{font-size:12.5px;color:var(--muted);line-height:1.55;margin:0 0 8px}
.adm-layer .links{margin:0}
.adm-layer .links a{color:var(--royal);font-weight:600;text-decoration:none;font-size:12.5px}
.adm-layer .links a:hover{text-decoration:underline}
