:root {
  --bg: var(--background);
  --panel: var(--surface);
  --line: var(--border);
  --text: var(--foreground);
  --muted: var(--muted);
  --accent: var(--accent);
  --accent-dark: var(--foreground);
  --accent-soft: color-mix(in oklab, var(--accent) 12%, transparent);
  --success: var(--success);
  --danger: var(--danger);
  --shadow: var(--app-shadow);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  color: var(--text);
  font-family: var(--font-sans);
  background: var(--bg);
}

.login-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}

.login-panel {
  width: min(560px, 100%);
}

.app-layout {
  display: flex;
  min-height: 100vh;
}

.sidebar {
  width: 300px;
  padding: 24px 18px;
  border-right: 1px solid var(--line);
  background: var(--panel);
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.page-shell {
  flex: 1;
  width: min(1260px, calc(100vw - 32px));
  margin: 0 auto;
  padding: 28px 20px 48px;
}

.brand {
  padding: 8px 8px 14px;
}

.small {
  font-size: 14px;
}

.nav {
  display: grid;
  gap: 10px;
}

.nav-link {
  width: 100%;
  text-align: left;
  padding: 14px 16px;
  border-radius: 18px;
  background: var(--default);
  color: var(--default-foreground);
  border: 1px solid var(--border);
  font-weight: 700;
}

.nav-link.active {
  background: color-mix(in oklab, var(--accent) 14%, var(--surface));
  color: var(--foreground);
  box-shadow: none;
  border-color: color-mix(in oklab, var(--accent) 30%, var(--border));
}

.sidebar-actions {
  margin-top: auto;
  display: grid;
  gap: 10px;
}

.hero,
.panel,
.card {
  background: var(--panel);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

.hero {
  border-radius: 28px;
  padding: 28px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: flex-end;
}

.eyebrow {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 12px;
  color: var(--muted);
}

h1,
h2 {
  margin: 0;
  font-family: var(--font-sans);
}

.lead {
  max-width: 720px;
  color: var(--muted);
}

.hero-actions,
.cards,
.grid,
.panel-header,
.inspect-grid,
.inline {
  display: flex;
  gap: 14px;
}

.filters {
  margin-top: 16px;
  flex-wrap: wrap;
}

.hero-actions {
  flex-wrap: wrap;
}

.cards {
  margin: 22px 0;
  flex-wrap: wrap;
}

.cards-tight {
  margin: 16px 0 18px;
}

.card {
  flex: 1 1 200px;
  border-radius: 22px;
  padding: 18px;
}

.card .label {
  color: var(--muted);
  font-size: 13px;
}

.card .value {
  margin-top: 10px;
  font-size: 30px;
  font-weight: 700;
}

.grid {
  margin-top: 22px;
  flex-wrap: wrap;
}

.panel {
  flex: 1 1 390px;
  min-width: 0;
  border-radius: 24px;
  padding: 22px;
}

.panel-soft {
  margin-top: 18px;
  background: var(--surface-secondary);
}

.content-section {
  display: none;
  gap: 22px;
}

.content-section.is-active {
  display: grid;
}

.panel-header {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}

.button,
button {
  border: 1px solid color-mix(in oklab, var(--accent) 72%, var(--border));
  border-radius: 999px;
  background: var(--accent);
  color: var(--accent-foreground);
  padding: 12px 18px;
  cursor: pointer;
  text-decoration: none;
  font-weight: 700;
}

.button.secondary {
  background: #fff1e7;
  color: var(--muted);
}

.button.secondary.is-selected {
  background: color-mix(in oklab, var(--accent) 14%, var(--surface));
  color: var(--foreground);
  box-shadow: none;
  border-color: color-mix(in oklab, var(--accent) 30%, var(--border));
}

.table-action {
  padding: 8px 12px;
  font-size: 13px;
}

.history-link {
  border: 0;
  background: transparent;
  color: var(--muted);
  font-weight: 700;
  padding: 0;
  cursor: pointer;
  text-decoration: underline;
}

.danger-action {
  background: color-mix(in oklab, var(--danger) 12%, var(--surface));
  color: var(--danger);
}

.stack {
  display: grid;
  gap: 12px;
}

input,
select {
  width: 100%;
  border: 1px solid rgba(89, 57, 29, 0.14);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--text);
  padding: 12px 14px;
}

.period-block {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(89, 57, 29, 0.12);
  border-radius: 18px;
  background: rgba(255, 252, 248, 0.72);
}

.period-block-compact {
  width: min(560px, 100%);
}

.period-badge {
  display: inline-flex;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  background: #fff1e7;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.period-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.date-field {
  display: grid;
  gap: 8px;
  font-weight: 600;
}

.date-field span {
  color: var(--muted);
}

.inspect-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 16px;
  align-items: start;
}

.inspect-grid label {
  display: grid;
  gap: 8px;
  font-weight: 600;
  color: var(--text);
}

.preview-col-toggle {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  min-height: 88px;
  gap: 8px;
}

.preview-col-toggle span {
  display: block;
  line-height: 1.15;
}

.preview-col-toggle input {
  width: 16px;
  height: 16px;
  margin-top: auto;
}

.column-check {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
}

.column-check input {
  width: auto;
  margin: 0;
}

.summary,
.warnings {
  margin-top: 12px;
}

.summary {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: flex-start;
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 13px;
  background: #fff4eb;
}

.pill-label {
  font-weight: 600;
}

.pill-value {
  display: inline-flex;
  align-items: center;
}

.pill .history-link {
  display: inline-flex;
  align-items: center;
  line-height: 1.1;
}

.pill.success {
  background: rgba(22, 121, 93, 0.12);
  color: var(--success);
}

.pill.danger {
  background: color-mix(in oklab, var(--danger) 12%, var(--surface));
  color: var(--danger);
}

.table-wrap {
  overflow-x: auto;
  margin-top: 12px;
}

#hot-telegram-base.table-wrap {
  max-height: 70vh;
  overflow: auto;
}

#hot-telegram-duplicates.table-wrap {
  max-height: 70vh;
  overflow: auto;
}

#finance-matched-payers.table-wrap,
#finance-unmatched-payers.table-wrap {
  max-height: 70vh;
  overflow: auto;
}

#other-bot-current-base.table-wrap {
  max-height: 70vh;
  overflow: auto;
}

.hot-referrer-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 12px;
}

.hot-referrer-chip {
  padding: 10px 14px;
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

th,
td {
  padding: 10px 8px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}

th input[type="checkbox"],
td input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
}

