/* ============================================
   Dofus Ocre Tracker - Theme Bootstrap Custom
   ============================================ */

/* ============================================
   Google Fonts Import
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;500;600;700;800&display=swap');

:root {
  /* Couleurs principales - Palette sombre */
  --ocre-deep-navy: #0a0e1a;
  --ocre-navy: #121829;
  --ocre-navy-light: #1a2235;
  --ocre-navy-lighter: #232d42;

  /* Accent violet */
  --ocre-violet: #7c3aed;
  --ocre-violet-light: #a78bfa;
  --ocre-violet-dark: #5b21b6;
  --ocre-violet-glow: rgba(124, 58, 237, 0.4);

  /* Accent or/ocre */
  --ocre-gold: #f59e0b;
  --ocre-gold-light: #fbbf24;
  --ocre-gold-dark: #d97706;

  /* Couleurs sémantiques - Status */
  --ocre-success: #10b981;
  --ocre-success-light: #34d399;
  --ocre-success-dark: #059669;
  --ocre-danger: #ef4444;
  --ocre-danger-light: #f87171;
  --ocre-danger-ultralight: #9e5a5a;
  --ocre-danger-dark: #dc2626;
  --ocre-info: #0891b2;
  --ocre-info-light: #22d3ee;
  --ocre-cyan: #17a2b8;
  --ocre-cyan-light: #5bc0de;

  /* Gris neutres */
  --ocre-gray: #6b7280;
  --ocre-gray-light: #adb5bd;
  --ocre-gray-dark: #4b5563;
  --ocre-gray-darker: #475569;

  /* Texte */
  --ocre-text-primary: #e2e8f0;
  --ocre-text-secondary: #b2becf;
  --ocre-text-muted: #64748b;

  /* Bordures */
  --ocre-border: rgba(148, 163, 184, 0.1);
  --ocre-border-light: rgba(148, 163, 184, 0.2);
  --ocre-border-dark: #2d3748;

  /* Gradients */
  --ocre-gradient-gold: linear-gradient(135deg, var(--ocre-gold) 0%, var(--ocre-gold-dark) 100%);
  --ocre-gradient-violet: linear-gradient(135deg, var(--ocre-violet) 0%, var(--ocre-violet-dark) 100%);
  --ocre-gradient-success: linear-gradient(135deg, var(--ocre-success) 0%, var(--ocre-success-dark) 100%);
  --ocre-gradient-danger: linear-gradient(135deg, var(--ocre-danger) 0%, var(--ocre-danger-dark) 100%);
  --ocre-gradient-gray: linear-gradient(135deg, var(--ocre-gray) 0%, var(--ocre-gray-dark) 100%);

  /* Box shadows */
  --ocre-shadow-violet: 0 4px 14px rgba(124, 58, 237, 0.3);
  --ocre-shadow-violet-lg: 0 6px 20px rgba(124, 58, 237, 0.4);
  --ocre-shadow-gold: 0 4px 14px rgba(245, 158, 11, 0.3);
  --ocre-shadow-gold-lg: 0 6px 20px rgba(245, 158, 11, 0.4);
  --ocre-shadow-dark: 0 4px 12px rgba(0, 0, 0, 0.3);
  --ocre-shadow-dark-lg: 0 10px 40px rgba(0, 0, 0, 0.4);
  --ocre-shadow-glow: 0 0 20px var(--ocre-violet-glow);

  /* Overlays */
  --ocre-overlay-dark-10: rgba(0, 0, 0, 0.1);
  --ocre-overlay-dark-20: rgba(0, 0, 0, 0.2);
  --ocre-overlay-dark-30: rgba(0, 0, 0, 0.3);
  --ocre-overlay-dark-50: rgba(0, 0, 0, 0.5);
  --ocre-overlay-dark-70: rgba(0, 0, 0, 0.7);
  --ocre-overlay-dark-85: rgba(0, 0, 0, 0.85);
  --ocre-overlay-light-05: rgba(255, 255, 255, 0.05);
  --ocre-overlay-light-10: rgba(255, 255, 255, 0.1);
  --ocre-overlay-light-15: rgba(255, 255, 255, 0.15);
  --ocre-overlay-light-20: rgba(255, 255, 255, 0.2);
  --ocre-overlay-light-30: rgba(255, 255, 255, 0.3);
  --ocre-overlay-violet-08: rgba(124, 58, 237, 0.08);
  --ocre-overlay-violet-15: rgba(124, 58, 237, 0.15);
  --ocre-overlay-violet-25: rgba(124, 58, 237, 0.25);
  --ocre-overlay-success-15: rgba(0, 200, 83, 0.15);
  --ocre-overlay-success-20: rgba(0, 200, 83, 0.2);
  --ocre-overlay-success-25: rgba(0, 200, 83, 0.25);
  --ocre-overlay-success-40: rgba(0, 200, 83, 0.4);
  --ocre-overlay-danger-10: rgba(220, 53, 69, 0.1);
  --ocre-overlay-danger-15: rgba(220, 53, 69, 0.15);
  --ocre-overlay-danger-20: rgba(220, 53, 69, 0.2);
  --ocre-overlay-danger-25: rgba(220, 53, 69, 0.25);
  --ocre-overlay-danger-40: rgba(220, 53, 69, 0.4);
  --ocre-overlay-danger-50: rgba(220, 53, 69, 0.5);
  --ocre-overlay-gold-30: rgba(245, 158, 11, 0.3);
  --ocre-overlay-gold-50: rgba(245, 158, 11, 0.5);

  /* Transitions */
  --ocre-transition-fast: 0.15s ease;
  --ocre-transition-normal: 0.3s ease;
  --ocre-transition-slow: 0.6s ease;

  /* Typography scale */
  --ocre-fs-xxs: 0.65rem;
  --ocre-fs-xs: 0.7rem;
  --ocre-fs-sm: 0.75rem;
  --ocre-fs-base: 0.85rem;
  --ocre-fs-md: 0.875rem;
  --ocre-fs-lg: 0.9rem;
  --ocre-fs-xl: 0.95rem;
  --ocre-fw-normal: 400;
  --ocre-fw-medium: 500;
  --ocre-fw-semibold: 600;
  --ocre-fw-bold: 700;
  --ocre-fw-extrabold: 800;

  /* Bootstrap overrides */
  --bs-primary: #7c3aed;
  --bs-primary-rgb: 124, 58, 237;

  --bs-secondary: #f59e0b;
  --bs-secondary-rgb: 245, 158, 11;

  --bs-success: #10b981;
  --bs-success-rgb: 16, 185, 129;

  --bs-warning: #f59e0b;
  --bs-warning-rgb: 245, 158, 11;

  --bs-danger: #ef4444;
  --bs-danger-rgb: 239, 68, 68;

  --bs-info: #3b82f6;
  --bs-info-rgb: 59, 130, 246;

  --bs-dark: #0a0e1a;
  --bs-dark-rgb: 10, 14, 26;

  /* Fond et texte */
  --bs-body-bg: #0a0e1a;
  --bs-body-color: #e2e8f0;

  /* Surfaces (cards, modales, etc.) */
  --bs-tertiary-bg: #1a2235;
  --bs-secondary-bg: #121829;

  /* Liens */
  --bs-link-color: #a78bfa;
  --bs-link-hover-color: #fbbf24;

  /* Bordures */
  --bs-border-color: rgba(148, 163, 184, 0.15);

  /* Typographie */
  --bs-body-font-family: 'Nunito', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --bs-body-font-size: 1rem;
  --bs-body-line-height: 1.6;

  /* Bordures arrondies */
  --bs-border-radius: 0.5rem;
  --bs-border-radius-lg: 0.75rem;
  --bs-border-radius-sm: 0.375rem;
  --bs-border-radius-xl: 1rem;
}

