/* ─────────────────────────────────────────────────────────────
   Fluxia — app.css v0.3
   Source: Fluxia Brief.md + Fluxia Brand.html (v0.1 · mai 2026)

   SSR painel styles. Pure CSS. Loads AFTER tokens.css.

   PRODUCT DEFAULT THEME = LIGHT. Set data-theme="light" on <html>.
   Dark mode: data-theme="dark".

   Token discipline: every color uses --paper / --ink / --line /
   --muted / --copper / --state-*. These swap meaning between
   modes (paper = bg in light, ink-swap in dark) so a single
   rule works in both.

   Sections:
     1. Reset / base
     2. Typography helpers
     3. Layout shell (.app, .sidebar, .topbar, .page)
     4. Page header
     5. Cards (.card)
     6. Buttons (.btn-primary / -secondary / -link / -danger / -icon)
     7. Forms (.field, .input — UNDERLINE style, .select, .textarea, .checkbox)
     8. Tables (.admin-table, .edit-row)
     9. Pills + role chips (.pill, .role)
    10. Filter bar (.filter-bar)
    11. Stats / KPI tiles
    12. Progress + P45 meter (.gauge)
    13. Alerts
    14. Tabs
    15. Empty state
    16. Utilities
    17. Responsive
   ───────────────────────────────────────────────────────────── */


/* 1. ── Reset / base ───────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
a.link { color: var(--copper); }
a.link:hover { text-decoration: underline; }

button { font: inherit; cursor: pointer; }
input, textarea, select { font: inherit; color: inherit; }
img, svg { display: block; max-width: 100%; }

::selection { background: var(--copper-soft); color: var(--copper-2); }
[data-theme="dark"] ::selection { color: var(--copper); }

:focus-visible {
  outline: 2px solid var(--copper);
  outline-offset: 2px;
  border-radius: var(--radius-soft);
}


/* 2. ── Typography helpers ────────────────────────────────── */
.t-mono   { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.t-tnum   { font-variant-numeric: tabular-nums; }
.t-muted  { color: var(--muted); }
.t-faint  { color: var(--faint); }
.t-ink    { color: var(--ink); }
.t-copper { color: var(--copper); }
.t-teal   { color: var(--teal); }
.t-ok     { color: var(--state-ok); }
.t-warn   { color: var(--state-warn); }
.t-alert  { color: var(--state-alert); }

/* Eyebrow — block label. Mono uppercase, +12 % tracking. */
.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
}
.eyebrow .dot { color: var(--copper); margin: 0 6px; }

.t-display {
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-display);
  margin: 0;
}
.t-h1 {
  font-size: var(--fs-h1);
  line-height: var(--lh-h1);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-h1);
  margin: 0;
}
.t-h2 {
  font-size: var(--fs-h2);
  line-height: var(--lh-h2);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-h2);
  margin: 0;
}
.t-h3 {
  font-size: var(--fs-h3);
  line-height: var(--lh-h3);
  font-weight: var(--fw-medium);
  margin: 0;
}
.t-body-l { font-size: var(--fs-body-l); line-height: var(--lh-body-l); }
.t-body-s { font-size: var(--fs-body-s); line-height: var(--lh-body-s); }

/* The dot — copper accent that completes the "fluxia." wordmark
   and reappears as the active-state indicator across the system. */
.dot {
  color: var(--copper);
  font-weight: inherit;
}


/* 3. ── Layout shell ──────────────────────────────────────── */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: 100vh;
}

/* .sidebar — paper-shade panel. ink text. mono numbers as counts.
   In light mode: #E8E1D2 bg. In dark: #101113 bg. */