.preview-table {
  max-height: 320px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 18px;
  margin-top: 12px;
}

.muted {
  color: var(--muted);
}

canvas {
  width: 100%;
  background: linear-gradient(180deg, rgba(255, 248, 240, 0.8), rgba(255, 252, 247, 0.95));
  border-radius: 18px;
  border: 1px solid var(--line);
  padding: 8px;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(28, 19, 12, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 100;
}

.modal-backdrop[hidden] {
  display: none !important;
}

.modal-card {
  width: min(1080px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  border-radius: 24px;
  padding: 22px;
  background: rgba(255, 251, 245, 0.98);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

.modal-card-compact {
  width: min(520px, 100%);
  max-height: none;
}

.modal-choice-row {
  margin-top: 12px;
  margin-bottom: 4px;
}

.modal-actions {
  display: flex;
  justify-content: flex-start;
  margin-top: 12px;
}

.modal-actions-end {
  justify-content: flex-end;
}

#user-edit-form .inspect-grid {
  align-items: end;
}

.conflict-list {
  display: grid;
  gap: 14px;
  margin-top: 12px;
}

.conflict-card {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 253, 249, 0.9);
  padding: 18px;
}

.conflict-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.conflict-col {
  border: 1px solid rgba(89, 57, 29, 0.1);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.72);
}

.conflict-col.current {
  background: rgba(255, 244, 235, 0.7);
}

.conflict-col.incoming {
  background: rgba(235, 250, 243, 0.7);
}

.conflict-title {
  font-weight: 700;
  margin-bottom: 8px;
}

.conflict-field {
  display: grid;
  gap: 4px;
  margin-top: 8px;
}

.conflict-field.changed {
  border-left: 4px solid var(--accent);
  padding-left: 8px;
}

.conflict-label {
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

@media (max-width: 860px) {
  .app-layout {
    flex-direction: column;
  }

  .sidebar {
    width: 100%;
    height: auto;
    position: static;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .page-shell {
    width: min(100vw - 20px, 1260px);
    padding-top: 12px;
  }

  .hero {
    flex-direction: column;
    align-items: stretch;
  }

  .panel {
    flex-basis: 100%;
  }

  .period-grid {
    grid-template-columns: 1fr;
  }

  .inspect-grid {
    grid-template-columns: 1fr;
  }

  .conflict-grid {
    grid-template-columns: 1fr;
  }
}

/* Users screen refresh */
#section-users {
  gap: 20px;
}

.users-screen-panel {
  gap: 22px;
}

.users-screen-head,
.users-card-head,
.users-table-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.users-screen-head {
  padding-bottom: 4px;
}

.users-screen-head h2,
.users-card-head h3 {
  margin: 0;
}

.users-screen-lead {
  max-width: 58ch;
}

.users-screen-badges,
.users-table-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.users-compose-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.9fr);
  gap: 20px;
}

.users-compose-card {
  background: color-mix(in oklab, var(--surface) 98%, var(--background));
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 22px;
  box-shadow: var(--app-shadow);
}

.users-card-copy {
  margin: 4px 0 18px;
}

.users-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.field-shell {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.field-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.field-span-2 {
  grid-column: span 2;
}

.users-submit-button {
  margin-top: 4px;
}

.users-policy-list {
  display: grid;
  gap: 14px;
  margin-top: 8px;
}

.users-policy-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 14px 16px;
  border-radius: 16px;
  background: color-mix(in oklab, var(--surface-secondary) 82%, var(--surface));
  border: 1px solid var(--border);
}

.users-policy-item strong {
  display: block;
  margin-bottom: 4px;
}

.users-policy-item p {
  margin: 0;
  color: var(--muted);
}

.users-policy-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--accent);
  margin-top: 6px;
  flex: 0 0 auto;
}

.users-table-card {
  padding-top: 18px;
}

.users-table-wrap {
  overflow-x: auto;
}

.users-data-table {
  min-width: 940px;
}

.users-person-cell,
.users-meta-cell {
  display: flex;
  align-items: center;
  gap: 12px;
}

.users-meta-cell {
  display: grid;
  gap: 2px;
}

.users-meta-cell span,
.users-login {
  font-size: 0.88rem;
  color: var(--muted);
}

.users-avatar {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  background: color-mix(in oklab, var(--accent) 16%, var(--surface));
  color: var(--foreground);
  border: 1px solid color-mix(in oklab, var(--accent) 26%, var(--border));
}

.users-person-cell strong,
.users-meta-cell strong {
  font-size: 0.95rem;
}

.users-data-table td {
  vertical-align: middle;
}

.users-table-actions .table-action {
  min-width: 122px;
}

@media (max-width: 1100px) {
  .users-compose-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .users-screen-head,
  .users-card-head,
  .users-table-head {
    flex-direction: column;
  }

  .users-form-grid {
    grid-template-columns: 1fr;
  }

  .field-span-2 {
    grid-column: span 1;
  }
}

/* Final HeroUI foundation */
:root,
.light,
.default,
[data-theme="light"],
[data-theme="default"] {
  --accent: oklch(74.63% 0.1783 57.54);
  --accent-foreground: oklch(15% 0.0300 57.54);
  --background: oklch(97.02% 0.0077 57.54);
  --border: oklch(90.00% 0.0077 57.54);
  --danger: oklch(65.32% 0.2364 2.19);
  --danger-foreground: oklch(99.11% 0 0);
  --default: oklch(94.00% 0.0077 57.54);
  --default-foreground: oklch(21.03% 0.0059 57.54);
  --field-background: oklch(100.00% 0.0039 57.54);
  --field-foreground: oklch(21.03% 0.0077 57.54);
  --field-placeholder: oklch(55.17% 0.0154 57.54);
  --focus: oklch(74.63% 0.1783 57.54);
  --foreground: oklch(21.03% 0.0077 57.54);
  --muted: oklch(55.17% 0.0154 57.54);
  --overlay: oklch(100.00% 0.0023 57.54);
  --overlay-foreground: oklch(21.03% 0.0077 57.54);
  --scrollbar: oklch(87.10% 0.0077 57.54);
  --segment: oklch(100.00% 0.0077 57.54);
  --segment-foreground: oklch(21.03% 0.0077 57.54);
  --separator: oklch(92.00% 0.0077 57.54);
  --success: oklch(73.29% 0.1965 127.26);
  --success-foreground: oklch(21.03% 0.0059 127.26);
  --surface: oklch(100.00% 0.0039 57.54);
  --surface-foreground: oklch(21.03% 0.0077 57.54);
  --surface-secondary: oklch(95.24% 0.0062 57.54);
  --surface-secondary-foreground: oklch(21.03% 0.0077 57.54);
  --surface-tertiary: oklch(93.73% 0.0062 57.54);
  --surface-tertiary-foreground: oklch(21.03% 0.0077 57.54);
  --warning: oklch(78.19% 0.1609 48.78);
  --warning-foreground: oklch(21.03% 0.0059 48.78);
  --radius: 0.75rem;
  --field-radius: 0.75rem;
  --font-sans: var(--font-varela-round, "Varela Round", "Avenir Next", "Inter", "Segoe UI", sans-serif);
    --app-shadow: 0 8px 24px color-mix(in oklab, var(--foreground) 6%, transparent);
}

