/* ============================================================
   CuraSovo — App stylesheet (layout + components)
   Requires tokens.css.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  color: var(--text);
  background: var(--bg);
  font-feature-settings: "tnum" 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1,h2,h3,h4,p { margin: 0; }
a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font-family: inherit; cursor: pointer; }
ul { margin: 0; padding: 0; list-style: none; }
.tnum { font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1; }
.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

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

/* ---- Sidebar ---------------------------------------------- */
.sidebar {
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh;
}
.sidebar__brand {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: 0 20px;            /* fixed: keep the logo identically placed across pages */
  height: var(--topbar-h);
}
.sidebar__brand img { height: 26px; width: auto; display: block; }
/* tagline-free lockup for compact placements */
.brandmark { display: flex; align-items: center; }
.brandmark img { height: 40px; width: auto; display: block; }
/* help button — bare, oversized glyph (matches lang-switch text size) */
.help-btn {
  border: 0; background: transparent; color: var(--text-3); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; padding: 0; border-radius: var(--r-pill);
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.help-btn:hover { color: var(--brand); background: var(--surface-2); }
.help-btn .ico { font-size: 26px; }
.sidebar__nav { padding: var(--sp-3) var(--sp-3); flex: 1; overflow-y: auto; }
.nav-group__label {
  font-size: 11px; font-weight: var(--fw-semi); letter-spacing: var(--tracking-cap);
  text-transform: uppercase; color: var(--text-3);
  padding: var(--sp-4) var(--sp-3) var(--sp-2);
}
.nav-item {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: 9px var(--sp-3); border-radius: var(--r-md);
  color: var(--text-2); font-weight: var(--fw-medium); font-size: var(--fs-base);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  margin-bottom: 2px;
}
.nav-item:hover { background: var(--surface-2); color: var(--text); text-decoration: none; }
.nav-item.is-active { background: var(--brand-tint); color: var(--brand); }
.nav-item.is-active .ico { color: var(--brand); }
.nav-item .ico { color: var(--text-3); flex: none; }
.nav-item .nav-badge {
  margin-left: auto; font-size: 11px; font-weight: var(--fw-semi);
  background: var(--surface-3); color: var(--text-2);
  padding: 1px 7px; border-radius: var(--r-pill); min-width: 20px; text-align: center;
}
.nav-item.is-active .nav-badge { background: var(--brand); color: #fff; }

.sidebar__foot {
  padding: var(--sp-4);
  border-top: 1px solid var(--border);
}

/* ---- Trust marker (recurring, quiet) ---------------------- */
.trust-chip {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-size: var(--fs-xs); font-weight: var(--fw-medium);
  color: var(--teal-700); background: var(--teal-tint);
  border: 1px solid #bfe0de; border-radius: var(--r-pill);
  padding: 5px 11px 5px 9px; line-height: 1; white-space: nowrap;
}
.trust-chip .ico { color: var(--teal); }
.trust-chip--block { display: flex; width: 100%; justify-content: center; text-align: center; white-space: normal; line-height: var(--lh-snug); border-radius: var(--r-md); }
.trust-chip--block .ico { flex: none; }

/* ---- Topbar ----------------------------------------------- */
.main { display: flex; flex-direction: column; min-width: 0; }
.topbar {
  height: var(--topbar-h); flex: none;
  display: flex; align-items: center; gap: var(--sp-4);
  padding: 0 var(--sp-7);
  background: rgba(255,255,255,.82); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 30;
}
.topbar__title { font-size: var(--fs-lg); font-weight: var(--fw-semi); }
.topbar__crumb { color: var(--text-3); font-size: var(--fs-sm); }
.topbar__spacer { flex: 1; }
.topbar__actions { display: flex; align-items: center; gap: var(--sp-3); }

.content { padding: var(--sp-7); max-width: var(--content-max); width: 100%; }
.content--wide { max-width: 1400px; }

/* ---- Language switcher ------------------------------------ */
.lang-switch { display: inline-flex; background: var(--surface-2); border-radius: var(--r-md); padding: 3px; gap: 2px; }
.lang-switch button {
  border: 0; background: transparent; color: var(--text-2);
  font-size: var(--fs-xs); font-weight: var(--fw-semi); letter-spacing: .02em;
  padding: 5px 9px; border-radius: var(--r-sm); text-transform: uppercase;
  transition: all var(--t-fast) var(--ease);
}
.lang-switch button.is-active { background: var(--surface); color: var(--brand); box-shadow: var(--shadow-xs); }
.lang-switch button:not(.is-active):not(.is-on):hover { background: var(--surface); color: var(--text); }

/* ---- Avatar ----------------------------------------------- */
.avatar {
  width: 34px; height: 34px; border-radius: var(--r-pill);
  background: var(--brand-tint); color: var(--brand);
  display: grid; place-items: center; font-weight: var(--fw-bold); font-size: var(--fs-sm);
  border: 1px solid var(--brand-ring); text-decoration: none;
  transition: filter var(--t-fast) var(--ease);
}
a.avatar:hover, .avatar:hover { filter: brightness(.96); text-decoration: none; cursor: pointer; }
.avatar.is-open { filter: brightness(.92); box-shadow: 0 0 0 3px var(--brand-ring); }
.avatar--img { background-size: cover; background-position: center; border-color: var(--border-2); }

/* profile picture control (settings) */
.profile-pic { display: flex; align-items: center; gap: var(--sp-4); }
.profile-pic__avatar {
  width: 72px; height: 72px; border-radius: 50%; flex: none; display: grid; place-items: center;
  background: var(--brand-tint); color: var(--brand); font-weight: var(--fw-bold); font-size: var(--fs-xl);
  border: 1px solid var(--brand-ring); background-size: cover; background-position: center;
}
.profile-pic__avatar.has-img { border-color: var(--border-2); }
.profile-pic__title { font-weight: var(--fw-semi); font-size: var(--fs-sm); }
.profile-pic__sub { font-size: var(--fs-xs); color: var(--text-3); margin-top: 2px; max-width: 44ch; line-height: var(--lh-snug); }

/* avatar dropdown */
.avatar-wrap { position: relative; }
.avatar-menu {
  position: absolute; top: calc(100% + 8px); right: 0; z-index: 80; width: 248px;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
  box-shadow: var(--shadow-pop); padding: 6px; animation: avIn .16s var(--ease);
}
@keyframes avIn { from { opacity: 0; transform: translateY(-5px); } }
.avatar-menu__head { padding: 9px 11px 11px; border-bottom: 1px solid var(--border); margin-bottom: 6px; }
.avatar-menu__name { font-weight: var(--fw-semi); font-size: var(--fs-sm); }
.avatar-menu__mail { font-size: var(--fs-xs); color: var(--text-3); margin-top: 1px; }
.avatar-menu__item {
  display: flex; align-items: center; gap: 10px; padding: 9px 11px; border-radius: var(--r-md);
  font-size: var(--fs-sm); color: var(--text-2); text-decoration: none; font-weight: var(--fw-medium);
}
.avatar-menu__item .ico { color: var(--text-3); }
.avatar-menu__item:hover { background: var(--surface-2); color: var(--text); text-decoration: none; }
.avatar-menu__item--danger { color: var(--drift-fg); }
.avatar-menu__item--danger .ico { color: var(--drift-fg); }
.avatar-menu__item--danger:hover { background: #fdecec; color: var(--st-over-fg, #b4341f); }
.avatar-menu__sep { height: 1px; background: var(--border); margin: 6px 4px; }

/* ---- Buttons ---------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  font-size: var(--fs-base); font-weight: var(--fw-semi);
  padding: 9px 15px; border-radius: var(--r-md);
  border: 1px solid transparent; background: var(--surface); color: var(--text);
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
  white-space: nowrap;
}
.btn:hover { text-decoration: none; }
.btn .ico { flex: none; }
.btn--primary { background: var(--brand); color: var(--text-on-brand); }
.btn--primary:hover { background: var(--brand-600); }
.btn--primary:active { background: var(--brand-700); }
.btn--ghost { background: transparent; border-color: var(--border-2); color: var(--text-2); }
.btn--ghost:hover { background: var(--surface-2); color: var(--text); }
.btn--soft { background: var(--brand-tint); color: var(--brand); }
.btn--soft:hover { background: #e2e0f4; }
.btn--slate { background: #4a5568; color: #fff; border-color: #4a5568; }
.btn--slate:hover { background: #3d4655; border-color: #3d4655; }
.btn--success { background: var(--success); color: #fff; border-color: var(--success); }
.btn--success:hover { background: var(--success-600); border-color: var(--success-600); }
.btn--success:active { background: var(--success-700); border-color: var(--success-700); }
.btn--success-soft { background: var(--success-tint); color: var(--success); border-color: var(--ok-bd); }
.btn--success-soft:hover { background: var(--success); color: #fff; border-color: var(--success); }
.btn--sm { padding: 6px 11px; font-size: var(--fs-sm); border-radius: var(--r-sm); }
.btn--icon { padding: 8px; width: 36px; height: 36px; }
.btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--brand-ring); }

/* ---- Cards ------------------------------------------------- */
.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); box-shadow: var(--shadow-card);
}
.card__head {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-5) var(--sp-5) 0;
}
.card__title { font-size: var(--fs-lg); font-weight: var(--fw-semi); letter-spacing: -0.01em; }
.card__sub { font-size: var(--fs-sm); color: var(--text-3); }
.card__body { padding: var(--sp-5); }
.card__head + .card__body { padding-top: var(--sp-4); }
.card__divider { height: 1px; background: var(--border); border: 0; margin: 0; }