.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--paper-shade);
  color: var(--ink);
  border-right: 1px solid var(--line);
  overflow: hidden;
}
.sidebar__head {
  padding: 22px 20px 18px;
}
.sidebar__brand {
  display: inline-flex;
  align-items: baseline;
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  font-size: 22px;
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--ink);
}
.sidebar__brand .dot { font-weight: var(--fw-medium); }
.sidebar__tagline {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.sidebar__nav {
  flex: 1;
  padding: 8px 10px 12px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.sidebar__section {
  margin-top: 4px;
}

.sidebar__group {
  padding: 18px 10px 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}

.sidebar__group-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  margin: 0;
  padding: 14px 10px 6px;
  border: 0;
  background: transparent;
  cursor: pointer;
  text-align: left;
  border-radius: var(--radius-soft);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}

.sidebar__group-toggle:hover {
  background: var(--paper);
  color: var(--muted);
}

.sidebar__section.is-open .sidebar__group-toggle {
  color: var(--ink);
}

.sidebar__group-label {
  flex: 1;
}

.sidebar__chevron {
  width: 12px;
  height: 12px;
  flex: none;
  color: var(--muted);
  transition: transform var(--t-fast) var(--ease);
}

.sidebar__section.is-open .sidebar__chevron {
  transform: rotate(90deg);
}

.sidebar__item--maintenance {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: var(--radius-soft);
  color: var(--muted);
}

.sidebar__maint-badge {
  margin-left: auto;
  font-size: 9px;
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--paper);
  border: 1px solid var(--line);
  color: var(--muted);
}

.module-maintenance-screen {
  max-width: 520px;
  margin: 2rem auto;
  padding: 2rem 2.5rem;
  text-align: center;
}

.module-maintenance-screen__badge {
  display: inline-block;
  font-size: var(--fs-label);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-bottom: 1rem;
}

.module-maintenance-screen h2 {
  margin: 0 0 0.75rem;
  font-size: var(--fs-title);
}

.module-maintenance-screen__hint {
  margin-top: 1.5rem;
}

.sidebar__section-body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.2s var(--ease);
}

.sidebar__section.is-open .sidebar__section-body {
  grid-template-rows: 1fr;
}

.sidebar__section-inner {
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding-bottom: 4px;
}
.sidebar__item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 8px 10px;
  color: var(--ink);
  font-size: var(--fs-body-s);
  font-weight: var(--fw-regular);
  line-height: 1.2;
  text-decoration: none;
  user-select: none;
  border-radius: var(--radius-soft);
}
.sidebar__item:hover {
  background: var(--paper);
  color: var(--ink);
}
.sidebar__item[aria-current="page"],
.sidebar__item.is-active {
  background: var(--paper-light);
  color: var(--ink);
  font-weight: var(--fw-medium);
}
.sidebar__item .ico {
  width: 16px; height: 16px;
  flex: none;
  color: var(--muted);
}
.sidebar__item:hover .ico,
.sidebar__item[aria-current="page"] .ico,
.sidebar__item.is-active .ico { color: var(--ink); }

.sidebar__item-count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}
.sidebar__item[aria-current="page"] .sidebar__item-count,
.sidebar__item.is-active .sidebar__item-count { color: var(--copper); }

.sidebar__foot {
  padding: 12px 14px 16px;
  border-top: 1px solid var(--line);
}
.sidebar__user {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 6px;
  color: var(--ink);
  border-radius: var(--radius-soft);
}
.sidebar__user:hover { background: var(--paper); }
.sidebar__avatar {
  width: 30px; height: 30px;
  flex: none;
  display: grid; place-items: center;
  background: var(--ink);
  color: var(--paper);
  border-radius: 50%;
  font-size: 11px;
  font-weight: var(--fw-medium);
  font-family: var(--font-mono);
}
.sidebar__uname {
  font-size: var(--fs-body-s);
  font-weight: var(--fw-medium);
  line-height: 1.2;
  color: var(--ink);
}
.sidebar__urole {
  margin-top: 3px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}

/* .main — right side */
.main {
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 100vh;
  background: var(--paper);
}

