/* =========================================================================
   Dashboard cf-mcp · app.css
   Built on Colombia Fintech tokens (lib/colors_and_type.css)
   ========================================================================= */

/* ===== Reset-ish ===== */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
/* UA [hidden]{display:none} loses to component rules that set display.
   Force it so toggling .hidden via the attribute always works. */
[hidden] { display: none !important; }
body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  color: var(--fg-default);
  background: var(--bg-canvas);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
button { font-family: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
input, select, textarea { font-family: inherit; font-size: inherit; color: inherit; }

/* Tweak-driven density vars (overridden by JS). */
:root {
  --density-row-y: 14px;
  --density-fs:    14px;
}

/* =========================================================================
   App shell
   ========================================================================= */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-w, 240px) 1fr;
  min-height: 100vh;
  transition: grid-template-columns var(--dur-base) var(--ease-out);
}
.app[data-sidebar="collapsed"] { --sidebar-w: 76px; }

/* ===== Sidebar ===== */
.sidebar {
  background: var(--cf-navy);
  color: var(--fg-on-dark);
  display: flex;
  flex-direction: column;
  padding: 20px 14px 16px;
  gap: 22px;
  position: sticky;
  top: 0;
  height: 100vh;
  border-right: 1px solid color-mix(in oklab, #000 25%, var(--cf-navy));
}

.sidebar__brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 8px 14px;
  border-bottom: 1px solid color-mix(in oklab, var(--fg-on-dark) 12%, transparent);
}
.sidebar__mark {
  width: 32px; height: 32px;
  background: var(--cf-mint);
  border-radius: 9px;
  display: grid; place-items: center;
  flex: none;
  color: var(--cf-navy);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -0.04em;
}
.sidebar__wordmark { display: flex; flex-direction: column; line-height: 1.1; }
.sidebar__wordmark strong {
  font-family: var(--font-display); font-weight: 500;
  font-size: 14px; letter-spacing: -0.01em;
}
.sidebar__wordmark span {
  font-family: var(--font-mono);
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-mono-tag);
  color: color-mix(in oklab, var(--fg-on-dark) 60%, transparent);
  margin-top: 3px;
}
.app[data-sidebar="collapsed"] .sidebar__wordmark { display: none; }

.sidebar__group { display: flex; flex-direction: column; gap: 2px; }
.sidebar__group-label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-mono-tag);
  color: color-mix(in oklab, var(--fg-on-dark) 50%, transparent);
  padding: 0 10px 8px;
}
.app[data-sidebar="collapsed"] .sidebar__group-label { display: none; }

.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 10px;
  border-radius: var(--radius-md);
  font-size: 14px;
  color: color-mix(in oklab, var(--fg-on-dark) 78%, transparent);
  background: transparent;
  border: 0;
  text-align: left;
  width: 100%;
  position: relative;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.nav-item:hover {
  background: color-mix(in oklab, var(--fg-on-dark) 8%, transparent);
  color: var(--fg-on-dark);
}
.nav-item[aria-current="page"] {
  background: color-mix(in oklab, var(--cf-mint) 22%, transparent);
  color: #fff;
}
.nav-item[aria-current="page"]::before {
  content: "";
  position: absolute; left: -14px; top: 8px; bottom: 8px;
  width: 3px; border-radius: 0 3px 3px 0;
  background: var(--cf-mint);
}
.nav-item svg { flex: none; width: 18px; height: 18px; stroke-width: 1.6; }
.nav-item .nav-item__count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: var(--tracking-mono-tag);
  padding: 2px 7px;
  border-radius: var(--radius-pill);
  background: color-mix(in oklab, var(--fg-on-dark) 12%, transparent);
  color: color-mix(in oklab, var(--fg-on-dark) 80%, transparent);
}
.nav-item[data-locked="true"] {
  opacity: 0.45;
  cursor: not-allowed;
}
.nav-item .lock {
  margin-left: auto; width: 13px; height: 13px;
}
.app[data-sidebar="collapsed"] .nav-item { justify-content: center; padding: 10px; }
.app[data-sidebar="collapsed"] .nav-item__label,
.app[data-sidebar="collapsed"] .nav-item__count { display: none; }
.app[data-sidebar="collapsed"] .nav-item[aria-current="page"]::before { left: -14px; }

.sidebar__spacer { flex: 1; }