.grid { display: grid; gap: var(--sp-5); }
.grid--stats { grid-template-columns: repeat(2, 1fr); }
.grid--cashflow { grid-template-columns: 1.05fr 1.35fr; align-items: stretch; }

/* ---- Section label ---------------------------------------- */
.eyebrow {
  font-size: 11px; font-weight: var(--fw-semi); letter-spacing: var(--tracking-cap);
  text-transform: uppercase; color: var(--text-3);
}

/* ---- Status / quota cards --------------------------------- */
.statcard { display: flex; flex-direction: column; gap: var(--sp-4); }
.statcard__top { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
.statcard__lead { display: flex; align-items: center; gap: var(--sp-2); }
.statcard__title { font-size: var(--fs-lg); font-weight: var(--fw-semi); letter-spacing: -0.01em; }
.statcard__div { height: 1px; background: var(--border); border: 0; margin: 0; }
.statcard__icon {
  width: 38px; height: 38px; border-radius: var(--r-md);
  display: grid; place-items: center; flex: none;
  background: var(--brand-tint); color: var(--brand);
}
.statcard__icon--teal { background: var(--teal-tint); color: var(--teal); }
.statcard__label { font-size: var(--fs-sm); color: var(--text-2); font-weight: var(--fw-medium); }
.statcard__big { font-size: var(--fs-2xl); font-weight: var(--fw-bold); letter-spacing: -0.02em; line-height: 1.1; }
.statcard__big small { font-size: var(--fs-md); font-weight: var(--fw-medium); color: var(--text-3); }

/* progress / quota bar */
.quota { display: flex; flex-direction: column; gap: 7px; }
.quota__track { height: 9px; border-radius: var(--r-pill); background: var(--surface-3); overflow: hidden; }
.quota__fill { height: 100%; border-radius: var(--r-pill); background: var(--brand); transition: width var(--t-base) var(--ease); }
.quota__fill--warn { background: var(--law-mvg); }
.quota__meta { display: flex; justify-content: space-between; font-size: var(--fs-xs); color: var(--text-3); }

/* connection status dot */
.conn { display: inline-flex; align-items: center; gap: 7px; font-size: var(--fs-sm); font-weight: var(--fw-medium); }
.dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.dot--ok { background: #22a657; box-shadow: 0 0 0 3px rgba(34,166,87,.16); }
.dot--off { background: var(--text-3); }
.dot--warn { background: var(--law-mvg); box-shadow: 0 0 0 3px rgba(217,119,6,.16); }

/* ---- Bare card icon (no background box) -------------------- */
.card-ico { display: inline-flex; align-items: center; justify-content: center; color: var(--brand); flex: none; }
.card-ico--teal { color: var(--teal); }
.card-ico .ico { font-size: 26px; }
.card-ico--sm .ico { font-size: 18px; }

/* ---- Pills (status) — rounded-rect, no border, no dot ------ */
.pill {
  display: inline-flex; align-items: center; justify-content: center;
  height: 24px; min-width: 96px; box-sizing: border-box;
  font-size: var(--fs-xs); font-weight: var(--fw-semi); line-height: 1;
  padding: 0 10px; border-radius: var(--r-xs); border: 0;
  white-space: nowrap;
}
.pill .pdot { display: none; }
.pill--read  { background: var(--st-read-bg);  color: var(--st-read-fg); }
.pill--draft { background: var(--st-draft-bg); color: var(--st-draft-fg); }
.pill--open  { background: var(--st-open-bg);  color: var(--st-open-fg); }
.pill--over  { background: var(--st-over-bg);  color: var(--st-over-fg); }
.pill--part  { background: var(--st-part-bg);  color: var(--st-part-fg); }
.pill--paid  { background: var(--st-paid-bg);  color: var(--st-paid-fg); }
.pill--canc  { background: var(--st-canc-bg);  color: var(--st-canc-fg); }

/* law tag */
.tag {
  display: inline-flex; align-items: center; justify-content: center;
  height: 20px; min-width: 48px; box-sizing: border-box;
  font-size: 11px; font-weight: var(--fw-bold);
  padding: 0 8px; border-radius: var(--r-xs); letter-spacing: .02em;
}
.tag--kvg { background: var(--tag-kvg-bg); color: var(--tag-kvg-fg); }
.tag--uvg { background: var(--tag-uvg-bg); color: var(--tag-uvg-fg); }
.tag--ivg { background: var(--tag-ivg-bg); color: var(--tag-ivg-fg); }
.tag--mvg { background: var(--tag-mvg-bg); color: var(--tag-mvg-fg); }

/* ---- Hint / Warn boxes ------------------------------------ */
.box {
  display: flex; gap: var(--sp-3); padding: var(--sp-4);
  border-radius: var(--r-md); border: 1px solid; font-size: var(--fs-sm); line-height: var(--lh-snug);
}
.box .ico { flex: none; margin-top: 1px; }
.box__body { min-width: 0; }
.box__title { font-weight: var(--fw-semi); margin-bottom: 2px; }
.box--hint { background: var(--hint-bg); border-color: var(--hint-bd); color: var(--hint-fg); }
.box--hint .ico { color: var(--hint-ic); }
.box--warn { background: var(--warn-bg); border-color: var(--warn-bd); color: var(--warn-fg); }
.box--warn .ico { color: var(--warn-ic); }
.box--ok { background: var(--ok-bg); border-color: var(--ok-bd); color: var(--ok-fg); }
/* collapsible info box — collapsed shows only a keyword, click for full text */
.box.collapsible { display: block; padding: 0; }
.box__summary {
  display: flex; align-items: center; gap: var(--sp-3); width: 100%;
  padding: 10px var(--sp-4); background: transparent; border: 0; color: inherit;
  font: inherit; font-size: var(--fs-sm); font-weight: var(--fw-semi); cursor: pointer; text-align: left;
}
.box__summary > .ico { flex: none; }
.box__summary .chev { margin-left: auto; opacity: .7; transition: transform var(--t-fast) var(--ease); }
.box.is-open .box__summary .chev { transform: rotate(180deg); }
.box__more {
  display: none; padding: 0 var(--sp-4) var(--sp-4) calc(var(--sp-4) + 16px + var(--sp-3));
  font-size: var(--fs-sm); line-height: var(--lh-snug); font-weight: var(--fw-regular);
}
.box.is-open .box__more { display: block; }

/* help popover — question-mark icon in a card corner, hover reveals a hint panel */
.help-pop { position: relative; display: inline-flex; }
.help-pop__btn {
  width: 26px; height: 26px; border-radius: 50%; padding: 0;
  display: inline-grid; place-items: center;
  border: 1px solid var(--border-2); background: var(--surface);
  color: var(--text-3); cursor: help;
  transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.help-pop__btn .ico { font-size: 16px; }
.help-pop:hover .help-pop__btn, .help-pop__btn:focus-visible {
  color: var(--hint-ic); border-color: var(--hint-bd); background: var(--hint-bg); outline: none;
}
/* attention blink on page load — fires 3× so the eye finds the in-context help */
@keyframes helpBlink {
  0%, 100% { box-shadow: 0 0 0 0 rgba(var(--hint-ic-rgb, 37,99,235), 0); border-color: var(--border-2); color: var(--text-3); }
  30%      { box-shadow: 0 0 0 5px rgba(var(--hint-ic-rgb, 37,99,235), .22); border-color: var(--hint-bd); color: var(--hint-ic); background: var(--hint-bg); }
  60%      { box-shadow: 0 0 0 0 rgba(var(--hint-ic-rgb, 37,99,235), 0); }
}
.help-pop__btn.blink { animation: helpBlink 1s var(--ease) 3; }
.help-pop:hover .help-pop__btn.blink, .help-pop__btn.blink:focus-visible { animation: none; }
@media (prefers-reduced-motion: reduce) { .help-pop__btn.blink { animation: none; } }
.help-pop__panel {
  position: absolute; top: calc(100% + 9px); right: 0; z-index: 40;
  width: 322px; max-width: 78vw;
  background: var(--hint-bg); border: 1px solid var(--hint-bd); color: var(--hint-fg);
  border-radius: var(--r-md); padding: var(--sp-4);
  font-size: var(--fs-sm); line-height: var(--lh-snug); font-weight: var(--fw-regular); text-align: left;
  box-shadow: var(--shadow-pop);
  opacity: 0; visibility: hidden; transform: translateY(-4px);
  transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), visibility var(--t-fast);
}
.help-pop:hover .help-pop__panel, .help-pop:focus-within .help-pop__panel {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.help-pop__panel .hp-head { display: flex; align-items: center; gap: 8px; font-weight: var(--fw-semi); margin-bottom: 6px; }
.help-pop__panel .hp-head .ico { color: var(--hint-ic); flex: none; }
.help-pop__panel::before {           /* arrow */
  content: ""; position: absolute; top: -5px; right: 9px; width: 9px; height: 9px;
  background: var(--hint-bg); border-left: 1px solid var(--hint-bd); border-top: 1px solid var(--hint-bd);
  transform: rotate(45deg);
}
.help-pop__panel::after {            /* invisible bridge across the gap so hover persists */
  content: ""; position: absolute; top: -10px; left: 0; right: 0; height: 11px;
}
/* left-anchored variant (panel grows to the right, arrow on the left) */
.help-pop--left .help-pop__panel { right: auto; left: 0; }
.help-pop--left .help-pop__panel::before { right: auto; left: 9px; }
.help-pop__panel--wide { width: 380px; }
/* in-panel divider + orange swatch for the drift note */
.hp-rule { height: 1px; background: var(--hint-bd); margin: 10px 0; }
.hp-swatch { width: 14px; height: 14px; border-radius: 3px; flex: none; margin-top: 2px;
  background: var(--drift-bg); box-shadow: inset 0 0 0 1px var(--drift-fg); }

/* inline note */
.note { display: inline-flex; align-items: center; gap: 5px; font-size: var(--fs-xs); color: var(--text-3); }

/* ---- Table ------------------------------------------------- */
.tablewrap { width: 100%; overflow-x: auto; }
.table { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); }
.table th {
  text-align: left; font-weight: var(--fw-semi); color: var(--text-3);
  font-size: 11px; letter-spacing: var(--tracking-cap); text-transform: uppercase;
  padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border);
  white-space: nowrap; background: var(--surface);
}
.table td { padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border); vertical-align: middle; }
.table tbody tr { transition: background var(--t-fast) var(--ease); }
.table tbody tr:hover { background: var(--brand-tint-2); }
.table tbody tr:last-child td { border-bottom: 0; }
.table tbody tr.is-drift { background: var(--drift-bg); }
.table tbody tr.is-drift:hover { background: #fff0dd; }
.cell-strong { font-weight: var(--fw-semi); color: var(--text); }
.cell-sub { color: var(--text-3); font-size: var(--fs-xs); margin-top: 2px; }
.cell-date { display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }
.cell-date .ico { color: var(--text-3); flex: none; }
/* block-level line — forces each item onto its own row (stacked cells) */
.cell-line { display: flex; align-items: center; gap: 6px; white-space: nowrap; }
.cell-line .ico { color: var(--text-3); flex: none; }
.cell-line + .cell-line { margin-top: 3px; }
.cell-link { color: var(--brand); font-weight: var(--fw-semi); }
.deeplink { display: inline-flex; align-items: center; gap: 5px; color: var(--brand); font-weight: var(--fw-semi); }
.deeplink .ico { opacity: .7; }
.amount { font-variant-numeric: tabular-nums; font-weight: var(--fw-semi); white-space: nowrap; }
.text-r { text-align: right; }

/* drift marker inside cell */
.drift-flag { display: flex; align-items: center; gap: 5px; color: var(--drift-fg); font-size: var(--fs-xs); font-weight: var(--fw-semi); margin-top: 3px; white-space: normal; }
.drift-flag .ico { flex: none; }

/* ---- Toolbar (search + filter) ---------------------------- */
.toolbar { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.searchbox {
  display: flex; align-items: center; gap: var(--sp-2);
  background: var(--surface); border: 1px solid var(--border-2); border-radius: var(--r-md);
  padding: 0 var(--sp-3); height: 38px; min-width: 260px; flex: 1; max-width: 380px;
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.searchbox:focus-within { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-ring); }
.searchbox .ico { color: var(--text-3); flex: none; }
.searchbox input { border: 0; outline: none; background: transparent; font: inherit; font-size: var(--fs-sm); width: 100%; color: var(--text); }

/* dropdown */
.select {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  background: var(--surface); border: 1px solid var(--border-2); border-radius: var(--r-md);
  padding: 0 var(--sp-3); height: 38px; font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--text-2);
}
.select .ico { color: var(--text-3); }
.select:hover { border-color: var(--border-strong); }

/* filter chips (active filters) */
.fchip {
  display: inline-flex; align-items: center; gap: 6px; font-size: var(--fs-xs); font-weight: var(--fw-semi);
  background: var(--brand-tint); color: var(--brand); padding: 5px 8px 5px 10px; border-radius: var(--r-pill);
}
.fchip button { border: 0; background: transparent; color: inherit; display: inline-flex; padding: 0; opacity: .7; }
.fchip button:hover { opacity: 1; }

/* ---- Tooltip ---------------------------------------------- */
.tip { position: relative; display: inline-flex; }
.tip__pop {
  position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%) translateY(4px);
  background: #2a3140; color: #fff; font-size: var(--fs-xs); font-weight: var(--fw-medium);
  padding: 6px 9px; border-radius: var(--r-sm); white-space: nowrap; pointer-events: none;
  opacity: 0; transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease); z-index: 50;
  box-shadow: var(--shadow-pop);
}
.tip:hover .tip__pop { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ---- Skeleton --------------------------------------------- */
.sk { background: var(--surface-2); border-radius: var(--r-sm); position: relative; overflow: hidden; }
.sk::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.65), transparent);
  transform: translateX(-100%); animation: sk 1.4s infinite;
}
@keyframes sk { 100% { transform: translateX(100%); } }
.sk--line { height: 12px; }
.sk--pill { height: 22px; width: 78px; border-radius: var(--r-pill); }
@media (prefers-reduced-motion: reduce) { .sk::after { animation: none; } }