/* .topbar — sticky chrome. Breadcrumb in mono uppercase. */
.topbar {
  position: sticky; top: 0;
  z-index: var(--z-sticky);
  height: var(--topbar-h);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 0 var(--gutter);
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.topbar__crumb {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
}
.topbar__crumb b   { color: var(--ink); font-weight: var(--fw-medium); }
.topbar__crumb .sep { color: var(--faint); }
.topbar__actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Ocultar valores (global) */
.hide-values-toggle .ico--eye-off {
  display: none;
}
.hide-values-toggle.is-active {
  background: var(--copper-soft, var(--paper-shade));
  color: var(--copper);
}
.hide-values-toggle.is-active .ico--eye-on {
  display: none;
}
.hide-values-toggle.is-active .ico--eye-off {
  display: block;
}

html[data-hide-values="true"] [data-fluxia-sensitive] {
  filter: blur(8px);
  user-select: none;
  pointer-events: none;
}

html[data-hide-values="true"] input.input--money,
html[data-hide-values="true"] input[inputmode="decimal"].js-charge-amount-partial {
  -webkit-text-security: disc;
  text-security: disc;
  color: transparent;
}

html[data-hide-values="true"] .pix-copy-code {
  filter: blur(6px);
  user-select: none;
}

/* .page — content wrapper */
.page {
  flex: 1;
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-6) var(--gutter) var(--space-9);
}


/* 4. ── Page header ───────────────────────────────────────── */
.page-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.page-header__copy { min-width: 0; }
.page-header__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 12px;
}
.page-header__eyebrow .dot { color: var(--copper); margin: 0 6px; }
.page-header__title {
  font-size: var(--fs-h1);
  line-height: var(--lh-h1);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-h1);
  margin: 0;
}
.page-header__sub {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: var(--fs-body);
  max-width: 64ch;
}
.page-header__actions {
  display: flex;
  gap: 8px;
  flex: none;
}


/* 5. ── Cards ─────────────────────────────────────────────── */
/* Brand is matte: 1 px line on paper-light. No radius. No shadow. */
.card {
  background: var(--paper-light);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
}
.card__title {
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
  letter-spacing: -0.005em;
}
.card__sub {
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
}
.card__body  { padding: 20px; }
.card__body--flush { padding: 0; }
.card__foot {
  padding: 14px 20px;
  background: var(--paper-shade);
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}


/* 6. ── Buttons ───────────────────────────────────────────── */
/* Hierarchy:
     .btn-primary    — ink fill   (auto-swaps in dark to paper fill)
     .btn-secondary  — bordered, transparent bg
     .btn-link       — copper text, no bg
     .btn-danger     — alert bordered
     .btn-icon       — 32 px square, no label
   "Sem botões coloridos. Sem cobre em botões." (brief §7.3) */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 36px;
  padding: 0 18px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  font-family: var(--font-sans);
  font-size: var(--fs-body-s);
  font-weight: var(--fw-medium);
  letter-spacing: 0;
  white-space: nowrap;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease),
              color var(--t-fast) var(--ease);
}
.btn:disabled,
.btn[aria-disabled="true"] {
  opacity: 0.4;
  pointer-events: none;
}
.btn .ico { width: 14px; height: 14px; }
.btn--sm  { height: 30px; padding: 0 12px; font-size: var(--fs-label); }
.btn--lg  { height: 42px; padding: 0 22px; font-size: var(--fs-body); }

.btn-primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.btn-primary:hover  { background: var(--muted);  border-color: var(--muted); }
.btn-primary:active { opacity: 0.85; }

.btn-secondary {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
}
.btn-secondary:hover  { background: var(--paper-shade); }
.btn-secondary:active { background: var(--line); }

.btn-link {
  background: transparent;
  color: var(--copper);
  border-color: transparent;
  height: auto;
  padding: 0;
  font-weight: var(--fw-medium);
}
.btn-link:hover { text-decoration: underline; }

.btn-danger {
  background: transparent;
  color: var(--state-alert);
  border: 1px solid var(--state-alert);
}
.btn-danger:hover { background: var(--state-alert-soft); }

