/* ═══════════════════════════════════════════════════════════════════
   Biences Compliance — Design System v2
   Direction : "Compliance Sérieuse" (inspiration Stripe / Airtable)
   Dark warm + orange Biences, densité pro, hiérarchie claire
   ═══════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────
   1. DESIGN TOKENS
   ───────────────────────────────────────────────────────────────── */

:root {
  /* ── Quasar overrides ─────────────────────────────────────────── */
  --q-primary: #E87722;

  /* ── Brand / Accent ───────────────────────────────────────────── */
  --b-orange:        #E87722;
  --b-orange-hover:  #F08B3F;
  --b-orange-dark:   #C85A0A;
  --b-orange-dim:    rgba(232, 119, 34, 0.10);
  --b-orange-ghost:  rgba(232, 119, 34, 0.06);

  /* ── Surfaces (warm charcoal with serious density) ────────────── */
  --b-bg:            #0E0C0A;   /* page background */
  --b-surface-1:     #16130F;   /* cards, drawer, header */
  --b-surface-2:     #1D1915;   /* inputs, elevated */
  --b-surface-3:     #262019;   /* hover, selected */
  --b-surface-4:     #2F2822;   /* dialog, top elevation */

  /* ── Borders (better contrast, visible) ───────────────────────── */
  --b-border:        #352D25;
  --b-border-strong: #4A4137;
  --b-border-focus:  var(--b-orange);

  /* ── Text (WCAG AA compliant) ─────────────────────────────────── */
  --b-text:          #F0EBE3;   /* primary */
  --b-text-strong:   #FFFBF5;   /* headings */
  --b-text-muted:    #BFB4A3;   /* secondary labels */
  --b-text-subtle:   #8B8170;   /* meta, hints */
  --b-text-disabled: #5A5247;

  /* ── Semantic colors (recalibrated for dark bg) ───────────────── */
  --b-success:       #4ADE80;
  --b-success-bg:    rgba(74, 222, 128, 0.12);
  --b-success-border:rgba(74, 222, 128, 0.35);

  --b-warning:       #FBBF24;
  --b-warning-bg:    rgba(251, 191, 36, 0.12);
  --b-warning-border:rgba(251, 191, 36, 0.35);

  --b-error:         #F87171;
  --b-error-bg:      rgba(248, 113, 113, 0.12);
  --b-error-border:  rgba(248, 113, 113, 0.35);

  --b-info:          #60A5FA;
  --b-info-bg:       rgba(96, 165, 250, 0.12);
  --b-info-border:   rgba(96, 165, 250, 0.35);

  --b-neutral:       var(--b-text-muted);
  --b-neutral-bg:    rgba(191, 180, 163, 0.08);
  --b-neutral-border:var(--b-border);

  /* ── Legacy aliases (do not remove, used in Python code) ──────── */
  --b-white:         var(--b-surface-1);
  --b-beige:         var(--b-surface-2);
  --b-beige-dark:    var(--b-surface-3);
  --b-brown:         var(--b-text);
  --b-brown-light:   var(--b-text-strong);
  --b-taupe:         var(--b-text-muted);
  --b-border-hover:  var(--b-border-strong);
  --b-green:         var(--b-success);
  --b-red:           var(--b-error);
  --b-amber:         var(--b-warning);
  --b-blue:          var(--b-info);
  --b-orange-light:  var(--b-orange-hover);

  /* ── Shadows (subtle, serious) ────────────────────────────────── */
  --b-shadow-xs:     0 1px 2px rgba(0, 0, 0, 0.25);
  --b-shadow-sm:     0 2px 6px rgba(0, 0, 0, 0.30);
  --b-shadow:        0 4px 12px rgba(0, 0, 0, 0.35);
  --b-shadow-md:     0 6px 20px rgba(0, 0, 0, 0.40);
  --b-shadow-lg:     0 12px 36px rgba(0, 0, 0, 0.45);
  --b-shadow-orange: 0 2px 8px rgba(232, 119, 34, 0.25);
  --b-ring-focus:    0 0 0 3px rgba(232, 119, 34, 0.18);
  --b-ring-error:    0 0 0 3px rgba(248, 113, 113, 0.18);

  /* ── Radius (moins "pill", plus pro) ──────────────────────────── */
  --b-radius-xs:     4px;
  --b-radius-sm:     6px;
  --b-radius:        8px;
  --b-radius-lg:     12px;
  --b-radius-pill:   999px;

  /* ── Spacing scale (4px base) ─────────────────────────────────── */
  --sp-0:  0;
  --sp-1:  4px;
  --sp-2:  8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  20px;
  --sp-6:  24px;
  --sp-8:  32px;
  --sp-10: 40px;
  --sp-12: 48px;

  /* ── Typography scale ─────────────────────────────────────────── */
  --fs-xs:   0.75rem;   /* 12px */
  --fs-sm:   0.8125rem; /* 13px */
  --fs-base: 0.875rem;  /* 14px — body */
  --fs-md:   1rem;      /* 16px */
  --fs-lg:   1.125rem;  /* 18px */
  --fs-xl:   1.375rem;  /* 22px — h2 */
  --fs-2xl:  1.75rem;   /* 28px — h1 */

  --fw-regular:  400;
  --fw-medium:   500;
  --fw-semibold: 600;
  --fw-bold:     700;

  /* ── Transitions ──────────────────────────────────────────────── */
  --b-transition:      all 0.15s ease;
  --b-transition-slow: all 0.25s ease;
}