/* ============================================
   Alpine.js utilities
   ============================================ */
[x-cloak] {
  display: none !important;
}

/* ============================================
   Base Styles
   ============================================ */
body {
  font-family: var(--bs-body-font-family);
  background: linear-gradient(180deg, var(--ocre-deep-navy) 0%, var(--ocre-navy) 100%);
  background-attachment: fixed;
  color: var(--bs-body-color);
  min-height: 100vh;
}

/* Background pattern subtil */
body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: 
    radial-gradient(ellipse at 20% 20%, rgba(124, 58, 237, 0.08) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(245, 158, 11, 0.05) 0%, transparent 50%);
  pointer-events: none;
  z-index: -1;
}

/* ============================================
   Typography
   ============================================ */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: 'Nunito', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  font-weight: 700;
  color: var(--ocre-text-primary);
}

.display-1, .display-2, .display-3, .display-4, .display-5, .display-6 {
  font-family: 'Nunito', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  font-weight: 800;
}

/* ============================================
   Surcharges des composants Bootstrap
   ============================================ */

/* Boutons primaires (violet) - Use for main actions */
.btn-primary {
  --bs-btn-bg: var(--ocre-violet-dark);
  --bs-btn-border-color: var(--ocre-violet);
  --bs-btn-color: #fff;
  --bs-btn-hover-bg: var(--ocre-violet);
  --bs-btn-hover-border-color: var(--ocre-violet-dark);
  --bs-btn-active-bg: var(--ocre-violet);
  --bs-btn-active-border-color: var(--ocre-violet-dark);
  box-shadow: var(--ocre-shadow-violet);
}

.btn-primary:hover {
  box-shadow: var(--ocre-shadow-violet-lg);
}

/* Boutons secondaires (gold) - Use for secondary/alternative actions */
.btn-secondary {
  --bs-btn-bg: var(--ocre-gold);
  --bs-btn-border-color: var(--ocre-gold);
  --bs-btn-color: var(--ocre-deep-navy);
  --bs-btn-hover-bg: var(--ocre-gold-dark);
  --bs-btn-hover-border-color: var(--ocre-gold-dark);
  --bs-btn-hover-color: var(--ocre-deep-navy);
  box-shadow: var(--ocre-shadow-gold);
}

.btn-secondary:hover {
  box-shadow: var(--ocre-shadow-gold-lg);
}

/* Boutons outline violet - Use for navigation/back buttons */
.btn-outline-primary {
  --bs-btn-color: var(--ocre-violet-light);
  --bs-btn-border-color: var(--ocre-violet);
  --bs-btn-hover-bg: var(--ocre-violet);
  --bs-btn-hover-border-color: var(--ocre-violet);
  --bs-btn-hover-color: #fff;
}