.btn-icon {
  width: 32px; height: 32px;
  padding: 0;
  display: inline-grid; place-items: center;
  border: 1px solid transparent;
  border-radius: var(--radius-soft);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.btn-icon:hover { background: var(--paper-shade); color: var(--ink); }
.btn-icon .ico { width: 16px; height: 16px; }


/* 7. ── Forms ─────────────────────────────────────────────── */
/* "Inputs: borda inferior apenas (estilo planilha), não box.
   Background transparente. Padding 10×0." — brief §7.4 */
.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.field__label {
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
}
.field__hint  { font-size: 12px; color: var(--muted); }
.field__error { font-size: 12px; color: var(--state-alert); }

.input,
.select,
.textarea {
  width: 100%;
  padding: 10px 0;
  border: 0;
  border-bottom: 1px solid var(--line-2);
  background: transparent;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  color: var(--ink);
  outline: none;
  border-radius: 0;
  transition: border-color var(--t-fast) var(--ease);
}
.input { height: 38px; }
.textarea {
  height: auto;
  min-height: 88px;
  padding: 10px 0;
  resize: vertical;
  line-height: 1.5;
}
.input:hover, .select:hover, .textarea:hover { border-bottom-color: var(--muted); }
.input:focus, .select:focus, .textarea:focus {
  border-bottom: 2px solid var(--ink);
  padding-bottom: 9px; /* compensate the extra px */
  outline: none;
}
.input[disabled], .select[disabled], .textarea[disabled] {
  color: var(--faint);
  cursor: not-allowed;
  border-bottom-style: dashed;
}
.input::placeholder { color: var(--faint); }
.input--mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

.select {
  height: 38px;
  appearance: none;
  padding-right: 24px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%236B6862' d='M0 0h10L5 6z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 4px center;
}
[data-theme="dark"] .select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%238C8880' d='M0 0h10L5 6z'/></svg>");
}

/* Boxed variant — opt-in for places where the planilha style
   gets confusing (filter bars, search, dense forms). */
.input--boxed {
  height: 36px;
  padding: 0 12px;
  border: 1px solid var(--line-2);
  background: var(--paper-light);
  border-radius: var(--radius-soft);
}
.input--boxed:focus { border-color: var(--ink); padding-bottom: 0; border-bottom-width: 1px; }
.select.input--boxed {
  height: 36px;
  padding: 0 28px 0 12px;
  border: 1px solid var(--line-2);
  background-color: var(--paper-light);
  border-radius: var(--radius-soft);
  background-position: right 10px center;
}

/* Checkbox & radio — square, ink fill */
.checkbox,
.radio {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-body);
  color: var(--ink);
  cursor: pointer;
  user-select: none;
}
.checkbox input,
.radio input {
  appearance: none;
  width: 16px; height: 16px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-soft);
  background: transparent;
  display: inline-grid; place-items: center;
  flex: none;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.radio input { border-radius: 50%; }
.checkbox input:checked,
.radio input:checked {
  background: var(--ink);
  border-color: var(--ink);
}
.checkbox input:checked::after {
  content: "";
  width: 9px; height: 5px;
  border: 2px solid var(--paper);
  border-top: 0; border-right: 0;
  transform: translateY(-1px) rotate(-45deg);
}
.radio input:checked::after {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--paper);
}

/* Switch */
.switch {
  position: relative;
  display: inline-block;
  width: 36px; height: 20px;
  flex: none;
}
.switch input { opacity: 0; width: 0; height: 0; }
.switch__track {
  position: absolute; inset: 0;
  background: var(--line-2);
  border-radius: var(--radius-pill);
  transition: background var(--t-fast) var(--ease);
}
.switch__track::before {
  content: "";
  position: absolute;
  width: 16px; height: 16px; left: 2px; top: 2px;
  background: var(--paper-light);
  border-radius: 50%;
  transition: transform var(--t-fast) var(--ease);
}
.switch input:checked + .switch__track { background: var(--ink); }
.switch input:checked + .switch__track::before { transform: translateX(16px); background: var(--paper); }