/* ─────────────────────────────────────────────────────────────────
   2. BASE & RESET
   ───────────────────────────────────────────────────────────────── */

html {
  font-size: 16px !important;
}

body,
.q-page,
.nicegui-content,
.q-page-container {
  background-color: var(--b-bg) !important;
  color: var(--b-text) !important;
  font-family: 'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, system-ui, sans-serif !important;
  font-size: var(--fs-base);
  line-height: 1.5;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.q-dark,
.body--dark {
  color: var(--b-text) !important;
  background: var(--b-bg) !important;
}

.body--dark .q-page-container,
.body--dark .q-page,
.body--dark .nicegui-content {
  background: var(--b-bg) !important;
}

::selection {
  background: var(--b-orange);
  color: #fff;
}

/* Scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--b-bg); }
::-webkit-scrollbar-thumb { background: var(--b-border-strong); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--b-text-subtle); }

/* ─────────────────────────────────────────────────────────────────
   3. TYPOGRAPHY — ÉCHELLE CLAIRE
   ───────────────────────────────────────────────────────────────── */

h1, .h1 {
  font-family: 'Lato', sans-serif;
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  line-height: 1.2;
  color: var(--b-text-strong);
  letter-spacing: -0.01em;
  margin: 0 0 var(--sp-2);
}

h2, .h2 {
  font-family: 'Lato', sans-serif;
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  line-height: 1.3;
  color: var(--b-text-strong);
  letter-spacing: -0.005em;
  margin: 0 0 var(--sp-2);
}

h3, .h3 {
  font-family: 'Lato', sans-serif;
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  line-height: 1.4;
  color: var(--b-text-strong);
  margin: 0 0 var(--sp-2);
}

h4, .h4 {
  font-family: 'Lato', sans-serif;
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  line-height: 1.4;
  color: var(--b-text-strong);
  margin: 0 0 var(--sp-1);
}

h5, .h5 {
  font-family: 'Lato', sans-serif;
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  line-height: 1.4;
  color: var(--b-text-strong);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0 0 var(--sp-1);
}

.section-label {
  font-family: 'Lato', sans-serif;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--b-text-muted);
  margin: 0 0 var(--sp-2);
}

.text-xs    { font-size: var(--fs-xs) !important; }
.text-sm    { font-size: var(--fs-sm) !important; }
.text-base  { font-size: var(--fs-base) !important; }
.text-md    { font-size: var(--fs-md) !important; }
.text-lg    { font-size: var(--fs-lg) !important; line-height: 1.4; }
.text-xl    { font-size: var(--fs-xl) !important; line-height: 1.3; }
.text-2xl   { font-size: var(--fs-2xl) !important; line-height: 1.2; letter-spacing: -0.01em; }

.text-muted   { color: var(--b-text-muted) !important; }
.text-subtle  { color: var(--b-text-subtle) !important; }
.text-strong  { color: var(--b-text-strong) !important; }
.text-success { color: var(--b-success) !important; }
.text-warning { color: var(--b-warning) !important; }
.text-error   { color: var(--b-error) !important; }
.text-info    { color: var(--b-info) !important; }
.text-accent  { color: var(--b-orange) !important; }

/* Legacy — utilisé dans le code */
.biences-title {
  font-family: 'Lato', sans-serif;
  font-weight: var(--fw-bold);
  font-size: var(--fs-2xl);
  line-height: 1.2;
  color: var(--b-text-strong);
  letter-spacing: -0.01em;
  margin: 0 0 var(--sp-1);
}

.biences-subtitle {
  font-size: var(--fs-sm);
  color: var(--b-text-muted);
  font-weight: var(--fw-regular);
  letter-spacing: 0;
  line-height: 1.5;
}

/* ─────────────────────────────────────────────────────────────────
   4. HEADER
   ───────────────────────────────────────────────────────────────── */

.q-header {
  background: var(--b-surface-1) !important;
  border-bottom: 1px solid var(--b-border) !important;
  box-shadow: none !important;
  color: var(--b-text) !important;
  min-height: 56px !important;
}

/* ─────────────────────────────────────────────────────────────────
   5. DRAWER / SIDEBAR
   ───────────────────────────────────────────────────────────────── */

.q-drawer {
  background: var(--b-surface-1) !important;
  border-right: 1px solid var(--b-border) !important;
  color: var(--b-text) !important;
}

.q-drawer--dark {
  background: var(--b-surface-1) !important;
}

.nav-section-title {
  font-family: 'Lato', sans-serif;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--b-text-subtle);
  padding: var(--sp-5) var(--sp-4) var(--sp-2);
}