.dark,
[data-theme="dark"] {
  color-scheme: dark;
  --accent: oklch(74.63% 0.1783 57.54);
  --accent-foreground: oklch(15% 0.0300 57.54);
  --background: oklch(12.00% 0.0077 57.54);
  --border: oklch(28.00% 0.0077 57.54);
  --danger: oklch(59.40% 0.1997 1.08);
  --danger-foreground: oklch(99.11% 0 0);
  --default: oklch(27.40% 0.0077 57.54);
  --default-foreground: oklch(99.11% 0 0);
  --field-background: oklch(21.03% 0.0154 57.54);
  --field-foreground: oklch(99.11% 0.0077 57.54);
  --field-placeholder: oklch(70.50% 0.0154 57.54);
  --focus: oklch(74.63% 0.1783 57.54);
  --foreground: oklch(99.11% 0.0077 57.54);
  --muted: oklch(70.50% 0.0154 57.54);
  --overlay: oklch(21.03% 0.0154 57.54);
  --overlay-foreground: oklch(99.11% 0.0077 57.54);
  --scrollbar: oklch(70.50% 0.0077 57.54);
  --segment: oklch(39.64% 0.0077 57.54);
  --segment-foreground: oklch(99.11% 0.0077 57.54);
  --separator: oklch(25.00% 0.0077 57.54);
  --success: oklch(73.29% 0.1965 127.26);
  --success-foreground: oklch(21.03% 0.0059 127.26);
  --surface: oklch(21.03% 0.0154 57.54);
  --surface-foreground: oklch(99.11% 0.0077 57.54);
  --surface-secondary: oklch(25.70% 0.0116 57.54);
  --surface-secondary-foreground: oklch(99.11% 0.0077 57.54);
  --surface-tertiary: oklch(27.21% 0.0116 57.54);
  --surface-tertiary-foreground: oklch(99.11% 0.0077 57.54);
  --warning: oklch(82.03% 0.1409 52.79);
  --warning-foreground: oklch(21.03% 0.0059 52.79);
  --app-shadow: 0 10px 28px color-mix(in oklab, black 22%, transparent);
}

html,
body {
  background: var(--background) !important;
  color: var(--foreground) !important;
}

body,
input,
select,
button,
textarea {
  font-family: var(--font-sans) !important;
}

body {
  min-height: 100vh;
  background-image: none !important;
}

body::before,
.login-shell::before,
.login-shell::after,
.sidebar::before,
.hero::before,
.hero::after,
.panel::before,
.card::before,
.card::after,
.login-panel::before {
  display: none !important;
  content: none !important;
}

h1,
h2,
h3,
.login-panel h1,
.login-form-head h2,
.page-topbar h2,
.card .value {
  font-family: var(--font-sans) !important;
  letter-spacing: -0.03em !important;
  color: var(--foreground) !important;
}


.app-layout {
  gap: 24px !important;
}

.page-shell,
.content-section,
.stack,
.summary,
.filters,
.inline,
.cards,
.grid,
.users-screen-panel {
  gap: 16px !important;
}

.sidebar,
.hero,
.panel,
.card,
.login-panel,
.login-form-shell,
.modal-card,
.panel-soft,
#hot-telegram-form,
#finance-form,
.confirm-form,
.empty-state,
.table-wrap,
.preview-table,
.modal-choice-row,
.filters,
.hot-referrer-toolbar,
.period-block,
.conflict-card,
.conflict-col,
.users-compose-card {
  background: var(--surface) !important;
  background-image: none !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--app-shadow) !important;
  backdrop-filter: none !important;
}

.sidebar {
  width: 304px !important;
  padding: 20px !important;
  border-radius: 28px !important;
}

.hero,
.panel,
.login-panel,
.card,
.users-compose-card,
.table-wrap,
.preview-table,
.empty-state,
.login-form-shell,
.modal-card {
  border-radius: 22px !important;
}

.hero,
.panel,
.card,
.login-panel,
.login-form-shell,
.users-compose-card {
  padding: 22px !important;
}

.hero {
  min-height: auto !important;
  align-items: flex-start !important;
  padding-right: 22px !important;
}

.brand-copy .eyebrow,
.eyebrow,
.sidebar-label,
.field-label,
th {
  color: var(--muted) !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}

.lead,
.small,
.muted,
.summary,
.card .label,
.sidebar-footer-note p,
.users-login,
.users-meta-cell span,
.users-policy-item p {
  color: var(--muted) !important;
}

.nav,
.sidebar-actions,
.login-highlights,
.users-screen-badges,
.users-table-actions {
  gap: 10px !important;
}

.nav-link,
.button.secondary,
.theme-toggle,
.table-action,
.history-link.button,
.page-chip,
.period-badge,
.pill,
.sidebar-status,
.sidebar-kicker {
  background: var(--default) !important;
  color: var(--default-foreground) !important;
  border: 1px solid var(--border) !important;
  box-shadow: none !important;
}

.nav-link,
.button.secondary,
.theme-toggle,
.table-action,
input,
select,
textarea {
  min-height: 46px !important;
  border-radius: 999px !important;
}

.button,
button[type="submit"],
a.button:not(.secondary),
.users-submit-button {
  background: var(--accent) !important;
  color: var(--accent-foreground) !important;
  border: 1px solid color-mix(in oklab, var(--accent) 72%, var(--border)) !important;
  box-shadow: none !important;
  min-height: 48px !important;
  border-radius: 999px !important;
}

.nav-link:hover,
.button.secondary:hover,
.theme-toggle:hover,
.table-action:hover,
.page-chip:hover,
.button:hover,
button:hover {
  transform: none !important;
  box-shadow: none !important;
}