.sidebar__user {
  display: flex; align-items: center; gap: 10px;
  padding: 10px;
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in oklab, var(--fg-on-dark) 12%, transparent);
  background: color-mix(in oklab, var(--fg-on-dark) 4%, transparent);
}
.sidebar__user-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--cf-mint);
  color: var(--cf-navy);
  display: grid; place-items: center;
  font-weight: 600; font-size: 13px;
  flex: none;
}
.sidebar__user-meta { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; }
.sidebar__user-meta strong { font-size: 13px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sidebar__user-meta span {
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: var(--tracking-mono-tag); text-transform: uppercase;
  color: color-mix(in oklab, var(--fg-on-dark) 60%, transparent);
  margin-top: 2px;
}
.sidebar__user button {
  margin-left: auto;
  background: transparent;
  border: 0;
  color: color-mix(in oklab, var(--fg-on-dark) 70%, transparent);
  padding: 4px;
  border-radius: 6px;
}
.sidebar__user button:hover { background: color-mix(in oklab, var(--fg-on-dark) 10%, transparent); color: #fff; }
.app[data-sidebar="collapsed"] .sidebar__user { padding: 0; border: 0; background: transparent; justify-content: center; }
.app[data-sidebar="collapsed"] .sidebar__user-meta,
.app[data-sidebar="collapsed"] .sidebar__user button { display: none; }

/* ===== Main column ===== */
.main { display: flex; flex-direction: column; min-width: 0; }

.topbar {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 14px 32px;
  border-bottom: 1px solid var(--border-subtle);
  background: var(--bg-canvas);
  position: sticky; top: 0; z-index: 30;
  backdrop-filter: blur(6px);
}
.topbar__crumbs {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 10.5px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted);
}
.topbar__crumbs .sep { opacity: 0.5; }
.topbar__crumbs .current { color: var(--fg-strong); }

.topbar__search {
  margin-left: auto;
  position: relative;
  width: 320px;
}
.topbar__search input {
  width: 100%;
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 9px 14px 9px 38px;
  font-size: 13.5px;
  color: var(--fg-default);
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.topbar__search input::placeholder { color: var(--fg-subtle); }
.topbar__search input:focus { border-color: var(--cf-navy); box-shadow: 0 0 0 3px color-mix(in oklab, var(--cf-navy) 10%, transparent); }
.topbar__search svg {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  width: 16px; height: 16px; color: var(--fg-muted);
  pointer-events: none;
}
.topbar__search kbd {
  position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em;
  color: var(--fg-subtle);
  background: var(--bg-subtle);
  padding: 2px 6px;
  border-radius: 5px;
}

.icon-btn {
  position: relative;
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border-radius: var(--radius-md);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  color: var(--fg-default);
}
.icon-btn:hover { background: var(--bg-subtle); }
.icon-btn svg { width: 16px; height: 16px; stroke-width: 1.6; }
.icon-btn .dot {
  position: absolute; top: 9px; right: 10px; width: 7px; height: 7px;
  background: var(--cf-mint-deep); border-radius: 50%;
  border: 2px solid var(--bg-canvas);
}

.sync-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted);
  padding: 5px 10px;
  border-radius: var(--radius-pill);
  background: var(--bg-subtle);
  border: 1px solid var(--border-subtle);
}
.sync-badge .pulse {
  width: 6px; height: 6px; border-radius: 50%; background: var(--success);
  box-shadow: 0 0 0 0 color-mix(in oklab, var(--success) 60%, transparent);
  animation: pulse 2.2s var(--ease-out) infinite;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 color-mix(in oklab, var(--success) 50%, transparent); }
  70%  { box-shadow: 0 0 0 8px transparent; }
  100% { box-shadow: 0 0 0 0 transparent; }
}

/* ===== Page container ===== */
.page {
  padding: 28px 32px 60px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  min-width: 0;
}

.page__header { display: flex; align-items: flex-end; gap: 24px; flex-wrap: wrap; }
.page__title-block { flex: 1; min-width: 280px; }
.page__eyebrow {
  font-family: var(--font-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted);
  margin-bottom: 8px;
  display: inline-flex; align-items: center; gap: 8px;
}
.page__eyebrow .accent {
  width: 14px; height: 14px; border-radius: 4px;
  background: var(--cf-mint);
  display: inline-block;
}
.page__title {
  font-family: var(--font-display); font-weight: 500;
  font-size: 30px; line-height: 1.15;
  letter-spacing: -0.018em;
  color: var(--fg-strong);
}
.page__lede {
  margin-top: 8px;
  font-size: 14.5px;
  color: var(--fg-muted);
  max-width: 64ch;
  line-height: 1.55;
}
.page__actions { display: flex; gap: 8px; align-items: center; }

/* ===== Buttons ===== */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  height: 36px;
  padding: 0 14px;
  border-radius: var(--radius-pill);
  font-size: 13.5px;
  border: 1px solid transparent;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out);
}
.btn:active { transform: translateY(1px); }
.btn svg { width: 15px; height: 15px; stroke-width: 1.7; }
.btn--primary { background: var(--cf-navy); color: var(--fg-on-dark); }
.btn--primary:hover { background: var(--cf-navy-ink); }
.btn--mint { background: var(--cf-mint); color: var(--cf-navy); }
.btn--mint:hover { background: var(--cf-mint-200); }
.btn--ghost { background: transparent; color: var(--fg-default); border-color: var(--border-subtle); }
.btn--ghost:hover { background: var(--bg-subtle); border-color: var(--border-default); }
.btn--quiet { background: transparent; color: var(--fg-muted); }
.btn--quiet:hover { color: var(--fg-strong); background: var(--bg-subtle); }
.btn--sm { height: 30px; padding: 0 12px; font-size: 12.5px; }