/* Boutons outline gold - Use for less emphasis actions */
.btn-outline-secondary {
  --bs-btn-color: var(--ocre-gold);
  --bs-btn-border-color: var(--ocre-gold);
  --bs-btn-hover-bg: var(--ocre-gold);
  --bs-btn-hover-border-color: var(--ocre-gold);
  --bs-btn-hover-color: var(--ocre-deep-navy);
}

.btn-outline-light {
  --bs-btn-color: var(--ocre-text-secondary);
  --bs-btn-border-color: var(--ocre-border-light);
  --bs-btn-hover-bg: var(--ocre-navy-light);
  --bs-btn-hover-color: var(--ocre-gold-light);
}

/* Tous les boutons */
.btn {
  font-weight: 600;
  border-radius: var(--bs-border-radius);
  padding: 0.625rem 1.25rem;
}

.btn-lg {
  padding: 0.875rem 2rem;
  font-size: 1.1rem;
}

/* Boutons disabled */
.btn:disabled,
.btn.disabled {
  background-color: var(--ocre-navy-lighter);
  border-color: var(--ocre-border-light);
  color: var(--ocre-text-muted);
  box-shadow: none;
  opacity: 0.7;
}

/* Bouton sombre avec état actif - Use for toggles and filters */
.btn-ocre {
  background: var(--ocre-navy-light);
  border: 1px solid var(--ocre-border-light);
  color: var(--ocre-text-secondary);
  transition: all var(--ocre-transition-fast);
}
.btn-ocre:hover {
  background: var(--ocre-navy-lighter);
  border-color: var(--ocre-border-light);
  color: var(--ocre-text-primary);
}
.btn-ocre.active {
  background: var(--ocre-navy-lighter);
  border-color: var(--ocre-violet);
  color: var(--ocre-violet-light);
}

/* Cards */
.card {
  --bs-card-bg: var(--ocre-navy-light);
  --bs-card-border-color: var(--ocre-border);
  --bs-card-cap-bg: var(--ocre-navy);
  border-radius: var(--bs-border-radius-lg);
  overflow: hidden;
}

.card-header {
  border-bottom-color: var(--ocre-border);
}

.card-footer {
  border-top-color: var(--ocre-border);
  background-color: var(--ocre-navy);
}

/* Navbar */
.navbar {
  --bs-navbar-color: var(--ocre-text-secondary);
  --bs-navbar-hover-color: white;
  --bs-navbar-active-color: var(--ocre-violet-light);
  --bs-navbar-brand-color: var(--ocre-violet-light);
  --bs-navbar-brand-hover-color: #fff;
  background: var(--ocre-deep-navy) !important;
  border-bottom: 1px solid var(--ocre-border);
}

.navbar-dark .navbar-brand,
.navbar .navbar-brand {
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 700;
  font-size: 1.5rem;
  color: #fff !important;
}

.navbar-dark .navbar-brand:hover,
.navbar .navbar-brand:hover,
.nav-link:hover {
  color: var(--ocre-navy-light) !important;
}

/* Espacement entre les éléments de navigation */
.navbar-nav .nav-item {
  margin: 0 0.25rem;
  border-radius: 0.2rem;
}

.navbar-nav .nav-item:hover {
  background-color: var(--ocre-violet-dark) !important;
  transition: background-color var(--ocre-transition-normal);
}

.navbar-dark .nav-link,
.navbar .nav-link {
  color: var(--ocre-text-primary) !important;
  font-weight: 500;
  padding: 0.5rem 1rem !important;
  border-radius: var(--bs-border-radius);
}

/* Dropdown menus */
.dropdown-menu {
  --bs-dropdown-border-color: var(--ocre-border);
  --bs-dropdown-link-hover-bg: var(--ocre-violet-dark);
  --bs-dropdown-link-active-bg: var(--ocre-violet-dark);
  --bs-dropdown-divider-bg: var(--ocre-overlay-light-20);
  box-shadow: var(--ocre-shadow-dark-lg);
}

.dropdown-item.active {
  background-color: var(--ocre-violet);
}

.nav-item.dropdown .btn {
  color: var(--ocre-text-primary);
}

/* Forms */
.form-control,
.form-select {
  background-color: var(--ocre-navy);
  border-color: var(--ocre-border-light);
  color: var(--ocre-text-primary);
  border-radius: var(--bs-border-radius);
}

.form-control:focus,
.form-select:focus {
  background-color: var(--ocre-navy);
  border-color: var(--ocre-violet);
  box-shadow: 0 0 0 0.2rem var(--ocre-violet-glow);
  color: var(--ocre-text-primary);
}

.form-control::placeholder {
  color: var(--ocre-text-muted);
}

/* Hide native number input spinners */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
}

input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}

.form-label {
  font-weight: 500;
  color: var(--ocre-text-secondary);
}

/* Badges */
.badge {
  font-weight: 600;
}

.bg-primary {
  background-color: var(--ocre-violet) !important;
}

.bg-secondary {
  background-color: var(--ocre-gold) !important;
  color: var(--ocre-deep-navy) !important;
}

.bg-dark {
  background-color: var(--ocre-deep-navy) !important;
}

.bg-violet {
  background-color: var(--ocre-violet) !important;
  color: white !important;
}

/* Progress bars */
.progress {
  background-color: var(--ocre-navy);
  border-radius: var(--bs-border-radius);
  height: 12px;
}