.nav-link.active,
.button.secondary.is-selected {
  background: color-mix(in oklab, var(--accent) 14%, var(--surface)) !important;
  color: var(--foreground) !important;
  border-color: color-mix(in oklab, var(--accent) 30%, var(--border)) !important;
}

.page-chip,
.period-badge,
.pill,
.sidebar-status,
.sidebar-kicker {
  background: var(--segment) !important;
  color: var(--segment-foreground) !important;
  border: 1px solid var(--separator) !important;
}

.pill.success {
  background: color-mix(in oklab, var(--success) 16%, var(--surface)) !important;
  color: var(--success-foreground) !important;
}

.pill.danger,
.danger-action {
  background: color-mix(in oklab, var(--danger) 12%, var(--surface)) !important;
  color: var(--danger) !important;
  border-color: color-mix(in oklab, var(--danger) 22%, var(--border)) !important;
}

input,
select,
textarea {
  background: var(--field-background) !important;
  color: var(--field-foreground) !important;
  border: 1px solid var(--border) !important;
  box-shadow: none !important;
  padding-inline: 18px !important;
}

input::placeholder,
textarea::placeholder {
  color: var(--field-placeholder) !important;
}

input:focus,
select:focus,
textarea:focus,
.button:focus-visible,
button:focus-visible,
.nav-link:focus-visible {
  outline: none !important;
  border-color: color-mix(in oklab, var(--focus) 34%, var(--border)) !important;
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--focus) 14%, transparent) !important;
}

.table-wrap,
.preview-table,
.users-table-wrap {
  overflow-x: auto !important;
  background: var(--surface-secondary) !important;
}

table,
.users-data-table {
  background: transparent !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

th {
  background: var(--surface-secondary) !important;
  color: var(--muted) !important;
  font-size: 0.76rem !important;
}

td {
  color: var(--foreground) !important;
  background: transparent !important;
  vertical-align: middle !important;
}

tr:hover td {
  background: color-mix(in oklab, var(--accent) 4%, transparent) !important;
}

.users-avatar {
  background: color-mix(in oklab, var(--accent) 12%, var(--surface)) !important;
  color: var(--foreground) !important;
  border: 1px solid color-mix(in oklab, var(--accent) 20%, var(--border)) !important;
}

.users-policy-item {
  background: var(--surface-secondary) !important;
  border: 1px solid var(--border) !important;
}

.users-policy-dot,
.theme-toggle-dot {
  background: var(--accent) !important;
  box-shadow: none !important;
}

.empty-state {
  background: var(--surface-secondary) !important;
  border-style: solid !important;
}

.modal-backdrop {
  background: color-mix(in oklab, var(--overlay) 70%, transparent) !important;
}

.login-shell,
.login-panel {
  background: transparent !important;
}

.theme-toggle-floating {
  position: fixed !important;
  top: 16px !important;
  right: 16px !important;
  z-index: 120 !important;
  width: auto !important;
  min-width: 116px !important;
  padding-inline: 14px !important;
}

.sidebar .theme-toggle {
  display: none !important;
}

#current-user-card {
  padding: 10px 12px !important;
  border-radius: 18px !important;
}

#current-user-card .summary {
  gap: 8px !important;
  align-items: center !important;
}

#current-user-card .pill {
  min-height: 0 !important;
  padding: 7px 12px !important;
  font-size: 0.95rem !important;
  line-height: 1.1 !important;
  border-radius: 999px !important;
}

#current-user-card .pill.success {
  background: color-mix(in oklab, var(--success) 14%, var(--surface)) !important;
}

.login-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at 18% 20%, color-mix(in oklab, var(--accent) 10%, transparent) 0%, transparent 28%),
    radial-gradient(circle at 82% 82%, color-mix(in oklab, var(--foreground) 5%, transparent) 0%, transparent 22%),
    linear-gradient(180deg, color-mix(in oklab, var(--background) 92%, var(--surface-secondary)) 0%, var(--background) 100%) !important;
}

.login-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 32px;
}

.login-card {
  width: min(540px, 100%);
  padding: 28px 26px 24px !important;
  border-radius: 34px !important;
  border: 1px solid color-mix(in oklab, var(--border) 92%, white 8%) !important;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 98%, white 2%), color-mix(in oklab, var(--surface-secondary) 94%, var(--surface))) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 40%, transparent) inset,
    0 20px 55px color-mix(in oklab, var(--foreground) 10%, transparent) !important;
}

[data-theme="dark"] .login-card,
.dark .login-card {
  border-color: color-mix(in oklab, var(--border) 84%, white 8%) !important;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 96%, white 2%), color-mix(in oklab, var(--surface-secondary) 96%, var(--surface))) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 6%, transparent) inset,
    0 22px 60px color-mix(in oklab, black 32%, transparent) !important;
}

.login-card .login-kicker {
  margin: 0 0 16px;
  font-size: 0.92rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted) !important;
}

.login-card h1 {
  margin: 0 0 14px;
  font-family: var(--font-sans) !important;
  font-size: clamp(2.45rem, 6vw, 3.4rem);
  font-weight: 700;
  line-height: 0.92;
  color: var(--foreground) !important;
  letter-spacing: -0.06em !important;
}

.login-card .lead {
  margin: 0 0 18px;
  max-width: 24rem;
  font-size: 0.96rem;
  line-height: 1.35;
  color: var(--muted) !important;
}

.login-form {
  display: grid;
  gap: 16px;
}

.login-page .login-form input {
  min-height: 56px !important;
  padding: 0 18px !important;
  border-radius: 24px !important;
  border: 1px solid var(--border) !important;
  background: color-mix(in oklab, var(--field-background) 96%, var(--surface)) !important;
  color: var(--field-foreground) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 30%, transparent) inset,
    0 10px 24px color-mix(in oklab, var(--foreground) 5%, transparent) !important;
  font-size: 1.05rem !important;
}

[data-theme="dark"] .login-page .login-form input,
.dark .login-page .login-form input {
  box-shadow:
    0 1px 0 color-mix(in oklab, white 6%, transparent) inset,
    0 12px 28px color-mix(in oklab, black 24%, transparent) !important;
}

.login-page .login-form input::placeholder {
  color: var(--field-placeholder) !important;
}