/* ===== KPI cards ===== */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
}
.kpi {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 22px 22px 20px;
  display: flex; flex-direction: column; gap: 10px;
  position: relative; overflow: hidden;
}
.kpi__label {
  font-family: var(--font-mono); font-size: 10.5px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted);
}
.kpi__value {
  font-family: var(--font-display); font-weight: 500;
  font-size: 36px; line-height: 1;
  color: var(--fg-strong);
  letter-spacing: -0.025em;
  font-feature-settings: "tnum" 1;
}
.kpi__value .unit { font-size: 18px; color: var(--fg-muted); margin-left: 4px; letter-spacing: 0; }
.kpi__sub {
  display: flex; align-items: center; gap: 8px;
  font-size: 12.5px; color: var(--fg-muted);
}
.kpi__delta {
  display: inline-flex; align-items: center; gap: 3px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.04em;
  padding: 2px 7px;
  border-radius: var(--radius-pill);
}
.kpi__delta--up { color: var(--success); background: color-mix(in oklab, var(--success) 12%, transparent); }
.kpi__delta--down { color: var(--danger); background: color-mix(in oklab, var(--danger) 14%, transparent); }
.kpi__delta--flat { color: var(--fg-muted); background: var(--bg-subtle); }

.kpi--feature {
  background: var(--cf-navy);
  color: var(--fg-on-dark);
  position: relative;
}
.kpi--feature .kpi__label { color: color-mix(in oklab, var(--fg-on-dark) 70%, transparent); }
.kpi--feature .kpi__value { color: var(--fg-on-dark); }
.kpi--feature .kpi__sub { color: color-mix(in oklab, var(--fg-on-dark) 75%, transparent); }
.kpi--feature::after {
  /* signature stacked rounded-square motif */
  content: "";
  position: absolute; right: -18px; bottom: -18px; width: 110px; height: 110px;
  background:
    radial-gradient(circle at 30% 30%, color-mix(in oklab, var(--cf-mint) 32%, transparent), transparent 60%);
  pointer-events: none;
}
.kpi--mint { background: var(--bg-subtle); border-color: color-mix(in oklab, var(--cf-mint) 40%, transparent); }

/* Sparkline inside KPI */
.spark { width: 100%; height: 36px; margin-top: 2px; display: block; }

/* ===== Cards ===== */
.card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 22px 24px;
}
.card__head {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 18px;
}
.card__head h3 {
  font-family: var(--font-display); font-weight: 500;
  font-size: 17px; letter-spacing: -0.01em;
  margin: 0;
}
.card__head .eyebrow {
  font-family: var(--font-mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted);
}
.card__actions { margin-left: auto; display: flex; gap: 6px; align-items: center; }

/* ===== Filter bar ===== */
.filterbar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 14px 18px;
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
}
.filterbar__group { display: flex; align-items: center; gap: 6px; }
.filterbar__label {
  font-family: var(--font-mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted);
}
.select {
  height: 32px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 0 28px 0 12px;
  font-size: 13px;
  background: var(--bg-surface);
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232b3241' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 12px;
  color: var(--fg-default);
  cursor: pointer;
}
.select:focus { outline: 2px solid color-mix(in oklab, var(--cf-navy) 30%, transparent); outline-offset: 1px; }
.input {
  height: 32px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 0 12px 0 32px;
  font-size: 13px;
  background: var(--bg-surface) no-repeat 10px center;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23718096' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='7'/><line x1='21' y1='21' x2='16.65' y2='16.65'/></svg>");
  background-size: 14px;
  min-width: 220px;
}
.input:focus { outline: 2px solid color-mix(in oklab, var(--cf-navy) 30%, transparent); outline-offset: 1px; border-color: var(--cf-navy); }

.chip {
  display: inline-flex; align-items: center; gap: 6px;
  height: 26px; padding: 0 10px;
  border-radius: var(--radius-pill);
  background: var(--bg-subtle);
  border: 1px solid var(--border-subtle);
  font-size: 12px;
  color: var(--fg-default);
}
.chip button { background: transparent; border: 0; padding: 0; color: var(--fg-muted); display: grid; place-items: center; }
.chip button:hover { color: var(--fg-strong); }
.chip svg { width: 12px; height: 12px; stroke-width: 2; }

.chiprow { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }

.viewtoggle { display: inline-flex; padding: 3px; gap: 2px; background: var(--bg-subtle); border-radius: var(--radius-pill); border: 1px solid var(--border-subtle); margin-left: auto; }
.viewtoggle button {
  background: transparent;
  border: 0; padding: 4px 12px;
  border-radius: var(--radius-pill);
  font-size: 12px; color: var(--fg-muted);
  display: inline-flex; align-items: center; gap: 6px;
}
.viewtoggle button[aria-pressed="true"] { background: var(--bg-surface); color: var(--fg-strong); box-shadow: var(--shadow-xs); }
.viewtoggle svg { width: 13px; height: 13px; stroke-width: 1.7; }

/* ===== Badges / Segment chips ===== */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px;
  font-size: 11.5px;
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  border: 1px solid transparent;
  white-space: nowrap;
}
.badge .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; opacity: 0.8; }

.badge--activo    { background: color-mix(in oklab, var(--success) 13%, transparent); color: color-mix(in oklab, var(--success) 80%, var(--cf-navy)); }
.badge--proceso   { background: color-mix(in oklab, var(--warning) 16%, transparent); color: color-mix(in oklab, var(--warning) 60%, var(--cf-navy)); }
.badge--inactivo  { background: var(--bg-subtle); color: var(--fg-muted); }
.badge--prospecto { background: color-mix(in oklab, var(--info) 14%, transparent); color: color-mix(in oklab, var(--info) 70%, var(--cf-navy)); }

