/* ============================================================
   Flux CRM — Design tokens & base styles
   ============================================================ */
:root {
  /* Brand */
  --brand:        #2b5ce6;
  --brand-600:    #2350d4;
  --brand-700:    #1c41b0;
  --brand-50:     #eef3ff;
  --brand-100:    #dbe5ff;
  --accent:       #38bdf8; /* electric cyan, used sparingly */

  /* Sidebar (deep navy) */
  --nav-bg:       #0e1a33;
  --nav-bg-2:     #0a1426;
  --nav-fg:       #c3cee0;
  --nav-fg-dim:   #7e8bab;
  --nav-active:   #1b2c4f;
  --nav-border:   #1c2c4d;

  /* Surfaces */
  --bg:           #f5f7fb;
  --surface:      #ffffff;
  --surface-2:    #f9fafc;
  --border:       #e6eaf1;
  --border-2:     #eef1f6;

  /* Text */
  --ink:          #0f1c34;
  --ink-2:        #46536b;
  --ink-3:        #8a96ac;
  --ink-inv:      #ffffff;

  /* Status palette (fg / bg) */
  --st-aberto:        #5b6b85;  --st-aberto-bg:        #eef1f6;
  --st-aguard-apr:    #b4690e;  --st-aguard-apr-bg:    #fdf3e2;
  --st-aprovado:      #15803d;  --st-aprovado-bg:      #e7f6ec;
  --st-reprovado:     #c2342f;  --st-reprovado-bg:     #fbe9e8;
  --st-iniciado:      #1d4ed8;  --st-iniciado-bg:      #e7eeff;
  --st-aguardando:    #c2570c;  --st-aguardando-bg:    #fcefe3;
  --st-semsolucao:    #9f1239;  --st-semsolucao-bg:    #fbe7ee;
  --st-finalizado:    #0d8d80;  --st-finalizado-bg:    #e1f5f2;
  --st-faturado:      #6d35d1;  --st-faturado-bg:      #f0e9fc;

  /* Semantic */
  --pos:          #16a34a;
  --neg:          #dc2626;
  --warn:         #d97706;

  /* Radii & shadow */
  --r-sm: 7px;
  --r:    10px;
  --r-lg: 14px;
  --r-xl: 20px;
  --shadow-sm: 0 1px 2px rgba(16,28,52,.06), 0 1px 1px rgba(16,28,52,.04);
  --shadow:    0 4px 16px -4px rgba(16,28,52,.10), 0 2px 6px -2px rgba(16,28,52,.06);
  --shadow-lg: 0 24px 60px -12px rgba(16,28,52,.28), 0 8px 24px -8px rgba(16,28,52,.16);
  --shadow-nav: 0 0 0 1px rgba(255,255,255,.02);

  --sidebar-w: 248px;
  --sidebar-w-collapsed: 76px;
  --topbar-h: 64px;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.tnum { font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1; }
h1,h2,h3,h4 { margin: 0; font-weight: 700; letter-spacing: -.01em; color: var(--ink); }
button { font-family: inherit; cursor: pointer; }
input, select, textarea { font-family: inherit; font-size: 14px; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--brand-100); }