.login-page .login-form .button {
  min-height: 58px !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, color-mix(in oklab, var(--accent) 92%, white 8%), color-mix(in oklab, var(--accent) 82%, black 10%)) !important;
  color: var(--accent-foreground) !important;
  border: 1px solid color-mix(in oklab, var(--accent) 64%, var(--border)) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 30%, transparent) inset,
    0 18px 34px color-mix(in oklab, var(--accent) 18%, transparent) !important;
  font-size: 1.08rem !important;
  font-weight: 700 !important;
}

.login-page #login-message {
  margin-top: 16px;
}

.login-page .summary {
  min-height: 24px;
}

@media (max-width: 1100px) {
  .sidebar {
    width: auto !important;
  }

  .users-compose-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 720px) {
  .theme-toggle-floating {
    top: 12px !important;
    right: 12px !important;
  }

  .hero,
  .panel,
  .card,
  .login-panel,
  .login-form-shell,
  .users-compose-card {
    padding: 18px !important;
    border-radius: 20px !important;
  }

  .users-form-grid {
    grid-template-columns: 1fr !important;
  }

  .field-span-2 {
    grid-column: span 1 !important;
  }

  .login-screen {
    padding: 16px;
  }

  .login-card {
    padding: 28px 22px 24px !important;
    border-radius: 28px !important;
  }

  .login-page .login-form input,
  .login-page .login-form .button {
    min-height: 56px !important;
  }
}


/* App shell polish */
.page-shell {
  padding: 24px 22px 40px !important;
}

.sidebar {
  width: 292px !important;
  padding: 18px 16px !important;
  gap: 14px !important;
  border-right: 0 !important;
  border-radius: 0 32px 32px 0 !important;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 98%, white 2%), color-mix(in oklab, var(--surface-secondary) 96%, var(--surface))) !important;
  box-shadow: 18px 0 42px color-mix(in oklab, var(--foreground) 5%, transparent) !important;
}

.dark .sidebar,
[data-theme="dark"] .sidebar {
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 98%, white 2%), color-mix(in oklab, var(--surface-secondary) 98%, var(--surface))) !important;
  box-shadow: 18px 0 42px color-mix(in oklab, black 24%, transparent) !important;
}

.brand {
  padding: 6px 8px 10px !important;
}

.brand-copy h1 {
  font-size: clamp(2.1rem, 3vw, 2.6rem) !important;
  font-weight: 700 !important;
  letter-spacing: -0.05em !important;
}

.brand-copy .small,
.sidebar .lead.small {
  max-width: 18rem !important;
  line-height: 1.35 !important;
}

.nav-link,
.button.secondary,
.theme-toggle,
.table-action {
  min-height: 44px !important;
  border-radius: 18px !important;
  padding: 12px 14px !important;
  font-weight: 650 !important;
}

.nav-link.active {
  box-shadow:
    0 1px 0 color-mix(in oklab, white 24%, transparent) inset,
    0 10px 24px color-mix(in oklab, var(--accent) 10%, transparent) !important;
}

.sidebar-actions {
  gap: 8px !important;
}

.hero,
.panel,
.card,
.users-compose-card,
.table-wrap,
.preview-table,
.empty-state,
.login-card,
.modal-card,
.panel-soft,
.period-block,
#hot-telegram-form,
#finance-form,
.confirm-form {
  border-radius: 30px !important;
}

.hero,
.panel,
.users-compose-card,
.panel-soft,
#hot-telegram-form,
#finance-form,
.confirm-form {
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 99%, white 1%), color-mix(in oklab, var(--surface-secondary) 94%, var(--surface))) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 30%, transparent) inset,
    0 18px 42px color-mix(in oklab, var(--foreground) 8%, transparent) !important;
}

.dark .hero,
.dark .panel,
.dark .users-compose-card,
.dark .panel-soft,
.dark #hot-telegram-form,
.dark #finance-form,
.dark .confirm-form,
[data-theme="dark"] .hero,
[data-theme="dark"] .panel,
[data-theme="dark"] .users-compose-card,
[data-theme="dark"] .panel-soft,
[data-theme="dark"] #hot-telegram-form,
[data-theme="dark"] #finance-form,
[data-theme="dark"] .confirm-form {
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 98%, white 2%), color-mix(in oklab, var(--surface-secondary) 98%, var(--surface))) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 6%, transparent) inset,
    0 18px 44px color-mix(in oklab, black 24%, transparent) !important;
}

.hero {
  padding: 24px !important;
}

.hero h2,
.panel-header h2,
#section-hot > .section-intro h2,
#section-finance > .section-intro h2,
#section-reconciliation > .section-intro h2,
#section-users h2 {
  font-size: clamp(1.95rem, 2.6vw, 2.7rem) !important;
  letter-spacing: -0.045em !important;
}

#section-finance > .section-intro {
  display: none !important;
}

.cards {
  margin: 14px 0 0 !important;
  gap: 14px !important;
}

.card {
  min-height: 152px !important;
  padding: 20px !important;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 98%, white 2%), color-mix(in oklab, var(--surface-secondary) 90%, var(--surface))) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 24%, transparent) inset,
    0 12px 28px color-mix(in oklab, var(--foreground) 6%, transparent) !important;
}

.dark .card,
[data-theme="dark"] .card {
  box-shadow:
    0 1px 0 color-mix(in oklab, white 5%, transparent) inset,
    0 16px 32px color-mix(in oklab, black 22%, transparent) !important;
}

.card .label {
  font-size: 0.92rem !important;
}

.card .value {
  font-size: clamp(2.25rem, 3vw, 3.1rem) !important;
  margin-top: 14px !important;
}

input,
select,
textarea {
  min-height: 54px !important;
  border-radius: 22px !important;
  padding-inline: 18px !important;
  background: color-mix(in oklab, var(--field-background) 96%, var(--surface)) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 28%, transparent) inset,
    0 8px 18px color-mix(in oklab, var(--foreground) 4%, transparent) !important;
}

.dark input,
.dark select,
.dark textarea,
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  box-shadow:
    0 1px 0 color-mix(in oklab, white 5%, transparent) inset,
    0 10px 22px color-mix(in oklab, black 18%, transparent) !important;
}

.button,
button[type="submit"],
a.button:not(.secondary),
.users-submit-button {
  min-height: 54px !important;
  padding-inline: 20px !important;
  border-radius: 999px !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 24%, transparent) inset,
    0 14px 28px color-mix(in oklab, var(--accent) 16%, transparent) !important;
}

.table-wrap,
.preview-table,
.users-table-wrap {
  border-radius: 26px !important;
  padding: 2px !important;
}

table,
.users-data-table {
  border-radius: 24px !important;
  overflow: hidden !important;
}