.nav-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-4);
  margin: 1px var(--sp-2);
  border-radius: var(--b-radius);
  color: var(--b-text-muted);
  text-decoration: none;
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  transition: var(--b-transition);
  position: relative;
}

.nav-item:hover {
  color: var(--b-text-strong);
  background: var(--b-surface-3);
}

.nav-item.active {
  color: var(--b-orange);
  background: var(--b-orange-dim);
  font-weight: var(--fw-semibold);
}

.nav-item.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 25%;
  height: 50%;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: var(--b-orange);
}

/* ─────────────────────────────────────────────────────────────────
   6. CARDS
   ───────────────────────────────────────────────────────────────── */

.q-card {
  background: var(--b-surface-1) !important;
  border: 1px solid var(--b-border) !important;
  border-radius: var(--b-radius) !important;
  box-shadow: var(--b-shadow-xs) !important;
  transition: var(--b-transition);
  color: var(--b-text) !important;
}

.q-card:hover {
  border-color: var(--b-border-strong) !important;
}

.q-card--dark {
  background: var(--b-surface-1) !important;
  color: var(--b-text) !important;
}

/* Stat cards — more subtle, professional */
.stat-card {
  background: var(--b-surface-1) !important;
  border: 1px solid var(--b-border) !important;
  border-radius: var(--b-radius) !important;
  padding: var(--sp-5) !important;
  position: relative;
  overflow: hidden;
  transition: var(--b-transition);
  min-width: 180px;
}

.stat-card:hover {
  border-color: var(--b-orange) !important;
  box-shadow: var(--b-shadow-sm) !important;
}

.stat-card .stat-icon {
  position: absolute;
  right: -8px;
  bottom: -12px;
  font-size: 5rem !important;
  opacity: 0.05;
  color: var(--b-orange);
}

.stat-card .stat-value {
  font-family: 'Lato', sans-serif;
  font-weight: var(--fw-bold);
  font-size: 2rem;
  color: var(--b-text-strong);
  line-height: 1;
  margin-top: var(--sp-2);
  letter-spacing: -0.02em;
}