/* ---- Empty state ------------------------------------------ */
.empty { text-align: center; padding: var(--sp-9) var(--sp-5); }
.empty__icon {
  width: 56px; height: 56px; border-radius: var(--r-lg); margin: 0 auto var(--sp-4);
  display: grid; place-items: center; background: var(--brand-tint); color: var(--brand);
}
.empty__title { font-size: var(--fs-lg); font-weight: var(--fw-semi); margin-bottom: 6px; }
.empty__text { color: var(--text-2); font-size: var(--fs-sm); max-width: 380px; margin: 0 auto var(--sp-5); }

/* ---- Icons ------------------------------------------------- */
.ico { display: inline-flex; width: 1em; height: 1em; flex: none; }
.ico svg { width: 100%; height: 100%; display: block; }
.ico--sm { font-size: 14px; }
.ico--md { font-size: 16px; }
.ico--lg { font-size: 20px; }

/* ---- Dropdown menu ---------------------------------------- */
.menu-anchor { position: relative; display: inline-flex; }
.menu {
  position: absolute; top: calc(100% + 6px); right: 0; min-width: 200px;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md);
  box-shadow: var(--shadow-pop); padding: 6px; z-index: 60;
  opacity: 0; visibility: hidden; transform: translateY(-4px);
  transition: opacity var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), visibility var(--t-fast);
}
.menu.is-open { opacity: 1; visibility: visible; transform: translateY(0); }
.menu--left { right: auto; left: 0; }
.menu--up { top: auto; bottom: calc(100% + 6px); transform: translateY(6px); min-width: 90px; }
.menu--up.is-open { transform: translateY(0); }