th {
  padding-top: 16px !important;
  padding-bottom: 16px !important;
}

td {
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

.section-intro {
  margin-bottom: -2px !important;
}

.section-intro .lead,
.panel > .muted,
.users-card-copy {
  max-width: 62rem !important;
  line-height: 1.45 !important;
}

.period-block,
.users-policy-item {
  border-radius: 24px !important;
}

#current-user-card {
  border-radius: 22px !important;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 99%, white 1%), color-mix(in oklab, var(--surface-secondary) 95%, var(--surface))) !important;
}


/* Density polish */
body,
input,
select,
button,
textarea,
.nav-link,
.button,
.button.secondary,
.table-action,
.page-chip,
.period-badge,
.pill,
.summary,
th,
td,
.lead,
.muted,
.small,
.card .label {
  font-family: var(--font-sans) !important;
}

h1,
h2,
h3,
.brand-copy h1,
.hero h2,
.panel-header h2,
.login-card h1,
.login-form-head h2,
.card .value {
  font-family: var(--font-sans) !important;
  letter-spacing: -0.045em !important;
}

.page-shell {
  width: min(1220px, calc(100vw - 24px)) !important;
  padding: 18px 16px 28px !important;
}

.app-layout {
  gap: 18px !important;
}

.sidebar {
  width: 270px !important;
  padding: 14px 12px !important;
  gap: 10px !important;
}

.brand {
  padding: 4px 6px 8px !important;
}

.brand-copy h1 {
  font-size: clamp(1.8rem, 2.4vw, 2.2rem) !important;
}

.sidebar .lead.small {
  font-size: 0.9rem !important;
  line-height: 1.28 !important;
  max-width: 15rem !important;
}

.nav {
  gap: 8px !important;
}

.nav-link,
.button.secondary,
.theme-toggle,
.table-action {
  min-height: 40px !important;
  padding: 10px 12px !important;
  border-radius: 16px !important;
  font-size: 0.95rem !important;
}

.sidebar-actions {
  gap: 6px !important;
}

#current-user-card {
  padding: 8px 10px !important;
}

#current-user-card .pill {
  padding: 6px 10px !important;
  font-size: 0.88rem !important;
}

.content-section,
.stack,
.summary,
.filters,
.inline,
.cards,
.grid,
.users-screen-panel {
  gap: 12px !important;
}

.hero,
.panel,
.card,
.users-compose-card,
.panel-soft,
#hot-telegram-form,
#finance-form,
.confirm-form {
  padding: 18px !important;
  border-radius: 24px !important;
}

.hero {
  gap: 14px !important;
}

.hero h2,
.panel-header h2,
#section-hot > .section-intro h2,
#section-finance h2,
#section-reconciliation > .section-intro h2,
#section-users h2 {
  font-size: clamp(1.55rem, 2vw, 2.1rem) !important;
  line-height: 1.02 !important;
}

.eyebrow,
.sidebar-label,
.field-label,
th {
  font-size: 0.7rem !important;
  letter-spacing: 0.08em !important;
}

.lead,
.panel > .muted,
.section-intro .lead,
.users-card-copy {
  font-size: 0.96rem !important;
  line-height: 1.38 !important;
}

.hero-actions,
.inline,
.filters {
  gap: 10px !important;
}

.button,
button[type="submit"],
a.button:not(.secondary),
.users-submit-button {
  min-height: 48px !important;
  padding-inline: 18px !important;
  font-size: 0.97rem !important;
}

input,
select,
textarea {
  min-height: 48px !important;
  padding-inline: 16px !important;
  border-radius: 18px !important;
  font-size: 0.96rem !important;
}

.period-block,
.users-policy-item {
  padding: 12px 14px !important;
  border-radius: 20px !important;
}

.cards {
  margin: 10px 0 0 !important;
  gap: 12px !important;
}

.card {
  min-height: 126px !important;
  padding: 16px !important;
}

.card .label {
  font-size: 0.84rem !important;
}

.card .value {
  margin-top: 10px !important;
  font-size: clamp(1.9rem, 2.6vw, 2.55rem) !important;
}

.panel-header {
  margin-bottom: 10px !important;
}

.table-wrap,
.preview-table,
.users-table-wrap {
  border-radius: 22px !important;
}

th {
  padding-top: 12px !important;
  padding-bottom: 12px !important;
  font-size: 0.7rem !important;
}

td {
  padding-top: 14px !important;
  padding-bottom: 14px !important;
  font-size: 0.93rem !important;
}

.users-avatar {
  width: 36px !important;
  height: 36px !important;
  border-radius: 12px !important;
}

.users-person-cell,
.users-meta-cell {
  gap: 10px !important;
}

.users-login,
.users-meta-cell span {
  font-size: 0.82rem !important;
}

.login-screen {
  padding: 24px !important;
}

@media (max-width: 1100px) {
  .sidebar {
    width: 100% !important;
    border-radius: 24px !important;
  }

  .page-shell {
    width: min(100%, calc(100vw - 18px)) !important;
  }
}


/* Contrast balance */
.dark,
[data-theme="dark"] {
  --background: oklch(16.2% 0.0086 57.54) !important;
  --surface: oklch(24.5% 0.0145 57.54) !important;
  --surface-secondary: oklch(28.3% 0.0128 57.54) !important;
  --surface-tertiary: oklch(31.5% 0.0128 57.54) !important;
  --default: oklch(30.4% 0.0092 57.54) !important;
  --border: oklch(33.5% 0.0086 57.54) !important;
  --segment: oklch(36.8% 0.0092 57.54) !important;
  --separator: oklch(31.2% 0.0086 57.54) !important;
}

body {
  background: linear-gradient(180deg, color-mix(in oklab, var(--background) 92%, var(--surface-secondary)) 0%, var(--background) 100%) !important;
}

.sidebar {
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 97%, white 3%), color-mix(in oklab, var(--surface-secondary) 98%, var(--surface))) !important;
}

.hero,
.panel,
.users-compose-card,
.panel-soft,
#hot-telegram-form,
#finance-form,
.confirm-form {
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 99%, white 1%), color-mix(in oklab, var(--surface-secondary) 96%, var(--surface))) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 8%, transparent) inset,
    0 18px 40px color-mix(in oklab, black 18%, transparent) !important;
}

.card {
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--surface) 98%, white 2%), color-mix(in oklab, var(--surface-secondary) 93%, var(--surface))) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 8%, transparent) inset,
    0 14px 30px color-mix(in oklab, black 16%, transparent) !important;
}

