/* ============================================================================
   portal.css — module-scoped tweaks for the Customer Portal view.
   Every class is prefixed .portal-* and uses ONLY palette tokens (no hex/fonts).
   The .portal-preview block is the framed mock of the CUSTOMER-FACING portal —
   it is deliberately styled to feel like a different, lighter product surface
   so the admin can tell internal vs external apart at a glance.
   ========================================================================== */

/* ── external marker pill in the header ──────────────────────────────────── */
.portal-ext-pill{letter-spacing:1.2px}

/* ── KPI tiles ───────────────────────────────────────────────────────────── */
.portal-kpi{gap:6px}
.portal-kpi .kpi-value{line-height:1.02}

/* ── customer logo chip (initials avatar, square) ────────────────────────── */
.portal-logo{
  width:30px;height:30px;border-radius:9px;flex:none;
  display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.3px;
  color:var(--bg);background:var(--accent-grad);
  box-shadow:0 0 12px var(--glow)}
.portal-logo.lg{width:42px;height:42px;font-size:15px;border-radius:11px}

/* ── accounts table ──────────────────────────────────────────────────────── */
/* min-width:0 lets these grid children shrink below their content width so the
   wide table / preview scroll internally instead of overflowing the viewport. */
.portal-table-card,.portal-preview-card{min-width:0}
.portal-table-card{display:flex;flex-direction:column}
.portal-table-head{padding:16px 16px 13px;margin-bottom:0}
.portal-table-scroll{overflow:auto;max-height:440px}
.portal-table thead th{
  position:sticky;top:0;z-index:1;
  background:var(--panel-hi);backdrop-filter:blur(6px)}
.portal-table thead th.portal-th-act{text-align:right}

.portal-row{transition:background .14s}
.portal-acct{display:flex;align-items:center;gap:10px;min-width:0}
.portal-acct-body{min-width:0}
.portal-acct-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap}
.portal-acct-sub{
  font-size:10px;color:var(--text-faint);margin-top:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:170px}

.portal-email{font-size:12px;color:var(--text-muted);white-space:nowrap}

.portal-scopes{display:flex;flex-wrap:wrap;gap:4px;max-width:210px}
.portal-scope-chip{
  display:inline-flex;align-items:center;
  font-family:var(--font-mono);font-size:9px;letter-spacing:.4px;
  padding:2px 7px;border-radius:20px;
  color:var(--text-muted);background:var(--bg2);border:1px solid var(--border)}

.portal-seen{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);white-space:nowrap}
.portal-seen.is-stale{color:var(--warn)}

.portal-row-actions{display:flex;gap:6px;justify-content:flex-end;white-space:nowrap}
.portal-btn-danger{color:var(--danger);border-color:rgba(255,77,109,.3)}
.portal-btn-danger:hover{background:rgba(255,77,109,.08);border-color:var(--danger)}

/* ── invite panel ────────────────────────────────────────────────────────── */
.portal-invite{display:flex;flex-direction:column;gap:13px}
.portal-field{display:flex;flex-direction:column;gap:6px}
.portal-label{
  font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--text-faint)}
.portal-select,.portal-input{
  width:100%;background:var(--bg);color:var(--text);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:9px 11px;font-size:13px;font-family:var(--font-body);outline:none;
  transition:border-color .16s var(--ease)}
.portal-select:focus,.portal-input:focus{border-color:var(--border-hi)}
.portal-select{appearance:none;cursor:pointer;
  background-image:linear-gradient(45deg,transparent 50%,var(--text-faint) 50%),linear-gradient(135deg,var(--text-faint) 50%,transparent 50%);
  background-position:calc(100% - 16px) 50%,calc(100% - 11px) 50%;
  background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:30px}
.portal-input:disabled,.portal-select:disabled{opacity:.5;cursor:not-allowed}

.portal-scope-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.portal-scope-check{
  display:flex;align-items:center;gap:8px;text-align:left;
  padding:9px 10px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--bg2);
  color:var(--text-muted);transition:all .15s var(--ease)}
.portal-scope-check:hover{border-color:var(--border-hi);color:var(--text)}
.portal-scope-check.on{
  border-color:var(--border-hi);color:var(--text);
  background:var(--panel-hi);box-shadow:inset 0 0 0 1px rgba(0,229,209,.22)}
.portal-scope-box{
  width:18px;height:18px;border-radius:5px;flex:none;
  display:grid;place-items:center;font-size:10px;
  border:1.5px solid var(--border-hi);color:transparent;transition:.15s var(--ease)}
.portal-scope-check.on .portal-scope-box{
  background:var(--accent-grad);border-color:transparent;color:var(--bg)}