/* Scrollbars */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb { background: #cdd5e2; border-radius: 20px; border: 2px solid transparent; background-clip: content-box; }
*::-webkit-scrollbar-thumb:hover { background: #b3bdcf; background-clip: content-box; }
*::-webkit-scrollbar-track { background: transparent; }

/* ============================================================
   App shell
   ============================================================ */
.app { display: flex; min-height: 100vh; }

/* brand themes (class-based so changes repaint reliably) */
.app.brand-azul   { --brand:#2b5ce6; --brand-600:#2350d4; --brand-700:#1c41b0; --brand-50:#eef3ff; --brand-100:#dbe5ff; --accent:#38bdf8; --st-iniciado:#1d4ed8; --st-iniciado-bg:#e7eeff; }
.app.brand-teal   { --brand:#0d9488; --brand-600:#0b8178; --brand-700:#0a6c64; --brand-50:#e3f4f1; --brand-100:#c2e9e3; --accent:#2dd4bf; --st-iniciado:#0d8d80; --st-iniciado-bg:#e1f5f2; }
.app.brand-indigo { --brand:#5b54e6; --brand-600:#4f48d6; --brand-700:#3f38b0; --brand-50:#eeedff; --brand-100:#dddaff; --accent:#a78bfa; --st-iniciado:#5b54e6; --st-iniciado-bg:#eeedff; }
.app.brand-ambar  { --brand:#e2701a; --brand-600:#cf6210; --brand-700:#ac520c; --brand-50:#fdf1e6; --brand-100:#fbddc0; --accent:#f5b13e; --st-iniciado:#cf6210; --st-iniciado-bg:#fdf1e6; }
.app.cantos-reto  { --r-sm:3px; --r:4px; --r-lg:5px; --r-xl:7px; }
.app.cantos-reto .btn, .app.cantos-reto .inp, .app.cantos-reto .field input,
.app.cantos-reto .field select, .app.cantos-reto .field textarea,
.app.cantos-reto .badge, .app.cantos-reto .pill, .app.cantos-reto .chip,
.app.cantos-reto .act, .app.cantos-reto .icon-btn, .app.cantos-reto .searchbar,
.app.cantos-reto .search-inline, .app.cantos-reto .nav-item, .app.cantos-reto .stat .ic { border-radius: 4px; }

/* ---- Sidebar ---- */
.sidebar {
  width: var(--sidebar-w);
  flex: 0 0 var(--sidebar-w);
  background: linear-gradient(180deg, var(--nav-bg) 0%, var(--nav-bg-2) 100%);
  color: var(--nav-fg);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
  transition: width .22s cubic-bezier(.4,0,.2,1), flex-basis .22s cubic-bezier(.4,0,.2,1);
  z-index: 40;
}
.sidebar.collapsed { width: var(--sidebar-w-collapsed); flex-basis: var(--sidebar-w-collapsed); }
.sidebar { border-right: 1px solid var(--nav-border); }
.sidebar.theme-dark {
  --nav-bg: #0e1a33; --nav-bg-2: #0a1426; --nav-fg: #c3cee0; --nav-fg-dim: #7e8bab;
  --nav-active: #1b2c4f; --nav-active-fg: #ffffff; --nav-border: #1c2c4d; --nav-title: #ffffff;
}
.sidebar.theme-light {
  --nav-bg: #ffffff; --nav-bg-2: #f6f8fc; --nav-fg: #46536b; --nav-fg-dim: #9aa6bc;
  --nav-active: var(--brand-50); --nav-active-fg: var(--brand-700); --nav-border: #e6eaf1; --nav-title: #0f1c34;
}
.brand {
  display: flex; align-items: center; gap: 11px;
  padding: 0 18px; height: var(--topbar-h);
  flex: 0 0 var(--topbar-h);
  border-bottom: 1px solid var(--nav-border);
}
.brand-mark {
  width: 34px; height: 34px; border-radius: 9px; flex: 0 0 34px;
  display: grid; place-items: center;
  background: linear-gradient(150deg, var(--brand) 0%, #4f7bff 60%, var(--accent) 130%);
  box-shadow: 0 4px 14px -3px rgba(43,92,230,.7);
}
.brand-name { font-size: 19px; font-weight: 800; color: var(--nav-title, #fff); letter-spacing: -.02em; white-space: nowrap; }
.brand-name b { color: var(--accent); }
.brand-sub { font-size: 10px; color: var(--nav-fg-dim); letter-spacing: .14em; text-transform: uppercase; margin-top: 1px; white-space: nowrap; }
.sidebar.collapsed .brand-text { display: none; }

.nav-scroll { flex: 1; overflow-y: auto; padding: 14px 12px; }
.nav-group-label {
  font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--nav-fg-dim); padding: 0 12px; margin: 16px 0 7px;
}
.sidebar.collapsed .nav-group-label { text-align: center; padding: 0; overflow: hidden; }
.nav-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 9px; margin-bottom: 3px;
  color: var(--nav-fg); font-weight: 600; font-size: 13.5px;
  position: relative; transition: background .14s, color .14s; white-space: nowrap;
}
.nav-item svg { flex: 0 0 20px; opacity: .82; }
.nav-item:hover { background: rgba(255,255,255,.05); color: #fff; }
.nav-item:hover svg { opacity: 1; }
.nav-item.active { background: var(--nav-active); color: var(--nav-active-fg, #fff); }
.nav-item.active svg { opacity: 1; color: var(--accent); }
.nav-item.active::before {
  content: ""; position: absolute; left: -12px; top: 50%; transform: translateY(-50%);
  width: 3px; height: 20px; border-radius: 0 3px 3px 0; background: var(--accent);
}
.nav-badge {
  margin-left: auto; background: var(--brand); color: #fff; font-size: 11px; font-weight: 700;
  border-radius: 20px; padding: 1px 7px; min-width: 20px; text-align: center;
}
.sidebar.collapsed .nav-item { justify-content: center; padding: 11px 0; }
.sidebar.collapsed .nav-label, .sidebar.collapsed .nav-badge { display: none; }

.nav-foot { padding: 12px; border-top: 1px solid var(--nav-border); }
.nav-user {
  display: flex; align-items: center; gap: 10px; padding: 8px; border-radius: 10px;
  transition: background .14s; cursor: pointer;
}
.nav-user:hover { background: rgba(255,255,255,.05); }
.nav-user .meta { min-width: 0; }
.nav-user .meta .n { color: var(--nav-title, #fff); font-weight: 700; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nav-user .meta .r { color: var(--nav-fg-dim); font-size: 11.5px; }
.sidebar.collapsed .nav-user .meta { display: none; }

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

.topbar {
  height: var(--topbar-h); flex: 0 0 var(--topbar-h);
  background: rgba(255,255,255,.82); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 14px; padding: 0 24px;
  position: sticky; top: 0; z-index: 30;
}
.icon-btn {
  width: 38px; height: 38px; border-radius: 9px; border: 1px solid var(--border);
  background: var(--surface); color: var(--ink-2); display: grid; place-items: center;
  transition: .14s; position: relative;
}
.icon-btn:hover { background: var(--surface-2); color: var(--ink); border-color: #d7dde8; }
.icon-btn.ghost { border-color: transparent; background: transparent; }
.icon-btn.ghost:hover { background: var(--surface-2); }
.icon-btn .dot { position: absolute; top: 8px; right: 9px; width: 7px; height: 7px; border-radius: 50%; background: var(--neg); border: 1.5px solid #fff; }

.searchbar {
  flex: 1; max-width: 460px; height: 40px; border-radius: 10px;
  border: 1px solid var(--border); background: var(--surface-2);
  display: flex; align-items: center; gap: 9px; padding: 0 13px; color: var(--ink-3);
  transition: .15s;
}
.searchbar:focus-within { background: #fff; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-50); }
.searchbar input { border: none; background: transparent; outline: none; flex: 1; color: var(--ink); }
.searchbar input::placeholder { color: var(--ink-3); }
.kbd { font-size: 11px; color: var(--ink-3); border: 1px solid var(--border); border-radius: 5px; padding: 1px 6px; background: #fff; }

.topbar-spacer { flex: 1; }

.avatar {
  border-radius: 50%; background: linear-gradient(140deg, var(--brand), #5a82ff);
  color: #fff; display: grid; place-items: center; font-weight: 700; flex: 0 0 auto;
  overflow: hidden;
}

/* ---- Page ---- */
.page { padding: 26px 30px 60px; max-width: 1480px; margin: 0 auto; width: 100%; }
.page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 22px; flex-wrap: wrap; }
.page-title { font-size: 25px; font-weight: 800; letter-spacing: -.025em; }
.page-sub { color: var(--ink-3); font-size: 13.5px; margin-top: 3px; }
.crumb { display: flex; align-items: center; gap: 7px; color: var(--ink-3); font-size: 12.5px; font-weight: 600; margin-bottom: 8px; }
.crumb .sep { opacity: .5; }

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 40px; padding: 0 16px; border-radius: 9px; border: 1px solid transparent;
  font-weight: 700; font-size: 13.5px; transition: .14s; white-space: nowrap; user-select: none;
}
.btn svg { flex: 0 0 auto; }
.btn-primary { background: var(--brand); color: #fff; box-shadow: 0 6px 16px -6px rgba(43,92,230,.7); }
.btn-primary:hover { background: var(--brand-600); }
.btn-primary:active { background: var(--brand-700); }
.btn-secondary { background: var(--surface); color: var(--ink); border-color: var(--border); box-shadow: var(--shadow-sm); }
.btn-secondary:hover { background: var(--surface-2); border-color: #d7dde8; }
.btn-ghost { background: transparent; color: var(--ink-2); }
.btn-ghost:hover { background: var(--surface-2); color: var(--ink); }
.btn-danger { background: var(--neg); color: #fff; }
.btn-danger:hover { filter: brightness(.94); }
.btn-sm { height: 34px; padding: 0 12px; font-size: 12.5px; border-radius: 8px; }
.btn-lg { height: 46px; padding: 0 22px; font-size: 14.5px; }
.btn:disabled { opacity: .5; pointer-events: none; }

/* row action icon buttons */
.act {
  width: 32px; height: 32px; border-radius: 8px; display: grid; place-items: center;
  border: 1px solid var(--border); background: #fff; color: var(--ink-2); transition: .13s;
}
.act:hover { color: #fff; border-color: transparent; }
.act.edit:hover { background: var(--brand); }
.act.del:hover  { background: var(--neg); }
.act.ok:hover   { background: var(--pos); }
.act.print:hover{ background: var(--ink); }
.act.money:hover{ background: var(--st-finalizado); }
.act-row { display: inline-flex; gap: 6px; }

/* ============================================================
   Cards & surfaces
   ============================================================ */
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--shadow-sm); }
.card-pad { padding: 20px; }
.card-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 20px; border-bottom: 1px solid var(--border-2); }
.card-head h3 { font-size: 15px; font-weight: 700; }
.card-head .sub { color: var(--ink-3); font-size: 12.5px; }

/* Toolbar above tables */
.toolbar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.toolbar .grow { flex: 1; }
.select-mini {
  height: 38px; border-radius: 9px; border: 1px solid var(--border); background: #fff;
  padding: 0 10px; color: var(--ink); font-weight: 600;
}
.search-inline {
  height: 38px; min-width: 240px; border-radius: 9px; border: 1px solid var(--border);
  background: var(--surface-2); display: flex; align-items: center; gap: 8px; padding: 0 12px; color: var(--ink-3);
}
.search-inline input { border: none; background: transparent; outline: none; flex: 1; color: var(--ink); }
.search-inline:focus-within { background: #fff; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-50); }

/* ============================================================
   Tables
   ============================================================ */
.table-wrap { overflow-x: auto; border-radius: var(--r-lg); }
table.tbl { width: 100%; border-collapse: collapse; font-size: 13.5px; }
table.tbl thead th {
  text-align: left; font-weight: 700; color: var(--ink-3); font-size: 11.5px;
  letter-spacing: .04em; text-transform: uppercase; padding: 13px 16px;
  border-bottom: 1px solid var(--border); background: var(--surface-2); white-space: nowrap;
  position: sticky; top: 0;
}
table.tbl thead th.sortable { cursor: pointer; user-select: none; }
table.tbl thead th .th-in { display: inline-flex; align-items: center; gap: 5px; }
table.tbl tbody td { padding: 13px 16px; border-bottom: 1px solid var(--border-2); vertical-align: middle; }
table.tbl tbody tr { transition: background .12s; }
table.tbl tbody tr:hover { background: var(--brand-50); }
table.tbl tbody tr:last-child td { border-bottom: none; }
.t-strong { font-weight: 700; color: var(--ink); }
.t-sub { color: var(--ink-3); font-size: 12px; }
.t-id { color: var(--ink-3); font-weight: 700; font-variant-numeric: tabular-nums; }
.t-right { text-align: right; }
.t-center { text-align: center; }

/* highlighted (overdue/attention) row */
tr.row-flag { background: #fff5f4 !important; }
tr.row-flag:hover { background: #ffeceb !important; }

/* priority/severity dot at row start */
.row-dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }

/* ============================================================
   Badges
   ============================================================ */
.badge {
  display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 12px;
  padding: 4px 10px 4px 8px; border-radius: 20px; white-space: nowrap; line-height: 1;
}
.badge .b-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.badge.aberto        { color: var(--st-aberto);     background: var(--st-aberto-bg); }
.badge.aguard-apr    { color: var(--st-aguard-apr); background: var(--st-aguard-apr-bg); }
.badge.aprovado      { color: var(--st-aprovado);   background: var(--st-aprovado-bg); }
.badge.reprovado     { color: var(--st-reprovado);  background: var(--st-reprovado-bg); }
.badge.iniciado      { color: var(--st-iniciado);   background: var(--st-iniciado-bg); }
.badge.aguardando    { color: var(--st-aguardando); background: var(--st-aguardando-bg); }
.badge.semsolucao    { color: var(--st-semsolucao); background: var(--st-semsolucao-bg); }
.badge.finalizado    { color: var(--st-finalizado); background: var(--st-finalizado-bg); }
.badge.faturado      { color: var(--st-faturado);   background: var(--st-faturado-bg); }

.pill { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 11.5px; padding: 3px 9px; border-radius: 7px; background: var(--surface-2); color: var(--ink-2); border: 1px solid var(--border); }
.tag { display: inline-flex; font-weight: 700; font-size: 11px; padding: 3px 9px; border-radius: 6px; background: var(--brand-50); color: var(--brand-700); }

.chip {
  display: inline-flex; align-items: center; gap: 7px; height: 32px; padding: 0 12px;
  border-radius: 8px; border: 1px solid var(--border); background: #fff; color: var(--ink-2);
  font-weight: 600; font-size: 12.5px; transition: .13s;
}
.chip:hover { border-color: #d7dde8; background: var(--surface-2); }
.chip.on { background: var(--brand-50); border-color: var(--brand-100); color: var(--brand-700); }
.chip .cnt { font-variant-numeric: tabular-nums; opacity: .7; }

/* whatsapp icon button in table */
.wa { width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center; background: #e7f8ee; color: #25933f; transition: .13s; }
.wa:hover { background: #25d366; color: #fff; }

/* ============================================================
   Pagination
   ============================================================ */
.pager { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 14px 18px; border-top: 1px solid var(--border-2); flex-wrap: wrap; }
.pager .info { color: var(--ink-3); font-size: 13px; }
.pager .info b { color: var(--ink); }
.pages { display: flex; gap: 5px; align-items: center; }
.pages button {
  min-width: 34px; height: 34px; padding: 0 9px; border-radius: 8px; border: 1px solid var(--border);
  background: #fff; color: var(--ink-2); font-weight: 700; font-size: 13px; transition: .12s;
}
.pages button:hover:not(:disabled) { background: var(--surface-2); }
.pages button.on { background: var(--brand); color: #fff; border-color: var(--brand); }
.pages button:disabled { opacity: .45; cursor: default; }

/* ============================================================
   Stat cards (dashboard)
   ============================================================ */
.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.stat {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 18px; box-shadow: var(--shadow-sm); position: relative; overflow: hidden;
}
.stat .ic { width: 40px; height: 40px; border-radius: 11px; display: grid; place-items: center; margin-bottom: 13px; }
.stat .lbl { color: var(--ink-3); font-size: 12.5px; font-weight: 700; letter-spacing: .02em; }
.stat .val { font-size: 27px; font-weight: 800; letter-spacing: -.02em; margin-top: 3px; font-variant-numeric: tabular-nums; }
.stat .delta { display: inline-flex; align-items: center; gap: 4px; font-weight: 700; font-size: 12px; margin-top: 8px; }
.stat .delta.up { color: var(--pos); }
.stat .delta.down { color: var(--neg); }
.stat .delta .muted { color: var(--ink-3); font-weight: 600; }

/* ============================================================
   Forms
   ============================================================ */
.field { display: flex; flex-direction: column; gap: 6px; }
.field > label { font-weight: 700; font-size: 12.5px; color: var(--ink-2); }
.field .hint { font-size: 11.5px; color: var(--ink-3); }
.inp, .field input, .field select, .field textarea {
  height: 42px; border-radius: 9px; border: 1px solid var(--border); background: #fff;
  padding: 0 13px; color: var(--ink); outline: none; transition: .14s; width: 100%;
}
.field textarea { height: auto; padding: 11px 13px; resize: vertical; min-height: 96px; line-height: 1.55; }
.inp:focus, .field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-50);
}
.field input::placeholder, .field textarea::placeholder { color: var(--ink-3); }
.field input:disabled, .inp:disabled { background: var(--surface-2); color: var(--ink-2); }
.form-grid { display: grid; gap: 16px 18px; }
.col-span-1 { grid-column: span 1; }
.col-span-2 { grid-column: span 2; }
.col-span-3 { grid-column: span 3; }
.col-span-4 { grid-column: span 4; }
.col-span-5 { grid-column: span 5; }
.col-span-6 { grid-column: span 6; }
.col-span-7 { grid-column: span 7; }
.col-span-8 { grid-column: span 8; }
.col-span-9 { grid-column: span 9; }
.col-span-10 { grid-column: span 10; }
.col-span-11 { grid-column: span 11; }
.col-span-12 { grid-column: span 12; }
.col-span-full { grid-column: 1 / -1; }
.input-suffix { position: relative; }
.input-suffix .sfx { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); }

/* tabs (forms) */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--border); margin-bottom: 22px; }
.tab {
  padding: 11px 16px; font-weight: 700; font-size: 13.5px; color: var(--ink-3);
  border-bottom: 2px solid transparent; margin-bottom: -1px; transition: .14s; display: inline-flex; align-items: center; gap: 7px;
}
.tab:hover { color: var(--ink-2); }
.tab.on { color: var(--brand); border-color: var(--brand); }

/* ============================================================
   Modal / drawer
   ============================================================ */
.overlay {
  position: fixed; inset: 0; background: rgba(13,22,42,.46); backdrop-filter: blur(3px);
  display: flex; align-items: flex-start; justify-content: center; padding: 48px 20px; z-index: 100;
  animation: fade .16s ease;
}
@keyframes fade { from { opacity: 0; } }
.modal {
  background: var(--surface); border-radius: var(--r-xl); box-shadow: var(--shadow-lg);
  width: 100%; max-width: 900px; max-height: calc(100vh - 96px); display: flex; flex-direction: column;
  animation: pop .2s cubic-bezier(.34,1.4,.5,1); overflow: hidden;
}
.modal.wide { max-width: 1120px; }
@keyframes pop { from { opacity: 0; transform: translateY(14px) scale(.98); } }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--border); }
.modal-head h2 { font-size: 19px; font-weight: 800; }
.modal-head .sub { color: var(--ink-3); font-size: 13px; margin-top: 2px; }
.modal-body { padding: 24px; overflow-y: auto; }
.modal-foot { display: flex; align-items: center; justify-content: flex-end; gap: 10px; padding: 16px 24px; border-top: 1px solid var(--border); background: var(--surface-2); }
.modal-foot .grow { flex: 1; }
.x-btn { width: 38px; height: 38px; border-radius: 9px; border: none; background: transparent; color: var(--ink-3); display: grid; place-items: center; transition: .14s; }
.x-btn:hover { background: var(--surface-2); color: var(--ink); }

/* section header used in OS form */
.section-bar {
  display: flex; align-items: center; gap: 10px; padding: 12px 18px; border-radius: var(--r);
  background: var(--brand-50); color: var(--brand-700); font-weight: 800; font-size: 13px;
  letter-spacing: .02em; text-transform: uppercase; margin-bottom: 16px;
}
.section-bar svg { color: var(--brand); }

/* totals strip */
.totals { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
.total-cell { background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r); padding: 11px 13px; }
.total-cell .l { font-size: 11px; font-weight: 700; color: var(--ink-3); text-transform: uppercase; letter-spacing: .03em; }
.total-cell .v { font-size: 17px; font-weight: 800; font-variant-numeric: tabular-nums; margin-top: 3px; }
.total-cell.accent { background: var(--brand-50); border-color: var(--brand-100); }
.total-cell.accent .v { color: var(--brand-700); }

/* empty state */
.empty { text-align: center; padding: 54px 20px; color: var(--ink-3); }
.empty .ic { width: 56px; height: 56px; border-radius: 16px; background: var(--surface-2); display: grid; place-items: center; margin: 0 auto 14px; color: var(--ink-3); }
.empty h4 { font-size: 16px; color: var(--ink-2); margin-bottom: 5px; }

/* misc */
.row { display: flex; align-items: center; gap: 10px; }
.muted { color: var(--ink-3); }
.divider { height: 1px; background: var(--border-2); margin: 18px 0; }
.flex { display: flex; }
.between { justify-content: space-between; }
.center { align-items: center; }
.wrap { flex-wrap: wrap; }
.gap-6 { gap: 6px; } .gap-10 { gap: 10px; } .gap-16 { gap: 16px; }
.grow { flex: 1; }

/* toast */
.toast-wrap { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); z-index: 200; display: flex; flex-direction: column; gap: 8px; align-items: center; }
.toast {
  background: var(--ink); color: #fff; padding: 11px 18px; border-radius: 11px; font-weight: 600; font-size: 13.5px;
  box-shadow: var(--shadow-lg); display: flex; align-items: center; gap: 10px; animation: pop .2s ease;
}
.toast .tk { color: var(--accent); display: grid; place-items: center; }
.toast.ok .tk { color: #4ade80; }
.toast.del .tk { color: #fb7185; }

/* segmented control */
.seg { display: inline-flex; background: var(--surface-2); border: 1px solid var(--border); border-radius: 9px; padding: 3px; gap: 3px; }
.seg button { height: 30px; padding: 0 13px; border: none; background: transparent; border-radius: 7px; font-weight: 700; font-size: 12.5px; color: var(--ink-3); transition: .13s; }
.seg button.on { background: #fff; color: var(--ink); box-shadow: var(--shadow-sm); }

@media (max-width: 1080px) {
  .stat-grid { grid-template-columns: repeat(2, 1fr); }
  .totals { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .page { padding: 18px 16px 50px; }
  .stat-grid { grid-template-columns: 1fr; }
}