.table-wrap,
.preview-table,
.users-table-wrap,
.empty-state,
.modal-card,
.login-card {
  background: color-mix(in oklab, var(--surface-secondary) 92%, var(--surface)) !important;
  box-shadow:
    0 1px 0 color-mix(in oklab, white 8%, transparent) inset,
    0 16px 34px color-mix(in oklab, black 16%, transparent) !important;
}

input,
select,
textarea {
  background: color-mix(in oklab, var(--field-background) 84%, var(--surface-tertiary)) !important;
}

.nav-link,
.button.secondary,
.theme-toggle,
.table-action,
.page-chip,
.period-badge,
.pill,
.sidebar-status,
.sidebar-kicker {
  font-weight: 500 !important;
}

.nav-link,
.sidebar .lead.small,
.sidebar .small,
.sidebar .muted,
.sidebar .pill,
.sidebar .summary,
.sidebar-actions .button,
.sidebar-actions .nav-link,
.button,
button,
a.button,
.button.secondary,
.table-action {
  font-weight: 500 !important;
}

.brand-copy h1,
.hero h2,
.panel-header h2,
#section-hot > .section-intro h2,
#section-finance h2,
#section-reconciliation > .section-intro h2,
#section-users h2,
.login-card h1,
.login-form-head h2,
.card .value {
  font-weight: 700 !important;
}


/* Monthly analytics cleanup */
#monthly-table table,
#monthly-table thead,
#monthly-table tbody,
#monthly-table tr,
#monthly-table th,
#monthly-table td {
  border: 0 !important;
  box-shadow: none !important;
}

#monthly-table th,
#monthly-table td {
  border-bottom: 0 !important;
}

#monthly-table tr:hover td {
  background: transparent !important;
}


/* Theme emoji */
.theme-toggle-dot {
  width: 1.2rem !important;
  height: 1.2rem !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0.95rem !important;
  line-height: 1 !important;
  background: transparent !important;
}


/* Empty state cleanup */
.empty-state {
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 8px 4px 4px !important;
}

.table-wrap .empty-state,
.preview-table .empty-state,
#hot-telegram-history .empty-state,
#hot-telegram-base .empty-state,
#hot-telegram-duplicates .empty-state,
#finance-uploads .empty-state,
#finance-matched-payers .empty-state,
#finance-unmatched-payers .empty-state,
#finance-monthly-table .empty-state,
#monthly-table .empty-state,
#compare-results .empty-state,
#other-bot-results .empty-state,
#other-bot-payments-results .empty-state,
#other-bot-payments-monthly .empty-state,
#reconciliation-users .empty-state,
#reconciliation-monthly .empty-state,
#users-table .empty-state,
#logs-table .empty-state {
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

.table-wrap:has(.empty-state),
.preview-table:has(.empty-state) {
  padding-top: 0 !important;
}

.table-wrap:has(.empty-state) table,
.preview-table:has(.empty-state) table {
  display: none !important;
}


/* Empty state spacing pass */
.empty-state {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
  gap: 10px !important;
  min-height: 132px !important;
  max-width: 540px !important;
  margin: 10px 0 4px !important;
  padding: 20px 18px 18px !important;
  border-radius: 22px !important;
  background: color-mix(in oklab, var(--surface-secondary) 88%, var(--surface)) !important;
}

.empty-state strong {
  display: block !important;
  margin: 0 !important;
  line-height: 1.05 !important;
}

.empty-state p,
.empty-state .muted {
  margin: 0 !important;
  line-height: 1.4 !important;
}

#monthly-table .empty-state,
#hot-telegram-history .empty-state,
#hot-telegram-base .empty-state,
#hot-telegram-duplicates .empty-state,
#finance-uploads .empty-state,
#finance-monthly-table .empty-state,
#compare-results .empty-state,
#other-bot-results .empty-state,
#other-bot-payments-results .empty-state,
#other-bot-payments-monthly .empty-state,
#reconciliation-users .empty-state,
#reconciliation-monthly .empty-state,
#users-table .empty-state,
#logs-table .empty-state {
  max-width: min(560px, 100%) !important;
  min-height: 136px !important;
  margin: 12px 0 8px !important;
  padding: 22px 20px 20px !important;
}

#monthly-table,
#hot-telegram-history,
#hot-telegram-base,
#hot-telegram-duplicates,
#finance-uploads,
#finance-monthly-table,
#compare-results,
#other-bot-results,
#other-bot-payments-results,
#other-bot-payments-monthly,
#reconciliation-users,
#reconciliation-monthly,
#users-table,
#logs-table {
  padding-top: 6px !important;
  padding-bottom: 6px !important;
}

#monthly-table:has(.empty-state),
#hot-telegram-history:has(.empty-state),
#hot-telegram-base:has(.empty-state),
#hot-telegram-duplicates:has(.empty-state),
#finance-uploads:has(.empty-state),
#finance-monthly-table:has(.empty-state),
#compare-results:has(.empty-state),
#other-bot-results:has(.empty-state),
#other-bot-payments-results:has(.empty-state),
#other-bot-payments-monthly:has(.empty-state),
#reconciliation-users:has(.empty-state),
#reconciliation-monthly:has(.empty-state),
#users-table:has(.empty-state),
#logs-table:has(.empty-state) {
  border-top: 0 !important;
  background-image: none !important;
}


/* File input cleanup */
input[type="file"] {
  display: block !important;
  width: 100% !important;
  min-height: 58px !important;
  padding: 10px 14px !important;
  border-radius: 22px !important;
  line-height: 1.3 !important;
  overflow: hidden !important;
}

input[type="file"]::-webkit-file-upload-button {
  margin-right: 12px !important;
  padding: 10px 14px !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  background: var(--default) !important;
  color: var(--default-foreground) !important;
  font-family: var(--font-sans) !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
}

input[type="file"]::file-selector-button {
  margin-right: 12px !important;
  padding: 10px 14px !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  background: var(--default) !important;
  color: var(--default-foreground) !important;
  font-family: var(--font-sans) !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
}

#hot-telegram-form input[type="file"],
#finance-form input[type="file"],
#compare-form input[type="file"],
#other-bot-form input[type="file"] {
  white-space: normal !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
}


/* Hot empty cleanup */
.table-wrap:has(.empty-state),
.preview-table:has(.empty-state),
#hot-telegram-history:has(.empty-state),
#hot-telegram-base:has(.empty-state),
#hot-telegram-duplicates:has(.empty-state) {
  overflow: hidden !important;
  padding-bottom: 0 !important;
  min-height: 0 !important;
}