/* Search input (boxed) */
.search { position: relative; display: inline-flex; align-items: center; }
.search .ico {
  position: absolute;
  left: 12px;
  width: 14px; height: 14px;
  color: var(--muted);
  pointer-events: none;
}
.search .input--boxed { padding-left: 34px; }


/* 8. ── Tables (admin-table) ──────────────────────────────── */
.table-wrap { overflow-x: auto; }

.admin-table,
.data-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--fs-body-s);
}
.admin-table th,
.data-table th {
  text-align: left;
  padding: 12px 14px;
  background: var(--paper-shade);
  border-bottom: 1px solid var(--line);
  border-top: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
}
.admin-table th:first-child,
.data-table th:first-child { padding-left: 20px; }
.admin-table th:last-child,
.data-table th:last-child  { padding-right: 20px; text-align: right; }

.admin-table td,
.data-table td {
  padding: var(--pad-y) var(--pad-x);
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
  height: var(--row-h);
  color: var(--ink);
}
.admin-table td:first-child,
.data-table td:first-child { padding-left: 20px; }
.admin-table td:last-child,
.data-table td:last-child  { padding-right: 20px; text-align: right; }
.admin-table tr:last-child td,
.data-table tr:last-child td { border-bottom: 0; }

.admin-table tbody tr.is-clickable,
.data-table tbody tr.is-clickable { cursor: pointer; }
.admin-table tbody tr.is-clickable:hover td,
.data-table tbody tr.is-clickable:hover td { background: var(--paper-shade); }

.admin-table tr.is-expanded > td,
.data-table tr.is-expanded > td  { background: var(--paper-shade); }

.num,
.admin-table td.num,
.data-table td.num {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  text-align: right;
  color: var(--ink);
}

.admin-table .cell-id,
.data-table .cell-id {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--muted);
}

/* .edit-row — collapsed inline editor (toggled by JS) */
.edit-row { display: none; }
.edit-row.is-open { display: table-row; }
.edit-row > td {
  background: var(--paper-shade);
  padding: 22px 24px;
  border-bottom: 1px solid var(--line);
}
.edit-row__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px 24px;
  align-items: end;
}
.edit-row__actions {
  grid-column: 1 / -1;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding-top: 12px;
  margin-top: 6px;
  border-top: 1px dashed var(--line-2);
}
@media (max-width: 900px) { .edit-row__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .edit-row__grid { grid-template-columns: 1fr; } }


/* 9. ── Pills & role chips ────────────────────────────────── */
/* .pill — status pill. Variants by modifier class. */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 9px;
  height: 22px;
  border-radius: var(--radius-pill);
  background: var(--paper-shade);
  color: var(--ink);
  border: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  font-weight: var(--fw-medium);
  letter-spacing: 0.04em;
  line-height: 1;
  white-space: nowrap;
}
.pill__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