.stat-card .stat-label {
  font-size: var(--fs-xs);
  color: var(--b-text-muted);
  margin-top: var(--sp-1);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* Alert section — left accent border */
.alert-section {
  border-left: 3px solid var(--b-orange) !important;
  padding: var(--sp-4) !important;
}

.alert-section.alert-warning { border-left-color: var(--b-warning) !important; }
.alert-section.alert-danger  { border-left-color: var(--b-error) !important; }
.alert-section.alert-info    { border-left-color: var(--b-info) !important; }
.alert-section.alert-success { border-left-color: var(--b-success) !important; }

.alert-section .text-sm.font-bold {
  font-size: var(--fs-md) !important;
  font-weight: var(--fw-bold) !important;
}

/* ─────────────────────────────────────────────────────────────────
   7. TABLES (Airtable / Stripe style)
   ───────────────────────────────────────────────────────────────── */

.q-table {
  background: transparent !important;
}

.q-table__card {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  color: var(--b-text) !important;
}

.q-table thead tr {
  background: var(--b-surface-2) !important;
}

.q-table thead th {
  color: var(--b-text-muted) !important;
  font-weight: var(--fw-semibold) !important;
  font-size: var(--fs-xs) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  border-bottom: 1px solid var(--b-border) !important;
  padding: var(--sp-3) var(--sp-4) !important;
  white-space: nowrap;
}

/* Sortable columns */
.q-table thead th.sortable {
  cursor: pointer;
  transition: var(--b-transition);
  user-select: none;
}

.q-table thead th.sortable:hover {
  color: var(--b-text-strong) !important;
  background: var(--b-surface-3) !important;
}

.q-table thead th.sorted {
  color: var(--b-orange) !important;
}

.q-table thead th .q-table__sort-icon {
  color: var(--b-orange) !important;
  opacity: 0 !important;
  transition: opacity 0.15s ease;
}

.q-table thead th.sorted .q-table__sort-icon,
.q-table thead th.sortable:hover .q-table__sort-icon {
  opacity: 1 !important;
}

/* Rows */
.q-table tbody tr {
  transition: background 0.12s ease;
  border-bottom: 1px solid var(--b-border) !important;
  cursor: pointer;
}

.q-table tbody tr:nth-child(even) {
  background: rgba(29, 25, 21, 0.5);
}

.q-table tbody tr:hover {
  background: var(--b-surface-3) !important;
}

.q-table tbody tr.selected,
.q-table tbody tr.q-tr--selected {
  background: var(--b-orange-dim) !important;
  box-shadow: inset 3px 0 0 0 var(--b-orange);
}

.q-table tbody td {
  color: var(--b-text) !important;
  font-size: var(--fs-base) !important;
  padding: var(--sp-3) var(--sp-4) !important;
  border: none !important;
  vertical-align: middle;
}

.q-table--bordered {
  border: none !important;
}

.q-table--dense .q-td {
  padding: var(--sp-2) var(--sp-3) !important;
  font-size: var(--fs-sm) !important;
}

.q-table--dense thead th {
  padding: var(--sp-2) var(--sp-3) !important;
}

.q-table__bottom {
  color: var(--b-text-muted) !important;
  font-size: var(--fs-xs) !important;
  padding: var(--sp-3) var(--sp-4) !important;
  border-top: 1px solid var(--b-border);
  background: var(--b-surface-2);
}

/* Table wrapper container */
.table-wrapper {
  background: var(--b-surface-1);
  border: 1px solid var(--b-border);
  border-radius: var(--b-radius);
  padding: 0;
  overflow-x: auto;
  overflow-y: visible;
}

.table-wrapper .q-table__card {
  border: none !important;
  border-radius: 0 !important;
}

/* ─────────────────────────────────────────────────────────────────
   8. BUTTONS — Primary / Secondary / Danger / Ghost
   ───────────────────────────────────────────────────────────────── */

.q-btn {
  border-radius: var(--b-radius) !important;
  font-family: 'Lato', sans-serif !important;
  font-weight: var(--fw-semibold) !important;
  font-size: var(--fs-sm) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  transition: var(--b-transition);
  padding: var(--sp-2) var(--sp-4) !important;
  min-height: 36px !important;
}

/* Primary (default) — orange */
.q-btn--standard.bg-primary,
.q-btn[class*="bg-primary"] {
  background: var(--b-orange) !important;
  color: #fff !important;
  box-shadow: var(--b-shadow-orange) !important;
  border: 1px solid var(--b-orange) !important;
}

.q-btn--standard.bg-primary:hover,
.q-btn[class*="bg-primary"]:hover {
  background: var(--b-orange-hover) !important;
  border-color: var(--b-orange-hover) !important;
  box-shadow: 0 4px 12px rgba(232, 119, 34, 0.35) !important;
}

.q-btn--standard.bg-primary:active,
.q-btn[class*="bg-primary"]:active {
  background: var(--b-orange-dark) !important;
}

/* Secondary / Outline */
.q-btn--outline {
  background: transparent !important;
  border: 1px solid var(--b-border-strong) !important;
  color: var(--b-text) !important;
  box-shadow: none !important;
}

.q-btn--outline:hover {
  border-color: var(--b-orange) !important;
  color: var(--b-orange) !important;
  background: var(--b-orange-ghost) !important;
}

/* Ghost / Flat */
.q-btn--flat {
  color: var(--b-text-muted) !important;
  background: transparent !important;
  box-shadow: none !important;
}

.q-btn--flat:hover {
  color: var(--b-orange) !important;
  background: var(--b-orange-ghost) !important;
}

/* Danger */
.q-btn.bg-red,
.q-btn[class*="bg-red"],
.q-btn.btn-danger {
  background: var(--b-error) !important;
  color: #fff !important;
  border: 1px solid var(--b-error) !important;
  box-shadow: 0 2px 6px rgba(248, 113, 113, 0.20) !important;
}

.q-btn.bg-red:hover,
.q-btn[class*="bg-red"]:hover,
.q-btn.btn-danger:hover {
  background: #EF4444 !important;
  border-color: #EF4444 !important;
  box-shadow: 0 4px 10px rgba(248, 113, 113, 0.30) !important;
}

/* Dense */
.q-btn--dense {
  font-size: var(--fs-xs) !important;
  padding: var(--sp-1) var(--sp-3) !important;
  min-height: 28px !important;
}

/* Round / Icon buttons */
.q-btn--round {
  border-radius: 50% !important;
  padding: 0 !important;
}

.q-btn--fab {
  border-radius: 50% !important;
}

/* Disabled state */
.q-btn--disable,
.q-btn:disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
}

/* ─────────────────────────────────────────────────────────────────
   9. INPUTS & SELECTS — avec états
   ───────────────────────────────────────────────────────────────── */

.q-field__control {
  border-radius: var(--b-radius-sm) !important;
  min-height: 40px !important;
}

.q-field--outlined .q-field__control:before {
  border: 1px solid var(--b-border-strong) !important;
  border-radius: var(--b-radius-sm) !important;
  transition: var(--b-transition);
}

.q-field--outlined .q-field__control:hover:before {
  border-color: var(--b-text-muted) !important;
}

.q-field--outlined.q-field--focused .q-field__control:after {
  border: 2px solid var(--b-orange) !important;
  border-radius: var(--b-radius-sm) !important;
}

.q-field--outlined.q-field--focused .q-field__control {
  box-shadow: var(--b-ring-focus);
}

.q-field--dark .q-field__control,
.q-field__control {
  color: var(--b-text) !important;
  background: var(--b-surface-2) !important;
}

.q-field__label {
  color: var(--b-text-muted) !important;
  font-family: 'Lato', sans-serif !important;
  font-size: var(--fs-sm) !important;
  font-weight: var(--fw-medium) !important;
}

.q-field--focused .q-field__label {
  color: var(--b-orange) !important;
}