.progress-bar {
  background: var(--ocre-gradient-gold);
  border-radius: var(--bs-border-radius);
}

.progress-bar.bg-primary {
  background: var(--ocre-gradient-violet) !important;
}

/* Alerts */
.alert {
  border-radius: var(--bs-border-radius-lg);
}

/* Modals */
.modal-content {
  background-color: var(--ocre-navy);
  border-color: var(--ocre-border);
}

.modal-header {
  border-bottom-color: var(--ocre-border);
}

.modal-footer {
  border-top-color: var(--ocre-border);
}

/* Override border-secondary to use a neutral dark gray instead of gold */
.border-secondary {
  border-color: var(--ocre-border-dark) !important;
}

/* Tables */
.table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--ocre-text-primary);
  --bs-table-border-color: var(--ocre-border);
  --bs-table-striped-bg: var(--ocre-navy-light);
  --bs-table-hover-bg: var(--ocre-navy-lighter);
}

/* Nav Tabs - Dark Theme Override */
.nav-tabs {
  border-bottom-color: var(--ocre-border);
}

.nav-tabs .nav-link {
  color: var(--ocre-text-secondary);
  border: none;
  border-bottom: 2px solid transparent;
  background: transparent;
  transition: color var(--ocre-transition-fast), border-color var(--ocre-transition-fast);
}

.nav-tabs .nav-link:hover {
  color: var(--ocre-gold) !important;
  border-color: transparent;
  border-bottom-color: var(--ocre-border-light);
}

.nav-tabs .nav-link.active {
  color: var(--ocre-text-primary) !important;
  background: transparent;
  border-color: transparent;
  border-bottom-color: var(--ocre-violet);
}

/* Footer */
footer, .footer {
  background-color: var(--ocre-deep-navy) !important;
  border-top: 1px solid var(--ocre-border);
}

footer h5, .footer h5 {
  color: var(--ocre-gold);
}

footer a, .footer a {
  color: var(--ocre-text-secondary);
}

footer a:hover, .footer a:hover {
  color: var(--ocre-gold);
}

/* ============================================
   Utilitaires custom
   ============================================ */

/* Couleurs de texte custom utilities */
.text-gold {
  color: var(--ocre-gold) !important;
}

.text-violet {
  color: var(--ocre-violet-light) !important;
}


.text-muted {
  color: var(--ocre-text-muted) !important;
}

/* Couleurs de fond */
.bg-navy {
  background-color: var(--ocre-navy) !important;
}

.bg-navy-light {
  background-color: var(--ocre-navy-light) !important;
}

/* Divider décoratif gold - Use between sections for visual separation */
.divider-gold {
  height: 3px;
  width: 80px;
  background: var(--ocre-gradient-gold);
  border-radius: 2px;
  margin: 1.5rem auto;
}

/* ============================================
   Boutons custom
   ============================================ */

/* Bouton gold avec gradient - Use for important CTAs (Call To Action) */
.btn-gold {
  background: var(--ocre-gradient-gold);
  border: none;
  color: var(--ocre-deep-navy);
  font-weight: 600;
  box-shadow: var(--ocre-shadow-gold);
}

.btn-gold:hover {
  box-shadow: var(--ocre-shadow-gold-lg);
  color: var(--ocre-deep-navy);
}

/* Bouton outline violet - Use for alternative navigation or soft actions */
.btn-outline-violet {
  border: 2px solid var(--ocre-violet);
  color: var(--ocre-violet-light);
  background: transparent;
}

.btn-outline-violet:hover {
  background: var(--ocre-violet);
  color: #fff;
}

/* ============================================
   Composants custom - Hero Section
   ============================================ */
.hero-section {
  padding: 2rem 0 4rem;
}

.hero-title {
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1.1;
  margin-bottom: 1.5rem;
}

.hero-subtitle {
  font-size: 1.25rem;
  color: var(--ocre-text-secondary);
}

/* ============================================
   Composants custom - Stat Cards
   ============================================ */
.stat-card {
  text-align: center;
  padding: 2rem 1.5rem;
  background: linear-gradient(145deg, var(--ocre-navy-light) 0%, var(--ocre-navy) 100%);
  border: 1px solid var(--ocre-border);
  border-radius: var(--bs-border-radius-xl);
}

.stat-card:hover {
  box-shadow: var(--ocre-shadow-glow);
}

.stat-icon {
  width: 60px;
  height: 60px;
  margin: 0 auto 1rem;
  background: var(--ocre-gradient-violet);
  border-radius: var(--bs-border-radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
}

.stat-icon.gold {
  background: var(--ocre-gradient-gold);
}

.stat-number {
  font-family: 'Nunito', system-ui, sans-serif;
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--ocre-gold);
  line-height: 1;
  margin-bottom: 0.5rem;
}

.stat-label {
  color: var(--ocre-text-secondary);
  font-size: 0.95rem;
}

/* ============================================
   Composants custom - Feature Cards
   ============================================ */
.feature-card {
  padding: 2rem;
  background: var(--ocre-navy-light);
  border: 1px solid var(--ocre-border);
  border-radius: var(--bs-border-radius-xl);
  height: 100%;
}

.feature-card:hover {
  box-shadow: var(--ocre-shadow-glow);
}