/* per-page selector inside the pager */
.pager__per { display: flex; align-items: center; gap: 8px; margin-left: var(--sp-3); }
.pager__per label { font-size: var(--fs-sm); color: var(--text-3); }
.pager__perbtn {
  display: inline-flex; align-items: center; gap: 5px; height: 32px; padding: 0 8px 0 11px;
  border: 1px solid var(--border-2); border-radius: var(--r-sm); background: var(--surface);
  color: var(--text-2); font: inherit; font-size: var(--fs-sm); font-weight: var(--fw-medium); cursor: pointer;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.pager__perbtn:hover { border-color: var(--border-strong); background: var(--surface-2); }
.pager__perbtn .ico { color: var(--text-3); }
.menu__item {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: 8px 10px; border-radius: var(--r-sm); font-size: var(--fs-sm); color: var(--text-2);
  cursor: pointer; transition: background var(--t-fast) var(--ease);
}
.menu__item:hover { background: var(--surface-2); color: var(--text); }
.menu__item .ico { color: var(--text-3); }
.menu__item .check { margin-left: auto; opacity: 0; color: var(--brand); }
.menu__item.is-sel { color: var(--brand); font-weight: var(--fw-semi); }
.menu__item.is-sel .check { opacity: 1; }
.menu__sep { height: 1px; background: var(--border); margin: 5px 2px; }
.menu__label { font-size: 11px; font-weight: var(--fw-semi); letter-spacing: var(--tracking-cap); text-transform: uppercase; color: var(--text-3); padding: 6px 10px 3px; }

/* ---- Segmented control ------------------------------------ */
.seg { display: inline-flex; background: var(--surface-2); border-radius: var(--r-md); padding: 3px; gap: 2px; }
.seg button {
  border: 0; background: transparent; color: var(--text-2);
  font-size: var(--fs-sm); font-weight: var(--fw-medium); padding: 6px 12px; border-radius: var(--r-sm);
  display: inline-flex; align-items: center; gap: 6px; transition: all var(--t-fast) var(--ease);
}
.seg button.is-active { background: var(--surface); color: var(--text); box-shadow: var(--shadow-xs); }

/* ---- Modal ------------------------------------------------- */
.modal {
  position: fixed; inset: 0; z-index: 100; display: none;
  align-items: center; justify-content: center; padding: var(--sp-6);
  background: rgba(20,26,38,.42); backdrop-filter: blur(3px);
}
.modal.is-open { display: flex; }
.modal__dialog {
  background: var(--surface); border-radius: var(--r-xl); box-shadow: var(--shadow-pop);
  width: 100%; max-width: 460px; overflow: hidden;
  animation: modalin var(--t-base) var(--ease);
}
.modal__dialog--lg { max-width: 600px; }
@keyframes modalin { from { opacity: 0; transform: translateY(8px) scale(.98); } to { opacity: 1; transform: none; } }
.modal__head { display: flex; align-items: flex-start; gap: var(--sp-3); padding: var(--sp-5) var(--sp-5) var(--sp-3); }
.modal__head .x { margin-left: auto; }
.modal__title { font-size: var(--fs-lg); font-weight: var(--fw-semi); }
.modal__body { padding: 0 var(--sp-5) var(--sp-5); }
.modal__foot { display: flex; justify-content: flex-end; gap: var(--sp-3); padding: var(--sp-4) var(--sp-5); border-top: 1px solid var(--border); background: var(--surface-2); }

/* ---- Definition list (export summary) --------------------- */
.dl { display: grid; grid-template-columns: auto 1fr; gap: 8px 16px; font-size: var(--fs-sm); }
.dl dt { color: var(--text-3); }
.dl dd { margin: 0; text-align: right; font-weight: var(--fw-semi); font-variant-numeric: tabular-nums; }

/* ---- Checkbox (row select) -------------------------------- */
.cs-check { width: 16px; height: 16px; accent-color: var(--brand); cursor: pointer; margin: 0; vertical-align: middle; }
.col-check { width: 40px; text-align: center; }
.col-check, td.col-check { padding-left: var(--sp-4); padding-right: 0; }
.table tbody tr.is-sel { background: var(--brand-tint-2); }
.table tbody tr.is-sel:hover { background: var(--brand-tint); }

/* ---- Pager ------------------------------------------------ */
.pager { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-4); border-top: 1px solid var(--border); flex-wrap: wrap; }
.pager__info { font-size: var(--fs-sm); color: var(--text-3); }
.pager__info strong { color: var(--text-2); font-weight: var(--fw-semi); }
.pager__spacer { flex: 1; }
.pager__group { display: flex; align-items: center; gap: 4px; }
.pager__btn, .pager__page {
  min-width: 32px; height: 32px; border-radius: var(--r-sm); border: 1px solid var(--border-2);
  background: var(--surface); color: var(--text-2); font: inherit; font-size: var(--fs-sm); font-weight: var(--fw-medium);
  display: inline-grid; place-items: center; cursor: pointer; padding: 0 8px;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.pager__btn:hover:not(:disabled), .pager__page:hover:not(.is-active) { background: var(--surface-2); border-color: var(--border-strong); color: var(--text); }
.pager__page.is-active { background: var(--brand); color: #fff; border-color: var(--brand); }
.pager__btn:disabled { opacity: .45; cursor: not-allowed; }
.pager__ellipsis { color: var(--text-3); padding: 0 2px; }

/* utility */
.row { display: flex; align-items: center; }
.col { display: flex; flex-direction: column; }
.gap-1 { gap: var(--sp-1);} .gap-2 { gap: var(--sp-2);} .gap-3 { gap: var(--sp-3);} .gap-4 { gap: var(--sp-4);}
.muted { color: var(--text-3); }
.t2 { color: var(--text-2); }
.fw-semi { font-weight: var(--fw-semi); }
.text-sm { font-size: var(--fs-sm); }
.text-xs { font-size: var(--fs-xs); }
.mt-2 { margin-top: var(--sp-2);} .mt-3 { margin-top: var(--sp-3);} .mt-4 { margin-top: var(--sp-4);} .mt-5 { margin-top: var(--sp-5);}
.mb-4 { margin-bottom: var(--sp-4);} .mb-5 { margin-bottom: var(--sp-5);}
.spacer { flex: 1; }