.q-field__native,
.q-field__input {
  color: var(--b-text) !important;
  font-family: 'Lato', sans-serif !important;
  font-size: var(--fs-base) !important;
}

.q-field__native::placeholder,
.q-field__input::placeholder {
  color: var(--b-text-subtle) !important;
  opacity: 1;
}

/* Error state */
.q-field--error .q-field__control:before,
.q-field--error .q-field__control:after {
  border-color: var(--b-error) !important;
}

.q-field--error .q-field__label {
  color: var(--b-error) !important;
}

.q-field--error.q-field--focused .q-field__control {
  box-shadow: var(--b-ring-error);
}

.q-field__messages,
.q-field__bottom {
  color: var(--b-text-subtle) !important;
  font-size: var(--fs-xs) !important;
}

.q-field--error .q-field__messages {
  color: var(--b-error) !important;
}

/* Disabled */
.q-field--disabled .q-field__control {
  background: var(--b-surface-1) !important;
  opacity: 0.6;
}

.q-field--disabled .q-field__native,
.q-field--disabled .q-field__input {
  color: var(--b-text-disabled) !important;
}

/* Dense */
.q-field--dense .q-field__control {
  min-height: 36px !important;
}

.q-field--dense .q-field__label {
  font-size: var(--fs-sm) !important;
}

/* ─────────────────────────────────────────────────────────────────
   10. BADGES — Palette sémantique unifiée
   ───────────────────────────────────────────────────────────────── */

.q-badge {
  border-radius: var(--b-radius-sm) !important;
  font-family: 'Lato', sans-serif !important;
  font-weight: var(--fw-semibold) !important;
  font-size: var(--fs-xs) !important;
  padding: 3px 10px !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.4;
  border: 1px solid transparent;
}

/* Quasar color overrides → mapped to our semantic palette */
.q-badge.bg-green,
.q-badge.bg-positive {
  background: var(--b-success-bg) !important;
  color: var(--b-success) !important;
  border-color: var(--b-success-border) !important;
}

.q-badge.bg-red,
.q-badge.bg-negative {
  background: var(--b-error-bg) !important;
  color: var(--b-error) !important;
  border-color: var(--b-error-border) !important;
}

.q-badge.bg-orange,
.q-badge.bg-amber,
.q-badge.bg-warning {
  background: var(--b-warning-bg) !important;
  color: var(--b-warning) !important;
  border-color: var(--b-warning-border) !important;
}

.q-badge.bg-blue,
.q-badge.bg-info {
  background: var(--b-info-bg) !important;
  color: var(--b-info) !important;
  border-color: var(--b-info-border) !important;
}

.q-badge.bg-grey,
.q-badge.bg-grey-5,
.q-badge.bg-grey-6,
.q-badge.bg-grey-7,
.q-badge.bg-neutral {
  background: var(--b-neutral-bg) !important;
  color: var(--b-neutral) !important;
  border-color: var(--b-neutral-border) !important;
}

/* Semantic badge classes (utilitaires) */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 3px 10px;
  border-radius: var(--b-radius-sm);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: 1px solid;
  line-height: 1.4;
}

.badge--success { background: var(--b-success-bg); color: var(--b-success); border-color: var(--b-success-border); }
.badge--warning { background: var(--b-warning-bg); color: var(--b-warning); border-color: var(--b-warning-border); }
.badge--error   { background: var(--b-error-bg);   color: var(--b-error);   border-color: var(--b-error-border); }
.badge--info    { background: var(--b-info-bg);    color: var(--b-info);    border-color: var(--b-info-border); }
.badge--neutral { background: var(--b-neutral-bg); color: var(--b-neutral); border-color: var(--b-neutral-border); }
.badge--accent  { background: var(--b-orange-dim); color: var(--b-orange);  border-color: var(--b-orange); }

/* ─────────────────────────────────────────────────────────────────
   11. DIALOGS
   ───────────────────────────────────────────────────────────────── */

.q-dialog__backdrop {
  background: rgba(0, 0, 0, 0.65) !important;
  backdrop-filter: blur(4px);
}

.q-dialog .q-card {
  background: var(--b-surface-4) !important;
  border: 1px solid var(--b-border-strong) !important;
  border-radius: var(--b-radius-lg) !important;
  box-shadow: var(--b-shadow-lg) !important;
  color: var(--b-text) !important;
  min-width: 420px;
}

/* ─────────────────────────────────────────────────────────────────
   12. TABS
   ───────────────────────────────────────────────────────────────── */

.q-tabs {
  border-bottom: 1px solid var(--b-border);
}

.q-tab {
  color: var(--b-text-muted) !important;
  font-family: 'Lato', sans-serif !important;
  font-weight: var(--fw-medium) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-size: var(--fs-base) !important;
  transition: var(--b-transition);
  padding: var(--sp-3) var(--sp-4) !important;
}

.q-tab--active {
  color: var(--b-orange) !important;
  font-weight: var(--fw-semibold) !important;
}

.q-tab__indicator {
  background: var(--b-orange) !important;
  height: 2px !important;
}