.seg-chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11.5px;
  padding: 2px 8px 2px 6px;
  border-radius: var(--radius-pill);
  background: var(--bg-subtle);
  border: 1px solid var(--border-subtle);
  color: var(--fg-default);
  font-family: var(--font-sans);
  white-space: nowrap;
}
.seg-chip .sq {
  width: 10px; height: 10px;
  border-radius: 3px;
  display: inline-block;
}
.cat-chip {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--tracking-mono-tag);
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  background: var(--bg-canvas);
  border: 1px solid var(--border-subtle);
  color: var(--fg-default);
  text-transform: uppercase;
}
.cat-chip--early      { background: color-mix(in oklab, var(--lfm-yellow) 35%, var(--bg-surface)); border-color: color-mix(in oklab, var(--lfm-yellow) 60%, transparent); }
.cat-chip--growth     { background: color-mix(in oklab, var(--cf-mint) 25%, var(--bg-surface)); border-color: color-mix(in oklab, var(--cf-mint) 45%, transparent); }
.cat-chip--enterprise { background: var(--cf-navy); color: var(--fg-on-dark); border-color: var(--cf-navy); }
.cat-chip--pasivo     { background: var(--bg-canvas); color: var(--fg-muted); }

/* ===== Table ===== */
.table-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.table-card__head {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border-subtle);
}
.table-card__count {
  font-family: var(--font-mono); font-size: 10.5px;
  letter-spacing: var(--tracking-mono-tag);
  text-transform: uppercase; color: var(--fg-muted);
}
.table-card__count strong { color: var(--fg-strong); font-weight: 500; }
.table-scroll { overflow-x: auto; }
.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--density-fs);
}
.table thead th {
  text-align: left;
  font-family: var(--font-mono); font-size: 10.5px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted);
  padding: 10px 16px;
  background: color-mix(in oklab, var(--bg-canvas) 50%, var(--bg-surface));
  border-bottom: 1px solid var(--border-subtle);
  font-weight: 500;
  white-space: nowrap;
}
.table thead th .sortable { display: inline-flex; align-items: center; gap: 4px; cursor: pointer; user-select: none; color: inherit; background: transparent; border: 0; padding: 0; font: inherit; letter-spacing: inherit; }
.table thead th svg { width: 11px; height: 11px; opacity: 0.6; }
.table tbody td {
  padding: var(--density-row-y) 16px;
  border-bottom: 1px solid color-mix(in oklab, var(--cf-navy) 6%, transparent);
  vertical-align: middle;
}
.table tbody tr:last-child td { border-bottom: none; }
.table tbody tr { transition: background var(--dur-fast) var(--ease-out); }
.table tbody tr:hover td { background: var(--bg-subtle); }
.table tbody tr[data-active="true"] td { background: color-mix(in oklab, var(--cf-mint) 18%, transparent); }
.table tbody tr { cursor: pointer; }

.table .empresa {
  display: flex; align-items: center; gap: 12px;
}
.table .empresa__avatar {
  width: 30px; height: 30px;
  border-radius: 8px;
  background: var(--bg-subtle);
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 500; font-size: 12px;
  color: var(--cf-navy);
  border: 1px solid var(--border-subtle);
  flex: none;
}
.table .empresa__name { display: flex; flex-direction: column; line-height: 1.25; min-width: 0; }
.table .empresa__name strong { font-weight: 500; font-size: 13.5px; color: var(--fg-strong); }
.table .empresa__name small { color: var(--fg-muted); font-size: 11.5px; }

.table .nit { font-family: var(--font-mono); font-size: 11px; color: var(--fg-muted); letter-spacing: 0.02em; }
.table .am {
  display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--fg-default);
}
.table .am-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--cf-mint); color: var(--cf-navy);
  display: grid; place-items: center;
  font-size: 10px; font-weight: 600;
}

.pagination {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 18px;
  border-top: 1px solid var(--border-subtle);
  font-size: 12.5px; color: var(--fg-muted);
}
.pagination .pages { margin-left: auto; display: flex; gap: 4px; }
.pagination .pages button {
  min-width: 28px; height: 28px;
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  background: var(--bg-surface);
  font-size: 12px;
  color: var(--fg-default);
  padding: 0 8px;
}
.pagination .pages button:hover { background: var(--bg-subtle); }
.pagination .pages button[aria-current="page"] { background: var(--cf-navy); color: var(--fg-on-dark); border-color: var(--cf-navy); }
.pagination .pages button[disabled] { opacity: 0.4; cursor: not-allowed; }

/* ===== Card grid (alt view) ===== */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.member-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 18px;
  display: flex; flex-direction: column; gap: 12px;
  transition: transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  cursor: pointer;
}
.member-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--border-default); }
.member-card__top { display: flex; align-items: flex-start; gap: 10px; }
.member-card__top .empresa__avatar { width: 36px; height: 36px; font-size: 13px; }
.member-card__name { font-weight: 500; font-size: 14.5px; color: var(--fg-strong); line-height: 1.25; }
.member-card__razon { font-size: 11.5px; color: var(--fg-muted); margin-top: 2px; }
.member-card__row { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--fg-muted); flex-wrap: wrap; }
.member-card__footer {
  display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid var(--border-subtle);
  padding-top: 10px;
  font-size: 11.5px; color: var(--fg-muted);
  font-family: var(--font-mono); letter-spacing: 0.04em; text-transform: uppercase;
}