.portal-scope-ico{font-size:13px;line-height:1}
.portal-scope-name{font-size:12px;font-weight:600}
.portal-scope-check:disabled{opacity:.55;cursor:not-allowed}

.portal-invite-note{
  font-size:11px;color:var(--text-faint);line-height:1.5;
  border-top:1px solid var(--border);padding-top:11px}
.portal-invite-note b{color:var(--text-muted)}

/* ── CLIENT-VIEW PREVIEW — framed mock of the external portal ────────────── */
.portal-preview-card{display:flex;flex-direction:column}
.portal-preview-pick{width:auto;min-width:160px;padding:6px 28px 6px 10px;font-size:12px;
  background-position:calc(100% - 13px) 50%,calc(100% - 9px) 50%}
.portal-preview{
  border:1px solid var(--border-hi);border-radius:var(--radius);
  overflow:hidden;background:var(--bg2);
  box-shadow:0 18px 50px rgba(0,0,0,.4),inset 0 0 0 1px rgba(52,195,255,.06)}

/* browser-chrome strip — signals "this is a different, customer site" */
.portal-pv-chrome{
  display:flex;align-items:center;gap:7px;
  padding:9px 13px;background:var(--panel);border-bottom:1px solid var(--border)}
.portal-pv-dot{width:9px;height:9px;border-radius:50%;background:var(--border-hi);flex:none}
.portal-pv-dot:nth-child(1){background:var(--danger);opacity:.6}
.portal-pv-dot:nth-child(2){background:var(--warn);opacity:.6}
.portal-pv-dot:nth-child(3){background:var(--success);opacity:.6}
.portal-pv-url{
  flex:1;margin-left:6px;font-family:var(--font-mono);font-size:10px;
  letter-spacing:.4px;color:var(--text-faint);
  background:var(--bg);border:1px solid var(--border);border-radius:20px;
  padding:4px 12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.portal-pv-body{padding:18px;display:flex;flex-direction:column;gap:15px}
.portal-pv-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.portal-pv-brand{display:flex;align-items:center;gap:11px;min-width:0}
.portal-pv-hi{font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:-.2px;color:var(--text)}
.portal-pv-sub{font-size:11px;color:var(--text-faint);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.portal-pv-account{
  font-size:11px;color:var(--text-muted);white-space:nowrap;
  border:1px solid var(--border);border-radius:20px;padding:5px 12px;background:var(--panel)}
.portal-pv-head-right{display:flex;align-items:center;gap:12px;flex:none}
.portal-pv-trend{display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.portal-pv-trend-lbl{
  font-family:var(--font-mono);font-size:9px;letter-spacing:.6px;
  color:var(--text-faint);white-space:nowrap}
.portal-pv-spark{width:84px;height:30px}

.portal-pv-tabs{display:flex;gap:6px;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:11px}
.portal-pv-tab{
  font-size:12px;font-weight:600;color:var(--text-muted);
  padding:5px 12px;border-radius:8px;background:var(--panel)}
.portal-pv-tab.is-on{color:var(--accent2);background:rgba(52,195,255,.10);box-shadow:inset 0 0 0 1px rgba(52,195,255,.28)}

.portal-pv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:11px}
.portal-pv-tile{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:13px}
.portal-pv-tile-top{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  font-size:11px;color:var(--text-muted)}
.portal-pv-pill{
  font-family:var(--font-mono);font-size:8.5px;font-weight:700;letter-spacing:1px;
  padding:2px 7px;border-radius:20px;color:var(--text-muted);background:var(--bg2);border:1px solid var(--border)}
.portal-pv-pill.ok{color:var(--success);border-color:rgba(0,229,209,.3);background:rgba(0,229,209,.08)}
.portal-pv-pill.warn{color:var(--warn);border-color:rgba(245,165,36,.3);background:rgba(245,165,36,.08)}
.portal-pv-pill.info{color:var(--accent2);border-color:rgba(52,195,255,.3);background:rgba(52,195,255,.08)}
.portal-pv-big{font-family:var(--font-display);font-size:30px;font-weight:600;letter-spacing:-.5px;color:var(--text);margin:6px 0 3px}
.portal-pv-foot{font-size:11px;color:var(--text-faint)}

.portal-pv-list{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:5px 13px}
.portal-pv-list-head{
  font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--text-faint);padding:9px 0 7px;border-bottom:1px solid var(--border)}
.portal-pv-li{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}
.portal-pv-li:last-child{border-bottom:none}
.portal-pv-li-ico{font-size:14px;flex:none}
.portal-pv-li-main{flex:1;font-size:12.5px;font-weight:600;color:var(--text);min-width:0}
.portal-pv-li-amt{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);white-space:nowrap}
.portal-pv-li-status{
  font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
  padding:2px 8px;border-radius:20px;flex:none}