.q-tab:hover:not(.q-tab--active) {
  color: var(--b-text-strong) !important;
}

.q-tab-panel {
  padding: var(--sp-5) 0 !important;
  color: var(--b-text) !important;
}

/* ─────────────────────────────────────────────────────────────────
   13. PROGRESS BARS
   ───────────────────────────────────────────────────────────────── */

.q-linear-progress {
  border-radius: var(--b-radius-pill) !important;
  overflow: hidden;
  height: 6px !important;
}

.q-linear-progress__track {
  background: var(--b-surface-3) !important;
  opacity: 1 !important;
}

/* ─────────────────────────────────────────────────────────────────
   14. SEPARATORS
   ───────────────────────────────────────────────────────────────── */

.q-separator,
.q-separator--dark {
  background: var(--b-border) !important;
}

/* ─────────────────────────────────────────────────────────────────
   15. TOGGLES / SWITCHES
   ───────────────────────────────────────────────────────────────── */

.q-toggle__inner--truthy .q-toggle__track {
  background: var(--b-orange) !important;
  opacity: 0.4;
}

.q-toggle__inner--truthy .q-toggle__thumb {
  background: var(--b-orange) !important;
}

.q-toggle__label {
  color: var(--b-text) !important;
  font-size: var(--fs-base) !important;
}

/* ─────────────────────────────────────────────────────────────────
   16. STEPPERS
   ───────────────────────────────────────────────────────────────── */

.q-stepper,
.q-stepper--dark {
  background: transparent !important;
  box-shadow: none !important;
  color: var(--b-text) !important;
}

.q-stepper__tab--active .q-stepper__dot {
  background: var(--b-orange) !important;
}

.q-stepper__tab--done .q-stepper__dot {
  background: var(--b-success) !important;
}

.q-stepper__title {
  color: var(--b-text-strong) !important;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-base) !important;
}

.q-stepper__caption {
  color: var(--b-text-muted) !important;
  font-size: var(--fs-xs) !important;
}

.q-stepper__step-content {
  color: var(--b-text) !important;
}

/* ─────────────────────────────────────────────────────────────────
   17. NOTIFICATIONS / TOASTS
   ───────────────────────────────────────────────────────────────── */

.q-notification {
  border-radius: var(--b-radius) !important;
  font-family: 'Lato', sans-serif !important;
  font-size: var(--fs-base) !important;
  box-shadow: var(--b-shadow-md) !important;
  border: 1px solid var(--b-border-strong);
}

.q-notification--positive {
  background: var(--b-success) !important;
}

.q-notification--negative {
  background: var(--b-error) !important;
}

.q-notification--warning {
  background: var(--b-warning) !important;
  color: #000 !important;
}

.q-notification--info {
  background: var(--b-info) !important;
}

/* ─────────────────────────────────────────────────────────────────
   18. EMPTY STATES
   ───────────────────────────────────────────────────────────────── */

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-12) var(--sp-6);
  color: var(--b-text-muted);
  text-align: center;
  gap: var(--sp-3);
  background: var(--b-surface-1);
  border: 1px dashed var(--b-border-strong);
  border-radius: var(--b-radius-lg);
}

.empty-state .q-icon {
  font-size: 3.5rem !important;
  opacity: 0.4;
  color: var(--b-text-muted) !important;
}

.empty-state .empty-state-title {
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--b-text-strong);
  margin: 0;
}

.empty-state p,
.empty-state .empty-state-desc {
  font-size: var(--fs-sm);
  color: var(--b-text-muted);
  margin: 0;
  max-width: 360px;
  line-height: 1.5;
}

.empty-state .empty-state-cta {
  margin-top: var(--sp-3);
}

/* ─────────────────────────────────────────────────────────────────
   19. BRAND ELEMENTS
   ───────────────────────────────────────────────────────────────── */

.brand-logo {
  font-family: 'Lato', sans-serif;
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  letter-spacing: 0.18em;
  color: var(--b-orange);
  text-transform: uppercase;
}

.brand-separator {
  width: 1px;
  height: 22px;
  background: var(--b-border-strong);
  margin: 0 var(--sp-3);
}