.feature-icon {
  width: 56px;
  height: 56px;
  background: var(--ocre-gradient-violet);
  border-radius: var(--bs-border-radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 1.25rem;
}

.feature-icon.gold {
  background: var(--ocre-gradient-gold);
}

.feature-icon.success {
  background: var(--ocre-gradient-success);
}

.feature-title {
  font-family: 'Nunito', system-ui, sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
}

.feature-text {
  color: var(--ocre-text-secondary);
  font-size: 0.95rem;
  line-height: 1.6;
}

/* ============================================
   Composants custom - Card Ocre (hover effect)
   ============================================ */
.card-ocre {
  background: linear-gradient(145deg, var(--ocre-navy-light) 0%, var(--ocre-navy) 100%);
  border: 1px solid var(--ocre-border-light);
  border-radius: var(--bs-border-radius-lg);
}

.card-ocre .list-group-item.active {
  background-color: rgba(var(--bs-primary-rgb), 0.3) !important;
  border-color: transparent !important;
  border-left: 3px solid var(--bs-primary) !important;
}

/* ============================================
   Composants custom - Quest Progress
   ============================================ */
.quest-progress {
  height: 12px;
  background: var(--ocre-navy);
  border-radius: 6px;
  overflow: hidden;
}

.quest-progress .progress-bar {
  height: 100%;
  background: var(--ocre-gradient-gold);
  border-radius: 6px;
  transition: width var(--ocre-transition-slow);
}

.quest-progress.violet .progress-bar {
  background: var(--ocre-gradient-violet);
}

/* Progress bar for quest type progress (4 segments) */
.progress-quest {
  background: var(--ocre-navy);
  border-radius: 4px;
  overflow: hidden;
}

.progress-quest .progress-bar {
  border-radius: 0;
}

/* Dark green - passed steps (definitively validated) */
.progress-quest .progress-bar.bg-success {
  background: var(--ocre-success-dark) !important;
}

/* Light green - current step OK (ready for validation) */
.progress-quest .progress-bar.bg-success-light {
  background: var(--ocre-success-light) !important;
}

/* Light red - current step KO (not ready) */
.progress-quest .progress-bar.bg-danger-light {
  background: var(--ocre-danger-light) !important;
}

/* Ultra Light red - missing monsters */
.progress-quest .progress-bar.bg-danger-ultralight {
  background: var(--ocre-danger-ultralight) !important;
}

/* Grey - future steps (not started) */
.progress-quest .progress-bar.bg-secondary {
  background: var(--ocre-gray-darker) !important;
}

/* ============================================
   Composants custom - Badges
   ============================================ */

/* Badge with gold gradient - Use for important counters or highlights */
.badge-gold {
  background: var(--ocre-gradient-gold);
  color: var(--ocre-deep-navy);
}

/* Badge with violet gradient - Use for highlights or status indicators */
.badge-violet {
  background: var(--ocre-gradient-violet);
  color: #fff;
}

/* Badges de types de monstres */
.badge-monster {
  /* Monstre standard - Gris */
  background: var(--ocre-gradient-gray);
  color: #fff;
}

.badge-boss {
  /* Boss - Rouge */
  background: var(--ocre-gradient-danger);
  color: #fff;
}

.badge-archimonster {
  /* Archimonstre - Or */
  background: var(--ocre-gradient-gold);
  color: #000;
}

/* ============================================
   Badges utilisateurs - Couleurs dédiées
   ============================================ */
.bg-badge-beta {
  background: linear-gradient(135deg, #8b5cf6 0%, #6d28d9 100%) !important;
  color: #fff !important;
}

.bg-badge-bug {
  background: linear-gradient(135deg, #f97316 0%, #ea580c 100%) !important;
  color: #fff !important;
}

.bg-badge-contrib {
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%) !important;
  color: #fff !important;
}

.bg-badge-support {
  background: linear-gradient(135deg, #ec4899 0%, #db2777 100%) !important;
  color: #fff !important;
}

.bg-badge-veteran {
  background: linear-gradient(135deg, #eab308 0%, #ca8a04 100%) !important;
  color: #000 !important;
}

.bg-badge-event {
  background: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%) !important;
  color: #fff !important;
}

.bg-badge-mod {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
  color: #fff !important;
}

.bg-badge-admin {
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
  color: #fff !important;
}

/* Alignement vertical des badges dans les titres */
h1 .badge,
h2 .badge,
h3 .badge {
  vertical-align: middle;
  position: relative;
  top: -0.15em;
}

/* Background utility - gold gradient (used in badges, cards, etc.) */
.bg-ocre-gold {
  background: var(--ocre-gradient-gold);
  color: var(--ocre-deep-navy) !important;
}

/* ============================================
   Composants custom - CTA Section
   ============================================ */
.cta-section {
  background: linear-gradient(135deg, var(--ocre-overlay-violet-15) 0%, rgba(91, 33, 182, 0.1) 100%);
  border: 1px solid rgba(124, 58, 237, 0.3);
  border-radius: 1.5rem;
  padding: 4rem 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.cta-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(245, 158, 11, 0.1) 0%, transparent 60%);
  pointer-events: none;
}

/* ============================================
   Animations
   ============================================ */
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

@keyframes glow-pulse {
  0%, 100% { box-shadow: 0 0 20px var(--ocre-violet-glow); }
  50% { box-shadow: 0 0 30px rgba(124, 58, 237, 0.6); }
}

@keyframes shimmer {
  0% { box-shadow: 0 0 5px rgba(16, 185, 129, 0.4); }
  50% { box-shadow: 0 0 15px rgba(16, 185, 129, 0.7), 0 0 25px rgba(16, 185, 129, 0.4); }
  100% { box-shadow: 0 0 5px rgba(16, 185, 129, 0.4); }
}

.animate-float {
  animation: float 3s ease-in-out infinite;
}

.btn-shimmer {
  animation: shimmer 2s ease-in-out infinite;
}


/* ============================================
   Responsive
   ============================================ */
@media (max-width: 768px) {
  .hero-section {
    padding: 4rem 0 3rem;
  }

  .hero-title {
    font-size: 2rem;
  }

  .stat-number {
    font-size: 2rem;
  }

  .cta-section {
    padding: 3rem 1.5rem;
  }

  .feature-card {
    padding: 1.5rem;
  }
}

/* ============================================
   Notification Dropdown
   ============================================ */
.notification-bell {
  position: relative;
  padding: 0.5rem !important;
  color: var(--ocre-text-primary) !important;
}

.notification-bell:hover {
  color: var(--ocre-violet-light) !important;
  background-color: var(--ocre-overlay-violet-15) !important;
  border-radius: var(--bs-border-radius);
}

.notification-badge {
  font-size: 0.65rem;
  padding: 0.25em 0.5em;
  transform: translate(-50%, -25%) !important;
}

.notification-dropdown {
  background-color: var(--ocre-navy-light);
  border: 1px solid var(--ocre-border);
  box-shadow: var(--ocre-shadow-dark-lg);
  width: 360px;
  max-width: calc(100vw - 1rem);
  max-height: 480px;
  overflow-y: auto;
}

/* Mobile: full width dropdown */
@media (max-width: 576px) {
  .notification-dropdown {
    width: calc(100vw - 1rem);
    right: 0;
  }
}

.notification-dropdown .dropdown-header {
  color: var(--ocre-text-primary);
  background-color: var(--ocre-navy);
  padding: 0.75rem 1rem;
}

.notification-dropdown .dropdown-divider {
  border-color: var(--ocre-border);
  margin: 0;
}

.notification-item {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--ocre-border);
  white-space: normal;
  color: var(--ocre-text-primary) !important;
  text-decoration: none;
}

.notification-item:last-child {
  border-bottom: none;
}

.notification-item:hover {
  background-color: var(--ocre-navy-lighter) !important;
  color: var(--ocre-text-primary) !important;
}

.notification-item.unread {
  background-color: var(--ocre-overlay-violet-08);
}

.notification-item.unread:hover {
  background-color: var(--ocre-overlay-violet-15) !important;
}

.notification-indicator {
  width: 10px;
  flex-shrink: 0;
}

.indicator-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  background-color: var(--ocre-violet);
  border-radius: 50%;
}