/* ===== Drawer ===== */
.drawer-scrim {
  position: fixed; inset: 0;
  background: color-mix(in oklab, var(--cf-navy) 30%, transparent);
  opacity: 0; pointer-events: none;
  transition: opacity var(--dur-base) var(--ease-out);
  z-index: 80;
}
.drawer-scrim[data-open="true"] { opacity: 1; pointer-events: auto; }
.drawer {
  position: fixed; right: 0; top: 0; bottom: 0;
  width: min(620px, 50vw);
  background: var(--bg-surface);
  box-shadow: var(--shadow-lg);
  transform: translateX(100%);
  transition: transform var(--dur-base) var(--ease-out);
  z-index: 90;
  display: flex; flex-direction: column;
  border-left: 1px solid var(--border-default);
}
.drawer[data-open="true"] { transform: translateX(0); }
.drawer__head {
  padding: 22px 26px 18px;
  display: flex; align-items: flex-start; gap: 14px;
  border-bottom: 1px solid var(--border-subtle);
}
.drawer__head .empresa__avatar { width: 44px; height: 44px; font-size: 16px; }
.drawer__head h2 { font-family: var(--font-display); font-weight: 500; font-size: 22px; margin: 0; letter-spacing: -0.015em; }
.drawer__head .meta { font-size: 12.5px; color: var(--fg-muted); margin-top: 4px; }
.drawer__close { margin-left: auto; }
.drawer__body { flex: 1; overflow-y: auto; padding: 22px 26px 40px; display: flex; flex-direction: column; gap: 26px; }
.drawer__section h4 {
  font-family: var(--font-mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted); margin: 0 0 12px;
  font-weight: 500;
}
.drawer__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.drawer__stat {
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 12px;
}
.drawer__stat .v { font-family: var(--font-display); font-size: 22px; font-weight: 500; letter-spacing: -0.02em; font-feature-settings: "tnum" 1; }
.drawer__stat .l { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: var(--tracking-mono-tag); color: var(--fg-muted); margin-top: 4px; }

.contact-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid color-mix(in oklab, var(--cf-navy) 6%, transparent);
}
.contact-row:last-child { border-bottom: 0; }
.contact-row .avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--bg-subtle); color: var(--cf-navy);
  display: grid; place-items: center; font-size: 11.5px; font-weight: 500;
  flex: none;
}
.contact-row .info { display: flex; flex-direction: column; line-height: 1.25; min-width: 0; flex: 1; }
.contact-row .info strong { font-weight: 500; font-size: 13px; }
.contact-row .info span { font-size: 11.5px; color: var(--fg-muted); }
.contact-row .info a { color: var(--fg-muted); font-size: 11.5px; text-decoration: none; }
.contact-row .info a:hover { color: var(--cf-navy); text-decoration: underline; }

.timeline { display: flex; flex-direction: column; gap: 0; position: relative; }
.timeline__item { display: flex; gap: 14px; padding: 10px 0; position: relative; }
.timeline__item::before {
  content: ""; position: absolute; left: 6px; top: 22px; bottom: -6px; width: 1px;
  background: color-mix(in oklab, var(--cf-navy) 12%, transparent);
}
.timeline__item:last-child::before { display: none; }
.timeline__dot { width: 13px; height: 13px; border-radius: 50%; background: var(--cf-mint); flex: none; margin-top: 4px; border: 2px solid var(--bg-surface); box-shadow: 0 0 0 1px var(--border-subtle); }
.timeline__content { display: flex; flex-direction: column; line-height: 1.35; }
.timeline__title { font-size: 13px; font-weight: 500; }
.timeline__meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-muted); margin-top: 2px; }