.brand-subtitle {
  font-size: var(--fs-xs);
  color: var(--b-text-muted);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Language toggle */
.lang-btn {
  font-size: var(--fs-xs) !important;
  font-weight: var(--fw-bold) !important;
  letter-spacing: 0.06em !important;
  min-width: 36px !important;
  padding: 3px 10px !important;
  border-radius: var(--b-radius-sm) !important;
}

.lang-btn.active {
  background: var(--b-orange) !important;
  color: #fff !important;
  box-shadow: var(--b-shadow-orange) !important;
}

.lang-btn:not(.active) {
  background: var(--b-surface-2) !important;
  color: var(--b-text) !important;
  border: 1px solid var(--b-border) !important;
}

.lang-btn:not(.active):hover {
  color: var(--b-orange) !important;
  border-color: var(--b-orange) !important;
}

/* ─────────────────────────────────────────────────────────────────
   20. IMPORT CARDS (left accent)
   ───────────────────────────────────────────────────────────────── */

.import-card-pending  { border-left: 3px solid var(--b-warning) !important; }
.import-card-assigned { border-left: 3px solid var(--b-success) !important; }
.import-card-rejected { border-left: 3px solid var(--b-text-muted) !important; }
.import-card-error    { border-left: 3px solid var(--b-error) !important; }

/* ─────────────────────────────────────────────────────────────────
   21. MENUS / DROPDOWNS
   ───────────────────────────────────────────────────────────────── */

.q-menu {
  background: var(--b-surface-4) !important;
  border: 1px solid var(--b-border-strong) !important;
  border-radius: var(--b-radius) !important;
  box-shadow: var(--b-shadow-md) !important;
}

.q-item {
  color: var(--b-text) !important;
  transition: var(--b-transition);
  font-size: var(--fs-base) !important;
  padding: var(--sp-2) var(--sp-4) !important;
  min-height: 36px !important;
}

.q-item:hover,
.q-item--active {
  background: var(--b-surface-3) !important;
}

.q-item--active {
  color: var(--b-orange) !important;
  font-weight: var(--fw-semibold);
}

/* ─────────────────────────────────────────────────────────────────
   22. UPLOAD
   ───────────────────────────────────────────────────────────────── */

.q-uploader {
  background: var(--b-surface-1) !important;
  border: 2px dashed var(--b-border-strong) !important;
  border-radius: var(--b-radius) !important;
  color: var(--b-text) !important;
}

.q-uploader:hover {
  border-color: var(--b-orange) !important;
  background: var(--b-orange-ghost) !important;
}

.q-uploader__header {
  background: var(--b-surface-2) !important;
  color: var(--b-text) !important;
}

/* ─────────────────────────────────────────────────────────────────
   23. CHECKBOX / RADIO
   ───────────────────────────────────────────────────────────────── */

.q-checkbox__inner--truthy .q-checkbox__bg,
.q-radio__inner--truthy .q-radio__bg {
  background: var(--b-orange) !important;
  border-color: var(--b-orange) !important;
}

.q-checkbox__label,
.q-radio__label {
  color: var(--b-text) !important;
  font-size: var(--fs-base) !important;
}

.q-table .q-checkbox__inner--truthy .q-checkbox__bg {
  background: var(--b-orange) !important;
  border-color: var(--b-orange) !important;
}

/* ─────────────────────────────────────────────────────────────────
   24. EXPANSION ITEMS
   ───────────────────────────────────────────────────────────────── */

.q-expansion-item {
  color: var(--b-text) !important;
}

.q-expansion-item__content {
  background: var(--b-surface-2) !important;
}

/* ─────────────────────────────────────────────────────────────────
   25. CHIPS
   ───────────────────────────────────────────────────────────────── */

.q-chip {
  background: var(--b-surface-2) !important;
  color: var(--b-text) !important;
  border-radius: var(--b-radius-pill) !important;
  font-size: var(--fs-xs) !important;
  font-weight: var(--fw-medium) !important;
}

/* Market Readiness country chips */
.mr-country-chip {
  cursor: pointer;
  transition: var(--b-transition);
  border: 1px solid var(--b-border) !important;
  background: var(--b-surface-2) !important;
  color: var(--b-text) !important;
  min-width: 42px !important;
  font-weight: var(--fw-bold) !important;
  font-size: var(--fs-xs) !important;
  letter-spacing: 0.06em !important;
  border-radius: var(--b-radius-sm) !important;
  padding: 4px 12px !important;
}

.mr-country-chip.active {
  background: var(--b-orange) !important;
  color: #fff !important;
  border-color: var(--b-orange) !important;
  box-shadow: var(--b-shadow-orange) !important;
}

.mr-country-chip:not(.active):hover {
  border-color: var(--b-orange) !important;
  color: var(--b-orange) !important;
}

/* ─────────────────────────────────────────────────────────────────
   26. TOOLTIP — pour pédagogie
   ───────────────────────────────────────────────────────────────── */

.q-tooltip {
  background: var(--b-surface-4) !important;
  color: var(--b-text) !important;
  border: 1px solid var(--b-border-strong) !important;
  border-radius: var(--b-radius-sm) !important;
  font-family: 'Lato', sans-serif !important;
  font-size: var(--fs-xs) !important;
  padding: var(--sp-2) var(--sp-3) !important;
  box-shadow: var(--b-shadow-md) !important;
  max-width: 320px;
  line-height: 1.5;
}

/* Info icon button (pédagogie) */
.info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: transparent;
  color: var(--b-text-subtle);
  cursor: help;
  margin-left: 4px;
  transition: var(--b-transition);
  font-size: 12px !important;
}

.info-icon:hover {
  color: var(--b-orange);
  background: var(--b-orange-ghost);
}

/* ─────────────────────────────────────────────────────────────────
   27. PAGINATION
   ───────────────────────────────────────────────────────────────── */

.q-table__bottom .q-btn {
  color: var(--b-text-muted) !important;
}