.notification-title {
  font-size: 0.9rem;
  margin-bottom: 0.25rem;
}

.notification-content {
  font-size: 0.85rem;
  line-height: 1.4;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.notification-time {
  font-size: 0.75rem;
}

.notification-arrow {
  display: flex;
  align-items: center;
  opacity: 0.5;
}

.notification-item:hover .notification-arrow {
  opacity: 1;
}

/* Min width helper for text truncation */
.min-width-0 {
  min-width: 0;
}

/* Monster mentions in notifications (same as messages) */
.notification-content .monster-mention {
  color: var(--ocre-gold);
  font-weight: 600;
  cursor: pointer;
}

.notification-content .monster-mention:hover {
  color: var(--ocre-gold-light);
}

/* Monster popover (shared with messages) */
.monster-popover {
  position: fixed;
  z-index: 2000;
  background-color: var(--ocre-navy);
  border: 1px solid var(--ocre-border-light);
  border-radius: var(--bs-border-radius-lg);
  padding: 0.75rem;
  box-shadow: var(--ocre-shadow-dark-lg);
  pointer-events: none;
  min-width: 180px;
}

.monster-popover img {
  width: 64px;
  height: 64px;
  object-fit: contain;
  display: block;
  margin: 0 auto 0.5rem;
  background: var(--ocre-navy-light);
  border-radius: var(--bs-border-radius);
}

.monster-popover .monster-name {
  color: var(--ocre-gold);
  font-weight: var(--ocre-fw-bold);
  text-align: center;
  margin-bottom: 0.25rem;
}

.monster-popover .monster-details {
  color: var(--ocre-text-secondary);
  font-size: var(--ocre-fs-base);
  text-align: center;
}

.monster-popover-img {
  width: 40px;
  height: 40px;
  object-fit: contain;
  border-radius: var(--bs-border-radius-sm);
  background-color: var(--ocre-navy-light);
}

/* Form switch in dark theme */
.form-switch .form-check-input {
  background-color: var(--ocre-border);
  border-color: var(--ocre-border);
}

.form-switch .form-check-input:checked {
  background-color: var(--ocre-violet);
  border-color: var(--ocre-violet);
}

/* ============================================
   Local Time - Timezone display utilities
   ============================================ */

/* Info icon - hidden by default (desktop), shown on mobile */
.local-time-info {
  display: none;
  margin-left: 0.25rem;
  color: var(--ocre-text-muted);
  cursor: pointer;
  vertical-align: middle;
}

.local-time-info:hover {
  color: var(--ocre-violet-light);
}

/* Show info icon only on touch devices / mobile */
@media (max-width: 768px), (hover: none) {
  .local-time-info {
    display: inline-flex;
    align-items: center;
  }
}

/* Mobile tooltip popup */
.local-time-mobile-tooltip {
  position: fixed;
  z-index: 9999;
  background-color: var(--ocre-navy);
  border: 1px solid var(--ocre-border);
  border-radius: var(--bs-border-radius);
  padding: 0.5rem 0.75rem;
  font-size: var(--ocre-fs-base);
  color: var(--ocre-text-primary);
  box-shadow: var(--ocre-shadow-dark);
  white-space: nowrap;
  transition: opacity var(--ocre-transition-normal);
}

.local-time-mobile-tooltip.fade-out {
  opacity: 0;
}

/* Scroll to top */

.scroll-to-top-btn {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--ocre-violet-dark);
    border: none;
    color: white;
    font-size: 1rem;
    cursor: pointer;
    z-index: 1000;
}