/* ===== Section grids ===== */
.grid-2 { display: grid; grid-template-columns: 2fr 1fr; gap: 18px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 1100px) {
  .grid-2 { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .grid-3 { grid-template-columns: 1fr; }
}

/* ===== Charts (vanilla SVG) ===== */
.chart-wrap { width: 100%; }
.chart-legend { display: flex; flex-wrap: wrap; gap: 10px 18px; margin-top: 14px; }
.chart-legend .item {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 12px; color: var(--fg-default);
}
.chart-legend .sq { width: 11px; height: 11px; border-radius: 3px; }
.chart-legend .v { color: var(--fg-muted); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; margin-left: 6px; }

/* Heatmap */
.heat {
  display: grid;
  grid-template-columns: 110px repeat(12, 1fr);
  gap: 4px;
  font-size: 11.5px;
}
.heat__col, .heat__row-label { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: var(--tracking-mono-tag); color: var(--fg-muted); }
.heat__col { text-align: center; padding-bottom: 8px; }
.heat__row-label { display: flex; align-items: center; gap: 6px; padding-right: 8px; }
.heat__cell {
  aspect-ratio: 1.4 / 1;
  border-radius: 6px;
  background: var(--cf-mint);
  cursor: pointer;
  position: relative;
  display: grid; place-items: center;
  font-family: var(--font-mono); font-size: 11px; color: var(--cf-navy);
  border: 1px solid transparent;
  transition: transform var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.heat__cell:hover { transform: scale(1.06); border-color: var(--cf-navy); z-index: 2; }
.heat__cell[data-active="true"] { border-color: var(--cf-navy); box-shadow: 0 0 0 2px var(--cf-navy); }
.heat__cell.zero { background: var(--bg-subtle); color: var(--fg-subtle); cursor: default; }
.heat__cell.zero:hover { transform: none; border-color: transparent; }
.heat__legend { display: flex; align-items: center; gap: 8px; margin-top: 14px; font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-mono-tag); text-transform: uppercase; color: var(--fg-muted); }
.heat__legend-scale { display: flex; gap: 2px; }
.heat__legend-scale span { width: 16px; height: 12px; border-radius: 3px; }

/* ===== Empty / locked states ===== */
.empty {
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  padding: 60px 24px;
  gap: 14px;
  color: var(--fg-muted);
  border: 1px dashed var(--border-default);
  border-radius: var(--radius-lg);
  background: var(--bg-surface);
}
.empty__icon {
  width: 56px; height: 56px;
  border-radius: var(--radius-md);
  display: grid; place-items: center;
  background: var(--bg-subtle);
  color: var(--cf-navy);
}
.empty__icon svg { width: 26px; height: 26px; stroke-width: 1.4; }
.empty h3 { font-family: var(--font-display); font-size: 20px; font-weight: 500; color: var(--fg-strong); letter-spacing: -0.01em; margin: 0; }
.empty p { max-width: 44ch; font-size: 14px; line-height: 1.55; margin: 0; }

/* ===== Roadmap banner (B sections) ===== */
.roadmap-banner {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  border-radius: var(--radius-md);
  background: color-mix(in oklab, var(--lfm-yellow) 28%, var(--bg-surface));
  border: 1px solid color-mix(in oklab, var(--lfm-yellow) 50%, transparent);
  font-size: 13px;
  color: var(--fg-strong);
}
.roadmap-banner svg { width: 16px; height: 16px; flex: none; color: color-mix(in oklab, var(--warning) 70%, var(--cf-navy)); }
.roadmap-banner b { font-weight: 500; }
.roadmap-banner .tag {
  margin-left: auto;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: var(--tracking-mono-tag); text-transform: uppercase;
  color: var(--fg-muted);
}

/* ===== Skeleton ===== */
.skeleton { background: linear-gradient(90deg, var(--bg-subtle) 0%, var(--bg-canvas) 50%, var(--bg-subtle) 100%); background-size: 200% 100%; animation: shimmer 1.4s var(--ease-in-out) infinite; border-radius: 6px; height: 14px; }
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ===== Login ===== */
.login {
  position: fixed; inset: 0; z-index: 200;
  display: grid; grid-template-columns: 1fr 1fr;
  background: var(--bg-canvas);
}
.login__brand {
  background: var(--cf-navy);
  color: var(--fg-on-dark);
  padding: 56px;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
}
.login__brand .mark-row { display: flex; align-items: center; gap: 10px; }
.login__brand .mark-row strong { font-family: var(--font-display); font-size: 16px; font-weight: 500; }
.login__brand .mark-row span { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-mono-tag); text-transform: uppercase; opacity: 0.7; }
.login__brand h1 {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1.05; letter-spacing: -0.025em;
  margin: auto 0 18px;
  max-width: 14ch;
  color: var(--fg-on-dark);
}
.login__brand p {
  font-size: 15px; line-height: 1.6;
  max-width: 42ch;
  color: color-mix(in oklab, var(--fg-on-dark) 75%, transparent);
  margin: 0 0 36px;
}
.login__brand .footer { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-mono-tag); text-transform: uppercase; color: color-mix(in oklab, var(--fg-on-dark) 55%, transparent); display: flex; gap: 24px; }
.login__shapes {
  position: absolute; right: -120px; top: -120px; width: 520px; height: 520px;
  pointer-events: none;
}
.login__shapes div {
  position: absolute;
  border-radius: 60px;
  background: var(--cf-mint);
  opacity: 0.18;
}
.login__shapes div:nth-child(1) { width: 300px; height: 300px; right: 20px; top: 40px; }
.login__shapes div:nth-child(2) { width: 220px; height: 220px; right: 200px; top: 220px; background: var(--cf-mint-deep); opacity: 0.22; }
.login__shapes div:nth-child(3) { width: 140px; height: 140px; right: 80px; top: 360px; background: var(--lfm-teal); opacity: 0.18; }

.login__form {
  padding: 56px; display: grid; place-items: center;
}
.login__form-inner { width: min(420px, 100%); display: flex; flex-direction: column; gap: 22px; }
.login__form-inner .eyebrow {
  font-family: var(--font-mono); font-size: 10.5px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted);
}
.login__form-inner h2 { font-family: var(--font-display); font-weight: 500; font-size: 28px; letter-spacing: -0.015em; margin: 0; }
.login__form-inner .sub { font-size: 14px; color: var(--fg-muted); margin-top: -10px; line-height: 1.5; }
.google-btn {
  height: 48px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-default);
  background: var(--bg-surface);
  display: flex; align-items: center; justify-content: center; gap: 10px;
  font-size: 14.5px; font-weight: 500; color: var(--fg-strong);
  transition: background var(--dur-fast) var(--ease-out);
}
.google-btn:hover { background: var(--bg-subtle); }
.login__fine {
  font-size: 11.5px; color: var(--fg-muted); line-height: 1.55;
  border-top: 1px solid var(--border-subtle); padding-top: 16px;
}
@media (max-width: 880px) {
  .login { grid-template-columns: 1fr; }
  .login__brand { padding: 32px; }
  .login__form { padding: 32px; }
}