.pill--brand  { background: var(--copper-soft);     color: var(--copper-2);    border-color: transparent; }
.pill--ok     { background: var(--state-ok-soft);   color: var(--state-ok);    border-color: transparent; }
.pill--warn   { background: var(--state-warn-soft); color: var(--state-warn-deep); border-color: transparent; }
.pill--alert,
.pill--danger { background: var(--state-alert-soft);color: var(--state-alert); border-color: transparent; }
.pill--info   { background: var(--state-info-soft); color: var(--state-info);  border-color: transparent; }
.pill--unknown{ background: var(--state-unknown-soft); color: var(--state-unknown); border-color: transparent; }
.pill--solid  { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.pill--outline { background: transparent; }

[data-theme="dark"] .pill--brand  { color: var(--copper); }
[data-theme="dark"] .pill--warn   { color: var(--state-warn); }

/* Content-specific pills */
.pill-fluxia       { background: var(--copper-soft);    color: var(--copper-2);    border-color: transparent; }
[data-theme="dark"] .pill-fluxia { color: var(--copper); }
.pill-fora         { background: var(--paper-shade);    color: var(--muted);       border-color: var(--line); }
.pill-p45-ok       { background: var(--state-ok-soft);  color: var(--state-ok);    border-color: transparent; }
.pill-p45-atencao  { background: var(--state-warn-soft);color: var(--state-warn-deep); border-color: transparent; }
.pill-p45-alerta   { background: var(--state-alert-soft); color: var(--state-alert); border-color: transparent; }
.pill-p45-sem      { background: var(--state-unknown-soft); color: var(--state-unknown); border-color: transparent; }
[data-theme="dark"] .pill-p45-atencao { color: var(--state-warn); }

/* .role — admin / operator / partner chip */
.role {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 2px 9px 2px 8px;
  border-radius: var(--radius-pill);
  background: var(--paper-shade);
  border: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
}
.role::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--muted);
}
.role--admin::before    { background: var(--state-alert); }
.role--operator::before { background: var(--state-info); }
.role--partner::before  { background: var(--copper); }


/* 10. ── Filter bar ───────────────────────────────────────── */
.filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--paper-light);
  border: 1px solid var(--line);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}
.filter-bar__label {
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
}
.filter-bar__sep {
  width: 1px; height: 22px;
  background: var(--line);
}
.filter-bar > .input,
.filter-bar > .select,
.filter-bar > .search { width: auto; min-width: 200px; flex: none; }
.filter-bar > .search { min-width: 260px; }
.filter-bar__spacer { flex: 1; }

/* .scope-select — primary visibility filter */
.scope-select {
  display: inline-flex; align-items: center; gap: 10px;
  height: 34px;
  padding: 0 14px;
  background: var(--paper-light);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-soft);
  font-family: var(--font-sans);
  font-size: var(--fs-body-s);
  font-weight: var(--fw-medium);
  color: var(--ink);
  cursor: pointer;
}
.scope-select::before {
  content: "";
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--copper);
}
.scope-select:hover { background: var(--paper-shade); }
.scope-select .caret { color: var(--muted); margin-left: 6px; }


/* 11. ── Stats / KPI tiles ────────────────────────────────── */
.stat {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 22px 22px 20px;
  background: var(--paper-light);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  min-width: 0;
}
.stat__label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--fw-medium);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
}
.stat__value {
  font-family: var(--font-mono);
  font-size: 28px;
  font-weight: var(--fw-medium);
  letter-spacing: -0.01em;
  line-height: 1.05;
  margin-top: 4px;
  color: var(--ink);
}
.stat__value .unit {
  margin-left: 4px;
  font-size: 13px;
  color: var(--muted);
}
.stat__value--copper { color: var(--copper); }
.stat__value--teal   { color: var(--teal); }
[data-theme="dark"] .stat__value--teal { color: var(--sand); }
.stat__value--ok     { color: var(--state-ok); }
.stat__value--alert  { color: var(--state-alert); }
.stat__delta {
  font-size: 12px;
  color: var(--muted);
}
.stat__delta--up    { color: var(--state-ok); }
.stat__delta--down  { color: var(--state-alert); }
.stat__delta--warn  { color: var(--state-warn-deep); }
[data-theme="dark"] .stat__delta--warn { color: var(--state-warn); }