@media (max-width: 768px) {
    .scroll-to-top-btn {
        bottom: 1rem;
        right: 1rem;
        width: 45px;
        height: 45px;
        font-size: 1.1rem;
    }
}

/* ============================================
   Utilitaires - Images & Avatars
   ============================================ */
.img-contain {
  object-fit: contain;
}

.avatar-circle {
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--ocre-navy);
  color: var(--ocre-violet);
}

/* Semantic sizing (preferred) */
.avatar-xs { width: 24px; height: 24px; }
.avatar-sm { width: 32px; height: 32px; }
.avatar-md { width: 40px; height: 40px; }
.avatar-lg { width: 60px; height: 60px; }
.avatar-xl { width: 80px; height: 80px; }

/* Pixel-based sizing (legacy support) */
.avatar-24 { width: 24px; height: 24px; }
.avatar-32 { width: 32px; height: 32px; }
.avatar-40 { width: 40px; height: 40px; }
.avatar-48 { width: 48px; height: 48px; }
.avatar-50 { width: 50px; height: 50px; }
.avatar-60 { width: 60px; height: 60px; }
.avatar-80 { width: 80px; height: 80px; }

/* Monster thumbnails */
.monster-thumb {
  width: 40px;
  height: 40px;
  background: var(--ocre-overlay-light-05);
  border-radius: var(--bs-border-radius-sm);
  object-fit: contain;
  flex-shrink: 0;
}

.monster-thumb-placeholder {
  width: 40px;
  height: 40px;
  background: var(--ocre-overlay-light-05);
  border-radius: var(--bs-border-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--ocre-overlay-light-20);
  flex-shrink: 0;
}

@media (max-width: 768px) {
  .monster-thumb,
  .monster-thumb-placeholder {
    width: 32px;
    height: 32px;
  }
}

/* ============================================
   Utilitaires - Overlays & Backgrounds
   ============================================ */
.overlay-dark-10 { background: var(--ocre-overlay-dark-10); }
.overlay-dark-20 { background: var(--ocre-overlay-dark-20); }
.overlay-dark-30 { background: var(--ocre-overlay-dark-30); }
.overlay-dark-50 { background: var(--ocre-overlay-dark-50); }
.overlay-dark-70 { background: var(--ocre-overlay-dark-70); }
.overlay-light-05 { background: var(--ocre-overlay-light-05); }
.overlay-light-10 { background: var(--ocre-overlay-light-10); }
.overlay-light-15 { background: var(--ocre-overlay-light-15); }
.overlay-light-20 { background: var(--ocre-overlay-light-20); }

.border-light-10 { border-color: var(--ocre-overlay-light-10) !important; }
.border-light-20 { border-color: var(--ocre-overlay-light-20) !important; }
.border-light-30 { border-color: var(--ocre-overlay-light-30) !important; }

/* ============================================
   Utilitaires - Box Shadows
   ============================================ */
.shadow-glow { box-shadow: var(--ocre-shadow-glow); }
.shadow-dark { box-shadow: var(--ocre-shadow-dark); }
.shadow-dark-lg { box-shadow: var(--ocre-shadow-dark-lg); }
.shadow-violet { box-shadow: var(--ocre-shadow-violet); }
.shadow-violet-lg { box-shadow: var(--ocre-shadow-violet-lg); }
.shadow-gold { box-shadow: var(--ocre-shadow-gold); }
.shadow-gold-lg { box-shadow: var(--ocre-shadow-gold-lg); }

/* ============================================
   Utilitaires - Typography
   ============================================ */
.fs-xxs { font-size: var(--ocre-fs-xxs); }
.fs-xs { font-size: var(--ocre-fs-xs); }
.fs-sm { font-size: var(--ocre-fs-sm); }
.fs-base { font-size: var(--ocre-fs-base); }
.fs-md { font-size: var(--ocre-fs-md); }
.fs-lg { font-size: var(--ocre-fs-lg); }

.fw-normal { font-weight: var(--ocre-fw-normal); }
.fw-medium { font-weight: var(--ocre-fw-medium); }
.fw-semibold { font-weight: var(--ocre-fw-semibold); }
.fw-bold { font-weight: var(--ocre-fw-bold); }
.fw-extrabold { font-weight: var(--ocre-fw-extrabold); }

