/* ============================================================
   VR3D DESIGN SYSTEM — Tokens + Composants Globaux
   Charger EN PREMIER, avant vr3d-theme.css et tout autre CSS.
   Source de vérité : design-system/MASTER.md v1.0
   ============================================================ */

/* ── Google Fonts ──────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap');

/* ── Design Tokens ─────────────────────────────────────────── */
:root {

  /* 1. Backgrounds */
  --color-bg-base:       #080D1A;
  --color-bg-surface:    #0F1629;
  --color-bg-elevated:   #161E35;
  --color-bg-overlay:    #1D2847;

  /* 2. Glassmorphism */
  --glass-card:           rgba(255, 255, 255, 0.05);
  --glass-elevated:       rgba(255, 255, 255, 0.08);
  --glass-modal:          rgba(8, 13, 26, 0.90);
  --glass-border:         rgba(255, 255, 255, 0.10);
  --glass-border-hover:   rgba(255, 255, 255, 0.20);
  --glass-border-focus:   rgba(59, 130, 246, 0.60);
  --glass-blur-sm:        blur(8px);
  --glass-blur-md:        blur(16px);
  --glass-blur-lg:        blur(24px);

  /* 3. Texte */
  --color-text-primary:   #F1F5F9;
  --color-text-secondary: #94A3B8;
  --color-text-muted:     #64748B;
  --color-text-disabled:  #334155;
  --color-text-inverse:   #0F1629;

  /* 4. Accents */
  --color-accent-primary:         #3B82F6;
  --color-accent-secondary:       #06B6D4;
  --color-accent-primary-hover:   #2563EB;
  --color-accent-secondary-hover: #0891B2;
  --color-accent-glow:            rgba(59, 130, 246, 0.25);

  /* 5. Sémantique */
  --color-success:     #10B981;
  --color-success-bg:  rgba(16, 185, 129, 0.12);
  --color-warning:     #F59E0B;
  --color-warning-bg:  rgba(245, 158, 11,  0.12);
  --color-error:       #EF4444;
  --color-error-bg:    rgba(239, 68,  68,  0.12);
  --color-info:        #3B82F6;
  --color-info-bg:     rgba(59,  130, 246, 0.12);

  /* 6. Typographie */
  --font-heading: 'Space Grotesk', 'Segoe UI', system-ui, sans-serif;
  --font-body:    'DM Sans', 'Segoe UI', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', 'Consolas', monospace;

  /* 7. Échelle typographique */
  --text-h1:   clamp(2rem, 4vw, 2.75rem);
  --text-h2:   clamp(1.5rem, 3vw, 2rem);
  --text-h3:   clamp(1.25rem, 2vw, 1.5rem);
  --text-h4:   1.125rem;
  --text-h5:   1rem;
  --text-xl:   1.25rem;
  --text-base: 1rem;
  --text-sm:   0.875rem;
  --text-xs:   0.75rem;
  --text-mono: 0.8125rem;

  /* 8. Line-height & Letter-spacing */
  --lh-tight:   1.25;
  --lh-snug:    1.375;
  --lh-normal:  1.5;
  --lh-relaxed: 1.625;
  --lh-loose:   1.75;

  --ls-tight:  -0.02em;
  --ls-normal:  0em;
  --ls-wide:    0.04em;
  --ls-wider:   0.08em;

  /* 9. Espacement (base 4px) */
  --space-1:   4px;
  --space-2:   8px;
  --space-3:   12px;
  --space-4:   16px;
  --space-5:   20px;
  --space-6:   24px;
  --space-8:   32px;
  --space-10:  40px;
  --space-12:  48px;
  --space-16:  64px;
  --space-20:  80px;
  --space-24:  96px;

  /* 10. Border Radius */
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   12px;
  --radius-xl:   16px;
  --radius-2xl:  24px;
  --radius-full: 9999px;

  /* 11. Ombres */
  --shadow-sm:  0 1px 3px  rgba(0, 0, 0, 0.40);
  --shadow-md:  0 4px 12px rgba(0, 0, 0, 0.50);
  --shadow-lg:  0 8px 32px rgba(0, 0, 0, 0.60);
  --shadow-xl:  0 16px 48px rgba(0, 0, 0, 0.70);

  --glow-primary:   0 0 20px rgba(59, 130, 246, 0.30);
  --glow-secondary: 0 0 20px rgba(6,  182, 212, 0.25);
  --glow-success:   0 0 16px rgba(16, 185, 129, 0.25);

  --focus-ring: 0 0 0 3px rgba(59, 130, 246, 0.50);

  /* 12. Z-Index */
  --z-base:     0;
  --z-raised:   10;
  --z-dropdown: 20;
  --z-sticky:   30;
  --z-overlay:  40;
  --z-modal:    50;
  --z-toast:    60;
  --z-tooltip:  70;

  /* 13. Animations */
  --duration-instant:  100ms;
  --duration-micro:    150ms;
  --duration-standard: 250ms;
  --duration-emphasis: 350ms;
  --duration-page:     400ms;

  --ease-out:    cubic-bezier(0.0, 0.0, 0.2, 1);
  --ease-in:     cubic-bezier(0.4, 0.0, 1, 1);
  --ease-in-out: cubic-bezier(0.4, 0.0, 0.2, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── Composants Globaux ────────────────────────────────────── */

/* 8.1 Glass Card */
.card {
  background: var(--glass-card);
  backdrop-filter: var(--glass-blur-md);
  -webkit-backdrop-filter: var(--glass-blur-md);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: border-color var(--duration-micro) var(--ease-out),
              box-shadow   var(--duration-micro) var(--ease-out);
}
.card:hover {
  border-color: var(--glass-border-hover);
  box-shadow: var(--shadow-md);
}
.card--elevated {
  background: var(--glass-elevated);
  border-color: rgba(255, 255, 255, 0.15);
}

/* 8.2 Boutons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background     var(--duration-micro) var(--ease-out),
              border-color   var(--duration-micro) var(--ease-out),
              box-shadow     var(--duration-micro) var(--ease-out),
              color          var(--duration-micro) var(--ease-out);
  min-height: 44px;
  min-width: 44px;
  white-space: nowrap;
  text-decoration: none;
  line-height: 1;
}
.btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }

.btn--primary { background: var(--color-accent-primary); color: #fff; }
.btn--primary:hover:not(:disabled) {
  background: var(--color-accent-primary-hover);
  box-shadow: var(--glow-primary);
}
.btn--secondary {
  background: var(--glass-card);
  color: var(--color-text-primary);
  border-color: var(--glass-border);
  backdrop-filter: var(--glass-blur-sm);
}
.btn--secondary:hover:not(:disabled) {
  border-color: var(--glass-border-hover);
  background: var(--glass-elevated);
}
.btn--ghost { background: transparent; color: var(--color-text-secondary); }
.btn--ghost:hover:not(:disabled) {
  color: var(--color-text-primary);
  background: var(--glass-card);
}
.btn--danger {
  background: var(--color-error-bg);
  color: var(--color-error);
  border-color: rgba(239, 68, 68, 0.25);
}
.btn--danger:hover:not(:disabled) { background: var(--color-error); color: #fff; }
.btn:disabled  { opacity: 0.4; cursor: not-allowed; pointer-events: none; }
.btn--loading  { pointer-events: none; opacity: 0.8; }
.btn--sm {
  min-height: 36px;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-xs);
  border-radius: var(--radius-sm);
}

/* 8.3 Inputs & Labels */
.label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}
.input {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  font-family: var(--font-body);
  font-size: var(--text-base);
  min-height: 44px;
  transition: border-color var(--duration-micro) var(--ease-out),
              box-shadow   var(--duration-micro) var(--ease-out);
}
.input::placeholder { color: var(--color-text-muted); }
.input:hover:not(:disabled) { border-color: var(--glass-border-hover); }
.input:focus {
  outline: none;
  border-color: var(--color-accent-primary);
  box-shadow: var(--focus-ring);
}
.input:disabled { opacity: 0.4; cursor: not-allowed; }
.input--error   { border-color: var(--color-error); box-shadow: 0 0 0 3px rgba(239,68,68,0.20); }

/* 8.4 Badges */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 2px var(--space-2);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  border-radius: var(--radius-full);
  white-space: nowrap;
}
.badge--info    { background: var(--color-info-bg);    color: var(--color-accent-primary); }
.badge--success { background: var(--color-success-bg); color: var(--color-success); }
.badge--warning { background: var(--color-warning-bg); color: var(--color-warning); }
.badge--error   { background: var(--color-error-bg);   color: var(--color-error); }
.badge--neutral { background: rgba(255,255,255,0.08);  color: var(--color-text-secondary); }