/* ===== Notification popover ===== */
.notif-pop {
  position: absolute; right: 24px; top: 58px;
  width: 360px;
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 0;
  z-index: 100;
  display: none;
  overflow: hidden;
}
.notif-pop[data-open="true"] { display: block; animation: pop-in 180ms var(--ease-out); }
@keyframes pop-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.notif-pop__head {
  display: flex; align-items: center;
  padding: 12px 14px;
  border-bottom: 1px solid var(--border-subtle);
}
.notif-pop__head strong { font-family: var(--font-display); font-weight: 500; font-size: 14px; flex: 1; }
.notif-pop__head .count {
  font-family: var(--font-mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: var(--tracking-mono-tag);
  color: var(--fg-muted);
  background: var(--bg-subtle);
  padding: 2px 7px;
  border-radius: var(--radius-pill);
}
.notif-pop__list { max-height: 360px; overflow-y: auto; }
.notif-item {
  display: flex; gap: 11px;
  padding: 11px 14px;
  border-bottom: 1px solid var(--border-subtle);
  text-align: left;
  background: transparent;
  border-left: 0; border-right: 0; border-top: 0;
  cursor: pointer;
  width: 100%;
}
.notif-item:hover { background: var(--bg-subtle); }
.notif-item:last-child { border-bottom: 0; }
.notif-item__icon {
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center;
  flex: none;
}
.notif-item__icon--warning { background: color-mix(in oklab, var(--warning) 18%, transparent); color: color-mix(in oklab, var(--warning) 70%, var(--cf-navy)); }
.notif-item__icon--info    { background: color-mix(in oklab, var(--info) 16%, transparent);    color: color-mix(in oklab, var(--info) 75%, var(--cf-navy)); }
.notif-item__icon--success { background: color-mix(in oklab, var(--success) 16%, transparent); color: color-mix(in oklab, var(--success) 75%, var(--cf-navy)); }
.notif-item__content { display: flex; flex-direction: column; gap: 3px; line-height: 1.35; min-width: 0; }
.notif-item__title { font-size: 13px; font-weight: 500; color: var(--fg-strong); }
.notif-item__body { font-size: 11.5px; color: var(--fg-muted); }
.notif-item__time {
  font-family: var(--font-mono); font-size: 9.5px;
  letter-spacing: var(--tracking-mono-tag); text-transform: uppercase;
  color: var(--fg-subtle); margin-top: 2px;
}
.notif-pop__foot {
  padding: 10px 14px;
  border-top: 1px solid var(--border-subtle);
  text-align: center;
  background: var(--bg-subtle);
}
.notif-pop__foot a { font-size: 12px; color: var(--fg-default); }

/* ===== Network error banner ===== */
.net-banner {
  display: flex; align-items: center; gap: 12px;
  margin: 14px 32px 0;
  padding: 12px 16px;
  background: color-mix(in oklab, var(--danger) 8%, var(--bg-surface));
  border: 1px solid color-mix(in oklab, var(--danger) 40%, transparent);
  border-radius: var(--radius-md);
  color: var(--fg-strong);
  font-size: 13.5px;
  animation: pop-in 200ms var(--ease-out);
}
.net-banner svg { color: var(--danger); flex: none; }
.net-banner b { font-weight: 500; margin-right: 6px; }

/* ===== Kebab / row actions popover ===== */
.row-actions {
  position: relative;
  display: inline-block;
}
.row-actions__menu {
  position: absolute;
  right: 0; top: calc(100% + 4px);
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: 4px;
  min-width: 200px;
  z-index: 20;
  display: none;
  animation: pop-in 140ms var(--ease-out);
}
.row-actions[data-open="true"] .row-actions__menu { display: block; }
.row-actions__menu button {
  display: flex; align-items: center; gap: 10px;
  width: 100%;
  background: transparent; border: 0;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  font-size: 13px; color: var(--fg-default);
  text-align: left;
  cursor: pointer;
}
.row-actions__menu button:hover { background: var(--bg-subtle); }
.row-actions__menu button svg { width: 14px; height: 14px; stroke-width: 1.7; color: var(--fg-muted); }
.row-actions__menu hr { border: 0; border-top: 1px solid var(--border-subtle); margin: 4px 0; }

/* ===== Columns toggle popover ===== */
.cols-pop {
  position: absolute;
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: 10px 4px;
  min-width: 210px;
  z-index: 30;
  display: none;
  animation: pop-in 140ms var(--ease-out);
}
.cols-pop[data-open="true"] { display: block; }
.cols-pop label {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 12px;
  font-size: 13px;
  cursor: pointer;
  border-radius: var(--radius-sm);
}
.cols-pop label:hover { background: var(--bg-subtle); }
.cols-pop input[type="checkbox"] {
  accent-color: var(--cf-navy);
  width: 14px; height: 14px;
}

/* ===== Sticky table head ===== */
.table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
}