#hot-telegram-referrers:empty {
  display: none !important;
}


/* Hot spacing */
#section-hot .module-band-hero {
  gap: 20px !important;
}

#section-hot #hot-telegram-form {
  margin-top: 8px !important;
}


/* Hot cleanup followup */
#hot-telegram-history,
#hot-telegram-base,
#hot-telegram-duplicates {
  overflow: hidden !important;
  scrollbar-width: none !important;
}

#hot-telegram-history::-webkit-scrollbar,
#hot-telegram-base::-webkit-scrollbar,
#hot-telegram-duplicates::-webkit-scrollbar,
#hot-telegram-history-details::-webkit-scrollbar {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
}

#hot-telegram-history .table-wrap,
#hot-telegram-base .table-wrap,
#hot-telegram-duplicates .table-wrap,
#hot-telegram-history-details .table-wrap {
  overflow: hidden !important;
}

#hot-telegram-history:has(.empty-state),
#hot-telegram-base:has(.empty-state),
#hot-telegram-duplicates:has(.empty-state),
#hot-telegram-history-details:empty {
  min-height: 0 !important;
  padding-bottom: 0 !important;
}

.hot-referrer-toolbar {
  margin-bottom: 10px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.hot-referrer-chip,
.button.secondary.hot-referrer-chip {
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 6px 0 !important;
  border-radius: 0 !important;
}

.hot-referrer-chip.is-selected,
.button.secondary.hot-referrer-chip.is-selected {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--foreground) !important;
}


/* Empty wrappers cleanup */
.table-wrap:empty,
.preview-table:empty,
#hot-telegram-history-details:empty,
#hot-telegram-duplicates:empty,
#finance-upload-details:empty,
#compare-results:empty,
#other-bot-results:empty,
#other-bot-payments-results:empty,
#other-bot-payments-monthly:empty,
#telegram-duplicates-table:empty,
#logs-table:empty,
#users-table:empty {
  display: none !important;
}

.table-wrap:empty + .table-wrap:empty,
.preview-table:empty + .table-wrap:empty,
.table-wrap:empty + .preview-table:empty {
  display: none !important;
}


/* Compare results cleanup */
#compare-results .filters {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 14px !important;
}

#compare-results .empty-state {
  padding: 22px 20px !important;
}


/* Compare results wrapper cleanup */
#compare-results:has(.empty-state) {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

#compare-results:has(.empty-state) .filters {
  margin-bottom: 12px !important;
}


/* Compare results hard cleanup */
#compare-results {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin-top: 0 !important;
}

#compare-results .empty-state {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding-left: 0 !important;
}


/* Additional bases filters wrapper cleanup */
#section-bot #compare-results,
#section-bot .panel-soft > .filters {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#section-bot .panel-soft > .filters {
  padding: 0 !important;
  margin-top: 10px !important;
}


/* Other bots filters wrapper cleanup */
#section-other-bots #other-bot-results,
#section-other-bots .panel-soft > .filters {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

#section-other-bots .panel-soft > .filters {
  padding: 0 !important;
  margin-top: 10px !important;
}

#section-reconciliation > .section-intro {
  display: none !important;
}


/* Pills contrast server polish */
.pill,
.page-chip,
.period-badge,
.sidebar-status {
  color: color-mix(in oklab, var(--foreground) 96%, white 4%) !important;
  background: color-mix(in oklab, var(--surface-secondary) 88%, var(--accent) 12%) !important;
  border: 1px solid color-mix(in oklab, var(--border) 64%, var(--accent) 36%) !important;
}

.pill.success,
#current-user-card .pill.success {
  color: color-mix(in oklab, var(--foreground) 94%, white 6%) !important;
  background: color-mix(in oklab, var(--success) 24%, var(--surface-secondary)) !important;
  border: 1px solid color-mix(in oklab, var(--success) 42%, var(--border)) !important;
}

#current-user-card .pill.success {
  background: color-mix(in oklab, var(--success) 30%, var(--surface-secondary)) !important;
}

#current-user-card .pill:not(.success) {
  color: color-mix(in oklab, var(--foreground) 92%, white 8%) !important;
  background: color-mix(in oklab, var(--surface-secondary) 94%, var(--accent) 6%) !important;
  border: 1px solid color-mix(in oklab, var(--border) 78%, var(--accent) 22%) !important;
}

.pill.danger {
  color: color-mix(in oklab, white 90%, var(--foreground) 10%) !important;
  background: color-mix(in oklab, var(--danger) 20%, var(--surface-secondary)) !important;
  border: 1px solid color-mix(in oklab, var(--danger) 38%, var(--border)) !important;
}


/* Users section spacing only */
.users-table-card {
  margin-top: 14px !important;
}


/* Server typography tighten + hot intro cleanup */
#section-hot > .section-intro {
  display: none !important;
}

.hero h2,
.panel-header h2,
#section-hot > .section-intro h2,
#section-finance h2,
#section-reconciliation > .section-intro h2,
#section-users h2 {
  font-size: clamp(1.42rem, 1.85vw, 1.92rem) !important;
}

.card .value {
  font-size: clamp(1.72rem, 2.2vw, 2.22rem) !important;
}


/* Monthly chart local polish */
#monthly-chart {
  background: linear-gradient(180deg, color-mix(in oklab, var(--surface-secondary) 92%, #f7efe2 8%), color-mix(in oklab, var(--surface) 96%, #fff9f0 4%)) !important;
  border: 1px solid color-mix(in oklab, var(--border) 76%, var(--accent) 24%) !important;
  border-radius: 24px !important;
  padding: 12px !important;
  box-shadow: inset 0 1px 0 color-mix(in oklab, white 10%, transparent), 0 12px 28px color-mix(in oklab, black 10%, transparent) !important;
}

.dark #monthly-chart,
[data-theme="dark"] #monthly-chart {
  background: linear-gradient(180deg, color-mix(in oklab, var(--surface-secondary) 94%, #2f261f 6%), color-mix(in oklab, var(--surface) 96%, #241c16 4%)) !important;
  border: 1px solid color-mix(in oklab, var(--border) 72%, var(--accent) 28%) !important;
  box-shadow: inset 0 1px 0 color-mix(in oklab, white 7%, transparent), 0 14px 30px color-mix(in oklab, black 20%, transparent) !important;
}