/* 8.5 Table */
.table-wrapper {
  overflow-x: auto;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
}
.table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.table th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--color-text-muted);
  background: rgba(255,255,255,0.03);
  border-bottom: 1px solid var(--glass-border);
}
.table td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-text-primary);
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.table tr:hover td { background: rgba(255,255,255,0.03); }
.table tr:last-child td { border-bottom: none; }

/* 8.6 Modal */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(8, 13, 26, 0.80);
  backdrop-filter: var(--glass-blur-sm);
  z-index: var(--z-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}
.modal {
  background: var(--color-bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  max-width: 560px; width: 100%;
  padding: var(--space-8);
  z-index: var(--z-modal);
  animation: ds-modal-in var(--duration-emphasis) var(--ease-spring);
}
@keyframes ds-modal-in {
  from { opacity: 0; transform: scale(0.96) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* 8.7 Toast */
.toast-container {
  position: fixed;
  bottom: var(--space-6); right: var(--space-6);
  z-index: var(--z-toast);
  display: flex; flex-direction: column; gap: var(--space-3);
  max-width: 380px;
}
.toast {
  display: flex; align-items: flex-start; gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-bg-overlay);
  border: 1px solid var(--glass-border);
  border-left: 3px solid;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  backdrop-filter: var(--glass-blur-md);
  animation: ds-toast-in var(--duration-standard) var(--ease-out);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
}
.toast--success { border-left-color: var(--color-success); }
.toast--error   { border-left-color: var(--color-error); }
.toast--warning { border-left-color: var(--color-warning); }
.toast--info    { border-left-color: var(--color-accent-primary); }
@keyframes ds-toast-in {
  from { opacity: 0; transform: translateX(24px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* 8.8 Sidebar Navigation */
.sidebar {
  width: 240px; min-width: 240px;
  background: var(--color-bg-surface);
  border-right: 1px solid var(--glass-border);
  display: flex; flex-direction: column;
  height: 100vh;
  position: sticky; top: 0;
  overflow-y: auto;
  z-index: var(--z-sticky);
  padding: var(--space-4) 0;
}
.nav-item {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm); font-weight: 500;
  color: var(--color-text-secondary);
  border-radius: var(--radius-md);
  margin: 0 var(--space-2);
  cursor: pointer;
  transition: color       var(--duration-micro) var(--ease-out),
              background  var(--duration-micro) var(--ease-out);
  text-decoration: none;
  min-height: 44px;
}
.nav-item:hover { color: var(--color-text-primary); background: var(--glass-card); }
.nav-item.active {
  color: var(--color-accent-primary);
  background: var(--color-info-bg);
  font-weight: 600;
}
.nav-item:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.nav-section-label {
  font-size: var(--text-xs); font-weight: 600;
  letter-spacing: var(--ls-wider); text-transform: uppercase;
  color: var(--color-text-disabled);
  padding: var(--space-3) var(--space-6) var(--space-2);
  margin-top: var(--space-4);
}

/* 8.9 Skip Link */
.skip-link {
  position: absolute;
  top: -100%; left: var(--space-4);
  z-index: calc(var(--z-tooltip) + 10);
  padding: var(--space-2) var(--space-4);
  background: var(--color-accent-primary);
  color: #ffffff;
  border-radius: var(--radius-md);
  font-weight: 600; text-decoration: none;
  transition: top var(--duration-micro) var(--ease-out);
}
.skip-link:focus { top: var(--space-4); }

/* ── Utilitaires ───────────────────────────────────────────── */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* ── Scrollbar ─────────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-full);
}
::-webkit-scrollbar-thumb:hover { background: rgba(255, 255, 255, 0.20); }

/* 8.10 Select & contrôles natifs ──────────────────────────── */
.select,
select.input,
select.form-select,
select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  padding-right: var(--space-10);
  background-color: rgba(255, 255, 255, 0.04);
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-4) center;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  font-family: var(--font-body);
  font-size: var(--text-base);
  min-height: 44px;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
  transition: border-color var(--duration-micro) var(--ease-out),
              box-shadow   var(--duration-micro) var(--ease-out);
}
select:hover:not(:disabled) { border-color: var(--glass-border-hover); }
select:focus {
  outline: none;
  border-color: var(--color-accent-primary);
  box-shadow: var(--focus-ring);
}
select:disabled { opacity: 0.4; cursor: not-allowed; }