.portal-pv-li-status.ok{color:var(--success);background:rgba(0,229,209,.08)}
.portal-pv-li-status.warn{color:var(--warn);background:rgba(245,165,36,.08)}

.portal-pv-cta{display:flex;gap:9px;flex-wrap:wrap}
.portal-pv-btn{
  flex:1;min-width:140px;padding:10px 14px;border-radius:9px;
  font-size:12.5px;font-weight:600;
  border:1px solid var(--border-hi);background:var(--panel);color:var(--text);
  transition:all .15s var(--ease)}
.portal-pv-btn:hover{background:var(--panel-hi);transform:translateY(-1px)}
.portal-pv-btn.primary{
  background:linear-gradient(120deg,var(--accent2),var(--accent3));
  color:var(--bg);border-color:transparent;box-shadow:0 0 18px rgba(52,195,255,.22)}

/* ── shared documents ────────────────────────────────────────────────────── */
.portal-docs{display:flex;flex-direction:column}
.portal-docs-list{flex:1}
.portal-doc-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}

/* ════════════════════════════════════════════════════════════════════════
   MULTI-CLIENT WORKSPACE — directory grid, per-client identity, add form,
   workspace re-theme. Per-client ACCENT is the ONLY hardcoded colour and is
   always passed INLINE from JS (here we only reference --c, set per element).
   ════════════════════════════════════════════════════════════════════════ */

/* ── client identity tile (emoji on accent, or coloured monogram) ────────── */
.portal-id{
  width:34px;height:34px;border-radius:10px;flex:none;
  display:grid;place-items:center;font-size:17px;
  border:1px solid var(--border-hi);background:var(--panel-hi)}
.portal-id.lg{width:46px;height:46px;border-radius:12px;font-size:22px}
.portal-id.xl{width:54px;height:54px;border-radius:14px;font-size:26px}
.portal-id-emoji{line-height:1}
.portal-id-mono{
  font-family:var(--font-display);font-weight:700;letter-spacing:.3px;font-size:12px}
.portal-id-mono.lg{font-size:16px}
.portal-id-mono.xl{font-size:19px}

/* ── area/industry tag — accent-tinted (inline colours) ──────────────────── */
.portal-area-tag{
  display:inline-flex;align-items:center;
  font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.8px;
  text-transform:uppercase;padding:2px 8px;border-radius:20px;
  border:1px solid var(--border);color:var(--text-muted);background:var(--panel);
  white-space:nowrap;vertical-align:middle}

/* ── DIRECTORY GRID — responsive client cards ────────────────────────────── */
.portal-grid{
  display:grid;gap:var(--gap);
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.portal-card{
  position:relative;display:flex;flex-direction:column;gap:13px;
  text-align:left;overflow:hidden;cursor:pointer}
.portal-card:hover{transform:translateY(-3px);border-color:var(--c,var(--border-hi))}
.portal-card-keyline{
  position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px;opacity:.85}
.portal-card-head{display:flex;align-items:center;gap:11px;min-width:0}
.portal-card-id{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}
.portal-card-name{
  font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:-.1px;
  color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.portal-card-status{flex:none}

.portal-card-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.portal-stat{display:flex;flex-direction:column;gap:2px;min-width:0}
.portal-stat-v{
  font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.portal-stat-l{
  font-family:var(--font-mono);font-size:8.5px;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint)}

.portal-card-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}
.portal-card-url{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.3px;color:var(--text-faint);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.portal-card-go{font-size:11px;font-weight:600;white-space:nowrap;flex:none}

/* ── ADD-CLIENT form ─────────────────────────────────────────────────────── */
.portal-add{display:flex;flex-direction:column;gap:14px}
.portal-add-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:12px}
.portal-icon-picker,.portal-accent-picker{display:flex;flex-wrap:wrap;gap:8px}
.portal-icon-opt{
  width:40px;height:40px;border-radius:10px;flex:none;font-size:19px;
  display:grid;place-items:center;
  border:1px solid var(--border);background:var(--bg2);transition:all .14s var(--ease)}
.portal-icon-opt:hover{border-color:var(--border-hi);transform:translateY(-1px)}
.portal-icon-opt.on{
  border-color:var(--border-hi);background:var(--panel-hi);box-shadow:inset 0 0 0 1px rgba(0,229,209,.3)}
.portal-icon-mono{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--text-muted)}
.portal-accent-opt{
  width:26px;height:26px;border-radius:50%;flex:none;
  border:2px solid transparent;box-shadow:0 0 0 1px var(--border);transition:transform .14s var(--ease)}
