/* Global theme tokens and typography baseline */
:root {
  --btn-font: "Inter", sans-serif;
  --font-sans:
    "Inter",
    system-ui,
    -apple-system,
    "Segoe UI",
    Roboto,
    "Helvetica Neue",
    Arial,
    sans-serif;

  --font-size-body: 15px;
  --font-size-small: 14px;
  --font-size-table: 14px;
  --line-height-body: 1.5;

  --mint-soft: #e8f4f0;
  --blue-mist: #eaf0fb;
  --lavender-soft: #f3eef9;
  --cream-warm: #fdf6ec;

  --app-bg: #f6f8fc;
  --app-bg-elevated:
    radial-gradient(
      1200px 520px at 0% 0%,
      rgba(243, 238, 249, 0.62),
      transparent 56%
    ),
    radial-gradient(
      900px 420px at 100% 0%,
      rgba(232, 244, 240, 0.56),
      transparent 54%
    ),
    linear-gradient(180deg, #fdfdfd 0%, #f6f8fc 54%, #eef3fb 100%);

  --surface-1: rgba(255, 255, 255, 0.94);
  --surface-2: rgba(250, 251, 255, 0.92);
  --surface-3: #eef3fb;
  --surface-glass: rgba(255, 255, 255, 0.78);

  --text-1: #172033;
  --text-2: #5e6b82;
  --text-3: #7b879b;
  --text-inverse: #f8fbff;

  --border-1: rgba(23, 32, 51, 0.12);
  --border-2: rgba(23, 32, 51, 0.08);
  --border-strong: rgba(79, 111, 216, 0.24);

  --shadow-1: 0 12px 30px rgba(19, 33, 68, 0.08);
  --shadow-2: 0 20px 46px rgba(19, 33, 68, 0.12);
  --shadow-3: 0 28px 70px rgba(19, 33, 68, 0.16);

  --primary-500: #4f6fd8;
  --primary-600: #3f5fc7;
  --primary-700: #334fb0;
  --primary-soft: #eaf0fb;
  --primary-soft-2: #dbe6ff;

  --state-positive-bg: #dff3e4;
  --state-positive-text: #215b43;
  --state-positive-border: rgba(33, 91, 67, 0.16);

  --state-negative-bg: #f8d7da;
  --state-negative-text: #8a1f2d;
  --state-negative-border: rgba(138, 31, 45, 0.16);

  --state-pending-bg: #fff3cd;
  --state-pending-text: #7a5a00;
  --state-pending-border: rgba(122, 90, 0, 0.16);

  --focus-ring: rgba(79, 111, 216, 0.24);

  --btn-radius: 14px;

  --btn-save: linear-gradient(135deg, #6A8DFF, #5B6FE8);
  --btn-new: linear-gradient(135deg, #A78BFA, #7C5CDB);
  --btn-search: linear-gradient(135deg, #5DD6A8, #2EBD8A);
  --btn-update: linear-gradient(135deg, #ffe3b8, #ffcfa0);
  --btn-export: linear-gradient(135deg, #60C8F5, #2FA8E8);
  --btn-import: linear-gradient(135deg, #F9A8D4, #E879A8);
  --btn-cancel: linear-gradient(135deg, #FFB8B8, #FFA0A0);
  --btn-warn: linear-gradient(135deg, #FFDDB8, #FFB86C);
  --btn-delete: linear-gradient(135deg, #ffc7cf, #ffb2bd);
  --btn-nav: linear-gradient(135deg, #EEE6FF, #D9D2F8);

  --btn-font-size-sm: 13px;
  --btn-font-size-md: 14px;
  --btn-font-size-lg: 15px;
  --btn-font-weight: 800;
  --btn-line-height: 1;
  --btn-letter-spacing: 0.01em;

  --btn-height-sm: 36px;
  --btn-height-md: 42px;
  --btn-height-lg: 48px;
  --btn-icon-button-sm: 32px;
  --btn-icon-button-md: 40px;

  --btn-padding-x-sm: 12px;
  --btn-padding-x-md: 16px;
  --btn-padding-x-lg: 18px;
  --btn-gap-sm: 6px;
  --btn-gap-md: 8px;

  --btn-radius-sm: 12px;
  --btn-radius-md: var(--btn-radius);
  --btn-radius-lg: 16px;
  --btn-radius-pill: 999px;

  --btn-icon-size-sm: 14px;
  --btn-icon-size-md: 16px;
  --btn-icon-size-lg: 18px;

  --btn-shadow-soft: 0 8px 18px rgba(19, 33, 68, 0.08);
  --btn-shadow-md: 0 12px 24px rgba(19, 33, 68, 0.12);
  --btn-shadow-md-hover: 0 16px 28px rgba(19, 33, 68, 0.16);
  --btn-shadow-primary: 0 12px 24px rgba(79, 111, 216, 0.22);
  --btn-shadow-primary-hover: 0 16px 30px rgba(79, 111, 216, 0.26);
  --btn-shadow-success: 0 12px 24px rgba(45, 106, 79, 0.2);
  --btn-shadow-success-hover: 0 16px 30px rgba(45, 106, 79, 0.24);
  --btn-shadow-danger: 0 12px 24px rgba(196, 59, 82, 0.18);
  --btn-shadow-danger-hover: 0 16px 30px rgba(196, 59, 82, 0.22);

  --btn-primary-bg: var(--btn-save);
  --btn-primary-border: rgba(91, 111, 232, 0.26);
  --btn-primary-text: #fff;

  --btn-success-bg: var(--btn-search);
  --btn-success-border: rgba(46, 189, 138, 0.24);
  --btn-success-text: #fff;

  --btn-danger-bg: var(--btn-delete);
  --btn-danger-border: rgba(214, 109, 126, 0.24);
  --btn-danger-text: #8a3347;

  --btn-warning-bg: var(--btn-warn);
  --btn-warning-border: rgba(255, 184, 108, 0.28);
  --btn-warning-text: #7a4a12;

  --btn-neutral-bg: var(--btn-nav);
  --btn-neutral-border: rgba(124, 92, 219, 0.18);
  --btn-neutral-text: #5a4fb1;

  --btn-ghost-bg: rgba(244, 240, 255, 0.86);
  --btn-ghost-border: rgba(124, 92, 219, 0.14);
  --btn-ghost-text: #6558bf;

  --btn-soft-primary-bg: rgba(255, 204, 106, 0.24);
  --btn-soft-primary-border: rgba(245, 166, 35, 0.24);
  --btn-soft-primary-text: #8b5b00;

  --btn-soft-danger-bg: rgba(255, 107, 107, 0.14);
  --btn-soft-danger-border: rgba(229, 83, 83, 0.2);
  --btn-soft-danger-text: #b43636;

  --btn-disabled-opacity: 0.58;
  --btn-transition:
    transform 0.14s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease,
    opacity 0.18s ease;

  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 24px;

  --dashboard-vh: 100dvh;
  --dashboard-shell-gap: clamp(18px, 1.8vw, 24px);
  --dashboard-shell-padding-x: clamp(14px, 2vw, 28px);
  --dashboard-shell-padding-y: 24px;
  --dashboard-shell-padding-bottom: max(32px, var(--decor-bottom-h, 32px));
  --dashboard-content-max: clamp(1100px, 92vw, 1440px);
  --dashboard-content-wide-max: clamp(1200px, 95vw, 1560px);
  --dashboard-content-compact-max: clamp(980px, 88vw, 1280px);
  --dashboard-content-max-active: var(--dashboard-content-max);
  --dashboard-main-max-height: calc(var(--dashboard-vh) - 180px);
  --dashboard-panel-max-height: calc(var(--dashboard-vh) - 240px);

  --container: var(--dashboard-content-max);
  --container-wide: var(--dashboard-content-wide-max);
  --decor-bottom-h: 240px;

  --sidebar-width: clamp(264px, 18vw, 300px);
  --sidebar-collapsed-width: 92px;
  --sidebar-mobile-width: min(88vw, 320px);
  --sidebar-shell-offset: 16px;

  --modal-size-sm: 560px;
  --modal-size-md: 860px;
  --modal-size-lg: 1100px;
  --modal-padding-x: 26px;
  --modal-padding-y: 22px;
  --modal-close-size: 46px;

  --sidebar-bg-1: #142238;
  --sidebar-bg-2: #0f1828;
  --sidebar-border: rgba(191, 204, 226, 0.12);
  --sidebar-surface: rgba(255, 255, 255, 0.06);
  --sidebar-hover: rgba(255, 255, 255, 0.1);
  --sidebar-text: #d9e3f5;
  --sidebar-muted: #98a8c6;
  --sidebar-shadow: 0 18px 48px rgba(10, 18, 35, 0.28);
}

html {
  font-family: var(--font-sans);
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-sans);
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
  color: var(--text-1);
  background: var(--app-bg);
  text-rendering: optimizeLegibility;
  font-synthesis-weight: none;
}

button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
}

input,
select,
textarea {
  accent-color: var(--primary-500);
}

::placeholder {
  color: var(--text-3);
  opacity: 1;
}

:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
}

.tabular-nums,
.badge,
.pill,
input[type="number"],
.currency,
.amount,
.saldo,
.metric-value,
.kpi-value {
  font-variant-numeric: tabular-nums;
  font-feature-settings:
    "tnum" 1,
    "lnum" 1;
}

.state-positive,
.is-positive {
  background: var(--state-positive-bg);
  color: var(--state-positive-text);
  border-color: var(--state-positive-border);
}

.state-negative,
.is-negative {
  background: var(--state-negative-bg);
  color: var(--state-negative-text);
  border-color: var(--state-negative-border);
}

.state-pending,
.is-pending {
  background: var(--state-pending-bg);
  color: var(--state-pending-text);
  border-color: var(--state-pending-border);
}

table.dataTable thead th,
table.dataTable tbody td,
table.display thead th,
table.display tbody td {
  font-size: var(--font-size-table);
}

.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate .paginate_button {
  font-size: var(--font-size-table);
}