/* 12. ── Progress + P45 gauge ─────────────────────────────── */
.progress {
  height: 6px;
  background: var(--paper-shade);
  position: relative;
  overflow: hidden;
}
.progress__bar {
  height: 100%;
  background: var(--copper);
  transition: width var(--t-slow) var(--ease);
}
/* tick marks every 10 % — matches brand book gauge */
.progress--ticked::after {
  content: "";
  position: absolute; inset: 0;
  background: repeating-linear-gradient(
    90deg, transparent 0 9.9%, rgba(0, 0, 0, 0.08) 9.9% 10%);
  pointer-events: none;
}
[data-theme="dark"] .progress--ticked::after {
  background: repeating-linear-gradient(
    90deg, transparent 0 9.9%, rgba(255, 255, 255, 0.10) 9.9% 10%);
}
.progress--ok     .progress__bar { background: var(--state-ok); }
.progress--warn   .progress__bar { background: var(--state-warn); }
.progress--alert  .progress__bar,
.progress--danger .progress__bar { background: var(--state-alert); }
.progress--teal   .progress__bar { background: var(--teal); }
[data-theme="dark"] .progress--teal .progress__bar { background: var(--sand); }
.progress--thin   { height: 4px; }
.progress--thick  { height: 10px; }

/* P45 gauge block */
.gauge {
  padding: 22px;
  background: var(--paper-light);
  border: 1px solid var(--line);
  display: grid;
  gap: 16px;
}
.gauge__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
}
.gauge__title {
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
  margin: 0;
}
.gauge__cap {
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
}
.gauge__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  border-top: 1px solid var(--line);
  padding-top: 16px;
}


/* 13. ── Alerts ───────────────────────────────────────────── */
.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: 14px 18px;
  background: var(--copper-soft);
  border: 1px solid var(--copper);
  border-left-width: 3px;
  border-radius: var(--radius);
  color: var(--ink);
  font-size: var(--fs-body);
}
.alert .ico {
  width: 18px; height: 18px;
  flex: none;
  margin-top: 1px;
  color: var(--copper);
}
.alert b { font-weight: var(--fw-medium); }
.alert--warn   { background: var(--state-warn-soft);  border-color: var(--state-warn);  }
.alert--warn   .ico { color: var(--state-warn-deep); }
[data-theme="dark"] .alert--warn .ico { color: var(--state-warn); }
.alert--alert,
.alert--danger { background: var(--state-alert-soft); border-color: var(--state-alert); }
.alert--alert .ico, .alert--danger .ico { color: var(--state-alert); }
.alert--info   { background: var(--state-info-soft);  border-color: var(--state-info); }
.alert--info   .ico { color: var(--state-info); }
.alert--ok     { background: var(--state-ok-soft);    border-color: var(--state-ok); }
.alert--ok     .ico { color: var(--state-ok); }


/* 14. ── Tabs ─────────────────────────────────────────────── */
.tabs {
  display: inline-flex;
  background: var(--paper-shade);
  border: 1px solid var(--line);
  padding: 3px;
  gap: 2px;
}
.tabs__btn {
  appearance: none;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: var(--fs-label);
  font-weight: var(--fw-medium);
  color: var(--muted);
  padding: 6px 12px;
  cursor: pointer;
}
.tabs__btn[aria-selected="true"],
.tabs__btn.is-active {
  background: var(--paper-light);
  color: var(--ink);
}

.tabs--lined {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--line);
  padding: 0;
  gap: 0;
}
.tabs--lined .tabs__btn {
  padding: 12px 16px;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  font-size: var(--fs-body-s);
}
.tabs--lined .tabs__btn[aria-selected="true"],
.tabs--lined .tabs__btn.is-active {
  background: transparent;
  color: var(--ink);
  border-bottom-color: var(--copper);
}


/* 15. ── Empty state ──────────────────────────────────────── */
.empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 72px 24px;
  gap: 14px;
}
.empty__icon {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  background: var(--paper-shade);
  border: 1px solid var(--line);
  color: var(--muted);
}
.empty__icon .ico { width: 24px; height: 24px; }
.empty__title { font-size: var(--fs-body); font-weight: var(--fw-medium); margin: 0; }
.empty__sub   { color: var(--muted); font-size: var(--fs-body-s); max-width: 48ch; margin: 0; }
.empty__acts  { display: flex; gap: 8px; margin-top: 6px; }