.q-table__bottom .q-btn--standard {
  background: var(--b-surface-2) !important;
}

/* ─────────────────────────────────────────────────────────────────
   28. TEXT COLOR OVERRIDES (legacy)
   ───────────────────────────────────────────────────────────────── */

.text-white {
  color: var(--b-text) !important;
}

.text-grey,
.text-grey-7,
.text-grey-6,
.text-grey-5 {
  color: var(--b-text-muted) !important;
}

.q-drawer .text-white,
.q-header .text-white {
  color: var(--b-text) !important;
}

.q-icon {
  color: var(--b-text-muted);
}

.q-scrollarea__content {
  color: var(--b-text) !important;
}

/* ─────────────────────────────────────────────────────────────────
   29. SPACING UTILITIES
   ───────────────────────────────────────────────────────────────── */

.gap-1 { gap: var(--sp-1) !important; }
.gap-2 { gap: var(--sp-2) !important; }
.gap-3 { gap: var(--sp-3) !important; }
.gap-4 { gap: var(--sp-4) !important; }
.gap-5 { gap: var(--sp-5) !important; }
.gap-6 { gap: var(--sp-6) !important; }

/* ─────────────────────────────────────────────────────────────────
   30. ANIMATIONS (subtle, not distracting)
   ───────────────────────────────────────────────────────────────── */

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}

.q-card {
  animation: fadeUp 0.2s ease both;
}

.q-card:nth-child(2) { animation-delay: 0.02s; }
.q-card:nth-child(3) { animation-delay: 0.04s; }
.q-card:nth-child(4) { animation-delay: 0.06s; }
.q-card:nth-child(5) { animation-delay: 0.08s; }

/* Skeleton loader */
.skeleton {
  background: linear-gradient(
    90deg,
    var(--b-surface-2) 0%,
    var(--b-surface-3) 50%,
    var(--b-surface-2) 100%
  );
  background-size: 800px 100%;
  animation: shimmer 1.5s infinite linear;
  border-radius: var(--b-radius-sm);
}

.skeleton-text {
  height: 14px;
  width: 100%;
  margin-bottom: var(--sp-2);
}

.skeleton-text.short { width: 60%; }
.skeleton-text.medium { width: 80%; }

/* ─────────────────────────────────────────────────────────────────
   31. STATUS PILL — compact status indicator
   ───────────────────────────────────────────────────────────────── */

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 8px;
  border-radius: var(--b-radius-pill);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  line-height: 1.4;
  white-space: nowrap;
}

.status-pill::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}

.status-pill--success { background: var(--b-success-bg); color: var(--b-success); }
.status-pill--warning { background: var(--b-warning-bg); color: var(--b-warning); }
.status-pill--error   { background: var(--b-error-bg);   color: var(--b-error); }
.status-pill--info    { background: var(--b-info-bg);    color: var(--b-info); }
.status-pill--neutral { background: var(--b-neutral-bg); color: var(--b-neutral); }

/* ─────────────────────────────────────────────────────────────────
   32. KPI CARD (dashboard variant)
   ───────────────────────────────────────────────────────────────── */

.kpi-card {
  background: var(--b-surface-1);
  border: 1px solid var(--b-border);
  border-radius: var(--b-radius);
  padding: var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  transition: var(--b-transition);
}

.kpi-card:hover {
  border-color: var(--b-border-strong);
  transform: translateY(-1px);
  box-shadow: var(--b-shadow-sm);
}

.kpi-card__label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--b-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.kpi-card__value {
  font-size: 2rem;
  font-weight: var(--fw-bold);
  color: var(--b-text-strong);
  line-height: 1;
  letter-spacing: -0.02em;
}

.kpi-card__trend {
  font-size: var(--fs-xs);
  color: var(--b-text-subtle);
}

.kpi-card__trend--up    { color: var(--b-success); }
.kpi-card__trend--down  { color: var(--b-error); }

/* ─────────────────────────────────────────────────────────────────
   33. DATA GRID (denser alternative to q-table)
   ───────────────────────────────────────────────────────────────── */

.data-grid {
  background: var(--b-surface-1);
  border: 1px solid var(--b-border);
  border-radius: var(--b-radius);
  overflow: hidden;
}

.data-grid-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--b-border);
  background: var(--b-surface-2);
}

.data-grid-title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--b-text-strong);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* ─────────────────────────────────────────────────────────────────
   34. BREADCRUMBS
   ───────────────────────────────────────────────────────────────── */

.breadcrumbs {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-sm);
  color: var(--b-text-muted);
  margin-bottom: var(--sp-4);
}

.breadcrumbs a {
  color: var(--b-text-muted);
  text-decoration: none;
  transition: var(--b-transition);
}

.breadcrumbs a:hover {
  color: var(--b-orange);
}

.breadcrumbs__sep {
  color: var(--b-text-subtle);
  font-size: var(--fs-xs);
}

.breadcrumbs__current {
  color: var(--b-text-strong);
  font-weight: var(--fw-semibold);
}