/* Options de la liste déroulante — override du thème natif */
select option {
  background-color: var(--color-bg-elevated) !important;
  color: var(--color-text-primary) !important;
  padding: var(--space-2) var(--space-3);
}
select option:checked,
select option:hover {
  background-color: var(--color-accent-primary) !important;
  color: #ffffff !important;
}
select option:disabled {
  color: var(--color-text-disabled) !important;
}

/* Date/time pickers natifs */
input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="month"],
input[type="week"] {
  color-scheme: dark;
}

/* Autocomplete Chromium — fond jaune par défaut */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--color-text-primary);
  -webkit-box-shadow: 0 0 0 1000px var(--color-bg-elevated) inset;
  transition: background-color 5000s ease-in-out 0s;
}

/* ── prefers-reduced-motion ────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ============================================================
   Bootstrap 5 Overrides — alignement avec le design system
   ============================================================ */

/* Table Bootstrap → dark */
.table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--color-text-primary);
  --bs-table-border-color: var(--glass-border);
  --bs-table-striped-bg: rgba(255, 255, 255, 0.03);
  --bs-table-hover-bg: rgba(255, 255, 255, 0.05);
  --bs-table-hover-color: var(--color-text-primary);
  color: var(--color-text-primary);
}
.table thead {
  background: var(--color-bg-elevated);
  color: var(--color-text-secondary);
}
.table thead th {
  background: var(--color-bg-elevated) !important;
  color: var(--color-text-secondary) !important;
  border-bottom: 1px solid var(--glass-border) !important;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  padding: var(--space-3) var(--space-4);
}
.table td {
  background: transparent !important;
  color: var(--color-text-primary) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04) !important;
  padding: var(--space-3) var(--space-4);
}
.table-hover tbody tr:hover td {
  background: rgba(255, 255, 255, 0.03) !important;
  color: var(--color-text-primary) !important;
}

/* Bootstrap form-select → alignement design system */
.form-select {
  background-color: rgba(255, 255, 255, 0.04) !important;
  color: var(--color-text-primary) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius-md) !important;
}
.form-select:focus {
  border-color: var(--color-accent-primary) !important;
  box-shadow: var(--focus-ring) !important;
}
.form-select option {
  background-color: var(--color-bg-elevated) !important;
  color: var(--color-text-primary) !important;
}

/* Bootstrap card → glassmorphism */
.card {
  background-color: var(--glass-card);
  border-color: var(--glass-border);
  color: var(--color-text-primary);
}

/* Bootstrap list-group */
.list-group-item {
  background-color: var(--glass-card) !important;
  color: var(--color-text-primary) !important;
  border-color: var(--glass-border) !important;
}
.list-group-item:hover {
  background-color: var(--glass-elevated) !important;
}
.list-group-item.active {
  background-color: var(--color-info-bg) !important;
  color: var(--color-accent-primary) !important;
  border-color: var(--color-accent-primary) !important;
}