.portal-accent-opt:hover{transform:scale(1.14)}
.portal-accent-opt.on{border-color:var(--bg);box-shadow:0 0 0 2px var(--text),0 0 12px var(--c)}

.portal-add-preview{display:flex;flex-direction:column;gap:8px;
  border-top:1px solid var(--border);padding-top:13px}
.portal-add-prev-tile{display:flex;align-items:center;gap:12px}
.portal-add-prev-meta{display:flex;flex-direction:column;gap:5px;min-width:0}
.portal-add-prev-name{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text)}
.portal-add-foot{display:flex;gap:9px;justify-content:flex-end}

/* ── WORKSPACE head (re-themed) + switcher ───────────────────────────────── */
.portal-ws-head{padding-bottom:14px}
.portal-ws-head .vh-title{align-items:center}
.portal-ws-accent{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:9px;letter-spacing:1px;color:var(--text-faint);
  border:1px solid var(--border);border-radius:20px;padding:2px 8px;vertical-align:middle}
.portal-ws-accent i{width:8px;height:8px;border-radius:50%;flex:none}
.portal-switcher{width:auto;min-width:170px;padding:7px 30px 7px 11px;font-size:12px}
.portal-switch-back{color:var(--bg);border-color:transparent}
.portal-switch-back:hover{filter:brightness(1.08)}

/* ── seat roster (workspace table) ───────────────────────────────────────── */
.portal-seat-av{
  width:30px;height:30px;border-radius:9px;flex:none;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:11px;
  border:1px solid var(--border-hi)}
.portal-role-chip{
  display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:9px;
  font-weight:600;letter-spacing:.6px;padding:2px 8px;border-radius:20px;
  border:1px solid var(--border);background:var(--panel)}

/* ── branding panel ──────────────────────────────────────────────────────── */
.portal-brand{display:flex;flex-direction:column;gap:13px}
.portal-brand-hero{
  display:flex;align-items:center;gap:13px;
  border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px}
.portal-brand-meta{display:flex;flex-direction:column;gap:6px;min-width:0}
.portal-brand-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text)}
.portal-brand-rows{display:flex;flex-direction:column}
.portal-brand-row{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:8px 0;border-bottom:1px solid var(--border);font-size:12px;color:var(--text-muted)}
.portal-brand-row:last-child{border-bottom:none}
.portal-brand-row b{color:var(--text);font-weight:600;font-size:12px}
.portal-brand-accent{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:11px}
.portal-brand-accent i{width:11px;height:11px;border-radius:4px;flex:none}
.portal-url-mock{
  display:flex;align-items:center;gap:8px;
  background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 9px}
.portal-url-lock{font-size:11px;flex:none}
.portal-url-text{
  flex:1;font-family:var(--font-mono);font-size:11px;letter-spacing:.2px;color:var(--text-muted);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.portal-url-copy{flex:none}

/* ── access ("what they can see") tiles ──────────────────────────────────── */
.portal-access-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.portal-access-tile{
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;text-align:left;
  padding:13px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:var(--bg2);
  color:var(--text-muted);transition:all .15s var(--ease)}
.portal-access-tile:hover{border-color:var(--border-hi);color:var(--text);transform:translateY(-1px)}
.portal-access-tile.on{color:var(--text)}
.portal-access-ico{font-size:18px;line-height:1}
.portal-access-name{font-size:13px;font-weight:600}
.portal-access-state{
  font-family:var(--font-mono);font-size:8.5px;font-weight:700;letter-spacing:1px;color:var(--text-faint)}
.portal-access-tile:disabled{opacity:.55;cursor:not-allowed}
.portal-access-note{
  font-size:11px;color:var(--text-faint);line-height:1.5;
  border-top:1px solid var(--border);padding-top:11px;margin-top:13px}

.portal-status-rows{display:flex;flex-direction:column}

.portal-pv-empty{
  font-size:12px;color:var(--text-faint);text-align:center;padding:16px;
  border:1px dashed var(--border-hi);border-radius:var(--radius-sm)}

/* ── responsive ──────────────────────────────────────────────────────────── */
@media (max-width:1180px){
  .portal-table-scroll{max-height:380px}
}
@media (max-width:820px){
  .portal-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
  .portal-add-grid{grid-template-columns:1fr}
  .portal-pv-head{flex-wrap:wrap}
  .portal-pv-head-right{display:none}
  .portal-row-actions{flex-wrap:wrap;justify-content:flex-start}
  .portal-ws-head .vh-actions{flex-wrap:wrap}
}
@media (max-width:560px){
  .portal-grid{grid-template-columns:1fr}
  .portal-pv-grid{grid-template-columns:1fr}
  .portal-switcher{min-width:130px}
  .portal-access-grid{grid-template-columns:1fr 1fr}
}