/* ===== Drawer prev/next ===== */
.drawer__nav {
  display: inline-flex; gap: 4px;
  margin-right: 8px;
}
.drawer__nav button {
  width: 30px; height: 30px;
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  display: grid; place-items: center;
  color: var(--fg-default);
  cursor: pointer;
}
.drawer__nav button:hover { background: var(--bg-subtle); }
.drawer__nav button[disabled] { opacity: 0.4; cursor: not-allowed; }

/* ===== Skeleton loader content ===== */
.sk-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 22px;
  display: flex; flex-direction: column; gap: 10px;
}
.sk-line { height: 12px; border-radius: 4px; }
.sk-line.l { width: 100%; }
.sk-line.m { width: 70%; }
.sk-line.s { width: 40%; }
.sk-line.xl { height: 36px; width: 60%; }
.sk-line.t  { height: 8px; }

/* ===== "v360 not available" hint in drawer ===== */
.v360-hint {
  display: flex; gap: 12px;
  padding: 14px;
  background: color-mix(in oklab, var(--lfm-yellow) 22%, var(--bg-surface));
  border: 1px solid color-mix(in oklab, var(--lfm-yellow) 50%, transparent);
  border-radius: var(--radius-md);
  font-size: 12.5px; line-height: 1.5;
}
.v360-hint svg { color: color-mix(in oklab, var(--warning) 70%, var(--cf-navy)); flex: none; }
.v360-hint b { font-weight: 500; }

/* ===== Source tag — labels which view a chunk of data comes from ===== */
.source-tag {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: 9.5px;
  letter-spacing: var(--tracking-mono-tag); text-transform: uppercase;
  color: var(--fg-subtle);
  padding: 2px 8px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-pill);
  background: var(--bg-canvas);
}
.source-tag .sq { width: 6px; height: 6px; border-radius: 2px; background: var(--cf-mint-deep); }
.source-tag--proposed .sq { background: var(--warning); }
.source-tag--roadmap .sq  { background: var(--ft-peach); }

/* ===== Hash route highlight in nav ===== */
.nav-item[data-locked="true"] svg.lock { display: inline-block; }

/* ===== Heatmap cell is now <button> ===== */
.heat__cell {
  border: 1px solid transparent;
  background: var(--cf-mint);
  padding: 0;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--cf-navy);
}
.heat__cell:focus-visible { outline: 2px solid var(--cf-navy); outline-offset: 1px; z-index: 3; }

/* ===== Table row focusability ===== */
.table tbody tr:focus { outline: 2px solid color-mix(in oklab, var(--cf-navy) 50%, transparent); outline-offset: -2px; background: var(--bg-subtle); }

/* ===== Fuzzy hint inside empty state ===== */
.fuzzy-hint {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--bg-subtle);
  border: 1px solid var(--border-subtle);
  padding: 6px 12px;
  border-radius: var(--radius-pill);
  font-size: 12.5px;
  margin-top: 12px;
}
.fuzzy-hint button {
  background: transparent; border: 0; padding: 0;
  font-weight: 500;
  color: var(--cf-navy);
  text-decoration: underline;
  cursor: pointer;
}

/* ===== Tweaks panel ===== */
.tweaks {
  position: fixed; right: 18px; bottom: 18px; z-index: 150;
  width: 280px;
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 14px;
  font-size: 13px;
  display: none;
  flex-direction: column;
  gap: 12px;
}
.tweaks[data-open="true"] { display: flex; }
.tweaks__head { display: flex; align-items: center; gap: 10px; }
.tweaks__head strong { font-family: var(--font-display); font-weight: 500; font-size: 15px; flex: 1; }
.tweaks__head button { background: transparent; border: 0; padding: 4px; color: var(--fg-muted); display: grid; place-items: center; }
.tweaks__head button:hover { color: var(--fg-strong); }
.tweaks__row { display: flex; flex-direction: column; gap: 6px; }
.tweaks__row label { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: var(--tracking-mono-tag); color: var(--fg-muted); }
.tweaks__seg { display: flex; gap: 2px; padding: 2px; background: var(--bg-subtle); border: 1px solid var(--border-subtle); border-radius: var(--radius-pill); }
.tweaks__seg button {
  flex: 1; background: transparent; border: 0; padding: 6px 10px;
  font-size: 12px; color: var(--fg-muted);
  border-radius: var(--radius-pill);
}
.tweaks__seg button[aria-pressed="true"] { background: var(--bg-surface); color: var(--fg-strong); box-shadow: var(--shadow-xs); }

/* ===== Misc helpers ===== */
.hidden { display: none !important; }
.row { display: flex; align-items: center; gap: 10px; }
.muted { color: var(--fg-muted); }
.mono { font-family: var(--font-mono); letter-spacing: var(--tracking-wide); text-transform: uppercase; font-size: 11px; }

/* Responsive: sidebar -> drawer */
@media (max-width: 880px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { position: fixed; left: 0; top: 0; bottom: 0; width: 240px; z-index: 60; transform: translateX(-100%); transition: transform var(--dur-base) var(--ease-out); }
  .app[data-mobile-nav="open"] .sidebar { transform: translateX(0); box-shadow: var(--shadow-lg); }
  .topbar { padding: 12px 16px; }
  .topbar__search { display: none; }
  .page { padding: 18px 16px 60px; }
  .drawer { width: 100vw; }
}