/* ============================================
   Utilitaires - Input widths
   ============================================ */
.w-24 { width: 24px; }
.w-32 { width: 32px; }
.w-40 { width: 40px; }
.w-48 { width: 48px; }
.w-60 { width: 60px; }
.w-80 { width: 80px; }
.w-200 { width: 200px; }
.max-w-300 { max-width: 300px; }
.max-w-400 { max-width: 400px; }
.min-w-140 { min-width: 140px; }

/* ============================================
   Utilitaires - Heights
   ============================================ */
.h-24 { height: 24px; }
.h-32 { height: 32px; }
.h-40 { height: 40px; }
.h-48 { height: 48px; }
.h-60 { height: 60px; }
.h-80 { height: 80px; }
.h-8 { height: 8px; }

/* ============================================
   Utilitaires - Gradients backgrounds
   ============================================ */
.bg-gradient-gold {
  background: var(--ocre-gradient-gold);
}

.bg-gradient-violet {
  background: var(--ocre-gradient-violet);
}

.bg-gradient-success {
  background: var(--ocre-gradient-success);
}

.bg-gradient-danger {
  background: var(--ocre-gradient-danger);
}

.bg-gradient-gray {
  background: var(--ocre-gradient-gray);
}

/* ============================================
   Utilitaires - Text truncation
   ============================================ */
.text-truncate-single {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.text-truncate-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.text-truncate-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ============================================
   Utilitaires - Z-index
   ============================================ */
.z-10 { z-index: 10; }
.z-100 { z-index: 100; }
.z-1000 { z-index: 1000; }
.z-1050 { z-index: 1050; }

/* ============================================
   Utilitaires - Object fit
   ============================================ */
.object-contain { object-fit: contain; }

/* ============================================
   Utilitaires - Overflow
   ============================================ */
.overflow-visible { overflow: visible !important; }

/* ============================================
   Utilitaires - Min/Max widths & heights
   ============================================ */
.min-w-100 { min-width: 100px; }
.min-w-120 { min-width: 120px; }
.min-w-150 { min-width: 150px; }
.min-w-200 { min-width: 200px; }
.min-w-500 { min-width: 500px; }
.max-w-50 { max-width: 50px; }
.max-w-60 { max-width: 60px; }
.max-w-250 { max-width: 250px; }
.max-h-220 { max-height: 220px; }

/* ============================================
   Utilitaires - Width auto
   ============================================ */
.w-auto { width: auto !important; }

/* ============================================
   Utilitaires - Borders
   ============================================ */
.border-dark-subtle { border-color: var(--ocre-border-dark) !important; }
.border-violet { border-color: var(--ocre-violet) !important; }

/* ============================================
   Utilitaires - Word wrap
   ============================================ */
.word-break-all {
  word-wrap: break-word;
  word-break: break-word;
}

/* ============================================
   Utilitaires - Display
   ============================================ */
.d-inline { display: inline !important; }

/* ============================================
   Utilitaires - Resize
   ============================================ */
.resize-none { resize: none; }

/* ============================================
   Utilitaires - Sizes combinés (width + height)
   ============================================ */
.size-32 { width: 32px; height: 32px; }
.size-50 { width: 50px; height: 50px; }

/* ============================================
   Utilitaires - Table widths
   ============================================ */
.table-col-40 { width: 40px; }
.table-col-100 { width: 100px; }

/* ============================================
   Utilitaires - Progress bar dimensions
   ============================================ */
.progress-w-80 { width: 80px; }
.progress-w-60 { width: 60px; }
.progress-h-8 { height: 8px; }
.progress-h-6 { height: 6px; }

/* ============================================
   Utilitaires - Cursors
   ============================================ */
.cursor-pointer { cursor: pointer; }

/* ============================================
   Utilitaires - White-space
   ============================================ */
.ws-pre-wrap { white-space: pre-wrap; }

/* ============================================
   Utilitaires - Sizes (24px)
   ============================================ */
.size-24 { width: 24px; height: 24px; }
.size-60 { width: 60px; height: 60px; }

/* ============================================
   Utilitaires - Font sizes (icons)
   ============================================ */
.fs-3rem { font-size: 3rem; }

/* ============================================
   Utilitaires - Badges
   ============================================ */
.badge-xs {
  font-size: 0.65rem;
  padding: 0.15em 0.4em;
}

@media (max-width: 768px) {
  .badge-xs {
    font-size: 0.6rem;
  }
}

.badge-sm {
  font-size: 0.7rem;
  padding: 0.2em 0.45em;
  vertical-align: middle;
}

/* ============================================
   Progress bar - Zone style
   ============================================ */
.progress-zone {
  background-color: var(--ocre-overlay-light-10);
  border-radius: var(--bs-border-radius-sm);
}
.progress-zone .progress-bar.bg-success {
  background: var(--ocre-success-dark) !important;
}
.progress-zone .progress-bar.bg-info {
  background: var(--ocre-info) !important;
}

/* ============================================
   Table row status colors
   ============================================ */
tr.status-needed {
  background-color: var(--ocre-overlay-danger-10) !important;
}
tr.status-ok {
  background-color: rgba(144, 190, 109, 0.1) !important;
}
tr.status-excess {
  background-color: var(--ocre-overlay-success-20) !important;
}