/* 16. ── Utilities ────────────────────────────────────────── */
.grid     { display: grid; gap: var(--gap-card); }
.grid-2   { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3   { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4   { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-12-8 { grid-template-columns: 5fr 3fr; }
.grid-8-12 { grid-template-columns: 3fr 5fr; }

.flex     { display: flex; }
.inline   { display: inline-flex; }
.between  { justify-content: space-between; }
.center   { align-items: center; }
.wrap     { flex-wrap: wrap; }
.gap-1    { gap: 4px; }
.gap-2    { gap: 8px; }
.gap-3    { gap: 12px; }
.gap-4    { gap: 16px; }
.gap-6    { gap: 24px; }
.col      { display: flex; flex-direction: column; }

.mt-1 { margin-top: 4px; }  .mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; } .mt-4 { margin-top: 16px; }
.mt-5 { margin-top: 24px; } .mt-6 { margin-top: 32px; }
.mb-1 { margin-bottom: 4px; }  .mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; } .mb-4 { margin-bottom: 16px; }

.w-full      { width: 100%; }
.text-right  { text-align: right; }
.text-center { text-align: center; }

/* SVG line icons baseline — brand book: 1.4 stroke, square caps */
.ico {
  width: 16px; height: 16px;
  flex: none;
  stroke-width: 1.4;
  stroke: currentColor;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Key/value list */
.kv {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 10px 24px;
  font-size: var(--fs-body-s);
}
.kv dt {
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  letter-spacing: var(--tr-label);
  text-transform: uppercase;
  color: var(--muted);
}
.kv dd { margin: 0; color: var(--ink); }
.kv dd.num { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

/* Split row (used in closings / financial breakdowns) */
.split-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 14px 0;
  align-items: center;
  border-bottom: 1px dashed var(--line);
}
.split-row:last-child { border-bottom: 0; }
.split-row__lbl { color: var(--ink); }
.split-row__val {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
}
.split-row__total {
  font-size: var(--fs-h3);
  border-top: 1px solid var(--ink);
  border-bottom: 0;
  margin-top: 6px;
  padding-top: 16px;
}
.split-row__total .split-row__val { font-size: var(--fs-h3); }

/* Placeholder image */
.ph-img {
  background:
    repeating-linear-gradient(45deg,
      var(--paper-shade) 0 8px,
      transparent 8px 16px),
    var(--paper-light);
  border: 1px solid var(--line);
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--faint);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* Mono number that bigs up — used in headlines and big values */
.bignum {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: var(--fw-medium);
  letter-spacing: -0.02em;
}


/* 17. ── Responsive ───────────────────────────────────────── */
@media (max-width: 1100px) {
  .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .grid-12-8, .grid-8-12 { grid-template-columns: 1fr; }
}

@media (max-width: 860px) {
  .app { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: var(--sidebar-w-mobile);
    z-index: var(--z-modal);
    transform: translateX(-100%);
    transition: transform var(--t-base) var(--ease);
    box-shadow: var(--shadow-pop);
  }
  body.is-sidebar-open .sidebar { transform: translateX(0); }
  body.is-sidebar-open::after {
    content: "";
    position: fixed; inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: var(--z-overlay);
  }
  .topbar  { padding: 0 var(--space-4); }
  .page    { padding: var(--space-5) var(--space-4) var(--space-8); }
}

@media (max-width: 720px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .page-header { flex-direction: column; align-items: flex-start; }
  .filter-bar { padding: var(--space-2) var(--space-3); }
}

.menu-toggle { display: none; }
@media (max-width: 860px) { .menu-toggle { display: inline-grid; } }

.charge-bank-actions {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.utility-payment-cell { min-width: 8rem; max-width: 14rem; vertical-align: top; }
.utility-payment-cell .pix-copy-details { margin-top: 2px; }
.utility-digitable { word-break: break-all; font-size: 0.75rem; }

.pix-copy-details { margin-top: 4px; width: 100%; }
.pix-copy-code {
  display: block;
  font-size: 11px;
  word-break: break-all;
  padding: 6px;
  background: var(--surface-2, #f4f4f5);
  border-radius: 4px;
}
