@charset "UTF-8";
/**
 * Point d'entrée Principal - CantalDestination
 * Compile vers: static/css/main.css
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Mixins SCSS - CantalDestination
 * Fonctions réutilisables pour éviter la duplication
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Base Styles - Infographie
 * Styles fondamentaux et variables CSS
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

:root {
  --primary: #2b5439;
  --primary-light: rgb(55.9677165354, 109.3322834646, 74.1897637795);
  --primary-dark: rgb(38.7, 75.6, 51.3);
  --secondary: #d4a674;
  --accent-magenta: #f800ff;
  --accent-lime: #2b5439;
  --accent-orange: #d4a674;
  --vert-sapin: #2b5439;
  --ocre: #d4a674;
  --rouge-cantal: #e52834;
  --basalte: #373234;
  --success: #00d4aa;
  --error: #ff6b6b;
  --warning: #f59e0b;
  --info: #3b82f6;
  --positive: #27ae60;
  --negative: #ff964f;
  --brand-red: #E30613;
  --bg-app: #f3f4f6;
  --bg-card: #ffffff;
  --bg-surface: rgba(255, 255, 255, 0.8);
  --bg-surface-glass: rgba(255, 255, 255, 0.6);
  --bg-surface-alt: rgba(249, 250, 251, 0.6);
  --bg-accent: rgba(var(--primary-rgb), 0.05);
  --text-primary: #373234;
  --text-secondary: #4b5563;
  --text-muted: #6b7280;
  --text-contrast: #2b5439;
  --border: rgba(0, 0, 0, 0.1);
  --border-subtle: rgba(0, 0, 0, 0.05);
  --border-glow: rgba(var(--primary-rgb), 0.2);
  --border-weak: rgba(0, 0, 0, 0.08);
  --chart-touristes: #2b5439;
  --chart-excursionnistes: #667eea;
  --chart-n: #2b5439;
  --chart-n-1: #a35fff;
  --chart-n-2: rgba(0, 0, 0, 0.4);
  --chart-n-3: #d4a674;
  --chart-grid: rgba(0, 0, 0, 0.05);
  --chart-tick: rgba(0, 0, 0, 0.5);
  --chart-tooltip-bg: rgba(var(--black-rgb), 0.85);
  --chart-accent: #f800ff;
  --white: #ffffff;
  --black: #000000;
  --text: #373234;
  --grid: rgba(0, 0, 0, 0.08);
  --background: #ffffff;
  --surface: #f9f9f9;
  --light-bg: #ffffff;
  --light-text: #111827;
  --light-text-secondary: #374151;
  --light-border: #e5e7eb;
  --accent-yellow: #F1C40F;
  --light-800: #111827;
  --light-700: #374151;
  --chart-1: rgba(var(--primary-rgb), 0.8);
  --chart-2: rgba(var(--accent-magenta-rgb), 0.8);
  --chart-3: rgba(var(--secondary-rgb), 0.8);
  --chart-4: rgba(var(--accent-lime-rgb), 0.8);
  --chart-5: rgba(var(--accent-orange-rgb), 0.8);
  --chart-6: rgba(0, 174, 255, 0.8);
  --chart-7: rgba(255, 0, 168, 0.8);
  --chart-8: rgba(255, 234, 0, 0.8);
  --chart-9: rgba(0, 255, 56, 0.8);
  --chart-10: rgba(0, 255, 212, 0.8);
  --chart-11: rgba(191, 255, 0, 0.8);
  --chart-12: rgba(255, 0, 115, 0.8);
  --chart-13: rgba(119, 0, 255, 0.8);
  --chart-14: rgba(0, 255, 149, 0.8);
  --chart-15: rgba(0, 140, 255, 0.81);
  --primary-rgb: 43, 84, 57;
  --secondary-rgb: 212, 166, 116;
  --accent-magenta-rgb: 248, 0, 255;
  --accent-lime-rgb: 39, 174, 96;
  --accent-orange-rgb: 255, 150, 79;
  --vert-sapin-rgb: 43, 84, 57;
  --ocre-rgb: 212, 166, 116;
  --rouge-cantal-rgb: 229, 40, 52;
  --basalte-rgb: 55, 50, 52;
  --accent-yellow-rgb: 241, 196, 15;
  --brand-red-rgb: 227, 6, 19;
  --light-800-rgb: 17, 24, 39;
  --light-700-rgb: 55, 65, 81;
  --success-rgb: 0, 212, 170;
  --error-rgb: 255, 107, 107;
  --warning-rgb: 245, 158, 11;
  --info-rgb: 59, 130, 246;
  --white-rgb: 255, 255, 255;
  --black-rgb: 0, 0, 0;
  --bg-app-rgb: 255, 255, 255;
  --bg-card-rgb: 249, 249, 249;
  --gap-xs: 0.25rem;
  --gap-sm: 0.5rem;
  --gap-md: 1rem;
  --gap-lg: 1.5rem;
  --gap-xl: 2rem;
  --gap-2xl: 3rem;
  --gap-3xl: 4rem;
  --font-display: 'EloquentJFItalicPro', 'Playfair Display', serif;
  --font-body: 'Outfit', 'Roboto', sans-serif;
  --size-xs: clamp(0.65rem, 1.2vw, 0.75rem);
  --size-sm: clamp(0.75rem, 1.4vw, 0.85rem);
  --size-base: clamp(0.85rem, 1.6vw, 1rem);
  --size-lg: clamp(1rem, 1.8vw, 1.2rem);
  --size-xl: clamp(1.2rem, 2vw, 1.5rem);
  --size-2xl: clamp(1.5rem, 2.2vw, 1.8rem);
  --size-3xl: clamp(1.8rem, 2.5vw, 2.2rem);
  --size-4xl: clamp(2rem, 3vw, 2.5rem);
  --letter-spacing-title: 1px;
  --line-height-base: 1.7;
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-full: 9999px;
  --shadow-sm: 0 2px 8px rgba(var(--black-rgb), 0.08);
  --shadow-md: 0 10px 20px -5px rgba(var(--black-rgb), 0.12), 0 4px 6px -2px rgba(var(--black-rgb), 0.05);
  --shadow-lg: 0 25px 50px -12px rgba(var(--black-rgb), 0.18);
  --shadow-glow: 0 0 25px rgba(var(--primary-rgb), 0.15);
  --shadow-border: 0 0 0 1px rgba(var(--black-rgb), 0.04);
  --shadow-glass: 0 12px 40px rgba(var(--black-rgb), 0.12), inset 0 0 0 1px rgba(var(--white-rgb), 0.6);
  --duration-fast: 150ms;
  --duration-base: 250ms;
  --duration-slow: 450ms;
  --easing-base: ease;
  --easing-out: ease-out;
  --easing-in-out: ease-in-out;
  --container-max: 1300px;
  --navbar-h: 60px;
  --z-base: 1;
  --z-sticky: 100;
  --z-fixed: 200;
  --z-modal: 1000;
  --z-tooltip: 1100;
  --chart-h: 400px;
  --chart-h-lg: 550px;
  --chart-h-xl: 800px;
  --primary-color: var(--primary);
  --secondary-color: var(--secondary);
  --border-color: var(--border);
  --shadow-card: var(--shadow-md);
  --success-color: var(--success);
  --error-color: var(--error);
  --warning-color: var(--warning);
  --info-color: var(--info);
  --chart-lighthouse-main: var(--warning);
  --chart-lighthouse-secondary: var(--text-muted);
  --capture-bg: var(--bg-card);
  --capture-preview-bg: var(--white);
  --body-font: var(--font-body);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  background-color: var(--bg-app);
  color: var(--text-primary);
  line-height: 1.7;
  font-size: 16px;
  overflow-x: hidden;
  padding-top: 80px;
  background-image: linear-gradient(to bottom, rgba(var(--bg-app-rgb), 0.95), rgba(var(--bg-app-rgb), 1)), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'%3E%3Cg fill-rule='evenodd'%3E%3Cg fill='%23000000' fill-opacity='0.03'%3E%3Cpath d='M0 38.59l2.83-2.83 1.41 1.41L1.41 40H0v-1.41zM10 40l1.41-1.41 2.83 2.83L11.41 40H10zM17.17 40l2.83-2.83 1.41 1.41L18.59 40h-1.42zM20 40l1.41-1.41 2.83 2.83L21.41 40H20zM27.17 40l2.83-2.83 1.41 1.41L28.59 40h-1.42zM30 40l1.41-1.41 2.83 2.83L31.41 40H30zM37.17 40l2.83-2.83 1.41 1.41L38.59 40h-1.42zM40 38.59l-1.41-1.41 2.83-2.83L40 37.17V38.59zM40 30l-1.41-1.41 2.83-2.83L40 27.17V30zM37.17 20l2.83-2.83 1.41 1.41L38.59 20h-1.42zM40 10l-1.41-1.41 2.83-2.83L40 7.17V10zM40 0l-1.41 1.41 2.83 2.83L40 2.83V0zM30 0l-1.41 1.41 2.83 2.83L31.41 0H30zM20 0l-1.41 1.41 2.83 2.83L21.41 0H20zM10 0l-1.41 1.41 2.83 2.83L11.41 0H10zM0 0l1.41 1.41 2.83 2.83L2.83 0H0zM0 10l1.41-1.41 2.83-2.83L2.83 10H0zM0 20l1.41-1.41 2.83-2.83L2.83 20H0zM0 30l1.41-1.41 2.83-2.83L2.83 30H0z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-attachment: fixed;
}
body::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(circle at top right, rgba(var(--primary-rgb), 0.03), transparent 70%), radial-gradient(circle at bottom left, rgba(var(--secondary-rgb), 0.03), transparent 70%);
  pointer-events: none;
  z-index: -1;
}
body::after {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(circle at 10% 20%, rgba(var(--primary-rgb), 0.04) 0%, transparent 40%), radial-gradient(circle at 90% 80%, rgba(var(--secondary-rgb), 0.04) 0%, transparent 40%), radial-gradient(circle at 50% 50%, rgba(var(--primary-rgb), 0.02) 0%, transparent 60%);
  filter: blur(60px);
  z-index: -2;
  pointer-events: none;
  animation: background-pulse 15s infinite alternate ease-in-out;
}

@keyframes background-pulse {
  from {
    opacity: 0.6;
    transform: scale(1);
  }
  to {
    opacity: 1;
    transform: scale(1.1);
  }
}
.container {
  max-width: var(--container-max, 1300px);
  margin: 0 auto;
  padding: 0 var(--gap-xl);
}

.btn-infographie:focus-visible,
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Styles Globaux & Utilitaires JS
 * Classes utilisées dynamiquement par le JavaScript
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

.active {
  border-color: #2b5439 !important;
  box-shadow: 0 0 15px rgba(var(--primary-rgb), 0.2);
}

.is-active {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.loading {
  opacity: 0.7;
  pointer-events: none;
  position: relative;
}
.loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -12px 0 0 -12px;
  width: 24px;
  height: 24px;
  border: 2px solid rgba(var(--black-rgb), 0.1);
  border-top-color: #2b5439;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.positive {
  color: var(--positive) !important;
}

.negative {
  color: var(--negative) !important;
}

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

.error {
  color: var(--negative) !important;
}

.info {
  color: var(--info) !important;
}

.section {
  margin-bottom: 70px;
  opacity: 0;
  animation: fade-in-up 0.8s ease-out forwards;
}

.section-title {
  font-family: "Orbitron", sans-serif;
  font-size: clamp(1.8rem, 4vw, 2.2rem);
  color: #373234;
  text-align: center;
  margin-bottom: 40px;
}
.section-title span {
  color: #2b5439;
}

.admin-container {
  max-width: 1300px;
  margin: 30px auto;
  padding: 0 25px 50px;
}

.value {
  font-weight: 700;
  color: #373234;
}

.unit {
  font-size: 0.8em;
  color: #4b5563;
  margin-left: 4px;
}

.icon {
  margin-right: 8px;
  color: #2b5439;
}

@keyframes fade-in-up {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * BASE: Typography & Lists
 * Extracted from style.css
 */
.fiche-title {
  font-family: var(--display-font);
  font-size: 2.2rem;
  color: var(--primary);
  margin-bottom: var(--gap-xl, 25px);
  text-align: center;
  position: relative;
  font-weight: 800;
  letter-spacing: var(--letter-spacing-title, 2px);
  color: var(--primary);
  margin-bottom: var(--gap-xl, 25px);
  text-align: center;
  position: relative;
  font-weight: 800;
  letter-spacing: var(--letter-spacing-title, 2px);
  text-shadow: none;
}
.fiche-title::after {
  content: "";
  position: absolute;
  width: 80px;
  height: 5px;
  background: var(--secondary);
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 50px;
  transition: var(--transition);
}
.fiche-title:hover::after {
  width: 120px;
  background: linear-gradient(to right, var(--accent-magenta), var(--secondary));
  box-shadow: 0 0 10px rgba(var(--accent-magenta-rgb), 0.5);
}

.section-title {
  font-family: var(--display-font);
  font-size: 1.5rem;
  color: var(--text-primary);
  font-weight: 600;
  margin: var(--gap-2xl, 35px) 0 var(--gap-xl, 20px);
  padding-left: var(--gap-md, 15px);
  border-left: 4px solid var(--secondary);
  display: flex;
  align-items: center;
  position: relative;
  letter-spacing: var(--letter-spacing-title, 2px);
  transition: all 0.4s ease;
}
.section-title::before {
  content: "";
  margin-right: var(--gap-sm, 12px);
  width: 10px;
  height: 10px;
  background: var(--secondary) !important;
  border-radius: 50%;
  display: inline-block;
  transition: all 0.4s ease;
  text-shadow: none;
}
.section-title:hover {
  transform: translateX(5px);
  color: var(--primary) !important;
}
.section-title:hover::before {
  transform: scale(1.5);
}

.section-content {
  margin-bottom: var(--gap-xl, 30px);
  padding: var(--gap-xl, 25px);
  background: #fdfdfd;
  backdrop-filter: blur(15px);
  border-radius: var(--radius-md, 12px);
  border: 1px solid rgba(var(--primary-rgb), 0.1);
  box-shadow: var(--shadow-md), inset 0 0 0 1px rgba(var(--white-rgb), 0.8);
  position: relative;
  overflow: hidden;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.section-content:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-lg), inset 0 0 0 1px rgba(var(--white-rgb), 1);
}
.section-content::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background: linear-gradient(to right, var(--primary), var(--secondary), var(--accent-magenta));
  opacity: 0.7;
}
.section-content::after {
  content: "";
  position: absolute;
  bottom: -20px;
  right: -20px;
  width: 80px;
  height: 80px;
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 0.08;
  z-index: 0;
  filter: saturate(1.2);
  transition: all 0.5s ease;
}
.section-content:hover::after {
  opacity: 0.15;
  transform: scale(1.2) rotate(10deg);
}
.section-content:nth-of-type(3n+1)::after {
  background-image: url("../images/mountain.svg");
}
.section-content:nth-of-type(3n+2)::after {
  background-image: url("../images/beach.svg");
}
.section-content:nth-of-type(3n+3)::after {
  background-image: url("../images/city.svg");
}

/* Typography styles */
.paragraphe {
  font-family: var(--body-font);
  font-size: 1.05rem;
  line-height: 1.7;
  margin-bottom: var(--gap-md, 15px);
  position: relative;
  z-index: 1;
  color: var(--text-primary);
  transition: all 0.3s ease;
}
.paragraphe strong {
  color: var(--primary);
  font-weight: 600;
}
.paragraphe:hover {
  transform: translateX(5px);
  color: var(--primary-dark);
}

.remarque {
  font-family: var(--body-font);
  font-style: italic;
  background: linear-gradient(to right, rgba(var(--warning-rgb), 0.1), rgba(var(--warning-rgb), 0.05));
  padding: var(--gap-xl, 20px);
  border-left: 4px solid var(--accent-magenta);
  margin: var(--gap-xl, 20px) 0;
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  position: relative;
  box-shadow: 0 5px 15px rgba(var(--black-rgb), 0.05);
  color: var(--text-contrast);
}
.remarque::before {
  content: "💡";
  position: absolute;
  left: -15px;
  top: 50%;
  transform: translateY(-50%);
  background: var(--white);
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  box-shadow: 0 3px 8px rgba(var(--black-rgb), 0.1);
  border: 1px solid rgba(var(--black-rgb), 0.05);
}

/* Lists */
ol {
  counter-reset: item;
  margin-left: 0;
  padding-left: 0;
}
ol > li {
  display: block;
  position: relative;
  margin-bottom: 15px;
  padding-left: 45px;
  line-height: 1.6;
}
ol > li::before {
  content: counter(item) "";
  counter-increment: item;
  position: absolute;
  left: 0;
  top: 0;
  background: linear-gradient(135deg, var(--primary), var(--primary-light));
  height: var(--gap-lg, 30px);
  width: var(--gap-lg, 30px);
  border-radius: 50%;
  color: var(--white);
  text-align: center;
  line-height: var(--gap-lg, 30px);
  font-weight: bold;
  box-shadow: 0 3px 8px rgba(var(--primary-rgb), 0.3);
}

ul.nested-list {
  list-style: none;
  margin: 15px 0 15px 10px;
  padding-left: 20px;
}
ul.nested-list li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 12px;
  line-height: 1.5;
}
ul.nested-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 12px;
  height: 12px;
  background: linear-gradient(135deg, var(--secondary), var(--primary-light));
  border-radius: 50%;
  box-shadow: 0 2px 5px rgba(var(--secondary-rgb), 0.3);
}

/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * BASE: Animations & Visual Effects
 * Extracted from style.css
 */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
@keyframes shine {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(100%);
  }
}
@keyframes glow {
  0% {
    text-shadow: 0 0 10px rgba(var(--white-rgb), 0.1);
  }
  100% {
    text-shadow: 0 0 20px #F1C40F, 0 0 30px #F1C40F;
  }
}
@keyframes glow-mountain {
  0% {
    text-shadow: 0 0 5px rgba(248, 0, 255, 0.5);
  }
  100% {
    text-shadow: 0 0 15px rgba(248, 0, 255, 0.8), 0 0 20px rgba(248, 0, 255, 0.4);
  }
}
@keyframes glow-water {
  0% {
    text-shadow: 0 0 5px rgba(43, 84, 57, 0.5);
  }
  100% {
    text-shadow: 0 0 15px rgba(43, 84, 57, 0.8), 0 0 20px rgba(43, 84, 57, 0.4);
  }
}
@keyframes glow-beach {
  0% {
    text-shadow: 0 0 5px rgba(212, 166, 116, 0.5);
  }
  100% {
    text-shadow: 0 0 15px rgba(212, 166, 116, 0.8), 0 0 20px rgba(212, 166, 116, 0.4);
  }
}
@keyframes glow-city {
  0% {
    text-shadow: 0 0 5px rgba(43, 84, 57, 0.5);
  }
  100% {
    text-shadow: 0 0 15px rgba(43, 84, 57, 0.8), 0 0 20px rgba(43, 84, 57, 0.4);
  }
}
@keyframes floating {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}
@keyframes wave-animation {
  0%, 100% {
    transform: translateX(-50%);
  }
  50% {
    transform: translateX(0%);
  }
}
@keyframes subtle-move {
  0% {
    background-position: 0% 0%;
  }
  100% {
    background-position: 100% 100%;
  }
}
@keyframes pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.05;
  }
  50% {
    transform: scale(1.1);
    opacity: 0.08;
  }
}
@keyframes pulse-success {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
}
.fade-in {
  animation: fadeIn 0.5s ease-in-out;
}

.ripple-effect {
  animation: ripple-effect 0.8s linear;
}

@keyframes ripple-effect {
  to {
    transform: scale(4);
    opacity: 0;
  }
}
/* Custom Scrollbar */
::-webkit-scrollbar {
  width: 10px;
}

::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.8);
  border-radius: 10px;
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(to bottom, rgb(55.9677165354, 109.3322834646, 74.1897637795), #2b5439);
  border-radius: 10px;
}
::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(to bottom, #2b5439, rgb(55.9677165354, 109.3322834646, 74.1897637795));
}

/* Loading Indicators */
.loading-indicator {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.loading-indicator .spinner {
  width: 40px;
  height: 40px;
  border: 4px solid rgba(43, 84, 57, 0.1);
  border-top-color: #2b5439;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

/* ==========================================================================
   RESPONSIVE DESIGN - FLUXVISION
   ========================================================================== */
/* Variables breakpoints centralisées */
:root {
  --breakpoint-xs: 480px;
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
  --breakpoint-xxl: 1400px;
  /* Espacements responsive */
  --padding-xs: 10px;
  --padding-sm: 15px;
  --padding-md: 20px;
  --padding-lg: 25px;
  --padding-xl: 30px;
  /* Tailles de police responsive */
  --font-xs: 0.75rem;
  --font-sm: 0.875rem;
  --font-md: 1rem;
  --font-lg: 1.125rem;
  --font-xl: 1.25rem;
}

/* ==========================================================================
   NAVBAR RESPONSIVE
   ========================================================================== */
/* Desktop et tablettes en paysage */
@media (max-width: var(--breakpoint-xl)) {
  .main-navbar {
    padding: 0 var(--padding-md);
  }
  .navbar-menu {
    gap: 6px;
  }
  .nav-item {
    padding: 10px 14px;
    font-size: 0.85rem;
  }
  .dropdown-menu {
    min-width: 260px;
  }
}
/* Tablettes */
@media (max-width: var(--breakpoint-lg)) {
  .main-navbar {
    padding: 0 var(--padding-md);
    height: auto;
    min-height: 72px;
  }
  .navbar-menu {
    gap: 4px;
  }
  .nav-item {
    padding: 8px 12px;
    font-size: var(--font-sm);
  }
  .dropdown-menu {
    min-width: 240px;
    padding: 6px;
  }
  .dropdown-item {
    padding: 10px 14px;
    font-size: var(--font-sm);
  }
  .brand-name {
    font-size: 1.25rem;
  }
  .brand-subtitle {
    font-size: 0.7rem;
  }
}
/* Tablettes verticales et mobiles large */
@media (max-width: var(--breakpoint-md)) {
  .main-navbar {
    padding: var(--padding-sm);
    flex-wrap: wrap;
    height: auto;
  }
  .navbar-brand {
    order: 1;
    flex: 1;
  }
  .navbar-actions {
    order: 2;
    flex-shrink: 0;
  }
  .navbar-menu {
    order: 3;
    width: 100%;
    justify-content: space-around;
    padding: 15px 0 10px;
    border-top: 1px solid var(--border);
    margin-top: 10px;
    gap: 0;
  }
  .nav-item {
    flex: 1;
    text-align: center;
    padding: 8px 4px;
    font-size: 0.7rem;
  }
  .nav-item span {
    display: none;
  }
  .nav-item i {
    font-size: 1.2rem;
  }
  .dropdown-menu {
    position: fixed;
    top: auto;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    width: 90vw;
    max-width: 300px;
    z-index: 9999;
  }
  .user-name {
    display: none;
  }
  .login-button span {
    display: none;
  }
}
/* Mobiles */
@media (max-width: var(--breakpoint-sm)) {
  .main-navbar {
    padding: var(--padding-xs);
  }
  .brand-logo {
    width: 32px;
    height: 32px;
  }
  .brand-name {
    font-size: 1rem;
  }
  .nav-item {
    padding: 6px 2px;
    font-size: 0.65rem;
  }
  .nav-item i {
    font-size: 1rem;
  }
}
/* ==========================================================================
   LAYOUT RESPONSIVE
   ========================================================================== */
/* Ajustements grille */
@media (max-width: var(--breakpoint-lg)) {
  .kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: var(--breakpoint-sm)) {
  .kpi-grid {
    grid-template-columns: 1fr;
  }
  .filter-group {
    width: 100%;
  }
  .filter-item {
    width: 100%;
  }
}
/* Ajustements graphiques */
@media (max-width: var(--breakpoint-md)) {
  .chart-container {
    height: 300px;
  }
  .chart-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
}
/* Ajustements tableau */
@media (max-width: var(--breakpoint-md)) {
  .table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  th,
  td {
    white-space: nowrap;
  }
}
/* ==========================================================================
   TOUCH DEVICES OPTIMIZATION
   ========================================================================== */
@media (hover: none) and (pointer: coarse) {
  .btn,
  .nav-item,
  .dropdown-item,
  input,
  select {
    min-height: 44px;
    /* Taille minimale recommandée par Apple */
  }
  /* Désactiver les hovers sur touch devices */
  .card:hover {
    transform: none;
  }
}
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Mixins SCSS - CantalDestination
 * Fonctions réutilisables pour éviter la duplication
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * COMPONENT: Main Navbar
 * Professional responsive refactor using fluid design.
 */
.main-navbar {
  background: var(--bg-surface-glass);
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  border-bottom: 1px solid var(--border-subtle);
  padding: 0 clamp(1rem, 3vw, 2.5rem);
  height: clamp(60px, 8vh, 72px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  box-shadow: var(--shadow-light);
  transition: all var(--transition-base, 0.25s);
}
@media (max-width: 768px) {
  .main-navbar {
    height: auto;
    min-height: 60px;
    flex-wrap: wrap;
    padding: 0.75rem 1rem;
  }
}

/* Brand section */
.navbar-brand {
  flex-shrink: 0;
}
.navbar-brand .brand-link {
  display: flex;
  align-items: center;
  text-decoration: none;
  transition: var(--transition-fast, 0.15s);
}
.navbar-brand .brand-link:hover {
  opacity: 0.8;
}
.navbar-brand .brand-logo img {
  height: clamp(28px, 4.5vh, 40px);
  width: auto;
  display: block;
}

/* Menu navigation */
.navbar-menu {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
  justify-content: center;
}
@media (max-width: 768px) {
  .navbar-menu {
    order: 3;
    width: 100%;
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--border);
    justify-content: space-around;
    gap: 0;
  }
}

.nav-item {
  display: flex;
  align-items: center;
  text-decoration: none;
  color: var(--text-primary);
  padding: 0.75rem 1rem;
  border-radius: var(--radius-md);
  font-weight: 500;
  font-size: clamp(0.75rem, 1.2vw, 0.9rem);
  transition: var(--transition-base, 0.25s);
  position: relative;
  gap: 0.5rem;
}
.nav-item:hover {
  background: rgba(var(--primary-rgb), 0.05);
  color: var(--primary);
}
.nav-item.active {
  color: var(--brand-vert-sapin);
  background: rgba(var(--secondary-rgb), 0.1);
}
.nav-item.active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 1rem;
  right: 1rem;
  height: 3px;
  background: var(--brand-ocre);
  border-radius: 4px 4px 0 0;
  box-shadow: 0 0 10px rgba(var(--secondary-rgb), 0.3);
}
.nav-item.active i {
  color: var(--brand-vert-sapin);
  opacity: 1;
}
.nav-item i {
  font-size: clamp(1rem, 1.5vw, 1.2rem);
  opacity: 0.8;
}
@media (max-width: 768px) {
  .nav-item span {
    display: none;
  }
}
.nav-item[href*="/admin"] {
  background: rgba(var(--accent-magenta-rgb), 0.08);
  border: 1px solid rgba(var(--accent-magenta-rgb), 0.2);
}
.nav-item[href*="/admin"]:hover {
  background: rgba(var(--accent-magenta-rgb), 0.15);
  color: var(--accent-magenta);
}
@media (max-width: 576px) {
  .nav-item {
    flex: 1;
    justify-content: center;
    padding: 0.5rem 0.25rem;
  }
}

/* Actions & User section */
.navbar-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.navbar-actions .user-badge {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0.75rem;
  background: var(--bg-surface-alt);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  transition: var(--transition-base, 0.25s);
  color: var(--text-primary);
}
@media (max-width: 576px) {
  .navbar-actions .user-badge {
    padding: 4px;
    border: none;
    background: transparent;
  }
}
.navbar-actions .user-badge .user-avatar {
  width: 32px;
  height: 32px;
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  font-weight: 700;
  font-size: 0.85rem;
}
.navbar-actions .user-badge .user-name {
  font-weight: 500;
  font-size: 0.9rem;
}
@media (max-width: 576px) {
  .navbar-actions .user-badge .user-name {
    display: none;
  }
}
.navbar-actions .login-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  font-weight: 600;
  text-decoration: none;
  transition: all 250ms "ease";
  cursor: pointer;
  border: none;
}
.navbar-actions .login-button:hover {
  transform: translateY(-2px);
  box-shadow: "0 0 25px rgba(var(--primary-rgb), 0.15)";
}
.navbar-actions .login-button:active {
  transform: translateY(0);
}
.navbar-actions .login-button {
  background: var(--secondary);
  padding: 0.6rem 1.25rem;
  font-size: 0.9rem;
  color: var(--white);
}
@media (max-width: 576px) {
  .navbar-actions .login-button {
    padding: 8px;
  }
  .navbar-actions .login-button span {
    display: none;
  }
}
.navbar-actions .logout-item {
  color: var(--text-muted);
  font-size: 1.2rem;
  transition: var(--transition-fast, 0.15s);
}
.navbar-actions .logout-item:hover {
  color: var(--error);
}
.navbar-actions .logout-item span {
  font-size: 0.9rem;
  margin-left: 0.5rem;
}
@media (max-width: 576px) {
  .navbar-actions .logout-item span {
    display: none;
  }
}

/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * COMPONENT: Buttons
 * Extracted from style.css
 */
.btn {
  font-family: var(--body-font);
  padding: 12px 20px;
  border: none;
  background: var(--bg-surface-glass);
  backdrop-filter: blur(10px);
  border-radius: var(--radius-md);
  cursor: pointer;
  font-weight: 600;
  transition: var(--transition-base, 0.25s);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  margin-right: 10px;
  border: 1px solid var(--border);
  box-shadow: 0 2px 10px rgba(var(--black-rgb), 0.05);
  position: relative;
  overflow: hidden;
  letter-spacing: 0.03em;
  font-size: 1rem;
}
.btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(45deg, transparent, rgba(var(--white-rgb), 0.1), transparent);
  transform: translateX(-100%);
  transition: transform 0.5s ease;
}
.btn:hover {
  background: var(--bg-surface);
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(var(--black-rgb), 0.2);
}
.btn:hover::before {
  transform: translateX(100%);
}
.btn:active {
  transform: translateY(-1px);
  box-shadow: 0 5px 10px rgba(var(--black-rgb), 0.2);
}
.btn i {
  margin-right: 8px;
  font-size: 1.1rem;
}
.btn--secondary {
  background: var(--secondary);
  color: var(--white);
}
.btn--secondary:hover {
  background: var(--secondary);
  filter: brightness(1.1);
}
.btn--small {
  padding: 6px 12px;
  font-size: 0.85rem;
  margin-top: 12px;
  border-radius: var(--radius-sm);
}
.btn--small:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(var(--black-rgb), 0.2);
}
.btn--filter {
  background: var(--primary);
  color: var(--bg-app);
  border-radius: var(--radius-md);
  font-weight: 700;
  box-shadow: 0 2px 8px rgba(var(--primary-rgb), 0.1);
  padding: 12px 20px;
}
.btn--filter:hover, .btn--filter:focus {
  background: var(--secondary);
  color: var(--white);
}
.btn--filter-secondary {
  background: var(--bg-surface-alt);
  color: var(--text-primary);
  border: 1.5px solid var(--primary-light);
  font-weight: 600;
}
.btn--filter-secondary:hover, .btn--filter-secondary:focus {
  background: var(--primary-light);
  color: var(--bg-app);
}

/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Mixins SCSS - CantalDestination
 * Fonctions réutilisables pour éviter la duplication
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * COMPONENT: Tables
 * Professional responsive overhaul with horizontal scroll & sticky column support.
 */
/* Wrapper pour le scroll horizontal (à appliquer sur un div parent) */
.table-responsive {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: var(--gap-lg, 1.5rem);
  border-radius: var(--radius-lg, 0.75rem);
  background: var(--bg-surface-glass);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(var(--white-rgb), 0.4);
  box-shadow: var(--shadow-glass);
  box-shadow: var(--shadow-light);
}
@media (max-width: 768px) {
  .table-responsive {
    margin-left: calc(-1 * clamp(0.5rem, 2vw, 1rem));
    margin-right: calc(-1 * clamp(0.5rem, 2vw, 1rem));
    width: calc(100% + 2 * clamp(0.5rem, 2vw, 1rem));
    border-radius: 0;
  }
}

.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: 1rem 0;
  background: transparent;
  color: var(--text-primary);
  font-size: clamp(0.75rem, 1.2vw, 0.9rem);
}
@media (max-width: 768px) {
  .table {
    min-width: 600px;
  }
}
.table thead {
  background: rgba(var(--white-rgb), 0.08);
}
.table thead th {
  text-align: left;
  padding: clamp(0.75rem, 2vw, 1.25rem);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.85em;
  letter-spacing: 0.05em;
  color: var(--text-primary);
  border-bottom: 2px solid rgba(var(--primary-rgb), 0.2);
  white-space: nowrap;
}
@media (max-width: 768px) {
  .table thead th {
    position: sticky;
    top: 0;
    background: var(--bg-card);
    z-index: 10;
  }
}
.table tbody tr {
  transition: background var(--transition-fast, 0.2s);
}
.table tbody tr:nth-child(even) {
  background-color: rgba(var(--primary-rgb), 0.02);
}
.table tbody tr:hover {
  background-color: rgba(var(--primary-rgb), 0.08);
}
.table tbody tr:last-child td {
  border-bottom: none;
}
.table tbody td {
  padding: clamp(0.75rem, 1.5vw, 1rem);
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  transition: color var(--transition-base, 0.25s);
}
@media (max-width: 768px) {
  .table th:first-child,
  .table td:first-child {
    /* --- STICKY COLUMNS (Mobile) --- */
    position: sticky;
    left: 0;
    z-index: 5;
    background: inherit;
    border-right: 1px solid rgba(var(--primary-rgb), 0.2);
    box-shadow: 2px 0 5px rgba(var(--black-rgb), 0.1);
  }
  .table th:first-child {
    z-index: 11;
    background: var(--bg-card);
  }
  .table tr:nth-child(even) td:first-child {
    background-color: var(--bg-card);
  }
}
.table--indicators .value-cell {
  font-family: var(--body-font);
  font-weight: 700;
  color: var(--primary);
}
.table--sub {
  margin-top: 1rem;
  font-size: 0.9em;
}
.table--sub thead {
  background: linear-gradient(to right, rgba(var(--secondary-rgb), 0.2), rgba(var(--primary-rgb), 0.1));
}

.table-note {
  padding: 1rem;
  font-style: italic;
  color: var(--text-muted);
  font-size: var(--text-xs);
  border-top: 1px dashed var(--border);
  opacity: 0.8;
}

.table-subtitle {
  margin: var(--gap-xl, 2rem) 0 var(--gap-md, 1rem);
  font-weight: 700;
  color: var(--primary);
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  padding-left: 0.75rem;
  border-left: 4px solid var(--secondary);
  font-family: var(--body-font);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Mixins SCSS - CantalDestination
 * Fonctions réutilisables pour éviter la duplication
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * COMPONENT: Sidebar
 * Professional responsive overhaul with fluid design and adaptive stacking.
 */
.sidebar {
  background: var(--bg-surface-glass);
  backdrop-filter: blur(20px);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  color: var(--text-primary);
  padding: clamp(1rem, 3vw, 1.5rem);
  min-height: calc(100vh - 100px);
  position: relative;
  overflow: hidden;
  z-index: 1;
  transition: all var(--transition-slow, 0.35s);
  border: 1px solid rgba(var(--white-rgb), 0.6);
}
@media (max-width: 992px) {
  .sidebar {
    width: 100%;
    min-height: auto;
    margin-bottom: var(--gap-lg, 1.5rem);
  }
}
.sidebar::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("../images/mountain.svg"), radial-gradient(circle at 120% 50%, rgba(var(--white-rgb), 0.05) 0%, transparent 60%);
  background-repeat: no-repeat, no-repeat;
  background-position: bottom right, top left;
  background-size: 200px, 300px;
  opacity: 0.2;
  z-index: -1;
  pointer-events: none;
}

.sidebar-header {
  position: relative;
  z-index: 1;
  margin-bottom: clamp(1.5rem, 4vh, 2rem);
  padding-bottom: 1.25rem;
  border-bottom: 1px solid rgba(var(--white-rgb), 0.1);
  text-align: center;
}
.sidebar-header h2 {
  font-family: var(--body-font);
  font-size: clamp(1.4rem, 3vw, 1.8rem);
  font-weight: 700;
  margin-bottom: var(--gap-xs, 0.5rem);
  background: linear-gradient(to right, var(--white), var(--text-secondary));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: var(--letter-spacing-title, 2px);
}

.logo-container {
  position: relative;
  z-index: 5;
  height: clamp(80px, 12vh, 120px);
  width: clamp(80px, 12vh, 120px);
  margin: 0 auto 1rem;
  background: rgba(var(--white-rgb), 0.95);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 25px rgba(var(--black-rgb), 0.2);
  overflow: hidden;
  padding: 10px;
}
.logo-container::before {
  content: "";
  position: absolute;
  top: -10px;
  left: -10px;
  right: -10px;
  bottom: -10px;
  background: linear-gradient(45deg, transparent 40%, rgba(var(--white-rgb), 0.4) 45%, rgba(var(--white-rgb), 0.6) 50%, rgba(var(--white-rgb), 0.4) 55%, transparent 60%);
  z-index: 2;
  animation: shine 3s infinite;
}

.logo {
  max-height: 100%;
  max-width: 100%;
  object-fit: contain;
  filter: drop-shadow(0 2px 5px rgba(var(--black-rgb), 0.2));
}

.tagline {
  color: var(--text-muted);
  font-size: var(--text-sm);
  margin-top: 0.5rem;
  font-weight: 500;
}

#fiches-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
@media (max-width: 992px) {
  #fiches-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
  }
}
@media (max-width: 576px) {
  #fiches-list {
    grid-template-columns: 1fr;
  }
}
#fiches-list li {
  padding: 0.75rem 1rem;
  background: rgba(var(--white-rgb), 0.03);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  transition: var(--transition-base, 0.25s);
  cursor: pointer;
}
#fiches-list li:hover {
  background: rgba(var(--primary-rgb), 0.1);
  border-color: rgba(var(--primary-rgb), 0.2);
  color: var(--primary);
  transform: translateX(5px);
}
@media (max-width: 992px) {
  #fiches-list li {
    text-align: center;
  }
  #fiches-list li:hover {
    transform: translateY(-3px);
  }
}

.geometric-shape {
  position: absolute;
  z-index: 0;
  opacity: 0.05;
  transition: all 0.8s ease;
}
@media (max-width: 992px) {
  .geometric-shape {
    display: none;
  }
}

.shape-1 {
  width: 80px;
  height: 80px;
  background: var(--secondary);
  top: 15%;
  left: -20px;
  transform: rotate(45deg);
}

.shape-2 {
  width: 60px;
  height: 60px;
  background: var(--primary);
  bottom: 20%;
  right: -15px;
  border-radius: 50%;
}

.content {
  padding: clamp(1rem, 4vw, 2rem);
  position: relative;
  z-index: 1;
}
.content::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 30% 20%, rgba(var(--info-rgb), 0.05) 0%, transparent 25%), radial-gradient(circle at 70% 80%, rgba(var(--warning-rgb), 0.05) 0%, transparent 25%);
  z-index: -1;
  pointer-events: none;
}

/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Mixins SCSS - CantalDestination
 * Fonctions réutilisables pour éviter la duplication
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * COMPONENT: Forms & Filters
 * Professional responsive overhaul with fluid design and touch optimization.
 */
/* Container du panneau de filtrage en glassmorphism */
.filter-container {
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 2vw, 1.5rem);
  padding: clamp(1rem, 4vw, 2.5rem);
  background: linear-gradient(120deg, var(--bg-surface-glass) 80%, var(--bg-surface-alt) 100%);
  background: var(--bg-surface-glass);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(var(--white-rgb), 0.4);
  box-shadow: var(--shadow-glass);
  border-color: var(--primary);
  border-radius: var(--radius-xl);
  position: relative;
  overflow: hidden;
  margin-bottom: var(--gap-lg, 20px);
}
.filter-container::before {
  content: "";
  position: absolute;
  top: -40px;
  right: -40px;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, var(--primary-light) 0%, transparent 80%);
  opacity: 0.15;
  z-index: 0;
}
@media (max-width: 768px) {
  .filter-container {
    padding: 1.25rem;
    border-radius: var(--radius-lg);
  }
}

.filter-row {
  display: flex;
  gap: clamp(1rem, 3vw, 2rem);
  flex-wrap: wrap;
  z-index: 1;
}
@media (max-width: 768px) {
  .filter-row {
    flex-direction: column;
    gap: 1.25rem;
  }
}

.filter-group {
  flex: 1 1 200px;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
@media (max-width: 768px) {
  .filter-group {
    width: 100%;
    min-width: unset;
  }
}
.filter-group label {
  color: var(--primary);
  font-weight: 700;
  font-size: clamp(0.9rem, 1.5vw, 1.05rem);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.filter-select {
  width: 100%;
  padding: clamp(0.75rem, 1.5vw, 0.85rem) 1.2rem;
  background: var(--bg-surface-alt);
  border: 1.5px solid rgba(var(--primary-rgb), 0.3);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: var(--text-base, 1rem);
  font-weight: 500;
  transition: all var(--transition-base, 0.25s);
  cursor: pointer;
}
.filter-select:hover {
  border-color: var(--primary);
}
.filter-select:focus {
  outline: none;
  border-color: var(--secondary);
  box-shadow: 0 0 0 4px rgba(var(--secondary-rgb), 0.15);
}
@media (max-width: 768px) {
  .filter-select {
    padding: 12px;
    font-size: var(--text-sm, 0.875rem);
  }
}

.filter-actions {
  display: flex;
  gap: 1rem;
  margin-top: 1rem;
  z-index: 1;
  flex-wrap: wrap;
}
@media (max-width: 576px) {
  .filter-actions {
    width: 100%;
  }
  .filter-actions button,
  .filter-actions .btn {
    flex: 1;
    width: 100%;
  }
}

/* Generic Form Styles */
.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}
.form-group label {
  font-weight: 600;
  color: var(--text-primary);
  font-size: var(--text-sm, 0.875rem);
}
.form-group input,
.form-group select,
.form-group textarea {
  padding: 0.75rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-card);
  color: var(--text-primary);
  font-size: var(--text-base, 1rem);
  transition: all var(--transition-base, 0.25s);
  font-family: inherit;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.2);
}
.form-group input::placeholder,
.form-group select::placeholder,
.form-group textarea::placeholder {
  color: var(--text-secondary);
  opacity: 0.5;
}
.form-group textarea {
  resize: vertical;
  min-height: 120px;
}
@media (max-width: 768px) {
  .form-group input,
  .form-group select,
  .form-group textarea {
    padding: 12px;
    font-size: var(--text-sm, 0.875rem);
  }
}

.form-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
}
@media (max-width: 576px) {
  .form-row {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

.form-actions {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}
@media (max-width: 576px) {
  .form-actions {
    flex-direction: column-reverse;
  }
  .form-actions button,
  .form-actions .btn {
    width: 100%;
  }
}

/* Advanced Period Picker – Dark theme aligned with comparison dashboard */
.pp-panel {
  /* Theme tokens mapping */
  --pp-bg: var(--bg-app);
  --pp-surface: var(--bg-card);
  --pp-text: var(--text-primary);
  --pp-muted: var(--text-secondary);
  --pp-stroke: var(--border);
  --pp-accent: var(--primary);
  --pp-danger: var(--error);
  --pp-radius: var(--radius-md, 0.75rem);
  --pp-shadow: 0 12px 40px rgba(var(--black-rgb), 0.35);
  position: absolute;
  min-width: 680px;
  padding: 14px;
  background: var(--pp-bg);
  color: var(--pp-text);
  border: 1px solid var(--pp-stroke);
  border-radius: var(--pp-radius);
  box-shadow: var(--pp-shadow);
  display: none;
  z-index: 9999;
  /* layout */
  display: none;
  flex-direction: row;
}

.pp-panel.floating {
  position: absolute;
}

.pp-panel.open {
  display: flex;
  animation: pp-fade-in 150ms ease-out;
  transform-origin: top left;
}

@keyframes pp-fade-in {
  0% {
    opacity: 0;
    transform: translateY(8px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
/* Backdrop overlay (portal) */
.pp-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(var(--black-rgb), 0.25);
  z-index: 9998;
}

.pp-backdrop[hidden] {
  display: none;
}

/* Open button */
.period-picker-input {
  background: var(--pp-surface);
  color: var(--pp-text);
  border: 1px solid var(--pp-stroke);
  padding: 0.5rem 0.8rem;
  border-radius: 0.6rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  transition: background-color 120ms ease, border-color 120ms ease, box-shadow 120ms ease;
}

.period-picker-input:hover {
  background-color: rgba(var(--white-rgb), 0.05);
  border-color: var(--primary);
}

.period-picker-input:focus-visible {
  outline: 2px solid var(--pp-accent);
  outline-offset: -2px;
}

/* Close button */
.pp-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid rgba(var(--white-rgb), 0.2);
  background: rgba(var(--white-rgb), 0.1);
  color: var(--pp-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: bold;
  z-index: 1000;
  transition: all 0.2s ease;
  user-select: none;
}

.pp-close:hover {
  color: var(--primary);
  background: rgba(var(--black-rgb), 0.05);
  border-color: rgba(var(--black-rgb), 0.1);
  transform: scale(1.1);
}

.pp-close:active {
  background: rgba(var(--white-rgb), 0.3);
  transform: scale(0.95);
}

.pp-close:focus-visible {
  outline: 2px solid var(--pp-accent);
  outline-offset: 2px;
}

/* Columns */
.pp-left {
  width: 240px;
  padding: 10px;
  border-right: 1px solid var(--pp-stroke);
  min-height: 300px;
}

.pp-right {
  flex: 1;
  padding: 10px;
  min-height: 300px;
}

.pp-title {
  font-weight: 600;
  color: var(--pp-text);
  font-size: 1rem;
  margin: 4px 0 8px 0;
  position: relative;
  padding-bottom: 6px;
}

.pp-title::after {
  content: "";
  position: absolute;
  left: 0;
  right: auto;
  bottom: 0;
  width: 44px;
  height: 2px;
  background: var(--pp-accent);
  border-radius: 1px;
}

/* Presets list */
#pp-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 320px;
  overflow: auto;
}

#pp-list::-webkit-scrollbar {
  width: 8px;
}

#pp-list::-webkit-scrollbar-track {
  background: transparent;
}

#pp-list::-webkit-scrollbar-thumb {
  background: rgba(var(--black-rgb), 0.1);
  border-radius: 6px;
}

#pp-list::-webkit-scrollbar-thumb:hover {
  background: rgba(var(--black-rgb), 0.2);
}

#pp-list .item {
  width: 100%;
  padding: 0.55rem 0.65rem;
  border-radius: 0.5rem;
  background: var(--pp-surface);
  border: 1px solid var(--pp-stroke);
  color: var(--pp-text);
  cursor: pointer;
  user-select: none;
  transition: background-color 120ms ease, border-color 120ms ease, box-shadow 120ms ease;
  position: relative;
}

#pp-list .item:hover {
  background: rgba(var(--white-rgb), 0.04);
}

#pp-list .item:active {
  background: rgba(var(--white-rgb), 0.06);
}

#pp-list .item.active {
  background: rgba(var(--primary-rgb), 0.12);
  border-color: var(--pp-accent);
}

#pp-list .item.active::before {
  content: "";
  position: absolute;
  left: -1px;
  top: -1px;
  bottom: -1px;
  width: 3px;
  background: var(--pp-accent);
  border-top-left-radius: 0.5rem;
  border-bottom-left-radius: 0.5rem;
}

/* Controls row */
.pp-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.pp-muted {
  color: var(--pp-muted);
  font-size: 0.85rem;
}

.pp-controls select {
  background: var(--pp-surface);
  color: var(--pp-text);
  border: 1px solid var(--pp-stroke);
  border-radius: 0.45rem;
  padding: 0.35rem 0.6rem;
}

.pp-nav {
  margin-left: auto;
  display: flex;
  gap: 4px;
}

.pp-btn {
  width: 32px;
  height: 32px;
  background: var(--pp-surface);
  color: var(--pp-text);
  border: 1px solid var(--pp-stroke);
  border-radius: 0.45rem;
  cursor: pointer;
}

.pp-btn:hover {
  background: rgba(var(--white-rgb), 0.06);
}

.pp-btn:active {
  background: rgba(var(--white-rgb), 0.1);
}

.pp-btn:focus-visible {
  outline: 2px solid var(--pp-accent);
  outline-offset: 2px;
}

/* Calendar grid */
.pp-cal {
  width: 100%;
  border-collapse: separate;
  border-spacing: 6px;
}

.pp-cal thead th {
  text-transform: uppercase;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--pp-muted);
  font-weight: 600;
}

.pp-cal tbody td {
  width: 42px;
  height: 42px;
  text-align: center;
  border-radius: 0.6rem;
  user-select: none;
  color: var(--pp-text);
  cursor: pointer;
  transition: background-color 120ms ease;
}

.pp-cal tbody td.empty {
  background: transparent;
  cursor: default;
  pointer-events: none;
  border: none;
}

.pp-cal tbody td.today {
  outline: 2px solid var(--pp-accent);
  outline-offset: -2px;
  color: var(--white);
}

/* Selection states */
.pp-cal tbody td.selected-start,
.pp-cal tbody td.pp-start {
  background: var(--pp-accent);
  color: var(--bg-app);
  font-weight: 700;
}

.pp-cal tbody td.selected-end,
.pp-cal tbody td.pp-end {
  background: var(--pp-accent);
  color: var(--bg-app);
  font-weight: 700;
}

.pp-cal tbody td.in-range,
.pp-cal tbody td.pp-inrange {
  background: rgba(var(--primary-rgb), 0.18);
  color: var(--pp-text);
}

.pp-cal tbody td:not(.empty):hover {
  background: rgba(var(--white-rgb), 0.06);
}

/* Footer */
.pp-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
}

#pp-hint {
  color: var(--pp-muted);
}

/* Today button like nav buttons but auto width */
#pp-today.pp-btn,
.pp-footer .pp-btn {
  height: auto;
  min-width: auto;
  width: auto;
  padding: 0.4rem 0.7rem;
  white-space: nowrap;
  text-align: center;
  box-sizing: border-box;
}

/* Specific styling for Today button to ensure proper sizing */
#pp-today {
  min-width: 100px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Wrapper alignment */
.period-picker-wrap {
  position: relative;
}

/* Responsive */
@media (max-width: 768px) {
  .pp-panel {
    min-width: 320px;
    max-width: 90vw;
    width: auto !important;
  }
  .pp-panel .pp-left,
  .pp-panel .pp-right {
    flex: 1;
    min-width: 0;
  }
  .pp-controls {
    flex-wrap: wrap;
    gap: 8px;
  }
  .pp-controls select {
    font-size: 14px;
    padding: 0.3rem 0.5rem;
  }
}
/* Positionnement intelligent */
.pp-panel.floating {
  position: fixed !important;
  z-index: 9999;
  box-shadow: 0 8px 32px rgba(var(--black-rgb), 0.3);
  border: 1px solid rgba(var(--primary-rgb), 0.2);
}

/* S'assurer que le panneau et ses éléments sont bien positionnés */
.pp-panel {
  position: relative;
  overflow: visible;
}

/* S'assurer que le bouton de fermeture est toujours cliquable */
.pp-panel .pp-close {
  position: absolute !important;
  z-index: 10000 !important;
  pointer-events: auto !important;
}

/* Assurer que le panneau reste dans les limites de la fenêtre */
.pp-panel {
  max-height: 90vh;
  overflow-y: auto;
  overflow-x: hidden;
}

/* Amélioration de la scrollbar pour le panneau */
.pp-panel::-webkit-scrollbar {
  width: 6px;
}

.pp-panel::-webkit-scrollbar-track {
  background: rgba(var(--white-rgb), 0.05);
  border-radius: 3px;
}

.pp-panel::-webkit-scrollbar-thumb {
  background: rgba(var(--primary-rgb), 0.3);
  border-radius: 3px;
}

.pp-panel::-webkit-scrollbar-thumb:hover {
  background: rgba(var(--primary-rgb), 0.5);
}

:root {
  --ht-red: var(--text-contrast);
  --ht-text-dark: var(--light-800);
  --ht-muted: var(--light-700);
  --ht-height-desktop: 180px;
  --ht-side-gap: 28px;
  --ht-col-gap: 24px;
  --ht-row-gap: 10px;
}

.header-tourisme {
  background: var(--white);
  color: var(--ht-text-dark);
  margin: calc(-1 * var(--gap-xl, 2rem)) calc(-1 * var(--gap-xl, 2rem)) var(--gap-2xl, 3rem) calc(-1 * var(--gap-xl, 2rem));
  padding: 0 var(--ht-side-gap);
  min-height: var(--ht-height-desktop);
  height: auto;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  grid-template-rows: auto auto;
  grid-template-areas: "left-top center right-top" "left-bottom center right-bottom";
  align-items: center;
  column-gap: var(--ht-col-gap);
  row-gap: var(--ht-row-gap);
  border-bottom: 3px solid var(--ht-red);
  border-radius: 12px 12px 0 0;
}

.ht-left-top {
  grid-area: left-top;
  justify-self: start;
}

.ht-left-bottom {
  grid-area: left-bottom;
  justify-self: start;
}

.ht-right-top {
  grid-area: right-top;
  justify-self: end;
}

.ht-right-bottom {
  grid-area: right-bottom;
  display: flex;
  align-items: center;
  justify-content: center;
  justify-self: end;
}

.ht-left-top img,
.ht-right-top img {
  height: 56px;
  max-width: 260px;
  object-fit: contain;
  display: block;
  background: transparent;
}

.ht-left-bottom img,
.ht-right-bottom img {
  height: 20px;
  max-width: 160px;
  object-fit: contain;
  display: block;
  background: transparent;
}

.ht-right-bottom .ht-eu-logo {
  height: 70px;
  max-height: 70px;
  object-fit: cover;
  object-position: center center;
}

.ht-center {
  grid-area: center;
  text-align: center;
  white-space: nowrap;
}

.ht-center .ht-title-line {
  font-family: var(--body-font);
  font-weight: 700;
  text-transform: uppercase;
  color: var(--ht-red);
  line-height: 1.05;
  margin: 0;
}

.ht-center .ht-title-line.line1 {
  font-size: 26px;
  margin-bottom: 6px;
}

.ht-center .ht-title-line.line2 {
  font-size: 24px;
  margin-bottom: 4px;
}

.ht-center .ht-title-line.line3 {
  font-size: 24px;
}

@media (max-width: 768px) {
  :root {
    --ht-height-desktop: auto;
  }
  .header-tourisme {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
    grid-template-areas: "left-top" "center" "right-top" "right-bottom";
    height: auto;
    padding-top: var(--gap-sm, 14px);
    padding-bottom: var(--gap-md, 16px);
    row-gap: var(--gap-xs, 10px);
  }
  .ht-left-top img {
    height: 48px;
  }
  .ht-center .ht-title-line.line1 {
    font-size: 22px;
  }
  .ht-center .ht-title-line.line2,
  .ht-center .ht-title-line.line3 {
    font-size: 20px;
  }
  .ht-right-top img {
    height: 48px;
  }
  .ht-left-bottom img,
  .ht-right-bottom img {
    height: 27px;
  }
}
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/* ==========================================================================
   COMPOSANT: DASHBOARD UI ELEMENTS
   Éléments d'interface utilisateur partagés (Tooltips, Loaders, Cards, Animations)
   ========================================================================== */
/* --- Carte de Comparaison (Comparison Card) --- */
.comparison-card {
  background: var(--bg-card);
  border-radius: var(--radius-md);
  padding: var(--gap-xl, 1.25rem);
  border: 1px solid var(--border-subtle);
  margin-bottom: var(--gap-2xl, 2rem);
  box-shadow: var(--shadow-card);
}

.comparison-title {
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--text-muted);
  margin-bottom: var(--gap-xl, 1.25rem);
  text-align: center;
}
.comparison-title i {
  color: var(--primary);
  margin-right: 8px;
}

.comparison-content {
  display: flex;
  justify-content: space-around;
  align-items: center;
  gap: var(--gap-lg, 1rem);
}
@media (max-width: 768px) {
  .comparison-content {
    flex-direction: column;
    gap: var(--gap-xl, 1.25rem);
  }
}

.comparison-item {
  text-align: center;
  flex: 1;
}

.comparison-label {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin-bottom: var(--gap-xs, 0.5rem);
}

.comparison-value {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 2px;
  line-height: 1.1;
}
@media (max-width: 768px) {
  .comparison-value {
    font-size: 1.8rem;
  }
}

.comparison-unit {
  font-size: 0.8rem;
  color: var(--text-muted);
}

.comparison-divider {
  width: 1px;
  height: var(--gap-2xl, 3.75rem);
  background: var(--border-subtle);
  align-self: center;
}
@media (max-width: 768px) {
  .comparison-divider {
    width: 80%;
    height: 1px;
  }
}

/* --- Infobulles (Tooltips) --- */
[data-tooltip] {
  position: relative;
  cursor: help;
}
[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-8px) scale(0.8);
  background-color: var(--bg-card);
  color: var(--text-primary);
  padding: var(--gap-xs, 0.5rem) var(--gap-md, 0.75rem);
  border-radius: var(--radius-sm, 4px);
  font-size: 0.85rem;
  line-height: 1.4;
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base), transform var(--transition-base);
  z-index: 1010;
  pointer-events: none;
  box-shadow: 0 4px 10px rgba(var(--black-rgb), 0.4);
  border: 1px solid var(--border-subtle);
  transform-origin: bottom center;
}
[data-tooltip]::before {
  content: "";
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(0px) scale(0.8);
  border-width: 6px;
  border-style: solid;
  border-color: var(--bg-card) transparent transparent transparent;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base), transform var(--transition-base);
  z-index: 1011;
  pointer-events: none;
  transform-origin: bottom center;
}
[data-tooltip]:hover::after, [data-tooltip]:hover::before {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0) scale(1);
}

[data-tooltip-wide]::after {
  white-space: normal;
  width: 250px;
  text-align: left;
}

/* --- Loader Dashboard --- */
.dashboard-loader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(var(--bg-app-rgb), 0.7);
  backdrop-filter: blur(5px);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s ease;
  pointer-events: none;
}
.dashboard-loader.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.loader-content {
  text-align: center;
  color: var(--text-primary);
}

.loader-spinner {
  margin: 0 auto 15px;
  width: 40px;
  height: 40px;
  border: 3px solid transparent;
  border-top-color: var(--primary);
  border-right-color: var(--secondary);
  border-radius: 50%;
  animation: spinner-rotate 1s linear infinite;
}

.loader-text {
  font-size: 1rem;
  letter-spacing: 1px;
  animation: text-pulse 1.5s ease-in-out infinite;
}

/* --- Animations & Keyframes --- */
@keyframes gradient-flow {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -100% 0;
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fade-in-up {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes pulse-positive {
  0%, 100% {
    text-shadow: 0 0 3px rgba(var(--positive-rgb), 0.3);
  }
  50% {
    text-shadow: 0 0 10px rgba(var(--positive-rgb), 0.7);
  }
}
@keyframes pulse-negative {
  0%, 100% {
    text-shadow: 0 0 3px rgba(var(--negative-rgb), 0.3);
  }
  50% {
    text-shadow: 0 0 10px rgba(var(--negative-rgb), 0.7);
  }
}
@keyframes spinner-rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes text-pulse {
  0%, 100% {
    opacity: 0.7;
  }
  50% {
    opacity: 1;
  }
}
@keyframes highlight-glow {
  0%, 100% {
    text-shadow: 0 0 5px rgba(var(--primary-rgb), 0.3);
  }
  50% {
    text-shadow: 0 0 15px rgba(var(--primary-rgb), 0.7), 0 0 25px rgba(var(--primary-rgb), 0.5);
  }
}
.value-highlight {
  animation: highlight-glow 3s ease-in-out infinite;
  color: var(--primary) !important;
}

/* Utility classes */
.fade-in-up {
  animation: fade-in-up 0.6s ease-out forwards;
}

.hover-scale {
  transition: transform 0.3s ease;
}
.hover-scale:hover {
  transform: scale(1.02);
}

/* --- Mode Selector Toggle --- */
.mode-selector-section {
  padding: var(--gap-xl, 1.5rem) 0;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: var(--gap-2xl, 2rem);
}

.mode-toggle-container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--gap-lg, 1.5rem);
}
@media (max-width: 768px) {
  .mode-toggle-container {
    flex-direction: column;
    gap: var(--gap-md, 1rem);
  }
}

.mode-toggle {
  display: flex;
  background: var(--bg-card);
  border-radius: var(--radius-md, 12px);
  padding: var(--gap-2xs, 4px);
  border: 1px solid var(--border-subtle);
  position: relative;
}
@media (max-width: 768px) {
  .mode-toggle {
    flex-direction: column;
    width: 100%;
  }
}

.mode-toggle input[type=radio] {
  display: none;
}

.mode-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: var(--gap-md, 0.75rem) var(--gap-lg, 1rem);
  border-radius: var(--radius-sm, 8px);
  cursor: pointer;
  transition: all 0.3s ease;
  color: var(--text-muted);
  font-weight: 500;
  font-size: 0.95rem;
  position: relative;
  min-width: 160px;
  justify-content: center;
}
@media (max-width: 768px) {
  .mode-option {
    min-width: auto;
    width: 100%;
  }
}
.mode-option:hover {
  color: var(--text-primary);
  background: rgba(var(--white-rgb), 0.05);
}
.mode-option i {
  font-size: 1rem;
  opacity: 0.8;
}
.mode-option:has(.badge-soon) {
  opacity: 0.7;
  cursor: not-allowed;
}
.mode-option:has(.badge-soon):hover {
  background: rgba(var(--white-rgb), 0.02);
}

.mode-toggle input[type=radio]:checked + .mode-option {
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  color: var(--bg-app);
  font-weight: 600;
  box-shadow: 0 4px 12px rgba(var(--primary-rgb), 0.3);
}
.mode-toggle input[type=radio]:checked + .mode-option i {
  opacity: 1;
}

.badge-soon {
  background: var(--warning);
  color: var(--bg-app);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.7rem;
  font-weight: 700;
  margin-left: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* --- Section Comparaison --- */
.comparison-section {
  margin: var(--gap-2xl, 2rem) 0;
}

.comparison-results-section {
  margin: var(--gap-2xl, 2rem) 0;
  position: relative;
}
.comparison-results-section::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary), var(--secondary), var(--accent-magenta), var(--primary));
  border-radius: 2px;
  animation: gradient-flow 3s ease-in-out infinite;
}

.comparison-results {
  background: linear-gradient(135deg, rgba(var(--bg-app-rgb), 0.95) 0%, rgba(var(--bg-card-rgb), 0.95) 100%);
  border-radius: 16px;
  border: 1px solid rgba(var(--primary-rgb), 0.2);
  box-shadow: 0 8px 32px rgba(var(--black-rgb), 0.4), 0 0 40px rgba(var(--primary-rgb), 0.1), inset 0 1px 0 rgba(var(--white-rgb), 0.1);
  backdrop-filter: blur(20px);
  position: relative;
  overflow: hidden;
  margin-top: var(--gap-xl, 20px);
}
.comparison-results::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url('data:image/svg+xml,<svg width="60" height="60" viewBox="0 0 60 60" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><g fill="%23ffffff" fill-opacity="0.02"><circle cx="30" cy="30" r="1"/></g></g></svg>');
  pointer-events: none;
}
.comparison-results .fade-in-up {
  animation: fade-in-up 0.8s ease-out forwards;
  opacity: 0;
  transform: translateY(30px);
}

/* Loading state specifique pour la comparaison */
.comparison-results-section .loading {
  text-align: center;
  padding: var(--gap-4xl, 4rem) var(--gap-2xl, 2rem);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gap-lg, 1.5rem);
  background: var(--bg-card);
  border-radius: 16px;
  border: 1px solid var(--border-subtle);
  box-shadow: 0 8px 32px rgba(var(--black-rgb), 0.3);
  position: relative;
  overflow: hidden;
}
.comparison-results-section .loading::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(var(--primary-rgb), 0.1), transparent);
  animation: shimmer 2s ease-in-out infinite;
}

@keyframes shimmer {
  0% {
    left: -100%;
  }
  100% {
    left: 100%;
  }
}
/**
 * Composant: Indicateurs Compacts - Infographie
 * Cartes d'indicateurs avec historique multi-années
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

.indicators-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap-md, 1rem);
}

.indicator-card-compact {
  background: var(--bg-card);
  border-radius: var(--radius-md);
  padding: var(--gap-md, 1rem);
  border: 1px solid var(--border);
  text-align: center;
  transition: all var(--duration-base) var(--easing-out);
  cursor: pointer;
}
.indicator-card-compact:hover, .indicator-card-compact:focus-visible {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--primary);
}

.indicator-icon {
  font-size: 1.5rem;
  color: var(--primary);
  margin-bottom: var(--gap-xs, 0.5rem);
}

.indicator-title {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--gap-xs, 0.5rem);
  line-height: 1.2;
}

.indicator-unit {
  font-size: 0.7rem;
  color: var(--text-secondary);
  margin-bottom: var(--gap-xs, 0.5rem);
  text-align: center;
}

.indicator-history {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.indicator-year-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.2rem 0.4rem;
  border-radius: 0.1875rem;
  background: rgba(var(--white-rgb), 0.01);
  border: 1px solid rgba(var(--white-rgb), 0.05);
  opacity: 0.6;
  transition: all var(--transition-base);
}
.indicator-year-row.current-year {
  background: rgba(var(--primary-rgb), 0.15);
  border-color: var(--primary);
  padding: 0.4rem 0.6rem;
  border-radius: var(--radius-sm, 0.375rem);
  opacity: 1;
  box-shadow: 0 0.125rem 0.5rem rgba(var(--primary-rgb), 0.2);
  margin-bottom: 0.4rem;
}
.indicator-year-row.current-year .indicator-year {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--primary);
  opacity: 1;
}
.indicator-year-row.current-year .indicator-value {
  font-size: 1.3rem;
  font-weight: 700;
  opacity: 1;
  text-align: left;
  flex: 1;
  color: var(--primary);
}
.indicator-year-row.current-year .indicator-evolution {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.2rem 0.4rem;
  border-radius: 0.25rem;
  min-width: 3.4375rem;
  opacity: 1;
  margin-left: auto;
}
.indicator-year-row.reference-year {
  background: rgba(var(--info-rgb), 0.15);
  border-color: var(--info);
  padding: 0.4rem 0.6rem;
  border-radius: var(--radius-sm, 0.375rem);
  opacity: 1;
  box-shadow: 0 0.125rem 0.5rem rgba(var(--info-rgb), 0.2);
  margin-bottom: 0.4rem;
}
.indicator-year-row.reference-year .indicator-year {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--info);
  opacity: 1;
}
.indicator-year-row.reference-year .indicator-value {
  font-size: 1.3rem;
  font-weight: 700;
  opacity: 1;
  text-align: left;
  flex: 1;
  color: var(--info);
}
.indicator-year-row.reference-year .indicator-evolution {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.2rem 0.4rem;
  border-radius: 0.25rem;
  min-width: 3.4375rem;
  opacity: 1;
  margin-left: auto;
}

.indicator-year {
  font-size: 0.65rem;
  font-weight: 600;
  color: var(--text-secondary);
  min-width: 2.5rem;
  opacity: 1;
}

.indicator-value {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-contrast);
  flex: 1;
  text-align: center;
  opacity: 1;
}

.indicator-evolution {
  font-size: 0.65rem;
  font-weight: 600;
  padding: 0.15rem 0.4rem;
  border-radius: 0.1875rem;
  min-width: 2.8125rem;
  text-align: center;
  opacity: 1;
}
.indicator-evolution.positive {
  color: var(--primary);
  background: transparent;
  border: 2px solid var(--success);
  font-weight: 700;
  box-shadow: none;
}
.indicator-evolution.negative {
  color: var(--brand-red);
  background: transparent;
  border: 2px solid var(--brand-red);
  font-weight: 700;
  box-shadow: none;
}
.indicator-evolution.reference {
  color: var(--secondary);
  background: rgba(var(--secondary-rgb), 0.1);
  border: 1px solid rgba(var(--secondary-rgb), 0.3);
  font-weight: 600;
}
.indicator-evolution.neutral {
  color: var(--text-secondary);
  background: rgba(var(--white-rgb), 0.05);
}

/**
 * Composant: Grilles Graphiques Origines - Infographie
 * Grilles pour graphiques départements, régions, pays
 * 
 * IMPORTANT: Ce fichier reproduit EXACTEMENT le CSS original
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

.origins-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: var(--gap-lg, 1.5rem);
}
.origins-grid.layout-empty {
  display: none;
}
.origins-grid.layout-single {
  grid-template-columns: 1fr;
  grid-template-rows: auto;
}
.origins-grid.layout-double {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto;
}
@media (max-width: 480px) {
  .origins-grid.layout-double {
    grid-template-columns: 1fr !important;
  }
}
.origins-grid.layout-full {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
}
@media (max-width: 480px) {
  .origins-grid.layout-full {
    grid-template-columns: 1fr !important;
  }
}

.chart-departements {
  grid-column: 1/-1;
  grid-row: 1;
}

.chart-regions {
  grid-column: 1;
  grid-row: 2;
}

.chart-pays {
  grid-column: 2;
  grid-row: 2;
}

.chart-container {
  background: rgba(var(--white-rgb), 0.05);
  border-radius: var(--radius-lg);
  padding: var(--gap-md, 1rem);
  border: 1px solid var(--border);
  transition: all var(--duration-base) var(--easing-out);
  position: relative;
  min-height: var(--chart-h);
  max-height: var(--chart-h-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  cursor: pointer;
}
.chart-container:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.chart-container:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-color: var(--primary);
  box-shadow: 0 0 0 0.25rem rgba(var(--primary-rgb), 0.1);
}

.chart-unit-indicator {
  background: rgba(var(--primary-rgb), 0.1);
  border: 1px solid rgba(var(--primary-rgb), 0.3);
  border-radius: var(--radius-pill, 12px);
  padding: 2px 10px;
  font-size: 11px;
  color: var(--primary);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  white-space: nowrap;
}

.chart-regions,
.chart-pays {
  min-height: var(--chart-h);
  max-height: var(--chart-h-lg);
}

.chart-departements {
  min-height: var(--chart-h-lg);
  max-height: var(--chart-h-xl);
}
.chart-departements .chart-wrapper {
  min-height: calc(var(--chart-h-lg) - 100px);
  max-height: calc(var(--chart-h-xl) - 100px);
  padding-top: var(--gap-xs, 0.5rem);
}

.chart-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  text-align: center;
  margin-bottom: var(--gap-sm, 0.75rem);
  padding-bottom: var(--gap-sm, 0.75rem);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  width: 100%;
}
.chart-header h4,
.chart-header h5 {
  font-size: clamp(0.9rem, 1.8vw, 1.05rem);
  font-weight: 700;
  color: var(--text-contrast);
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chart-subtitle {
  font-size: clamp(0.7rem, 1.4vw, 0.8rem);
  font-weight: 500;
  color: var(--text-secondary);
  margin: 0;
  font-style: italic;
  opacity: 0.9;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chart-wrapper {
  position: relative;
  flex: 1;
  width: 100%;
  background: rgba(var(--white-rgb), 0.02);
  border-radius: var(--radius-md);
  padding: var(--gap-sm, 0.75rem);
  padding-top: var(--gap-md, 1rem);
  min-height: clamp(250px, var(--chart-h) - 110px, 350px);
  max-height: clamp(300px, var(--chart-h-lg) - 110px, 450px);
  overflow: visible;
}
.chart-wrapper canvas {
  width: 100% !important;
  height: auto !important;
  max-width: 100%;
  max-height: none;
}

.chart-regions .chart-wrapper,
.chart-pays .chart-wrapper {
  min-height: clamp(280px, var(--chart-h) - 100px, 380px);
  max-height: clamp(320px, var(--chart-h-lg) - 100px, 480px);
  padding-top: var(--gap-lg, 1.5rem);
}

.stay-subsection {
  margin-bottom: var(--gap-xl, 2rem);
}
.stay-subsection .chart-wrapper {
  padding-top: var(--gap-xl, 2rem);
}
.stay-subsection .stay-header {
  text-align: center;
  margin-bottom: var(--gap-lg, 1.5rem);
}
.stay-subsection .origins-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto;
  gap: var(--gap-lg, 1.5rem);
}

.chart-stay-distribution {
  grid-column: 1/-1;
  min-height: var(--chart-h-lg);
  max-height: var(--chart-h-xl);
}
.chart-stay-distribution .chart-wrapper {
  min-height: clamp(320px, var(--chart-h-lg) - 100px, 480px);
  max-height: clamp(380px, var(--chart-h-xl) - 100px, 540px);
}

.full-width {
  grid-column: 1/-1;
  width: 100%;
}

.chart-wrapper canvas {
  width: 100% !important;
  height: auto !important;
  max-width: 100%;
  max-height: none;
}

.charts-placeholder {
  text-align: center;
  opacity: 0.6;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.placeholder-text i {
  font-size: 3rem;
  color: var(--text-secondary);
  margin-bottom: var(--gap-md, 1rem);
  display: block;
}
.placeholder-text p {
  color: var(--text-secondary);
  font-size: 1.1rem;
  font-style: italic;
}

@media (max-width: 480px) {
  .chart-unit-indicator {
    position: static;
    top: auto;
    right: auto;
    margin-top: 0.5rem;
    margin-left: 0;
    align-self: flex-start;
    width: fit-content;
  }
  .chart-header {
    padding-right: 1rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  .chart-container {
    padding: 0.5rem;
  }
  .chart-wrapper {
    padding: 0;
    padding-top: 0.5rem;
  }
  .origins-grid,
  .origins-grid.layout-mobile,
  .origins-grid.layout-full,
  .origins-grid.layout-double {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    gap: 1rem;
  }
  .chart-departements,
  .chart-regions,
  .chart-pays {
    grid-column: 1/-1 !important;
    grid-row: auto !important;
  }
}
/**
 * Composant: Header Dataviz
 * En-tête principal de l'infographie avec animation
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

.dataviz-header {
  padding: var(--gap-2xl, 3rem) 0 var(--gap-2xl, 4rem);
  position: relative;
  text-align: center;
  background: linear-gradient(180deg, #ffffff 0%, #f4f7f6 100%);
  box-shadow: inset 0 -40px 40px -40px rgba(var(--primary-rgb), 0.1);
  overflow: hidden;
}
.dataviz-header h1 {
  font-family: var(--display-font, "Orbitron", sans-serif);
  font-size: clamp(2.5rem, 6vw, 3.8rem);
  color: var(--text-contrast);
  letter-spacing: var(--letter-spacing-title, 2px);
  text-shadow: none;
  margin-bottom: var(--gap-xs, 0.5rem);
}
.dataviz-header .subtitle {
  font-size: 1.1rem;
  color: var(--text-secondary);
  margin-bottom: var(--gap-xl, 1.25rem);
  letter-spacing: 1px;
}
.dataviz-header .subtitle span {
  color: var(--secondary);
}
.dataviz-header .period-info {
  display: inline-block;
  background: rgba(var(--black-rgb), 0.2);
  padding: 8px var(--gap-xl, 1.25rem);
  border-radius: var(--radius-pill, 20px);
  font-size: 0.9rem;
  color: var(--text-secondary);
  border: 1px solid var(--border-weak);
}
.dataviz-header .period-info i {
  color: var(--primary);
  margin-right: var(--gap-xs, 0.5rem);
}

.header-decoration {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--secondary), transparent);
  background-size: 100% 100%;
  animation: none;
  box-shadow: none;
  opacity: 0.5;
}

@keyframes gradient-flow {
  0% {
    background-position: 100% 0;
  }
  100% {
    background-position: -100% 0;
  }
}
/**
 * Composant: Footer Dataviz
 * Pied de page de l'infographie
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

.dataviz-footer {
  background: var(--bg-app);
  padding: var(--gap-xl, 2rem) 0;
  margin-top: var(--gap-3xl, 4rem);
  border-top: 1px solid var(--border-weak);
  text-align: center;
  position: relative;
}
.dataviz-footer::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 3px;
  background: var(--brand-ochre);
  border-radius: 0 0 4px 4px;
}
.dataviz-footer .footer-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
}
.dataviz-footer .source-info {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  font-weight: 600;
}
.dataviz-footer .source-info strong {
  color: var(--brand-basalte);
  margin-left: 4px;
}
.dataviz-footer .footer-partners {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3rem;
  padding: 0.5rem 2rem;
}
.dataviz-footer .footer-partners img {
  height: 28px;
  width: auto;
  object-fit: contain;
  opacity: 0.8;
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.dataviz-footer .footer-partners img:hover {
  opacity: 1;
  transform: translateY(-2px);
}

/**
 * Composant: Filtres Infographie
 * Styles pour la section de filtrage (année, période)
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

.filters-section {
  margin-bottom: 40px;
  position: relative;
  z-index: 10;
}

.filters-container {
  background: var(--bg-card);
  padding: 20px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  backdrop-filter: blur(10px);
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: center;
  justify-content: center;
}
@media (max-width: 768px) {
  .filters-container {
    flex-direction: column;
    align-items: stretch;
  }
}

.filter-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.filter-group label {
  color: var(--text-secondary);
  font-size: 0.9rem;
  font-weight: 500;
}

.filter-select {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-primary);
  padding: 8px 12px;
  font-size: 0.95rem;
  min-width: 200px;
  cursor: pointer;
  transition: var(--transition-base, 0.25s);
  position: relative;
  overflow: hidden;
}
.filter-select:hover {
  border-color: var(--primary);
  box-shadow: 0 0 10px rgba(var(--primary-rgb), 0.1);
  transform: translateY(-2px);
}
.filter-select:focus {
  outline: none;
  border-color: var(--secondary);
  box-shadow: 0 0 15px rgba(var(--secondary-rgb), 0.2);
  transform: translateY(-2px);
}
.filter-select option {
  background: var(--bg-card);
  color: var(--text-primary);
  padding: 8px;
}

/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Mixins SCSS - CantalDestination
 * Fonctions réutilisables pour éviter la duplication
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * COMPONENT: Tabs
 * Universal responsive tabs component with fluid design.
 */
.tabs-container {
  margin-bottom: var(--gap-xl, 30px);
}

.tabs-navigation,
.tabs-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(0.5rem, 2vw, 1rem);
  border-bottom: 1px solid var(--border);
  padding-bottom: 1rem;
  margin-bottom: clamp(1.5rem, 3vh, 2rem);
  flex-wrap: wrap;
  position: relative;
  z-index: 10;
}
@media (max-width: 768px) {
  .tabs-navigation,
  .tabs-nav {
    flex-direction: column;
    align-items: stretch;
    border-bottom: none;
    padding-bottom: 0;
  }
}

.tab-button,
.tab-btn {
  background: rgba(var(--white-rgb), 0.03);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  padding: clamp(0.75rem, 2vw, 1rem) clamp(1.25rem, 3vw, 2rem);
  font-size: var(--text-base, 1rem);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-base, 0.25s);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  position: relative;
  overflow: hidden;
  min-width: clamp(140px, 15vw, 180px);
  font-family: inherit;
}
.tab-button i,
.tab-btn i {
  font-size: 1.1em;
  opacity: 0.8;
}
.tab-button:hover,
.tab-btn:hover {
  background: rgba(var(--primary-rgb), 0.08);
  border-color: rgba(var(--primary-rgb), 0.3);
  color: var(--text-primary);
  transform: translateY(-2px);
}
.tab-button.active,
.tab-btn.active {
  background: linear-gradient(145deg, rgba(var(--primary-rgb), 0.15), rgba(var(--secondary-rgb), 0.1));
  color: var(--primary);
  border-color: var(--primary);
  box-shadow: 0 4px 15px rgba(var(--primary-rgb), 0.1);
}
.tab-button.active::after,
.tab-btn.active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 40%;
  height: 3px;
  background: var(--primary);
  border-radius: 3px 3px 0 0;
  box-shadow: 0 0 10px var(--primary);
}
@media (max-width: 768px) {
  .tab-button,
  .tab-btn {
    width: 100%;
    min-width: unset;
    text-align: center;
  }
  .tab-button.active::after,
  .tab-btn.active::after {
    left: 0;
    transform: none;
    bottom: 50%;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: 60%;
    border-radius: 0 3px 3px 0;
  }
}

.tab-content,
.tab-pane {
  animation: fadeIn 250ms "ease" ease-out;
}

/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Mixins SCSS - CantalDestination
 * Fonctions réutilisables pour éviter la duplication
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * COMPONENT: KPI Cards
 * Professional responsive overhaul with fluid typography and auto-adaptive grid.
 */
.key-figures-grid,
.key-indicators-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(minmax(clamp(250px, 30vw, 320px), 1fr), 1fr));
  gap: 1.5rem;
  gap: clamp(1rem, 2vw, 1.5rem);
  padding: 0;
  margin-bottom: var(--gap-xl, 2rem);
}
@media (max-width: 576px) {
  .key-figures-grid,
  .key-indicators-grid {
    grid-template-columns: 1fr;
  }
}

.key-figure-card,
.figure-card {
  background: var(--bg-card);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}
.key-figure-card::after,
.figure-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(var(--white-rgb), 0.8), transparent);
  z-index: 1;
}
.key-figure-card:hover,
.figure-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
}
.key-figure-card,
.figure-card {
  opacity: 0;
  animation: fadeInUp 0.6s ease-out forwards;
}
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.key-figure-card,
.figure-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: clamp(180px, 25vh, 220px);
  padding: clamp(1rem, 3vw, 1.5rem);
}
.key-figure-card:nth-child(1),
.figure-card:nth-child(1) {
  animation-delay: 0.05s;
}
.key-figure-card:nth-child(2),
.figure-card:nth-child(2) {
  animation-delay: 0.1s;
}
.key-figure-card:nth-child(3),
.figure-card:nth-child(3) {
  animation-delay: 0.15s;
}
.key-figure-card:nth-child(4),
.figure-card:nth-child(4) {
  animation-delay: 0.2s;
}
.key-figure-card:nth-child(5),
.figure-card:nth-child(5) {
  animation-delay: 0.25s;
}
.key-figure-card:nth-child(6),
.figure-card:nth-child(6) {
  animation-delay: 0.3s;
}
.key-figure-card:nth-child(7),
.figure-card:nth-child(7) {
  animation-delay: 0.35s;
}
.key-figure-card:nth-child(8),
.figure-card:nth-child(8) {
  animation-delay: 0.4s;
}
.key-figure-card:nth-child(9),
.figure-card:nth-child(9) {
  animation-delay: 0.45s;
}
.key-figure-card:nth-child(10),
.figure-card:nth-child(10) {
  animation-delay: 0.5s;
}

.key-figure-card .card-header,
.figure-card .card-header,
.key-figure-card .key-figure-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.key-figure-card .key-figure-icon,
.figure-card .icon {
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  color: var(--primary);
  flex-shrink: 0;
  transition: transform var(--transition-base), color var(--transition-base);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: rgba(var(--primary-rgb), 0.05);
  border-radius: var(--radius-md);
}

.key-figure-card:hover .key-figure-icon,
.figure-card:hover .icon {
  transform: rotate(-10deg) scale(1.1);
  color: var(--accent-magenta);
  background: rgba(var(--accent-magenta-rgb), 0.1);
}

.key-figure-card .indicator-title,
.figure-card .indicator-title,
.key-figure-card .key-figure-label {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.key-figure-card .key-figure-content,
.figure-card .card-body {
  margin-bottom: 0.75rem;
  flex-grow: 1;
}

.key-figure-card .key-figure-value,
.figure-card .value {
  font-family: var(--display-font, "Orbitron", sans-serif);
  font-size: clamp(2rem, 5vw, 2.8rem);
  font-weight: 700;
  color: var(--text-contrast);
  margin-bottom: 0.25rem;
  line-height: 1;
  transition: all var(--transition-base);
}

.key-figure-card:hover .key-figure-value,
.figure-card:hover .value {
  color: var(--primary);
  text-shadow: 0 0 15px rgba(var(--primary-rgb), 0.3);
}

.key-figure-card .key-figure-subtitle,
.figure-card .value-prev-year {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--gap-xs, 0.5rem);
  font-weight: 500;
  display: block;
}

.key-figure-card .unit,
.figure-card .unit {
  font-size: 0.4em;
  color: var(--text-muted);
  margin-left: 4px;
}

.key-figure-card .card-footer,
.figure-card .card-footer {
  padding-top: 0.75rem;
  border-top: 1px solid rgba(var(--white-rgb), 0.05);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.key-figure-card .comparison,
.figure-card .comparison {
  font-size: var(--text-sm);
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.key-figure-card .comparison.positive,
.figure-card .comparison.positive {
  color: var(--positive);
}
.key-figure-card .comparison.positive::before,
.figure-card .comparison.positive::before {
  content: "▲";
  font-size: 0.7em;
}
.key-figure-card .comparison.negative,
.figure-card .comparison.negative {
  color: var(--negative);
}
.key-figure-card .comparison.negative::before,
.figure-card .comparison.negative::before {
  content: "▼";
  font-size: 0.7em;
}
.key-figure-card .comparison.neutral,
.figure-card .comparison.neutral {
  color: var(--text-muted);
}

.key-figure-card .remark,
.figure-card .remark {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--gap-xs, 0.5rem);
  font-style: italic;
  display: block;
  line-height: 1.4;
  opacity: 0.7;
}

.key-figures-grid .loading,
.key-figures-grid .error,
.key-figures-grid .info {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  color: var(--text-muted);
  font-style: italic;
  background: rgba(var(--bg-app-rgb), 0.5);
  border-radius: var(--radius-lg);
  border: 1px dashed var(--border);
  grid-column: 1/-1;
}

.key-figures-grid .error {
  color: var(--negative);
  border-color: rgba(var(--negative-rgb), 0.3);
}

/* Section bouton de téléchargement dans main-content */
.download-action-section {
  margin: 2rem 0;
  padding: 0;
}

.download-action-container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.5rem;
}

/* Section infographie */
.infographie-section {
  margin: 2rem 0;
}

.infographie-container {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(0, 0, 0, 0.05);
  box-shadow: 0 10px 40px -10px rgba(var(--black-rgb), 0.1), 0 0 0 1px rgba(var(--black-rgb), 0.02);
  min-height: 600px;
  position: relative;
  overflow: hidden;
}

/* Placeholder avant génération */
.infographie-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 600px;
  padding: var(--gap-2xl, 3rem);
  background: linear-gradient(135deg, rgba(var(--bg-card-rgb), 0.8) 0%, rgba(var(--bg-component-rgb, 42, 47, 65), 0.8) 100%);
}

.placeholder-content {
  text-align: center;
  max-width: 600px;
}

.placeholder-content i {
  font-size: 4rem;
  color: var(--primary);
  margin-bottom: var(--gap-lg, 1.5rem);
  display: block;
}

.placeholder-content h3 {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 1rem;
}

.placeholder-content p {
  font-size: 1.1rem;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 2rem;
}

.placeholder-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--gap-md);
  margin-top: var(--gap-xl);
}

.feature-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: var(--gap-md);
  background: rgba(var(--white-rgb), 0.1);
  border-radius: var(--radius-md);
  box-shadow: 0 2px 4px rgba(var(--black-rgb), 0.3);
  transition: transform 0.2s ease;
}

.feature-item:hover {
  transform: translateY(-2px);
}

.feature-item i {
  font-size: 1.2rem;
  color: var(--primary);
  width: 20px;
}

.feature-item span {
  font-weight: 500;
  color: var(--text-primary);
}

/* Infographie générée - Format final 800x2000 */
.infographie-content {
  display: flex;
  flex-direction: column;
  padding: var(--gap-xl);
  background: var(--bg-card);
  color: var(--text-primary);
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.3s ease;
  /* Dimensions exactes de l'image finale */
  width: 100%;
  max-width: 1200px;
  min-height: auto;
  /* Centrage et présentation comme l'image finale */
  margin: var(--gap-xl) auto;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  /* Layout vertical pour remplir la hauteur */
  position: relative;
  overflow: hidden;
}

.infographie-content.active {
  opacity: 1;
  transform: translateY(0);
}

/* Layout principal de l'infographie - Remplir toute la hauteur */
.infographie-layout {
  display: flex;
  flex-direction: column;
  gap: 3rem;
  flex: 1;
  min-height: 0;
}

/* Responsive Styles for Layout */
@media (max-width: 768px) and (min-width: 481px) {
  .infographie-content {
    width: 100%;
    max-width: 100%;
    margin: 1rem auto;
    padding: 1.25rem;
  }
}
@media (max-width: 480px) {
  .infographie-content {
    width: 100%;
    margin: 0.75rem auto;
    padding: 1rem;
    border-radius: 0.5rem;
  }
}
/* ===== MODE EXPORT - Styles optimisés ===== */
.infographie-content.export-mode {
  display: flex;
  flex-direction: column;
  padding: 2rem;
  background: var(--card-bg);
  color: var(--text-primary);
  width: 1200px;
  min-height: 2000px;
  max-width: 1200px;
  margin: 0;
  box-shadow: none;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
  opacity: 1;
  transform: none;
}

/* Suppression des animations pour l'export */
.infographie-content.export-mode,
.infographie-content.export-mode * {
  transition: none;
  animation: none;
  outline: none;
}

.infographie-content.export-mode .chart-wrapper,
.infographie-content.export-mode .chart-container,
.infographie-content.export-mode .indicator-card-compact {
  box-shadow: none;
}

.infographie-content.export-mode .infographie-period {
  font-size: 0.9rem;
  background: rgba(var(--black-rgb), 0.06);
  padding: 0.35rem var(--gap-sm, 0.75rem);
  border-radius: 0.875rem;
  display: inline-block;
  color: var(--light-text);
}

/* Layout principal identique */
.infographie-content.export-mode .infographie-layout {
  display: flex;
  flex-direction: column;
  gap: 3rem;
  flex: 1;
  min-height: 0;
}

/* =============================================================================
   COMMON UTILITIES & BUTTONS (Moved from Legacy)
   ============================================================================= */
/* Classe utilitaire pour masquer les éléments de manière robuste */
.is-hidden {
  display: none !important;
}

/* Focus visibles pour l'accessibilité clavier */
.btn-infographie:focus-visible,
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/* Focus pour les éléments de navigation */
button:focus-visible,
select:focus-visible,
a:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 1px;
}

/* Amélioration de l'accessibilité des filtres */
.filter-select:focus-visible {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(var(--primary-rgb), 0.2);
}

/* Amélioration de l'accessibilité du sélecteur de période */
.period-picker-input:focus-visible {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(var(--primary-rgb), 0.2);
}

/* Réduction d'animations pour les utilisateurs sensibles */
@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
  }
}
/* Animation de chargement */
.loading-spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 3px solid rgba(var(--white-rgb), 0.3);
  border-radius: 50%;
  border-top-color: var(--white);
  animation: spin 1s ease-in-out infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
/* Indicateur de chargement pour l'infographie */
.infographie-loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(var(--bg-app-rgb), 0.9);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.infographie-loading.active {
  opacity: 1;
  visibility: visible;
}

.infographie-loading-spinner {
  width: 60px;
  height: 60px;
  border: 4px solid rgba(var(--primary-rgb), 0.3);
  border-radius: 50%;
  border-top-color: var(--primary);
  animation: spin 1s linear infinite;
  margin-bottom: var(--gap-xl, 2rem);
}

.infographie-loading-text {
  color: var(--text-primary);
  font-size: 1.2rem;
  font-weight: 600;
  text-align: center;
  margin-bottom: 1rem;
}

.infographie-loading-subtext {
  color: var(--text-secondary);
  font-size: 1rem;
  text-align: center;
  max-width: 400px;
  line-height: 1.5;
}

.infographie-loading-progress {
  width: 300px;
  height: 4px;
  background: rgba(var(--white-rgb), 0.1);
  border-radius: 2px;
  overflow: hidden;
  margin-top: 1rem;
}

.infographie-loading-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--primary), var(--secondary));
  width: 0%;
  transition: width 0.3s ease;
  border-radius: 2px;
}

/* Styles pour le bouton infographie - Cohérent avec le tableau de bord */
.btn-infographie {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 24px;
  background: linear-gradient(135deg, var(--secondary) 0%, rgba(var(--secondary-rgb), 0.85) 100%);
  border: 1px solid rgba(var(--white-rgb), 0.2);
  border-radius: var(--radius-lg);
  color: var(--white);
  text-decoration: none;
  font-weight: 600;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  box-shadow: var(--shadow-md);
  position: relative;
  overflow: hidden;
  cursor: pointer;
  font-family: var(--body-font);
  letter-spacing: 0.02em;
}

.btn-infographie::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(var(--white-rgb), 0.2), transparent);
  transition: left 0.5s ease;
}

.btn-infographie:hover::before {
  left: 100%;
}

.btn-infographie:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
  color: var(--white);
  text-decoration: none;
  filter: brightness(1.05);
}

.btn-infographie:active {
  transform: translateY(0);
}

.btn-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  margin-right: 8px;
}

.btn-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.btn-title {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.2;
}

.btn-subtitle {
  font-size: 0.85rem;
  opacity: 0.8;
  font-weight: 400;
  line-height: 1;
}

/* Styles pour le bouton infographie désactivé */
.btn-infographie:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none !important;
  background: var(--bg-surface-alt);
  color: var(--text-secondary);
}

.btn-infographie:disabled:hover {
  transform: none !important;
  box-shadow: 0 4px 15px rgba(var(--blue-excursion-rgb, 102, 126, 234), 0.3);
  background: var(--bg-surface-alt);
}

/* Styles pour le bouton secondary désactivé */
.btn--secondary:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none !important;
  background: var(--bg-surface-alt);
  color: var(--text-secondary);
}

.btn--secondary:disabled:hover {
  transform: none !important;
  box-shadow: 0 4px 15px rgba(var(--blue-excursion-rgb, 102, 126, 234), 0.3);
  background: var(--bg-surface-alt);
}

/* Styles pour le sélecteur de période dans l'infographie */
.period-picker-wrap {
  position: relative;
  display: inline-block;
}

.period-picker-input {
  background: var(--bg-surface-glass);
  color: var(--text-primary);
  border: 1px solid var(--border);
  padding: 8px 12px;
  border-radius: var(--radius-md);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: all 0.3s ease;
  font-size: 0.9rem;
  font-weight: 500;
  backdrop-filter: blur(10px);
  box-shadow: 0 2px 20px rgba(var(--black-rgb), 0.4);
}

.period-picker-input:hover {
  background: var(--bg-surface);
  border-color: var(--primary);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(var(--primary-rgb), 0.15);
}

.period-picker-input:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-color: var(--primary);
}

/* Responsive pour les boutons infographie */
@media (max-width: 768px) {
  .btn-infographie {
    padding: 10px 16px;
    gap: 6px;
    font-size: 0.9rem;
  }
  .btn-icon {
    font-size: 1rem;
    margin-right: 6px;
  }
  .btn-title {
    font-size: 0.9rem;
  }
  .btn-subtitle {
    font-size: 0.75rem;
  }
  .download-action-container {
    flex-direction: column;
    gap: 12px;
  }
  .download-action-container .btn {
    width: 100%;
    justify-content: center;
  }
  .period-picker-input {
    padding: 6px 10px;
    font-size: 0.8rem;
    gap: 6px;
  }
  .period-picker-input .pp-display {
    font-size: 0.8rem;
  }
  .btn--secondary {
    padding: 10px 16px;
    font-size: 0.9rem;
  }
  .btn--secondary i {
    font-size: 1rem;
    margin-right: 6px;
  }
}
/* Ajustement des hauteurs pour les écrans moyens */
@media (max-width: 1024px) {
  :root {
    --chart-h: 320px;
    --chart-h-lg: 420px;
    --chart-h-xl: 500px;
  }
}
@media (max-width: 768px) {
  :root {
    --chart-h: 300px;
    --chart-h-lg: 380px;
    --chart-h-xl: 460px;
  }
}
.infographie-content.export-mode .origins-grid {
  gap: 1rem !important;
  min-height: 400px !important;
}

/* Optimisation des polices pour l'export */
.infographie-content.export-mode .infographie-title {
  font-size: 2.5rem !important;
  margin-bottom: 1rem !important;
}

.infographie-content.export-mode .infographie-subtitle {
  font-size: 1.3rem !important;
  margin-bottom: 1.5rem !important;
}

.infographie-content.export-mode .chart-header h5 {
  font-size: 1.1rem !important;
  margin-bottom: 0.5rem !important;
}

/* Styles d'impression PDF */
@media print {
  .infographie-content {
    box-shadow: none;
    border: 0;
    margin: 0;
    padding: 1rem;
    width: 100%;
    max-width: none;
    min-height: auto;
  }
  .partners-strip img {
    filter: none;
  }
  /* Optimisations pour l'impression */
  .chart-container {
    break-inside: avoid;
    page-break-inside: avoid;
  }
  .indicators-row {
    break-inside: avoid;
    page-break-inside: avoid;
  }
  /* Masquer les éléments non nécessaires à l'impression */
  .btn-infographie,
  .filter-select,
  .period-picker-input {
    display: none;
  }
  /* Assurer la lisibilité */
  * {
    print-color-adjust: exact;
  }
}
/* Header de l'infographie */
.infographie-header {
  text-align: center;
  margin-bottom: var(--gap-2xl, 3rem);
  padding-bottom: var(--gap-xl, 2rem);
  border-bottom: 3px solid var(--primary);
  background: var(--white);
  color: var(--light-text);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  margin: calc(var(--gap-xl, 2rem) * -1) calc(var(--gap-xl, 2rem) * -1) var(--gap-2xl, 3rem) calc(var(--gap-xl, 2rem) * -1);
  padding: var(--gap-md, 1rem) var(--gap-xl, 2rem) 1.25rem var(--gap-xl, 2rem);
}

.infographie-header .branding-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.infographie-header .branding-left,
.infographie-header .branding-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.infographie-header .branding-logo {
  height: 36px;
  max-width: 140px;
  object-fit: contain;
  background: transparent;
}

.infographie-header .header-text {
  margin-top: 0.5rem;
}

.infographie-title {
  font-size: clamp(1.6rem, 2.2vw, 2rem);
  font-weight: 700;
  margin-bottom: 0.25rem;
  color: var(--light-text);
}

.infographie-subtitle {
  font-size: 1rem;
  opacity: 0.9;
  margin-bottom: 0.25rem;
  color: var(--light-text-secondary);
}

.infographie-period {
  font-size: 0.9rem;
  background: rgba(var(--black-rgb), 0.06);
  padding: 0.35rem var(--gap-sm, 0.75rem);
  border-radius: 14px;
  display: inline-block;
  color: var(--light-text);
}

/* Footer de l'infographie - Fixé en bas */
.infographie-footer {
  text-align: center;
  margin-top: auto;
  border-top: 1px solid var(--border);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  margin-left: calc(var(--gap-xl, 2rem) * -1);
  margin-right: calc(var(--gap-xl, 2rem) * -1);
  margin-bottom: calc(var(--gap-xl, 2rem) * -1);
  overflow: hidden;
}

/* Bandeau des partenaires */
.partners-strip {
  background: var(--white);
  padding: 1.25rem var(--gap-xl, 2rem);
  border-top: 1px solid var(--light-border);
}

.partners-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  max-width: var(--container-width, 1200px);
  margin: 0 auto;
}

.partners-strip img {
  height: 56px;
  width: auto;
  object-fit: contain;
  filter: grayscale(0);
  transition: filter 0.2s ease;
  opacity: 0.9;
}

.partners-strip img:hover {
  filter: grayscale(0);
  opacity: 1;
}

/* Responsive pour les logos partenaires */
@media (max-width: 992px) {
  .partners-strip {
    padding: 1rem 1.5rem;
  }
  .partners-row {
    gap: 1.5rem;
  }
  .partners-strip img {
    height: 48px;
  }
}
@media (max-width: 768px) {
  .partners-strip {
    padding: 0.875rem 1rem;
  }
  .partners-row {
    gap: 1.25rem;
  }
  .partners-strip img {
    height: 44px;
  }
  .infographie-title {
    font-size: 1.6rem;
  }
}
@media (max-width: 480px) {
  .partners-strip {
    padding: 0.75rem 0.875rem;
  }
  .partners-row {
    gap: 1rem;
  }
  .partners-strip img {
    height: 40px;
  }
  .infographie-title {
    font-size: 1.3rem;
  }
}
/* ===== MODE EXPORT - Styles optimisés ===== */
/* Header export - Style identique à la page web pour cohérence */
.infographie-content.export-mode .infographie-header {
  text-align: center;
  margin-bottom: var(--gap-2xl, 3rem);
  padding-bottom: var(--gap-xl, 2rem);
  border-bottom: 2px solid var(--border);
  background: var(--white);
  color: var(--light-text);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  margin: calc(var(--gap-xl, 2rem) * -1) calc(var(--gap-xl, 2rem) * -1) var(--gap-2xl, 3rem) calc(var(--gap-xl, 2rem) * -1);
  padding: var(--gap-md, 1rem) var(--gap-xl, 2rem) 1.25rem var(--gap-xl, 2rem);
  box-shadow: none;
}

.infographie-content.export-mode .infographie-title {
  font-size: clamp(1.6rem, 2.2vw, 2rem);
  font-weight: 700;
  margin-bottom: 0.25rem;
  color: var(--light-text);
}

.infographie-content.export-mode .infographie-subtitle {
  font-size: 1rem;
  opacity: 0.9;
  margin-bottom: 0.25rem;
  color: var(--light-text-secondary);
}

.infographie-content.export-mode .infographie-period {
  font-size: 0.9rem;
  background: rgba(var(--black-rgb), 0.06);
  padding: 0.35rem var(--gap-sm, 0.75rem);
  border-radius: 0.875rem;
  display: inline-block;
  color: var(--light-text);
}

/* Footer identique au web */
.infographie-content.export-mode .infographie-footer {
  text-align: center !important;
  margin-top: auto !important;
  border-top: 1px solid var(--border) !important;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg) !important;
  margin-left: calc(var(--gap-xl, 2rem) * -1) !important;
  margin-right: calc(var(--gap-xl, 2rem) * -1) !important;
  margin-bottom: calc(var(--gap-xl, 2rem) * -1) !important;
  overflow: hidden !important;
}

.infographie-content.export-mode .partners-strip {
  background: var(--white) !important;
  padding: 1.25rem var(--gap-xl, 2rem) !important;
  border-top: 1px solid var(--light-border) !important;
}

.infographie-content.export-mode .partners-row {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 2rem !important;
  max-width: var(--container-width, 1200px) !important;
  margin: 0 auto !important;
}

.infographie-content.export-mode .partners-strip img {
  height: 56px !important;
  width: auto !important;
  object-fit: contain !important;
  filter: grayscale(0) !important;
  opacity: 0.9 !important;
}

/* =============================================================================
   CORRECTIONS LOGOS OFFICES DE TOURISME
   ============================================================================= */
/* S'assurer que tous les logos des partenaires ont une taille cohérente */
.partners-strip .partners-row img {
  height: auto !important;
  max-height: 50px !important;
  width: auto !important;
  max-width: calc(20% - 1.6rem) !important;
  /* Force 5 logos par ligne (100% / 5 = 20%, moins les gaps) */
  object-fit: contain !important;
  margin: 0 8px !important;
  vertical-align: middle !important;
  flex: 0 0 auto !important;
}

/* Badge tendance - Design compact et élégant */
.indicator-cagr-badge {
  margin-top: var(--gap-sm);
  padding: 0.3rem 0.5rem;
  background: linear-gradient(135deg, rgba(var(--bg-card-rgb), 0.5) 0%, rgba(var(--bg-card-rgb), 0.3) 100%);
  border: 1px solid rgba(var(--primary-rgb), 0.12);
  border-radius: var(--radius-sm);
  text-align: center;
  position: relative;
  backdrop-filter: blur(8px);
  transition: all 0.3s ease;
  display: inline-block;
  min-width: 100%;
}

.indicator-cagr-badge:hover {
  border-color: rgba(var(--primary-rgb), 0.25);
  transform: translateY(-1px);
  box-shadow: 0 3px 8px rgba(var(--primary-rgb), 0.08);
}

.indicator-cagr-badge.positive {
  border-color: rgba(var(--success-rgb), 0.2);
  background: linear-gradient(135deg, rgba(var(--success-rgb), 0.06) 0%, rgba(var(--success-rgb), 0.02) 100%);
}

.indicator-cagr-badge.positive:hover {
  border-color: rgba(var(--success-rgb), 0.35);
  box-shadow: 0 3px 8px rgba(var(--success-rgb), 0.12);
}

.indicator-cagr-badge.negative {
  border-color: rgba(var(--error-rgb), 0.2);
  background: linear-gradient(135deg, rgba(var(--error-rgb), 0.06) 0%, rgba(var(--error-rgb), 0.02) 100%);
}

.indicator-cagr-badge.negative:hover {
  border-color: rgba(var(--error-rgb), 0.35);
  box-shadow: 0 3px 8px rgba(var(--error-rgb), 0.12);
}

.indicator-cagr-badge .cagr-label {
  color: var(--text-muted);
  font-size: 0.55rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 500;
  margin-bottom: 0.15rem;
  display: block;
  opacity: 0.8;
}

.indicator-cagr-badge .cagr-value {
  color: var(--text-primary);
  font-size: 0.75rem;
  font-weight: 700;
  display: block;
  letter-spacing: 0.2px;
  line-height: 1.2;
  margin-left: 0.1rem;
}

.indicator-cagr-badge.positive .cagr-value {
  color: var(--success);
}

.indicator-cagr-badge.negative .cagr-value {
  color: var(--error);
}

.indicator-cagr-badge.neutral .cagr-value {
  color: var(--primary);
}

.indicator-cagr-badge:empty {
  display: none;
}

/* Section Définitions compacte */
.definitions-compact {
  background: rgba(var(--white-rgb), 0.03);
  border-radius: var(--radius-md);
  padding: var(--gap-md, 1rem);
  border: 1px solid var(--border);
  margin-top: var(--gap-md, 1rem);
}

.definitions-compact-header {
  text-align: center;
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--primary);
}

.definitions-compact-header h4 {
  color: var(--primary);
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.definitions-compact-content {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.definition-compact-item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.85rem;
  line-height: 1.4;
}

.definition-label {
  color: var(--primary);
  font-weight: 600;
  flex-shrink: 0;
  min-width: 120px;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.definition-label i {
  font-size: 0.9rem;
}

.definition-text {
  color: var(--text-secondary);
  flex: 1;
}

/* Sections principales : Touristes, Excursionnistes et Phare */
.tourist-section,
.excursionist-section,
.lighthouse-section {
  background: var(--bg-surface-glass);
  border-radius: var(--radius-lg);
  padding: var(--gap-xl, 2rem);
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-sm);
  transition: all var(--duration-base) var(--easing-out);
}
.tourist-section:hover,
.excursionist-section:hover,
.lighthouse-section:hover {
  background: var(--bg-surface);
  border-color: var(--border-glow);
}

/* Masquer les sections complètes si toutes les sous-sections sont masquées */
.tourist-section:has(.indicators-subsection.is-hidden):has(.origins-subsection.is-hidden):has(.stay-subsection.is-hidden) {
  display: none;
}

.excursionist-section:has(.indicators-subsection.is-hidden):has(.origins-subsection.is-hidden) {
  display: none;
}

/* Masquer automatiquement les sections d'indicateurs vides */
.indicators-subsection:not(:has(.indicator-card-compact)) {
  display: none;
}

/* Masquer automatiquement les titres quand les sections sont masquées */
.origins-subsection:has(.origins-grid.is-hidden) .origins-header {
  display: none;
}

.stay-subsection:has(.origins-grid.is-hidden) .stay-header {
  display: none;
}

.section-header {
  text-align: center;
  margin-bottom: var(--gap-xl, 2rem);
  padding-bottom: var(--gap-md, 1rem);
  border-bottom: 2px solid var(--primary);
}

.section-header h3 {
  color: var(--primary);
  font-size: 1.6rem;
  font-weight: 700;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}

/* Sous-sections indicateurs et origines */
.indicators-subsection,
.origins-subsection {
  margin-bottom: 2rem;
}

.indicators-subsection:last-child,
.origins-subsection:last-child {
  margin-bottom: 0;
}

.indicators-header,
.origins-header {
  text-align: center;
  margin-bottom: 1.5rem;
}

.indicators-header h4,
.origins-header h4 {
  color: var(--text-primary);
  font-size: 1.2rem;
  font-weight: 600;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

/* === SECTIONS INFOGRAPHIE === */
/* Sections spécifiques du template */
.infographie-section-kpi {
  background: rgba(var(--white-rgb), 0.05);
  border-radius: var(--radius-lg);
  padding: var(--gap-lg, 1.5rem);
  border: 1px solid var(--border);
}

.infographie-section-kpi h3 {
  color: var(--primary);
  font-size: 1.4rem;
  font-weight: 600;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Sections de l'infographie */
.infographie-section-card {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  padding: var(--gap-xl, 2rem);
  box-shadow: var(--shadow-light);
  border: 1px solid var(--border);
}

.infographie-section-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.infographie-section-title i {
  font-size: 1.2rem;
}

/* Indicateurs clés - Style identique au tableau de bord */
.key-figures-grid,
.key-indicators-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
}

.key-figure-card,
.figure-card {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  padding: var(--gap-lg, 1.5rem);
  box-shadow: var(--shadow-light);
  border: 1px solid var(--border);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.key-figure-card:hover,
.figure-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(var(--primary-rgb), 0.2);
  border-color: var(--primary);
}

.key-figure-card .card-header,
.figure-card .card-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.key-figure-card .key-figure-icon,
.figure-card .icon {
  font-size: 1.2rem;
  color: var(--primary);
  width: 24px;
  text-align: center;
}

.key-figure-card .indicator-title,
.figure-card .indicator-title {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
}

.key-figure-card .key-figure-content,
.figure-card .card-body {
  text-align: left;
}

.key-figure-card .key-figure-value,
.figure-card .value {
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 0.5rem;
  line-height: 1.2;
}

.key-figure-card .value-prev-year {
  font-size: 0.85rem;
  color: var(--text-secondary);
  margin-bottom: 0.25rem;
}

.key-figure-card .unit,
.figure-card .unit {
  font-size: 0.8rem;
  color: var(--text-secondary);
  margin-bottom: 0.5rem;
}

.key-figure-card .comparison,
.figure-card .comparison {
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.key-figure-card .comparison.positive,
.figure-card .comparison.positive {
  color: var(--success);
}

.key-figure-card .comparison.negative,
.figure-card .comparison.negative {
  color: var(--error);
}

.key-figure-card .remark,
.figure-card .remark {
  font-size: 0.75rem;
  color: var(--text-secondary);
  font-style: italic;
  line-height: 1.3;
}

/* === RESPONSIVE PROFESSIONNEL === */
/* Extra Large (>1200px) - Desktop large */
@media (min-width: 1201px) {
  .infographie-content {
    width: 1200px;
    margin: var(--gap-xl, 2rem) auto;
    box-shadow: 0 12px 48px rgba(var(--black-rgb), 0.2);
  }
  .indicators-row {
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
  }
}
/* Large (1025px - 1200px) - Desktop standard */
@media (max-width: 1200px) and (min-width: 1025px) {
  .infographie-content {
    width: 100%;
    max-width: 1000px;
    margin: 1.5rem auto;
  }
  .indicators-row {
    grid-template-columns: repeat(3, 1fr);
    gap: 0.875rem;
  }
  .chart-header h4 {
    font-size: 1rem;
  }
}
/* Medium (769px - 1024px) - Tablette paysage */
@media (max-width: 1024px) and (min-width: 769px) {
  .infographie-content {
    width: 100%;
    max-width: 95%;
    margin: 1.25rem auto;
    padding: 1.5rem;
  }
  .infographie-layout {
    gap: 1.75rem;
  }
  .indicators-row {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.875rem;
  }
  .indicator-card-compact {
    padding: 0.875rem;
  }
  .chart-wrapper {
    min-height: 320px;
    max-height: 400px;
    padding: 0.75rem;
  }
  .chart-header h4 {
    font-size: 0.95rem;
  }
  .chart-subtitle {
    font-size: 0.75rem;
  }
}
/* Small (481px - 768px) - Tablette portrait */
@media (max-width: 768px) and (min-width: 481px) {
  .indicators-row {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
  .indicator-card-compact {
    padding: 0.75rem;
  }
  .indicator-title {
    font-size: 0.8rem;
  }
  .indicator-value {
    font-size: 1.3rem;
  }
  .charts-grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .chart-wrapper {
    min-height: 300px;
    max-height: 360px;
    padding: 0.625rem;
  }
  .chart-header h4 {
    font-size: 0.9rem;
  }
  .chart-subtitle {
    font-size: 0.7rem;
  }
  .placeholder-features {
    grid-template-columns: 1fr;
    gap: var(--gap-md, 1rem);
  }
}
/* Extra Small (<480px) - Mobile */
@media (max-width: 480px) {
  .indicators-row {
    grid-template-columns: 1fr;
    gap: 0.625rem;
  }
  .indicator-card-compact {
    padding: 0.625rem;
  }
  .indicator-title {
    font-size: 0.75rem;
  }
  .indicator-value {
    font-size: 1.1rem;
  }
  .charts-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .chart-wrapper {
    min-height: 280px;
    max-height: 320px;
    padding: 0.5rem;
  }
  .chart-header h4 {
    font-size: 0.85rem;
  }
  .chart-subtitle {
    font-size: 0.65rem;
  }
  .placeholder-features {
    grid-template-columns: 1fr;
    gap: var(--gap-sm, 0.75rem);
  }
  .feature-item {
    padding: 0.75rem;
  }
  .feature-item i {
    font-size: 1rem;
  }
  .feature-item span {
    font-size: 0.85rem;
  }
}
/* === INDICATEURS EN MODE EXPORT - Héritent des styles de base === */
.infographie-content.export-mode .indicators-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
}

/* Section Définitions compacte en mode export */
.infographie-content.export-mode .definitions-compact {
  background: rgba(var(--white-rgb), 0.03) !important;
  border-radius: var(--radius-md) !important;
  padding: var(--gap-md, 1rem) !important;
  border: 1px solid var(--border) !important;
  margin-top: var(--gap-md, 1rem) !important;
  box-shadow: none !important;
  transform: none !important;
}

.infographie-content.export-mode .definitions-compact-header {
  text-align: center !important;
  margin-bottom: 0.75rem !important;
  padding-bottom: 0.5rem !important;
  border-bottom: 2px solid var(--primary) !important;
}

.infographie-content.export-mode .definitions-compact-header h4 {
  color: var(--primary) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
}

.infographie-content.export-mode .definitions-compact-content {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.5rem !important;
}

.infographie-content.export-mode .definition-compact-item {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.5rem !important;
  font-size: 0.85rem !important;
  line-height: 1.4 !important;
}

.infographie-content.export-mode .definition-label {
  color: var(--primary) !important;
  font-weight: 600 !important;
  flex-shrink: 0 !important;
  min-width: 120px !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.25rem !important;
}

.infographie-content.export-mode .definition-label i {
  font-size: 0.9rem !important;
}

.infographie-content.export-mode .definition-text {
  color: var(--text-secondary) !important;
  flex: 1 !important;
}

/* Sections principales en mode export */
.infographie-content.export-mode .tourist-section,
.infographie-content.export-mode .excursionist-section {
  background: rgba(var(--white-rgb), 0.05) !important;
  border-radius: var(--radius-lg) !important;
  padding: var(--gap-xl, 2rem) !important;
  border: 1px solid var(--border) !important;
  box-shadow: none !important;
  transform: none !important;
}

.infographie-content.export-mode .section-header {
  text-align: center !important;
  margin-bottom: var(--gap-xl, 2rem) !important;
  padding-bottom: var(--gap-md, 1rem) !important;
  border-bottom: 2px solid var(--primary) !important;
}

.infographie-content.export-mode .section-header h3 {
  color: var(--primary) !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.75rem !important;
}

.infographie-content.export-mode .indicators-subsection,
.infographie-content.export-mode .origins-subsection {
  margin-bottom: var(--gap-xl, 2rem) !important;
}

.infographie-content.export-mode .indicators-header,
.infographie-content.export-mode .origins-header {
  text-align: center !important;
  margin-bottom: 1.5rem !important;
}

.infographie-content.export-mode .indicators-header h4,
.infographie-content.export-mode .origins-header h4 {
  color: var(--text-primary) !important;
  font-size: 1.2rem !important;
  font-weight: 600 !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
}

/* Grilles identiques */
.infographie-content.export-mode .origins-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  grid-template-rows: auto auto auto !important;
  gap: 1.5rem !important;
}

.infographie-content.export-mode .chart-departements {
  grid-column: 1/-1 !important;
  grid-row: 1 !important;
}

.infographie-content.export-mode .chart-regions {
  grid-column: 1 !important;
  grid-row: 2 !important;
}

.infographie-content.export-mode .chart-pays {
  grid-column: 2 !important;
  grid-row: 2 !important;
}

/* Conteneurs graphiques identiques au web */
.infographie-content.export-mode .chart-container {
  background: rgba(var(--white-rgb), 0.05) !important;
  border-radius: var(--radius-lg) !important;
  padding: var(--gap-md, 1rem) !important;
  border: 1px solid var(--border) !important;
  transition: none !important;
  position: relative !important;
  min-height: var(--chart-h) !important;
  max-height: var(--chart-h-lg) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  box-shadow: none !important;
  transform: none !important;
}

.infographie-content.export-mode .chart-departements {
  min-height: var(--chart-h-lg) !important;
  max-height: var(--chart-h-xl) !important;
}

.infographie-content.export-mode .chart-header {
  text-align: center !important;
  margin-bottom: 0.5rem !important;
  padding-bottom: 0.5rem !important;
  border-bottom: 1px solid var(--border) !important;
  flex-shrink: 0 !important;
}

.infographie-content.export-mode .chart-header h4 {
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--text-primary) !important;
  margin: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.infographie-content.export-mode .chart-wrapper {
  position: relative !important;
  flex: 1 !important;
  width: 100% !important;
  background: rgba(var(--white-rgb), 0.02) !important;
  border-radius: var(--radius-md) !important;
  padding: var(--gap-sm, 0.5rem) !important;
  padding-top: var(--gap-sm, 0.5rem) !important;
  min-height: clamp(250px, var(--chart-h) - 110px, 350px) !important;
  max-height: clamp(300px, var(--chart-h-lg) - 110px, 450px) !important;
  overflow: visible !important;
  border: none !important;
  box-shadow: none !important;
  transform: none !important;
}

.infographie-content.export-mode .chart-departements .chart-wrapper {
  min-height: calc(var(--chart-h-lg) - 120px) !important;
  max-height: calc(var(--chart-h-xl) - 120px) !important;
}

/* Images et canvas - SANS backgrounds blancs */
.infographie-content.export-mode .chart-wrapper img,
.infographie-content.export-mode canvas {
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: none !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  background: transparent !important;
  border: none !important;
}

/* Responsive pour les nouvelles grilles d'origines */
@media (max-width: 1024px) {
  .definitions-compact-item {
    flex-direction: column;
    gap: 0.25rem;
  }
  .definition-label {
    min-width: auto;
  }
  .origins-grid {
    grid-template-columns: 1fr;
    /* 1 colonne sur tablette */
    grid-template-rows: auto auto auto;
  }
  .chart-departements {
    grid-column: 1;
    grid-row: 1;
  }
  .chart-regions {
    grid-column: 1;
    grid-row: 2;
  }
  .chart-pays {
    grid-column: 1;
    grid-row: 3;
  }
}
@media (max-width: 768px) {
  .definitions-compact {
    padding: 0.75rem;
    margin-top: 0.75rem;
  }
  .definitions-compact-header h4 {
    font-size: 0.9rem;
  }
  .definition-compact-item {
    font-size: 0.8rem;
  }
  .definition-label {
    min-width: 100px;
  }
  .origins-grid {
    grid-template-columns: 1fr;
    /* 1 colonne sur mobile */
    gap: 1rem;
  }
}
/* =============================================================================
   SECTION DURÉE DE SÉJOUR
   ============================================================================= */
/* Centrer le titre de la section durée de séjour */
.duree-sejour-header {
  text-align: center;
}

.duree-sejour-header h4 {
  text-align: center;
  margin: 0;
  padding: var(--gap-md, 1rem) 0;
}

/* =============================================================================
   COMPOSANT: METEO INFOGRAPHIE (PREMIUM)
   ============================================================================= */
.meteo-section {
  margin-bottom: var(--gap-xl);
  background: var(--bg-surface-glass);
  border-radius: var(--radius-lg);
  padding: var(--gap-md);
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-sm);
  transition: all var(--duration-base) var(--easing-out);
}
.meteo-section:hover {
  background: var(--bg-surface);
  border-color: var(--border-glow);
}

.meteo-header {
  border-bottom: 2px solid var(--secondary);
  margin-bottom: var(--gap-md) !important;
  display: flex;
  align-items: center;
  gap: var(--gap-sm);
}
.meteo-header h3 {
  color: var(--primary) !important;
  font-size: 1.1rem !important;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 0;
}
.meteo-header h3 i {
  margin-right: var(--gap-xs);
  color: var(--secondary);
}

.meteo-indicators-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap-md);
}

.meteo-section .indicator-card-compact {
  background: var(--white);
  border: 1px solid var(--border-weak);
  transition: transform var(--duration-base) var(--easing-out), box-shadow var(--duration-base) var(--easing-out), border-color var(--duration-base) var(--easing-out);
}
.meteo-section .indicator-card-compact:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--secondary);
}
.meteo-section .indicator-icon {
  color: var(--primary);
  font-size: 1.8rem;
  margin: 0 auto var(--gap-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 48px;
}

@media (max-width: 992px) {
  .meteo-indicators-row {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 600px) {
  .meteo-indicators-row {
    grid-template-columns: 1fr;
  }
}
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Mixins SCSS - CantalDestination
 * Fonctions réutilisables pour éviter la duplication
 */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

.login-page {
  background: var(--bg-app);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--gap-xl, 2rem);
  background-image: radial-gradient(circle at 20% 30%, rgba(var(--primary-rgb), 0.05) 0%, transparent 40%), radial-gradient(circle at 80% 70%, rgba(var(--secondary-rgb), 0.05) 0%, transparent 40%);
}
.login-page .login-container {
  width: 100%;
  max-width: 420px;
  animation: loginReveal 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.login-page .login-header {
  text-align: center;
  margin-bottom: var(--gap-2xl, 3rem);
}
.login-page .login-header .login-logo {
  max-width: 220px;
  margin-bottom: var(--gap-xl, 1.5rem);
  filter: drop-shadow(0 4px 12px rgba(var(--black-rgb), 0.1));
}
.login-page .login-header h1 {
  font-family: var(--display-font, "Orbitron", sans-serif);
  font-size: 1.8rem;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.login-page .login-header h1 span {
  color: var(--primary);
  font-size: 0.9rem;
  display: block;
  margin-top: calc(var(--gap-xs, 0.25rem) + 1px);
  letter-spacing: 4px;
}
.login-page .login-card {
  background: var(--bg-surface-glass);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--border-weak);
  border-radius: var(--radius-xl, 1rem);
  padding: var(--gap-2xl, 2.5rem);
  box-shadow: 0 20px 40px rgba(var(--black-rgb), 0.1);
  position: relative;
  overflow: hidden;
}
.login-page .login-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--primary), var(--secondary));
}
.login-page .form-group {
  margin-bottom: var(--gap-xl, 1.5rem);
  position: relative;
}
.login-page .form-group label {
  display: block;
  color: var(--text-secondary);
  font-size: 0.85rem;
  margin-bottom: var(--gap-xs, 0.5rem);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.login-page .form-group .input-wrapper {
  position: relative;
}
.login-page .form-group .input-wrapper i.prefix-icon {
  position: absolute;
  left: 15px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  transition: color 0.3s ease;
}
.login-page .form-group .input-wrapper input {
  width: 100%;
  background: rgba(var(--black-rgb), 0.02);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 12px 15px 12px 45px;
  color: var(--text-primary);
  font-size: 1rem;
  transition: all var(--transition-base, 0.3s cubic-bezier(0.4, 0, 0.2, 1));
}
.login-page .form-group .input-wrapper input:focus {
  outline: none;
  border-color: var(--primary);
  background: rgba(var(--black-rgb), 0.04);
  box-shadow: 0 0 15px rgba(var(--primary-rgb), 0.1);
}
.login-page .form-group .input-wrapper input:focus + i.prefix-icon {
  color: var(--primary);
}
.login-page .form-group .input-wrapper input::placeholder {
  color: var(--text-muted);
  font-size: 0.9rem;
}
.login-page .form-group .input-wrapper .password-toggle {
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  cursor: pointer;
  padding: var(--gap-xs, 5px);
  transition: color var(--transition-fast, 0.3s ease);
}
.login-page .form-group .input-wrapper .password-toggle:hover {
  color: var(--text-primary);
}
.login-page .login-submit {
  width: 100%;
  margin-top: var(--gap-md, 10px);
  height: 50px;
  border-radius: var(--radius-md);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.login-page .login-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(var(--primary-rgb), 0.2);
}
.login-page .login-submit i {
  font-size: 1.1rem;
}
.login-page .error-message {
  background: rgba(var(--error-rgb), 0.1);
  border: 1px solid rgba(var(--error-rgb), 0.3);
  color: var(--error);
  padding: 12px 15px;
  border-radius: var(--radius-md);
  margin-bottom: var(--gap-xl, 25px);
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  gap: 10px;
  animation: shake 0.5s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
}
.login-page .login-footer {
  text-align: center;
  margin-top: var(--gap-2xl, 30px);
}
.login-page .login-footer .back-link {
  color: var(--text-muted);
  text-decoration: none;
  font-size: 0.9rem;
  transition: color 0.3s ease;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.login-page .login-footer .back-link:hover {
  color: var(--primary);
}

@keyframes loginReveal {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes shake {
  10%, 90% {
    transform: translate3d(-1px, 0, 0);
  }
  20%, 80% {
    transform: translate3d(2px, 0, 0);
  }
  30%, 50%, 70% {
    transform: translate3d(-4px, 0, 0);
  }
  40%, 60% {
    transform: translate3d(4px, 0, 0);
  }
}
.urssaf-dashboard {
  --primary-red: var(--negative);
  --primary-green: var(--positive);
  --primary-white: var(--text-primary);
  --secondary-red: var(--error);
  --secondary-green: var(--success);
  --dark-green: var(--bg-card);
  --light-green: rgba(var(--positive-rgb), 0.1);
  --light-red: rgba(var(--negative-rgb), 0.1);
  --light-bg: var(--bg-app);
  --dark-bg: var(--bg-app);
  --text-dark: var(--text-primary);
  --text-light: var(--text-secondary);
  --border-color: var(--border);
  --shadow-sm: var(--shadow-light);
  --shadow: var(--shadow-card);
  --shadow-md: var(--shadow-md);
  --shadow-lg: var(--shadow-lg);
  --transition: var(--transition-base, 0.25s);
  --glass-bg: rgba(var(--black-rgb), 0.02);
  --glass-border: 1px solid rgba(var(--black-rgb), 0.05);
}

body {
  --primary-red: var(--negative);
  --primary-green: var(--positive);
  font-family: var(--body-font);
  color: var(--text-primary);
  line-height: 1.6;
  background: var(--bg-app);
  min-height: 100vh;
  position: relative;
  font-size: var(--size-base, 1rem);
  margin: 0;
  padding: 0;
}
body::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at 15% 50%, rgba(var(--primary-rgb), 0.08) 0%, transparent 25%), radial-gradient(circle at 85% 30%, rgba(var(--secondary-rgb), 0.08) 0%, transparent 25%);
  pointer-events: none;
  z-index: 0;
}

.urssaf-dashboard {
  position: relative;
  width: 100%;
}
.urssaf-dashboard .container {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  background: transparent;
  position: relative;
  z-index: 1;
}
.urssaf-dashboard .header {
  background: linear-gradient(180deg, rgba(var(--bg-app-rgb), 0.95) 0%, rgba(var(--bg-app-rgb), 0.8) 100%);
  border-bottom: 1px solid rgba(var(--primary-rgb), 0.3);
  color: var(--text-primary);
  padding: var(--gap-4xl, 60px) var(--gap-xl, 30px) var(--gap-5xl, 80px) var(--gap-xl, 30px);
  text-align: left;
  position: relative;
  overflow: hidden;
}
.urssaf-dashboard .header::before {
  content: "";
  position: absolute;
  top: -20%;
  right: -5%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(var(--primary-rgb), 0.07) 0%, transparent 70%);
  border-radius: 50%;
  animation: none;
}
.urssaf-dashboard .header::after {
  display: none;
}
.urssaf-dashboard .header h1 {
  font-family: var(--body-font);
  font-size: 2.8em;
  margin-bottom: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  position: relative;
  z-index: 1;
  background: linear-gradient(90deg, var(--basalte) 0%, var(--primary) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: none;
}
.urssaf-dashboard .header p {
  font-size: 1.15em;
  opacity: 0.8;
  margin: 8px 0;
  font-weight: 400;
  position: relative;
  z-index: 1;
  color: var(--text-secondary);
}
.urssaf-dashboard .header .date-info {
  font-size: 0.95em;
  opacity: 0.85;
  margin-top: 16px;
  font-weight: 300;
  position: relative;
  z-index: 1;
}
@keyframes urssaf-float {
  0%, 100% {
    transform: translate(0, 0) rotate(0deg);
  }
  33% {
    transform: translate(30px, -30px) rotate(120deg);
  }
  66% {
    transform: translate(-20px, 20px) rotate(240deg);
  }
}
.urssaf-dashboard .tabs-nav {
  margin-top: calc(-1 * var(--gap-xl, 30px));
}
@keyframes urssaf-fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.urssaf-dashboard .controls {
  background: var(--bg-card);
  padding: var(--gap-xl, 30px);
  box-shadow: none;
  border: 1px solid rgba(var(--white-rgb), 0.05);
  position: relative;
  margin-top: 0;
  border-radius: 0 0 var(--radius-lg, 16px) var(--radius-lg, 16px);
  z-index: 10;
  margin-bottom: var(--gap-3xl, 40px);
}
.urssaf-dashboard .control-group {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--gap-xl, 1.25rem);
  margin-bottom: var(--gap-xl, 1.25rem);
}
.urssaf-dashboard .control-item {
  display: flex;
  flex-direction: column;
}
.urssaf-dashboard .control-item label {
  font-family: var(--body-font);
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--primary);
  font-size: 0.9em;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.urssaf-dashboard .control-item select,
.urssaf-dashboard .control-item input[type=text] {
  padding: var(--gap-sm, 0.75rem) var(--gap-md, 1rem);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 8px);
  font-size: 0.95em;
  transition: var(--transition);
  background: var(--bg-app);
  color: var(--text-primary);
  font-family: inherit;
  font-weight: 500;
}
.urssaf-dashboard .control-item select:focus,
.urssaf-dashboard .control-item input[type=text]:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(var(--primary-rgb), 0.1);
  background: rgba(var(--black-rgb), 0.4);
}
.urssaf-dashboard .control-item select:hover,
.urssaf-dashboard .control-item input[type=text]:hover {
  border-color: rgba(var(--white-rgb), 0.2);
}
.urssaf-dashboard .control-item select option,
.urssaf-dashboard .control-item input[type=text] option {
  background: var(--bg-card);
  color: var(--text-primary);
}
.urssaf-dashboard .period-info {
  margin-top: 6px;
  padding: 8px 12px;
  background: rgba(var(--primary-rgb), 0.05);
  border: 1px solid rgba(var(--primary-rgb), 0.1);
  border-radius: 6px;
  display: none;
}
.urssaf-dashboard .period-info.show {
  display: block;
}
.urssaf-dashboard .period-info small {
  color: var(--primary);
  font-size: 0.85em;
  font-weight: 500;
}
.urssaf-dashboard .action-buttons {
  display: flex;
  gap: var(--gap-lg, 1rem);
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--gap-xl, 1.25rem);
}
.urssaf-dashboard .btn {
  padding: var(--gap-sm, 12px) var(--gap-xl, 24px);
  border: 1px solid transparent;
  border-radius: var(--radius-sm, 8px);
  cursor: pointer;
  font-size: 0.9em;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all 0.3s ease;
  font-family: var(--body-font);
  position: relative;
  overflow: hidden;
}
.urssaf-dashboard .btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(rgba(var(--white-rgb), 0.1), transparent);
  opacity: 0;
  transition: opacity 0.3s;
}
.urssaf-dashboard .btn:hover::before {
  opacity: 1;
}
.urssaf-dashboard .btn-info {
  background: rgba(var(--primary-rgb), 0.1);
  color: var(--primary);
  border-color: rgba(var(--primary-rgb), 0.3);
  box-shadow: 0 0 15px rgba(var(--primary-rgb), 0.05);
}
.urssaf-dashboard .btn-info:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 25px rgba(var(--primary-rgb), 0.2);
  border-color: var(--primary);
  background: rgba(var(--primary-rgb), 0.15);
}
.urssaf-dashboard .stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--gap-lg);
  padding: 0 var(--gap-xl) var(--gap-3xl) var(--gap-xl);
  background: transparent;
}
.urssaf-dashboard .stat-card {
  background: var(--bg-card);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}
.urssaf-dashboard .stat-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(var(--white-rgb), 0.8), transparent);
  z-index: 1;
}
.urssaf-dashboard .stat-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
}
.urssaf-dashboard .stat-card {
  padding: var(--gap-xl);
  min-height: 180px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 180px;
}
.urssaf-dashboard .stat-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 25%;
  bottom: 25%;
  width: 3px;
  background: var(--primary);
  border-radius: 0 4px 4px 0;
  box-shadow: 0 0 10px rgba(var(--primary-rgb), 0.5);
  transition: all 0.3s ease;
}
.urssaf-dashboard .stat-card:hover::before {
  top: 0;
  bottom: 0;
  box-shadow: none;
}
.urssaf-dashboard .stat-card:hover .stat-header i {
  transform: scale(1.1);
  color: var(--accent-magenta);
}
.urssaf-dashboard .stat-card .stat-header {
  display: flex;
  align-items: center;
  gap: var(--gap-md);
  margin-bottom: var(--gap-md);
}
.urssaf-dashboard .stat-card .stat-header i {
  font-size: 1.4rem;
  color: var(--primary);
  opacity: 0.8;
  transition: all 0.3s ease;
}
.urssaf-dashboard .stat-card .stat-header h3 {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-weight: 600;
  font-family: var(--font-body);
}
.urssaf-dashboard .stat-card .urssaf-value {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--text-contrast) !important;
  margin: auto 0;
  line-height: 1;
  letter-spacing: -1px;
  text-shadow: none;
}
.urssaf-dashboard .stat-card .change {
  font-size: 0.8rem;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  margin-top: var(--gap-md);
  color: var(--text-muted);
}
.urssaf-dashboard .stat-card .change i {
  font-size: 0.9em;
  opacity: 0.7;
}
.urssaf-dashboard .stat-card .change.positive {
  color: var(--accent-lime);
}
.urssaf-dashboard .stat-card .change.negative {
  color: var(--accent-orange);
}
.urssaf-dashboard .stat-card .change.label-activite {
  font-weight: 400;
  font-style: italic;
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  opacity: 0.8;
}
.urssaf-dashboard .stat-card.card-dominante::before {
  background: var(--secondary);
  box-shadow: 0 0 10px rgba(var(--secondary-rgb), 0.5);
}
.urssaf-dashboard .stat-card.card-dominante .stat-header i {
  color: var(--secondary);
}
.urssaf-dashboard .stat-card.card-dominante .urssaf-value {
  font-size: 1.8rem;
}
.urssaf-dashboard .stat-card.card-dominante:hover {
  border-color: rgba(var(--secondary-rgb), 0.3);
}
.urssaf-dashboard .stat-card.card-dominante:hover::before {
  box-shadow: 0 0 15px rgba(var(--secondary-rgb), 0.8);
}
.urssaf-dashboard .charts-container {
  padding: 0 var(--gap-xl, 30px) var(--gap-3xl, 40px) var(--gap-xl, 30px);
}
.urssaf-dashboard .chart-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: var(--gap-xl, 2rem);
}
.urssaf-dashboard .urssaf-chart-wrapper {
  background: var(--glass-bg);
  padding: var(--gap-xl, 30px);
  border-radius: var(--radius-md, 12px);
  margin-bottom: var(--gap-2xl, 32px);
  box-shadow: none;
  border: var(--glass-border);
  stroke: none;
  transition: var(--transition);
  position: relative;
  height: var(--chart-h-xl, 450px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: urssaf-fadeInUp 0.6s ease-out backwards;
  backdrop-filter: blur(5px);
}
.urssaf-dashboard .urssaf-chart-wrapper canvas {
  flex: 1;
  min-height: 0;
}
.urssaf-dashboard .urssaf-chart-wrapper:hover {
  border-color: rgba(var(--primary-rgb), 0.3);
  box-shadow: 0 0 20px rgba(var(--black-rgb), 0.2);
}
.urssaf-dashboard .urssaf-chart-wrapper h2 {
  margin-bottom: var(--gap-xl, 24px);
  color: var(--text-primary);
  font-size: 1.2em;
  font-weight: 600;
  position: relative;
  padding-bottom: var(--gap-xs, 12px);
  font-family: var(--body-font);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.urssaf-dashboard .urssaf-chart-wrapper h2::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40px;
  height: 2px;
  background: var(--primary);
  border-radius: 0;
  box-shadow: 0 0 10px rgba(var(--primary-rgb), 0.5);
}
@keyframes urssaf-fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.urssaf-dashboard canvas {
  max-width: 100%;
  display: block;
}
.urssaf-dashboard .table-wrapper {
  background: var(--glass-bg);
  padding: var(--gap-xl, 30px);
  border-radius: var(--radius-md, 12px);
  margin: var(--gap-3xl, 40px) var(--gap-xl, 30px);
  box-shadow: none;
  border: var(--glass-border);
  backdrop-filter: blur(5px);
}
.urssaf-dashboard .table-wrapper h2 {
  margin-bottom: var(--gap-xl, 24px);
  color: var(--text-primary);
  font-size: 1.2em;
  font-weight: 600;
  position: relative;
  padding-bottom: var(--gap-xs, 12px);
  font-family: var(--body-font);
  text-transform: uppercase;
}
.urssaf-dashboard .table-wrapper h2::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40px;
  height: 2px;
  background: var(--primary);
  box-shadow: 0 0 10px rgba(var(--primary-rgb), 0.5);
}
.urssaf-dashboard .table-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--gap-xl, 20px);
  flex-wrap: wrap;
  gap: var(--gap-lg, 15px);
}
.urssaf-dashboard .table-controls .btn-export {
  background: rgba(var(--secondary-rgb), 0.1);
  color: var(--secondary);
  border: 1px solid rgba(var(--secondary-rgb), 0.3);
}
.urssaf-dashboard .table-controls .btn-export:hover {
  background: rgba(var(--secondary-rgb), 0.2);
  border-color: var(--secondary);
  box-shadow: 0 0 15px rgba(var(--secondary-rgb), 0.15);
}
.urssaf-dashboard .table-container {
  overflow-x: auto;
  max-height: 600px;
  overflow-y: auto;
  border-radius: 8px;
  border: 1px solid rgba(var(--white-rgb), 0.05);
}
.urssaf-dashboard .table-container table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9em;
}
.urssaf-dashboard .table-container table thead {
  position: sticky;
  top: 0;
  z-index: 10;
}
.urssaf-dashboard .table-container table thead th {
  background: rgba(var(--bg-app-rgb), 0.95);
  color: var(--primary);
  padding: var(--gap-md, 16px) var(--gap-sm, 14px);
  text-align: left;
  font-weight: 600;
  white-space: nowrap;
  font-size: 0.9em;
  text-transform: uppercase;
  letter-spacing: 1px;
  border-bottom: 2px solid rgba(var(--primary-rgb), 0.3);
  font-family: var(--body-font);
}
.urssaf-dashboard .table-container table td {
  padding: var(--gap-sm, 14px) var(--gap-xs, 12px);
  border-bottom: 1px solid rgba(var(--white-rgb), 0.05);
  transition: var(--transition);
  color: var(--text-secondary);
}
.urssaf-dashboard .table-container table tbody tr {
  transition: var(--transition);
}
.urssaf-dashboard .table-container table tbody tr:hover {
  background: rgba(var(--primary-rgb), 0.03);
}
.urssaf-dashboard .table-container table tbody tr:hover td {
  color: var(--text-primary);
}
.urssaf-dashboard .table-container table tbody tr:nth-child(even) {
  background: rgba(var(--white-rgb), 0.01);
}
.urssaf-dashboard .table-container table tbody tr:nth-child(even):hover {
  background: rgba(var(--primary-rgb), 0.03);
}
.urssaf-dashboard .urssaf-loading {
  text-align: center;
  padding: var(--gap-4xl, 60px) var(--gap-xl, 20px);
  font-size: 1.1em;
  color: var(--primary);
  font-weight: 500;
  position: relative;
  text-shadow: 0 0 10px rgba(var(--primary-rgb), 0.3);
}
.urssaf-dashboard .urssaf-loading::before {
  content: "";
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 40px;
  border: 4px solid rgba(var(--primary-rgb), 0.1);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: urssaf-spin 1s linear infinite;
  box-shadow: 0 0 15px rgba(var(--primary-rgb), 0.2);
}
.urssaf-dashboard .urssaf-loading::after {
  content: "...";
  animation: urssaf-dots 1.5s steps(4, end) infinite;
}
@keyframes urssaf-spin {
  0% {
    transform: translateX(-50%) rotate(0deg);
  }
  100% {
    transform: translateX(-50%) rotate(360deg);
  }
}
@keyframes urssaf-dots {
  0%, 20% {
    content: ".";
  }
  40% {
    content: "..";
  }
  60%, 100% {
    content: "...";
  }
}
.urssaf-dashboard .footer {
  background: transparent;
  border-top: 1px solid rgba(var(--white-rgb), 0.05);
  color: var(--text-muted);
  padding: var(--gap-3xl, 40px) var(--gap-xl, 30px);
  text-align: center;
  position: relative;
  overflow: hidden;
  margin-top: var(--gap-4xl, 60px);
}
.urssaf-dashboard .footer::before {
  display: none;
}
.urssaf-dashboard .footer p {
  margin: 8px 0;
  font-weight: 400;
  font-size: 0.9em;
}
.urssaf-dashboard .footer .footer-note {
  font-size: 0.85em;
  opacity: 0.6;
  margin-top: 16px;
}

@media (max-width: 768px) {
  .urssaf-dashboard {
    padding: 10px;
  }
  .urssaf-dashboard .header h1 {
    font-size: 1.8em;
  }
  .urssaf-dashboard .header p {
    font-size: 1em;
  }
  .urssaf-dashboard .control-group,
  .urssaf-dashboard .stats-grid,
  .urssaf-dashboard .chart-row {
    grid-template-columns: 1fr;
  }
  .urssaf-dashboard .action-buttons {
    flex-direction: column;
  }
  .urssaf-dashboard .btn {
    width: 100%;
  }
  .urssaf-dashboard .container {
    overflow-x: hidden;
  }
}
/* Styles pour la page de sélection d'espace avec prévisualisation */
.share-infographic-container {
  display: flex;
  min-height: auto;
  /* Hauteur automatique */
  max-height: 100vh;
  /* Hauteur maximale */
  background: var(--bg-app);
  margin-top: calc(var(--navbar-height, 88px) * -1);
  /* Compenser la navbar */
  padding-top: var(--navbar-height, 88px);
  /* Ajouter le padding pour la navbar */
}

.share-selection-panel {
  flex: 0 0 400px;
  background: var(--bg-surface);
  border-right: 1px solid var(--border);
  padding: var(--gap-xl, 2rem);
  overflow-y: auto;
}

.share-preview-panel {
  flex: 1;
  background: var(--bg-card);
  display: flex;
  flex-direction: column;
  padding: var(--gap-xs, 0.5rem);
  /* Réduire encore plus le padding */
  min-height: auto;
  /* Hauteur automatique */
  max-height: 100vh;
  /* Hauteur maximale */
}

.panel-header {
  margin-bottom: 2rem;
}

.panel-header h1 {
  color: var(--text-primary);
  font-size: 1.8rem;
  margin-bottom: var(--gap-xs, 0.5rem);
}

.panel-header p {
  color: var(--text-secondary);
  font-size: 1rem;
}

.preview-header {
  margin-bottom: var(--gap-xs, 0.5rem);
  /* Réduire encore plus la marge */
  padding: 0.25rem 0;
  /* Réduire le padding */
}

.preview-header h2 {
  color: var(--text-primary);
  font-size: 1.1rem;
  /* Réduire encore plus la taille */
  margin-bottom: 0.15rem;
  /* Réduire encore plus la marge */
  line-height: 1.2;
  /* Réduire l'interligne */
}

.preview-header p {
  color: var(--text-secondary);
  font-size: 0.8rem;
  /* Réduire encore plus la taille */
  margin: 0;
  /* Supprimer les marges */
  line-height: 1.2;
  /* Réduire l'interligne */
}

/* Informations de l'infographie */
.infographic-info {
  background: var(--bg-surface-glass);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--gap-lg, 1.5rem);
  margin-bottom: var(--gap-xl, 2rem);
}

.infographic-info h3 {
  color: var(--text-primary);
  font-size: 1.2rem;
  margin-bottom: 1rem;
}

.info-grid {
  display: grid;
  gap: 0.75rem;
}

.info-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--gap-sm, 0.5rem) 0;
  border-bottom: 1px solid var(--border);
  gap: var(--gap-md, 1rem);
  /* Espacement entre label et valeur */
}

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

.info-label {
  color: var(--text-secondary);
  font-weight: 500;
  min-width: 80px;
  /* Largeur minimale fixe */
  flex-shrink: 0;
  /* Empêcher la réduction */
}

.info-value {
  color: var(--text-primary);
  font-weight: 600;
  white-space: nowrap;
  /* Empêcher le retour à la ligne */
  overflow: hidden;
  /* Masquer le débordement */
  text-overflow: ellipsis;
  /* Ajouter des points de suspension */
  max-width: 200px;
  /* Limiter la largeur */
  text-align: right;
  /* Aligner à droite */
  position: relative;
  /* Pour le tooltip */
}

/* Tooltip pour les longs textes */
.info-value:hover::after {
  content: attr(title);
  position: absolute;
  bottom: 100%;
  right: 0;
  background: var(--bg-surface-alt);
  color: var(--text-primary);
  padding: var(--gap-sm, 0.5rem);
  border-radius: var(--radius-sm);
  font-size: 0.8rem;
  white-space: nowrap;
  z-index: 1000;
  box-shadow: 0 4px 12px rgba(var(--black-rgb), 0.3);
  border: 1px solid var(--border);
}

.info-value.code {
  font-family: var(--font-code);
  font-size: 0.85rem;
  background: var(--bg-surface-alt);
  padding: var(--gap-xs, 0.25rem) var(--gap-sm, 0.5rem);
  border-radius: var(--radius-sm);
}

/* Sélection d'espace */
.space-selection {
  margin-bottom: 2rem;
}

.space-selection h3 {
  color: var(--text-primary);
  font-size: 1.2rem;
  margin-bottom: 1rem;
}

.spaces-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.space-option {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: all var(--transition-base);
}

.space-option:hover {
  border-color: var(--primary);
  box-shadow: 0 4px 12px rgba(var(--primary-rgb), 0.15);
}

.space-radio {
  display: flex;
  align-items: flex-start;
  padding: 1rem;
  cursor: pointer;
  position: relative;
}

.space-radio input[type=radio] {
  display: none;
}

.radio-custom {
  width: 20px;
  height: 20px;
  border: 2px solid var(--border);
  border-radius: 50%;
  margin-right: var(--gap-md, 1rem);
  margin-top: 0.25rem;
  position: relative;
  transition: all var(--transition-base);
}

.space-radio input[type=radio]:checked + .radio-custom {
  border-color: var(--primary);
  background: var(--primary);
}

.space-radio input[type=radio]:checked + .radio-custom::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  background: var(--white);
  border-radius: 50%;
}

.space-info {
  flex: 1;
}

.space-info h4 {
  color: var(--text-primary);
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
}

.space-info p {
  color: var(--text-secondary);
  font-size: 0.9rem;
  margin-bottom: 0.75rem;
}

.space-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.role-badge {
  padding: 0.25rem var(--gap-sm, 0.5rem);
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
}

.role-admin {
  background: var(--primary);
  color: var(--bg-app);
}

.role-validator {
  background: var(--warning);
  color: var(--bg-app);
}

.role-editor {
  background: var(--info);
  color: var(--white);
}

.role-reader {
  background: var(--text-secondary);
  color: var(--bg-app);
}

.member-count,
.infographic-count {
  color: var(--text-secondary);
  font-size: 0.8rem;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

/* Informations complémentaires */
.share-details {
  margin-bottom: 2rem;
}

.share-details h3 {
  color: var(--text-primary);
  font-size: 1.2rem;
  margin-bottom: 1rem;
}

.share-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

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

.form-group input,
.form-group textarea {
  padding: 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-surface-glass);
  color: var(--text-primary);
  font-size: 1rem;
  transition: all var(--transition-base);
}

.form-group input:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(var(--primary-rgb), 0.2);
}

/* Actions */
.share-actions {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
}

/* Prévisualisation */
.preview-container {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  overflow: hidden;
  position: relative;
}

.infographic-preview-image {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: var(--radius-md);
}

.preview-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}

.preview-content {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  padding: var(--gap-xl, 2rem);
  text-align: center;
  max-width: 400px;
  width: 100%;
}

.preview-header-tourisme {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--gap-xl, 2rem);
  padding-bottom: var(--gap-md, 1rem);
  border-bottom: 1px solid var(--border);
}

.preview-ht-center h3 {
  color: var(--primary);
  font-size: 1.2rem;
  margin-bottom: var(--gap-sm, 0.5rem);
}

.preview-ht-center h4 {
  color: var(--text-primary);
  font-size: 1.5rem;
  margin-bottom: 0.25rem;
}

.preview-ht-center h5 {
  color: var(--text-secondary);
  font-size: 1rem;
}

.preview-logo-placeholder {
  width: 60px;
  height: 40px;
  background: var(--bg-surface-alt);
  border-radius: var(--radius-sm);
}

.preview-chart-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  color: var(--text-secondary);
  font-size: 1.1rem;
}

.preview-chart-placeholder i {
  font-size: 3rem;
  color: var(--primary);
}

.preview-info {
  margin-top: 0.25rem;
  /* Réduire encore plus la marge */
  padding-top: 0.25rem;
  /* Réduire le padding */
  border-top: 1px solid var(--border);
}

.preview-meta {
  display: flex;
  justify-content: space-between;
  color: var(--text-secondary);
  font-size: 0.7rem;
  /* Réduire encore plus la taille */
  line-height: 1.1;
  /* Réduire l'interligne */
}

/* Styles pour l'aperçu live */
.live-preview-wrapper {
  position: relative;
  width: 100%;
  height: auto;
  /* Hauteur automatique basée sur le contenu */
  min-height: 600px;
  /* Hauteur minimale raisonnable */
  max-height: calc(100vh - 100px);
  /* Hauteur maximale avec marge */
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--bg-card);
}

.infographic-live-preview {
  width: 100%;
  height: auto;
  /* Hauteur automatique basée sur le contenu */
  min-height: 600px;
  /* Hauteur minimale */
  border: 0;
}

/* Ajuster la hauteur du conteneur de prévisualisation */
.preview-container {
  flex: 1;
  display: flex;
  align-items: flex-start;
  /* Aligner en haut au lieu d'étirer */
  justify-content: center;
  background: var(--bg-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  overflow: hidden;
  position: relative;
  min-height: 600px;
  /* Hauteur minimale raisonnable */
  max-height: calc(100vh - 120px);
  /* Hauteur maximale */
}

/* Mode embed pour l'infographie */
body.embedded .filters-section,
body.embedded .download-action-container {
  display: none !important;
}

body.embedded .dataviz-header {
  display: none !important;
  /* Masquer complètement l'en-tête */
}

body.embedded .page-wrapper {
  padding-top: 0;
}

body.embedded .main-content {
  padding-top: 0;
}

/* Responsive */
@media (max-width: 1024px) {
  .share-infographic-container {
    flex-direction: column;
  }
  .share-selection-panel {
    flex: none;
    order: 2;
  }
  .share-preview-panel {
    flex: none;
    order: 1;
    min-height: 400px;
  }
}
@media (max-width: 768px) {
  .share-selection-panel,
  .share-preview-panel {
    padding: 1rem;
  }
  .share-actions {
    flex-direction: column;
  }
  .space-meta {
    flex-direction: column;
    align-items: flex-start;
  }
}
/* Styles pour les espaces partagés désactivés */
.space-disabled {
  opacity: 0.6;
  pointer-events: none;
}

.space-disabled .space-radio {
  cursor: not-allowed;
}

.space-disabled .space-radio input[type=radio] {
  cursor: not-allowed;
}

.space-disabled .space-radio input[type=radio]:checked + .radio-custom {
  border-color: var(--text-muted);
  background-color: var(--text-muted);
}

.permission-warning {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem 0.5rem;
  background-color: var(--warning-color);
  color: var(--light-text);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 500;
}

.permission-warning i {
  color: var(--light-text);
}

/* Message d'information sur les permissions */
.spaces-list:before {
  content: "💡 Seuls les espaces où vous avez le rôle 'Éditeur' ou 'Admin' permettent de partager des infographies.";
  display: block;
  margin-bottom: var(--gap-md, 1rem);
  padding: var(--gap-sm, 0.75rem);
  background-color: var(--info);
  color: var(--white);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  line-height: 1.4;
}

/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/* ==========================================================================
   PAGE: Excursionnistes & Comparaison
   Layouts et composants spécifiques aux tableaux de bord
   ========================================================================== */
/* --- Sections --- */
.section {
  margin-bottom: var(--gap-2xl, 70px);
}

.section-title {
  font-family: var(--display-font, "Orbitron", sans-serif);
  font-size: clamp(1.8rem, 4vw, 2.2rem);
  color: var(--text-contrast);
  text-align: center;
  margin-bottom: var(--gap-2xl, 40px);
  letter-spacing: 1.5px;
  position: relative;
  padding-bottom: var(--gap-lg, 15px);
}
.section-title span {
  color: var(--secondary);
  margin-right: var(--gap-sm, 10px);
}
.section-title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 3px;
  background: linear-gradient(90deg, var(--secondary), var(--primary));
  border-radius: 2px;
  box-shadow: 0 0 8px rgba(var(--secondary-rgb), 0.5), 0 0 4px rgba(var(--primary-rgb), 0.4);
}

/* --- Grille de Dashboard --- */
.dashboard-grid {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: var(--gap-xl, 25px);
}
@media (max-width: 1024px) {
  .dashboard-grid {
    grid-template-columns: 1fr;
  }
}

.dashboard-column {
  display: flex;
  flex-direction: column;
  gap: var(--gap-xl, 25px);
}

.kpi-column {
  min-width: 300px;
}
@media (max-width: 1024px) {
  .kpi-column {
    min-width: unset;
  }
}

.key-figures-section {
  margin-bottom: 3rem;
}

.key-figures-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--gap-xl, 20px);
  min-height: 400px;
  padding: 0;
}

.thematic-group {
  display: contents;
}

.key-figures-grid .key-figure-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 200px;
}

.charts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--gap-xl, 20px);
  padding: var(--gap-xl, 20px);
}

/* --- Cartes Indicateurs (Key Figure Card / KPI) --- */
.key-figure-card,
.figure-card {
  background: linear-gradient(145deg, rgba(var(--bg-surface-alt-rgb), 0.7), rgba(var(--bg-surface-rgb), 0.8));
  backdrop-filter: blur(10px);
  border-radius: var(--radius-md);
  padding: var(--gap-xl, 25px) var(--gap-xl, 20px);
  border: 1px solid var(--border-subtle);
  border-top-color: var(--border-glow);
  box-shadow: 0 5px 15px rgba(var(--black-rgb), 0.3);
  display: flex;
  flex-direction: column;
  transition: transform var(--transition-base), box-shadow var(--transition-base), background-color var(--transition-base);
}
.key-figure-card:hover,
.figure-card:hover {
  transform: scale(1.02);
  box-shadow: 0 8px 20px rgba(var(--primary-rgb), 0.15);
  background: linear-gradient(145deg, rgba(var(--bg-surface-alt-rgb), 0.8), rgba(var(--bg-surface-rgb), 0.9));
}
.key-figure-card:hover .key-figure-icon,
.key-figure-card:hover .icon,
.figure-card:hover .key-figure-icon,
.figure-card:hover .icon {
  transform: scale(1.2);
  color: var(--accent-magenta);
}
.key-figure-card:hover .key-figure-value,
.key-figure-card:hover .value,
.figure-card:hover .key-figure-value,
.figure-card:hover .value {
  color: var(--primary);
}

.key-figure-card .card-header,
.figure-card .card-header {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 15px;
}

.key-figure-card .key-figure-icon,
.figure-card .icon {
  font-size: 1.6rem;
  color: var(--primary);
  flex-shrink: 0;
  transition: transform var(--transition-base), color var(--transition-base);
}

.key-figure-card .indicator-title,
.figure-card .indicator-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--text-muted);
}

.key-figure-card .key-figure-content,
.figure-card .card-body {
  margin-bottom: 15px;
}

.key-figure-card .key-figure-value,
.figure-card .value {
  font-size: 2.8rem;
  font-weight: 700;
  color: var(--text-contrast);
  margin-bottom: 2px;
  line-height: 1.1;
  transition: color var(--transition-base);
}

.key-figure-card .key-figure-label,
.figure-card .indicator-title {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: var(--gap-xs, 8px);
}

.key-figure-card .key-figure-subtitle,
.figure-card .value-prev-year {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-top: var(--gap-xs, 5px);
  margin-bottom: 7px;
  font-weight: 500;
  display: block;
}

.key-figure-card .unit,
.figure-card .unit {
  font-size: 0.9rem;
  color: var(--text-muted);
}

.key-figure-card .card-footer,
.figure-card .card-footer {
  margin-top: auto;
}

.key-figure-card .comparison,
.figure-card .comparison {
  font-size: 0.9rem;
  font-weight: 700;
}
.key-figure-card .comparison.positive,
.figure-card .comparison.positive {
  color: var(--positive);
}
.key-figure-card .comparison.negative,
.figure-card .comparison.negative {
  color: var(--negative);
}
.key-figure-card .comparison.neutral,
.figure-card .comparison.neutral {
  color: var(--text-muted);
}

.key-figure-card .remark,
.figure-card .remark {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin-top: var(--gap-xs, 8px);
  font-style: italic;
  display: block;
}

/* --- Cartes Graphiques (Chart Card) --- */
.chart-card {
  position: relative;
  transition: all var(--duration-base) var(--easing-out);
  transform-style: preserve-3d;
  perspective: 1000px;
}
.chart-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.chart-container {
  position: relative;
  height: 300px;
  width: 100%;
  margin-bottom: var(--gap-lg, 15px);
  padding: var(--gap-lg, 15px);
}

.chart-summary,
.highlight-info {
  font-size: 0.85rem;
  color: var(--text-muted);
  text-align: center;
  margin: var(--gap-lg, 15px) var(--gap-xl, 20px) var(--gap-xl, 20px);
  padding-top: var(--gap-lg, 15px);
  border-top: 1px dashed var(--border-subtle);
}
.chart-summary strong,
.highlight-info strong {
  color: var(--primary);
  font-weight: 700;
}

/* --- Panneaux Génériques --- */
.panel {
  background: rgba(var(--bg-surface-rgb), 0.6);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
  overflow: hidden;
  box-shadow: 0 5px 15px rgba(var(--black-rgb), 0.15);
  display: flex;
  flex-direction: column;
}

.panel-title {
  background: var(--bg-card);
  color: var(--text-contrast);
  padding: var(--gap-lg, 15px) var(--gap-xl, 20px);
  margin: 0;
  font-size: 1.2rem;
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.panel-title i {
  margin-right: var(--gap-sm, 10px);
  color: var(--primary);
}

.panel > *:not(.panel-title) {
  flex-grow: 1;
}

/* --- Système d'Onglets --- */
/* --- Messages d'état --- */
.key-figures-grid .loading,
.key-figures-grid .error,
.key-figures-grid .info {
  text-align: center;
  padding: var(--gap-2xl, 40px);
  color: var(--text-muted);
  font-style: italic;
  background: rgba(var(--bg-app-rgb), 0.3);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(var(--primary-rgb), 0.1);
  grid-column: 1/-1;
}

.key-figures-grid .error {
  color: var(--negative);
  font-weight: bold;
}

/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/* ==========================================================================
   PAGE: Comparaison (Overrides)
   Styles spécifiques au tableau de bord de comparaison
   ========================================================================== */
/* Period picker - Ajustement layout */
.period-picker-wrap {
  position: static;
  margin-top: var(--gap-xs, 8px);
  z-index: 10001;
  width: 100%;
  display: flex;
  justify-content: center;
}

.period-picker-input {
  margin-left: auto;
  margin-right: auto;
}

/* Grille spécifique pour afficher deux graphiques (Durée de séjour FR/INTL) */
.comparison-results .charts-grid.charts-grid-two {
  display: grid;
  grid-template-columns: 1fr 1fr !important;
  gap: var(--gap-xl, 20px);
}
.comparison-results .charts-grid.charts-grid-two > .chart-card:first-child {
  grid-column: auto !important;
}
@media (max-width: 900px) {
  .comparison-results .charts-grid.charts-grid-two {
    grid-template-columns: 1fr !important;
    gap: var(--gap-lg, 16px);
  }
}

/* Hauteurs dédiées des charts */
.comparison-results .chart-container {
  height: 320px;
}
@media (max-width: 1200px) {
  .comparison-results .chart-container {
    height: 300px;
  }
}
@media (max-width: 900px) {
  .comparison-results .chart-container {
    height: 280px;
  }
}
@media (max-width: 600px) {
  .comparison-results .chart-container {
    height: 260px;
  }
}

/* Placeholder pour la mobilité interne */
.mobility-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  text-align: center;
  padding: var(--gap-xl, 2rem);
}
.mobility-placeholder i {
  margin-bottom: var(--gap-md, 1rem);
}

/* Section bouton infographie dans main-content */
.infographie-action-section {
  margin: var(--gap-xl, 2rem) 0;
  padding: 0;
}

.infographie-action-container {
  display: flex;
  justify-content: center;
  align-items: center;
}

.header-main {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--gap-xl, 2rem);
  width: 100%;
}

.header-text {
  flex: 1;
}

.header-actions {
  flex-shrink: 0;
}

.btn-infographie {
  display: flex;
  align-items: center;
  gap: var(--gap-sm, 12px);
  padding: var(--gap-lg, 16px) var(--gap-xl, 20px);
  background: linear-gradient(135deg, var(--secondary) 0%, rgba(var(--secondary-rgb), 0.7) 100%);
  border: none;
  border-radius: var(--radius-lg);
  color: var(--white);
  text-decoration: none;
  font-weight: 600;
  transition: all var(--transition-base);
  box-shadow: 0 4px 15px rgba(var(--blue-excursion-rgb, 102, 126, 234), 0.3);
  position: relative;
  overflow: hidden;
}
.btn-infographie::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(var(--white-rgb), 0.2), transparent);
  transition: left 0.5s ease;
}
.btn-infographie:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(var(--blue-excursion-rgb, 102, 126, 234), 0.4);
  color: var(--white);
  text-decoration: none;
}
.btn-infographie:hover::before {
  left: 100%;
}
.btn-infographie:active {
  transform: translateY(0);
}

/* ==========================================================================
   VISIBILITY & LAYOUT HARMONIZATION
   ========================================================================== */
/* Fix pour la visibilité des onglets */
.tab-pane {
  display: none;
}
.tab-pane.active {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* Grille de Graphiques Harmonisée (1 Large + 2 Side-by-Side) */
.charts-grid.charts-grid-two {
  display: grid;
  grid-template-columns: 1fr 1fr !important;
  gap: var(--gap-xl, 20px);
}
.charts-grid.charts-grid-two > .chart-card:first-child {
  grid-column: 1/span 2 !important;
}
@media (max-width: 992px) {
  .charts-grid.charts-grid-two {
    grid-template-columns: 1fr !important;
  }
  .charts-grid.charts-grid-two > .chart-card:first-child {
    grid-column: auto !important;
  }
}

/* ==========================================================================
   MODULE ADMIN
   Point d'entrée pour les styles de l'administration
   ========================================================================== */
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/* =============================
   Interface de Gestion des Périodes - FluxVision
   Harmonisé avec le design system principal
   ============================= */
/* Container principal */
.periodes-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 20px 20px 40px;
  margin-top: 20px;
  font-family: var(--body-font);
  color: var(--text-primary);
  position: relative;
  /* Removed redundant var declarations if they match site defaults */
}

/* Header avec design harmonisé */
.periodes-header {
  background: var(--bg-surface-glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border);
  color: var(--text-primary);
  padding: 40px;
  border-radius: var(--radius-md);
  margin-bottom: 30px;
  text-align: center;
  box-shadow: var(--shadow-light);
  position: relative;
  overflow: hidden;
}
.periodes-header::before {
  content: "";
  position: absolute;
  top: -100px;
  left: -100px;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, var(--primary) 0%, transparent 70%);
  opacity: 0.1;
  pointer-events: none;
}
.periodes-header::after {
  content: "";
  position: absolute;
  bottom: -80px;
  right: -80px;
  width: 160px;
  height: 160px;
  background: radial-gradient(circle, var(--secondary) 0%, transparent 70%);
  opacity: 0.1;
  pointer-events: none;
}
.periodes-header h1 {
  font-family: var(--body-font);
  font-size: 2.8rem;
  margin-bottom: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  position: relative;
  z-index: 1;
}
.periodes-header p {
  font-size: 1.2rem;
  opacity: 0.8;
  position: relative;
  z-index: 1;
}

/* Stats grid avec design harmonisé */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 25px;
  margin-bottom: 40px;
}

.stat-card {
  background: var(--bg-surface-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  padding: 30px;
  text-align: center;
  transition: var(--transition-base, 0.25s);
  /* Assuming variable name, checking core later if needed */
  position: relative;
  overflow: hidden;
}
.stat-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(45deg, transparent, rgba(var(--white-rgb), 0.1), transparent);
  transform: translateX(-100%);
  transition: transform 0.5s ease;
}
.stat-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 25px rgba(var(--black-rgb), 0.1);
  border-color: var(--primary);
}
.stat-card:hover::before {
  transform: translateX(100%);
}
.stat-card .stat-icon {
  font-size: 2.5rem;
  color: var(--primary);
  margin-bottom: 20px;
  opacity: 1;
  font-weight: 900;
  text-shadow: 0 2px 4px rgba(var(--black-rgb), 0.1);
}
.stat-card .stat-value {
  font-size: 2.5rem;
  font-weight: 800;
  font-family: var(--body-font);
  color: var(--primary);
  margin-bottom: 10px;
}
.stat-card .stat-label {
  color: var(--text-primary);
  opacity: 0.7;
  font-size: 1rem;
  font-weight: 500;
}

/* Sections admin avec design harmonisé */
.admin-section {
  background: var(--bg-surface-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  padding: 35px;
  margin-bottom: 40px;
  transition: all 0.3s ease;
  overflow: hidden;
  position: relative;
}
.admin-section i {
  opacity: 1;
  font-weight: 900;
}

/* Visibility enhancements */
.admin-section i,
.groupe-card i,
.btn i,
.modal-header i,
.fas,
.far,
.fab,
.fal,
.fad {
  opacity: 1 !important;
  font-weight: 900 !important;
}

.fa-calendar-alt,
.fa-calendar-check,
.fa-calendar,
.fa-clock {
  color: var(--primary) !important;
  opacity: 1 !important;
  font-weight: 900 !important;
}

.section-header {
  display: flex;
  align-items: center;
  margin-bottom: 25px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
.section-header h2 {
  margin: 0;
  color: var(--text-primary);
  font-size: 1.6rem;
  font-weight: 600;
  font-family: var(--body-font);
}
.section-header i {
  margin-right: 12px;
  color: var(--primary);
  font-size: 1.4rem;
  opacity: 1;
  font-weight: 900;
}

/* Formulaires harmonisés */
.form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 25px;
  margin-bottom: 25px;
}

.form-group {
  display: flex;
  flex-direction: column;
}
.form-group label {
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 10px;
  font-size: 1rem;
}
.form-group input,
.form-group select {
  padding: 15px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-surface-glass);
  backdrop-filter: blur(10px);
  color: var(--text-primary);
  font-size: 1rem;
  transition: var(--transition-base, 0.25s);
}
.form-group input:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(var(--accent-yellow-rgb), 0.1);
  transform: translateY(-2px);
}

/* Date inputs */
input[type=date] {
  position: relative;
  color-scheme: dark;
}
input[type=date]::-webkit-calendar-picker-indicator {
  background-color: var(--primary);
  border-radius: 3px;
  cursor: pointer;
  filter: invert(1) brightness(1.2);
  opacity: 0.8;
  padding: 2px;
  transition: all 0.3s ease;
}
input[type=date]::-webkit-calendar-picker-indicator:hover {
  opacity: 1;
  transform: scale(1.1);
  background-color: var(--primary);
}

/* Boutons harmonisés */
.btn {
  font-family: var(--body-font);
  padding: 12px 20px;
  border: none;
  background: var(--bg-surface-glass);
  backdrop-filter: blur(10px);
  border-radius: var(--radius-md);
  cursor: pointer;
  font-weight: 600;
  transition: var(--transition-base, 0.25s);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  margin-right: 10px;
  border: 1px solid rgba(var(--white-rgb), 0.1);
  box-shadow: 0 2px 20px rgba(var(--black-rgb), 0.4);
  position: relative;
  overflow: hidden;
  letter-spacing: 0.03em;
  font-size: 1rem;
  color: var(--text-primary);
  gap: 8px;
}
.btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(45deg, transparent, rgba(var(--white-rgb), 0.1), transparent);
  transform: translateX(-100%);
  transition: transform 0.5s ease;
}
.btn:hover {
  background: var(--bg-surface);
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(var(--black-rgb), 0.2);
}
.btn:hover::before {
  transform: translateX(100%);
}
.btn i {
  font-size: 1.1rem;
  opacity: 1;
  font-weight: 900;
}

/* Variantes de boutons */
.btn--primary {
  background: var(--primary);
  color: var(--bg-app);
  border-color: var(--primary);
}
.btn--primary:hover {
  background: var(--primary);
}

.btn--secondary {
  background: var(--secondary);
  color: var(--text-primary);
  border-color: var(--secondary);
}
.btn--secondary:hover {
  background: var(--secondary);
}

.btn--success {
  background: var(--accent-lime);
  color: var(--text-primary);
  border-color: var(--accent-lime);
}

.btn--warning {
  background: var(--primary);
  color: var(--bg-app);
  border-color: var(--primary);
}

.btn--danger {
  background: var(--error);
  color: var(--text-primary);
  border-color: var(--error);
}

.btn--small {
  padding: 6px 12px;
  font-size: 0.85rem;
  border-radius: var(--radius-sm);
}

/* Tables harmonisées */
.periodes-table {
  overflow-x: auto;
  background: var(--bg-surface-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  box-shadow: 0 5px 20px rgba(var(--black-rgb), 0.1);
}
.periodes-table table {
  width: 100%;
  border-collapse: collapse;
  background: transparent;
}
.periodes-table th,
.periodes-table td {
  padding: 15px 20px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  color: var(--text-primary);
}
.periodes-table th {
  background: var(--bg-card);
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.periodes-table tr:hover {
  background: var(--bg-card);
}

/* Badges harmonisés */
.code-badge,
.year-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  background: var(--bg-surface-glass);
  backdrop-filter: blur(10px);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text-primary);
  transition: var(--transition-base, 0.25s);
}

.year-badge {
  background: linear-gradient(45deg, rgba(var(--accent-magenta-rgb), 0.1), rgba(var(--accent-magenta-rgb), 0.2));
  border: 1px solid rgba(var(--accent-magenta-rgb), 0.3);
  color: var(--accent-magenta);
}

.actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

/* Messages harmonisés */
.success-message,
.error-message {
  padding: 15px 20px;
  border-radius: var(--radius-md);
  margin-bottom: 20px;
  font-weight: 500;
  border: 1px solid;
  backdrop-filter: blur(10px);
}

.success-message {
  background: rgba(var(--success-rgb), 0.1);
  border-color: rgba(var(--success-rgb), 0.3);
  color: var(--success);
}

.error-message {
  background: rgba(var(--error-rgb), 0.1);
  border-color: rgba(var(--error-rgb), 0.3);
  color: var(--error);
}

.warning-message {
  background: rgba(var(--warning-rgb), 0.1);
  border: 1px solid rgba(var(--warning-rgb), 0.3);
  color: var(--warning);
  padding: 15px 20px;
  border-radius: var(--radius-md);
  font-weight: 500;
  backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Modales harmonisées */
.modal {
  position: fixed;
  z-index: 1000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(var(--black-rgb), 0.6);
  backdrop-filter: blur(5px);
  display: none;
}

.modal-content {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border);
  margin: 15% auto;
  padding: 0;
  width: 90%;
  max-width: 500px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-light);
  backdrop-filter: blur(20px);
}

.modal-header {
  padding: 20px 25px;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modal-header h3 {
  margin: 0;
  color: var(--text-primary);
  font-family: var(--body-font);
  font-size: 1.4rem;
}

.close {
  color: var(--text-primary);
  font-size: 28px;
  font-weight: bold;
  cursor: pointer;
  transition: var(--transition-base, 0.25s);
  opacity: 0.7;
}
.close:hover {
  opacity: 1;
  color: var(--error);
  transform: scale(1.1);
}

.duplicate-form {
  padding: 25px;
}

.quick-actions {
  display: flex;
  gap: 15px;
  margin-bottom: 30px;
  flex-wrap: wrap;
}

/* Groupes de périodes harmonisés */
.groupes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
  gap: 25px;
  margin-bottom: 40px;
}

.groupe-card {
  background: var(--bg-surface-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  padding: 25px;
  transition: var(--transition-base, 0.25s);
  position: relative;
  overflow: hidden;
}
.groupe-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(45deg, transparent, rgba(var(--white-rgb), 0.05), transparent);
  transform: translateX(-100%);
  transition: transform 0.5s ease;
}
.groupe-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 25px rgba(var(--black-rgb), 0.1);
  border-color: var(--primary);
}
.groupe-card:hover::before {
  transform: translateX(100%);
}

.groupe-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 20px;
}

.groupe-info h3 {
  color: var(--text-primary);
  font-size: 1.3rem;
  font-weight: 600;
  margin-bottom: 5px;
  font-family: var(--body-font);
}

.groupe-stats .stat-badge {
  background: linear-gradient(45deg, rgba(var(--primary-rgb), 0.1), rgba(var(--primary-rgb), 0.2));
  border: 1px solid rgba(var(--primary-rgb), 0.3);
  color: var(--primary);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  font-size: 0.8rem;
  font-weight: 600;
}

.groupe-content {
  margin-bottom: 20px;
}

.periode-range {
  display: flex;
  align-items: center;
  color: var(--text-primary);
  opacity: 0.8;
  margin-bottom: 15px;
  font-size: 0.95rem;
}
.periode-range i {
  margin-right: 8px;
  color: var(--primary);
  font-size: 1.1rem;
}

.annees-disponibles {
  margin-bottom: 20px;
}
.annees-disponibles strong {
  color: var(--text-primary);
  font-size: 0.9rem;
  display: block;
  margin-bottom: 10px;
}

.annees-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.year-tag {
  padding: 6px 12px;
  background: linear-gradient(45deg, rgba(var(--accent-magenta-rgb), 0.1), rgba(var(--accent-magenta-rgb), 0.2));
  border: 1px solid rgba(var(--accent-magenta-rgb), 0.3);
  color: var(--accent-magenta);
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  font-weight: 500;
  transition: var(--transition-base, 0.25s);
}
.year-tag:hover {
  background: linear-gradient(45deg, rgba(var(--accent-magenta-rgb), 0.2), rgba(var(--accent-magenta-rgb), 0.3));
  transform: translateY(-2px);
}

.groupe-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}
.groupe-actions .btn {
  margin: 0;
}

@keyframes fadeInScale {
  from {
    opacity: 0;
    transform: scale(0.9) translateY(20px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}
.groupe-card {
  animation: fadeInScale 0.6s ease forwards;
}

/* Responsive */
@media (max-width: 992px) {
  /* breakpoint-lg */
  .periodes-container {
    padding: 15px;
  }
  .periodes-header {
    padding: 30px 25px;
  }
  .periodes-header h1 {
    font-size: 2.2rem;
  }
  .stats-grid,
  .groupes-grid {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
  }
  .groupe-card {
    padding: 20px;
  }
  .groupe-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .groupe-actions {
    width: 100%;
    justify-content: flex-start;
  }
  .groupe-actions .btn {
    flex: 1;
    min-width: 0;
    font-size: 0.75rem;
    padding: 8px 10px;
  }
  .form-row {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .quick-actions {
    justify-content: center;
    gap: 10px;
  }
  .actions {
    flex-direction: column;
    gap: 5px;
  }
  .btn {
    padding: 12px 16px;
    font-size: 0.9rem;
  }
  .duplicate-form {
    padding: 20px;
  }
  .modal-content {
    width: 95%;
    margin: 10% auto;
  }
}
@media (max-width: 768px) {
  /* breakpoint-md */
  .periodes-header h1 {
    font-size: 1.8rem;
  }
  .periodes-header p {
    font-size: 1rem;
  }
  .admin-section {
    padding: 20px;
  }
  .section-header h2 {
    font-size: 1.3rem;
  }
  .form-group input,
  .form-group select {
    padding: 12px;
  }
  .btn {
    padding: 10px 15px;
    font-size: 0.85rem;
  }
  .groupe-actions .btn {
    padding: 6px 10px;
    font-size: 0.75rem;
  }
}
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Administration des Migrations de BDD
 * Harmonisé avec le design system FluxVision
 */
/* Sélecteur de bases de données */
.db-selector-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
  margin-top: 20px;
}

.db-card {
  background: var(--bg-surface-alt);
  border: 2px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px;
  cursor: pointer;
  transition: var(--transition-base, 0.25s);
  text-align: left;
  position: relative;
  overflow: hidden;
}
.db-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(45deg, transparent, rgba(var(--white-rgb), 0.05), transparent);
  transform: translateX(-100%);
  transition: transform 0.5s ease;
}
.db-card:hover:not(.disabled) {
  transform: translateY(-3px);
  border-color: var(--primary);
  box-shadow: 0 10px 25px rgba(var(--black-rgb), 0.2);
}
.db-card:hover:not(.disabled)::before {
  transform: translateX(100%);
}
.db-card.active {
  border-color: var(--primary);
  background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.1) 0%, rgba(var(--primary-rgb), 0.05) 100%);
}
.db-card.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.db-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.db-card-header i {
  font-size: 1.5rem;
  color: var(--primary);
}

.db-name {
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--text-primary);
  flex: 1;
}

.db-badge {
  background: var(--primary);
  color: var(--bg-app);
  padding: 3px 10px;
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: 600;
}

.db-card-desc {
  color: var(--text-primary);
  opacity: 0.7;
  font-size: 0.9rem;
  margin-bottom: 12px;
}

.db-card-stats {
  color: var(--primary);
  font-weight: 600;
  font-size: 0.95rem;
}

.db-card-error {
  color: var(--error);
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Cartes de statistiques (utilise les styles existants) */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 25px;
  margin-bottom: 40px;
}

.stat-card {
  background: var(--bg-surface-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  padding: 30px;
  display: flex;
  align-items: center;
  gap: 20px;
  transition: var(--transition-base, 0.25s);
  position: relative;
  overflow: hidden;
}
.stat-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(45deg, transparent, rgba(var(--white-rgb), 0.05), transparent);
  transform: translateX(-100%);
  transition: transform 0.5s ease;
}
.stat-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 25px rgba(var(--black-rgb), 0.1);
  border-color: var(--primary);
}
.stat-card:hover::before {
  transform: translateX(100%);
}
.stat-card.stat-card-warning {
  border-color: var(--error);
}
.stat-card.stat-card-warning .stat-icon {
  color: var(--error);
}

.stat-icon {
  font-size: 2.5rem;
  color: var(--primary);
  opacity: 1;
  font-weight: 900;
}

.stat-info {
  flex: 1;
}

.stat-value {
  font-size: 2.5rem;
  font-weight: 800;
  font-family: var(--body-font);
  color: var(--primary);
  line-height: 1;
  margin-bottom: 5px;
}

.stat-label {
  color: var(--text-primary);
  opacity: 0.7;
  font-size: 0.95rem;
  font-weight: 500;
}

/* Grille d'actions */
.actions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 15px;
}

.btn--large {
  padding: 20px;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
}
.btn--large i {
  font-size: 2rem;
}
.btn--large div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.btn--large strong {
  font-size: 1.1rem;
  font-weight: 600;
}
.btn--large small {
  font-size: 0.85rem;
  opacity: 0.8;
  font-weight: 400;
}

/* Toggle header pour section */
.section-toggle-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.section-toggle-header h2 {
  margin: 0;
  flex: 1;
}

.btn--small {
  padding: 8px 16px;
  font-size: 0.9rem;
}

/* Liste des migrations */
.migrations-list {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.migration-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px;
  transition: var(--transition-base, 0.25s);
}
.migration-card:hover {
  transform: translateX(5px);
  border-color: var(--primary);
}

.migration-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.migration-version {
  font-family: var(--font-code, monospace);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--primary);
}

.migration-status {
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  font-size: 0.8rem;
  font-weight: 600;
}
.migration-status.pending {
  background: rgba(var(--warning-rgb), 0.2);
  color: var(--warning);
  border: 1px solid var(--warning);
}
.migration-status.applied {
  background: rgba(var(--success-rgb), 0.2);
  color: var(--success);
  border: 1px solid var(--success);
}
.migration-status.failed {
  background: rgba(var(--error-rgb), 0.2);
  color: var(--error);
  border: 1px solid var(--error);
}

.migration-title {
  font-size: 1rem;
  color: var(--text-primary);
  margin-bottom: 8px;
  font-weight: 500;
}

.migration-meta {
  font-size: 0.85rem;
  color: var(--text-primary);
  opacity: 0.6;
  font-family: var(--font-code, monospace);
}

/* Messages d'alerte */
.alert-box {
  background: var(--bg-surface-alt);
  border-left: 4px solid var(--primary);
  border-radius: var(--radius-md);
  padding: 20px;
  margin: 20px 0;
}
.alert-box.success {
  border-left-color: var(--success);
}
.alert-box.warning {
  border-left-color: var(--warning);
}
.alert-box.error {
  border-left-color: var(--error);
}
.alert-box.info {
  border-left-color: var(--accent-lime);
}
.alert-box h3 {
  margin: 0 0 10px 0;
  color: var(--text-primary);
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  gap: 10px;
}
.alert-box p {
  margin: 0;
  color: var(--text-primary);
  opacity: 0.8;
}
.alert-box ul {
  margin: 10px 0 0 20px;
}
.alert-box ul li {
  margin-bottom: 5px;
}

/* Loader */
.loading-container {
  text-align: center;
  padding: 60px 20px;
}

.spinner {
  border: 4px solid rgba(var(--accent-yellow-rgb), 0.2);
  border-top: 4px solid var(--primary);
  border-radius: 50%;
  width: 50px;
  height: 50px;
  animation: spin 1s linear infinite;
  margin: 0 auto 20px;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.loading-text {
  color: var(--text-primary);
  font-size: 1.1rem;
  opacity: 0.8;
}

/* Générateur de migrations - Onglets */
.migration-generator-tabs {
  display: flex;
  gap: 10px;
  margin-bottom: 25px;
  flex-wrap: wrap;
}

.gen-tab {
  padding: 12px 20px;
  background: var(--bg-surface);
  border: 2px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: var(--transition-base, 0.25s);
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
  color: var(--text-primary);
}
.gen-tab:hover {
  border-color: var(--primary);
  background: var(--bg-surface-alt);
}
.gen-tab.active {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--bg-app);
}
.gen-tab i {
  font-size: 1.1rem;
}

/* Contenu des onglets */
.gen-tab-content {
  display: none;
  padding: 20px 0;
}
.gen-tab-content.active {
  display: block;
}

/* Formulaires */
.migration-form {
  background: var(--bg-surface);
  padding: 25px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
  margin-bottom: 20px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.form-group label {
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.95rem;
}
.form-group input,
.form-group select {
  padding: 12px 15px;
  border: 2px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg-app);
  color: var(--text-primary);
  font-size: 0.95rem;
  transition: var(--transition-base, 0.25s);
}
.form-group input:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(var(--accent-yellow-rgb), 0.2);
}

.form-checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 15px 0;
}
.form-checkbox input[type=checkbox] {
  width: 20px;
  height: 20px;
  cursor: pointer;
}
.form-checkbox label {
  cursor: pointer;
  font-weight: 500;
  color: var(--text-primary);
}

/* Info box générateur */
.generator-info-box {
  background: linear-gradient(135deg, rgba(var(--info-rgb), 0.1), rgba(var(--info-rgb), 0.05));
  border-left: 4px solid var(--accent-lime);
  padding: 15px 20px;
  border-radius: var(--radius-lg);
  margin-bottom: 20px;
  display: flex;
  align-items: flex-start;
  gap: 15px;
}
.generator-info-box i {
  font-size: 1.5rem;
  color: var(--accent-lime);
  flex-shrink: 0;
}
.generator-info-box p {
  margin: 0;
  color: var(--text-primary);
  line-height: 1.6;
}

/* Workflow intelligent */
.smart-workflow {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-top: 30px;
}

.workflow-step {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 20px;
  background: var(--bg-surface-alt);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  transition: var(--transition-base, 0.25s);
}
.workflow-step:hover {
  border-color: var(--primary);
  transform: translateX(5px);
}

.step-number {
  width: 40px;
  height: 40px;
  background: var(--primary);
  color: var(--bg-app);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  font-weight: 700;
  flex-shrink: 0;
}

.step-content {
  flex: 1;
}
.step-content strong {
  display: block;
  font-size: 1.1rem;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.step-content p {
  margin: 0 0 15px 0;
  color: var(--text-primary);
  opacity: 0.8;
}
.step-content .btn {
  margin-top: 10px;
}

/* Colonnes dynamiques (pour créer table) */
.table-column-item {
  background: var(--bg-surface-alt);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 15px;
  margin-bottom: 15px;
  position: relative;
}
.table-column-item .remove-column {
  position: absolute;
  top: 10px;
  right: 10px;
  background: var(--error);
  color: var(--white);
  border: none;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-base, 0.25s);
}
.table-column-item .remove-column:hover {
  background: var(--error);
  transform: scale(1.1);
}

/* Résultat de la détection auto */
.detection-result {
  background: var(--bg-surface-alt);
  border-radius: var(--radius-lg);
  padding: 20px;
  margin-top: 20px;
}

.detection-preview {
  background: var(--bg-app);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 15px;
  font-family: var(--font-code, monospace);
  font-size: 0.9rem;
  color: var(--text-primary);
  max-height: 400px;
  overflow-y: auto;
  white-space: pre-wrap;
  margin: 15px 0;
}

/* Responsive */
@media (max-width: 768px) {
  .stats-grid,
  .db-selector-grid,
  .actions-grid {
    grid-template-columns: 1fr;
  }
  .btn--large {
    flex-direction: row;
    text-align: left;
    justify-content: flex-start;
  }
  .btn--large div {
    align-items: flex-start;
  }
  .migration-generator-tabs {
    flex-direction: column;
  }
  .gen-tab {
    width: 100%;
  }
  .form-grid {
    grid-template-columns: 1fr;
  }
}
/* Styles pour l'onglet Données */
.tables-grid {
  display: grid;
  gap: 15px;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

.table-card {
  background: var(--bg-surface-alt);
  border: 2px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px;
  cursor: pointer;
  transition: var(--transition-base, 0.25s);
  position: relative;
}
.table-card:hover {
  border-color: var(--primary);
  transform: translateX(5px);
}
.table-card.selected {
  border-color: var(--primary);
  background: rgba(var(--accent-yellow-rgb), 0.05);
}
.table-card.selected::after {
  content: "\f058";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  top: 15px;
  right: 15px;
  color: var(--primary);
  font-size: 1.5rem;
}

.table-info {
  flex: 1;
}

.table-name {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.table-name i {
  color: var(--accent-lime);
}

.table-meta {
  font-size: 0.9rem;
  color: var(--text-primary);
  opacity: 0.7;
}

.snapshot-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 0.8rem;
  font-weight: 500;
  margin-left: 10px;
  white-space: nowrap;
}
.snapshot-badge.has-snapshot {
  background: rgba(var(--success-rgb), 0.1);
  color: var(--success);
  border: 1px solid rgba(var(--success-rgb), 0.3);
}
.snapshot-badge.no-snapshot {
  background: rgba(var(--white-rgb), 0.1);
  color: var(--text-muted);
  border: 1px solid rgba(var(--white-rgb), 0.3);
}

.change-stat {
  padding: 20px;
  background: var(--bg-surface);
  border-radius: var(--radius-lg);
  text-align: center;
}

.change-stat-value {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 8px;
}
.change-stat-value.insertions {
  color: var(--success);
}
.change-stat-value.updates {
  color: var(--warning);
}
.change-stat-value.deletions {
  color: var(--error);
}

.change-stat-label {
  font-size: 0.9rem;
  color: var(--text-primary);
  opacity: 0.8;
}

.changes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 15px;
  margin-top: 15px;
}

/* Sélection multiple de tables */
.table-selection-container {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  width: 100%;
}

.table-selection-checkbox {
  margin: 0;
  width: 18px;
  height: 18px;
  margin-top: 4px;
  cursor: pointer;
  flex-shrink: 0;
}

.table-card-checkbox {
  flex: 1;
  cursor: pointer;
}

.table-card {
  position: relative;
  padding-right: 60px !important;
}
.table-card.selected {
  border-color: var(--primary);
  background: rgba(var(--accent-yellow-rgb), 0.05);
}
.table-card.selected::after {
  content: "\f00c";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  top: 15px;
  right: 15px;
  color: var(--primary);
  font-size: 1.3rem;
  z-index: 10;
}

#selected-tables-summary {
  margin-top: 20px;
  margin-bottom: 20px;
}

#selected-tables-list {
  margin-top: 8px;
  padding: 8px;
  background: rgba(var(--white-rgb), 0.05);
  border-radius: 4px;
  font-family: monospace;
  word-break: break-word;
}

#data-workflow {
  margin-top: 30px;
  margin-bottom: 30px;
}

#data-detection-result {
  margin-top: 30px;
  clear: both;
}

.detection-summary {
  margin-bottom: 25px;
}

.alert-box + .alert-box {
  margin-top: 15px;
}

/* Badges de tracking (Sync incrémentale) */
.tracking-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 8px;
  border-radius: 12px;
  font-size: 0.7rem;
  font-weight: 500;
  background: rgba(var(--white-rgb), 0.1);
  color: rgba(var(--white-rgb), 0.7);
  white-space: nowrap;
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  flex-shrink: 0;
}
.tracking-badge.tracking-active {
  background: rgba(var(--success-rgb), 0.2);
  color: var(--success);
}
.tracking-badge i {
  font-size: 0.8em;
  flex-shrink: 0;
}

/* Indicateurs de préchargement */
.preload-indicator {
  margin-left: 8px;
  opacity: 0.7;
  transition: opacity 0.3s ease;
}
.preload-indicator.loading {
  opacity: 1;
}
.preload-indicator.loaded {
  opacity: 0.5;
  color: var(--success);
}
.preload-indicator.loaded i {
  color: var(--success);
}
.preload-indicator.error {
  opacity: 0.5;
  color: var(--error);
}
.preload-indicator.error i {
  color: var(--error);
}
.preload-indicator.hidden {
  display: none;
}

/* Calendrier de sélection de date */
.date-picker-container {
  margin: 15px 0;
}
.date-picker-container label {
  display: block;
  margin-bottom: 8px;
  font-weight: 500;
  color: var(--text-primary);
  font-size: 0.95rem;
}
.date-picker-container label i {
  color: var(--primary);
  margin-right: 5px;
}
.date-picker-container small {
  display: block;
  margin-top: 8px;
  opacity: 0.7;
  font-size: 0.85rem;
  color: var(--text-primary);
}
.date-picker-container small i {
  color: var(--primary);
  margin-right: 3px;
}

input[type=datetime-local].date-input {
  width: 100%;
  max-width: 320px;
  padding: 12px 15px;
  border: 2px solid var(--border);
  border-radius: var(--radius-md);
  font-size: 14px;
  font-family: var(--body-font);
  background: var(--bg-surface);
  color: var(--text-primary);
  transition: var(--transition-base, 0.25s);
  cursor: pointer;
  color-scheme: dark;
}
input[type=datetime-local].date-input:hover {
  border-color: var(--primary);
}
input[type=datetime-local].date-input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(var(--accent-yellow-rgb), 0.1);
  background: var(--bg-surface-alt);
}
input[type=datetime-local].date-input::-webkit-calendar-picker-indicator {
  cursor: pointer;
  padding: 5px;
  border-radius: 4px;
  transition: background-color 0.2s ease;
  filter: invert(1) brightness(1.2);
}
input[type=datetime-local].date-input::-webkit-calendar-picker-indicator:hover {
  background-color: rgba(var(--accent-yellow-rgb), 0.2);
}
input[type=datetime-local].date-input::-webkit-datetime-edit {
  color: var(--text-primary);
}
input[type=datetime-local].date-input::-webkit-datetime-edit-fields-wrapper {
  background: transparent;
}
input[type=datetime-local].date-input::-webkit-datetime-edit-text {
  color: var(--text-primary);
  padding: 0 4px;
}
input[type=datetime-local].date-input::-webkit-datetime-edit-month-field, input[type=datetime-local].date-input::-webkit-datetime-edit-day-field, input[type=datetime-local].date-input::-webkit-datetime-edit-year-field, input[type=datetime-local].date-input::-webkit-datetime-edit-hour-field, input[type=datetime-local].date-input::-webkit-datetime-edit-minute-field {
  color: var(--text-primary);
  background: rgba(var(--white-rgb), 0.05);
  padding: 2px 4px;
  border-radius: 3px;
}
input[type=datetime-local].date-input::-webkit-datetime-edit-month-field:focus, input[type=datetime-local].date-input::-webkit-datetime-edit-day-field:focus, input[type=datetime-local].date-input::-webkit-datetime-edit-year-field:focus, input[type=datetime-local].date-input::-webkit-datetime-edit-hour-field:focus, input[type=datetime-local].date-input::-webkit-datetime-edit-minute-field:focus {
  background: rgba(var(--accent-yellow-rgb), 0.2);
  color: var(--primary);
  outline: none;
}

/* Responsive pour petits écrans */
@media (max-width: 768px) {
  input[type=datetime-local].date-input {
    max-width: 100%;
  }
}
/**
 * Variables SCSS Centralisées - CantalDestination
 * ==========================================
 * Source unique de vérité pour toutes les valeurs de design
 * Utilisé par: navbar, tableaux de bord, infographie, period-picker
 */
.chart-container:focus-within,
.filter-select:focus-visible,
.period-picker-input:focus-visible,
.indicator-card-compact:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}

/**
 * Administration des Tables Temporaires
 * Harmonisé avec le design system FluxVision
 */
.admin-header {
  text-align: center;
  margin-bottom: 30px;
  padding: 20px;
  background: var(--bg-surface-glass);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  backdrop-filter: blur(10px);
}
.admin-header h1 {
  color: var(--primary);
  margin-bottom: 10px;
  font-family: var(--body-font);
}

/* Tabs */
.admin-tabs {
  display: flex;
  gap: 10px;
  margin-bottom: 25px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--border);
  padding-bottom: 15px;
}

.admin-tab {
  padding: 12px 20px;
  background: var(--bg-card);
  border: 2px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: var(--transition-base, 0.25s);
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--text-secondary);
  font-size: 1rem;
}
.admin-tab:hover {
  border-color: var(--primary);
  color: var(--text-primary);
  background: var(--bg-surface-alt);
}
.admin-tab.active {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--bg-app);
  box-shadow: 0 4px 15px rgba(var(--primary-rgb), 0.2);
}
.admin-tab i {
  font-size: 1.1rem;
}

.tab-content {
  display: none;
  animation: fadeIn 0.3s ease;
}
.tab-content.active {
  display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.admin-section {
  background: var(--bg-card);
  border-radius: var(--radius-md);
  padding: 25px;
  margin-bottom: 25px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-light);
}
.admin-section h2 {
  color: var(--text-primary);
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--primary);
  font-family: var(--body-font);
}

/* Stats Grid */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 20px;
  margin-bottom: 20px;
}

.stat-card {
  background: var(--bg-surface-glass);
  border-radius: var(--radius-md);
  padding: 20px;
  display: flex;
  align-items: center;
  border: 1px solid var(--border);
  transition: var(--transition-base, 0.25s);
}
.stat-card:hover {
  transform: translateY(-2px);
  border-color: var(--primary);
}
.stat-card .stat-icon {
  font-size: 2.5em;
  margin-right: 15px;
  color: var(--primary);
}
.stat-card .stat-info h3 {
  margin: 0;
  font-size: 1.8em;
  color: var(--primary);
  font-family: var(--body-font);
}
.stat-card .stat-info p {
  margin: 5px 0 0 0;
  color: var(--text-secondary);
}

/* Forms and Actions */
.form-row {
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
  align-items: center;
}

.admin-action-form {
  margin: 0;
}

.btn {
  padding: 12px 20px;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-weight: 500;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: var(--transition-base, 0.25s);
  font-size: 1rem;
}
.btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(var(--black-rgb), 0.2);
}

.section-description {
  background: var(--bg-surface-glass);
  padding: 15px;
  border-radius: var(--radius-md);
  border-left: 4px solid var(--primary);
  margin-bottom: 20px;
  color: var(--text-primary);
}

/* Messages */
.success-message,
.error-message,
.warning-message {
  padding: 15px;
  border-radius: var(--radius-md);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  backdrop-filter: blur(5px);
}

.success-message {
  background: rgba(var(--success-rgb), 0.1);
  border: 1px solid rgba(var(--success-rgb), 0.3);
  color: var(--success);
}

.error-message {
  background: rgba(var(--error-rgb), 0.1);
  border: 1px solid rgba(var(--error-rgb), 0.3);
  color: var(--error);
}

.warning-message {
  background: rgba(var(--warning-rgb), 0.1);
  border: 1px solid rgba(var(--warning-rgb), 0.3);
  color: var(--warning);
}

/* Tables */
.files-table,
.users-table {
  overflow-x: auto;
}
.files-table table,
.users-table table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 15px;
}
.files-table th,
.files-table td,
.users-table th,
.users-table td {
  padding: 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  color: var(--text-primary);
}
.files-table th,
.users-table th {
  background: var(--bg-surface-glass);
  font-weight: 600;
  color: var(--text-primary);
}
.files-table tr.inactive,
.users-table tr.inactive {
  opacity: 0.6;
}

/* Status Badges */
.status-badge {
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 0.85em;
  font-weight: 500;
}
.status-badge.active {
  background: rgba(var(--success-rgb), 0.2);
  color: var(--success);
}
.status-badge.inactive {
  background: rgba(var(--text-secondary-rgb), 0.2);
  color: var(--text-secondary);
}

/* Logs */
.logs-container {
  background: var(--bg-app);
  color: var(--text-primary);
  padding: 20px;
  border-radius: var(--radius-md);
  font-family: var(--font-code, monospace);
  font-size: 0.9em;
  max-height: 400px;
  overflow-y: auto;
  border: 1px solid var(--border);
}

.log-entry {
  margin-bottom: 5px;
  line-height: 1.4;
}

.help-text {
  color: var(--text-secondary);
  font-size: 0.9em;
  margin-top: 10px;
}

.code-block {
  background: var(--bg-app);
  color: var(--text-primary);
  padding: 15px;
  border-radius: var(--radius-md);
  font-family: var(--font-code, monospace);
  margin: 15px 0;
  border: 1px solid var(--border);
}

/* File Upload */
.file-input-wrapper {
  position: relative;
  display: inline-block;
}
.file-input-wrapper input[type=file] {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

.file-input-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  background: var(--bg-surface-glass);
  border: 2px dashed var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: var(--transition-base, 0.25s);
  color: var(--text-primary);
}
.file-input-label:hover {
  border-color: var(--primary);
  background: var(--bg-card);
}

.upload-form {
  background: var(--bg-surface-glass);
  padding: 20px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
}

/* Operation Details */
.operation-details-section {
  background: var(--bg-card);
  border-radius: 12px;
  padding: 25px;
  margin-bottom: 25px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-light);
}
.operation-details-section h3 {
  color: var(--text-primary);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.operation-duration {
  font-size: 0.8em;
  color: var(--text-secondary);
  font-weight: normal;
}

.summary-stats {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.stat-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 15px;
  border-radius: 8px;
  font-weight: 500;
}
.stat-item.success {
  background: rgba(var(--success-rgb), 0.1);
  color: var(--success);
}
.stat-item.error {
  background: rgba(var(--error-rgb), 0.1);
  color: var(--error);
}
.stat-item.unchanged {
  background: rgba(var(--text-secondary-rgb), 0.1);
  color: var(--text-secondary);
}

.tables-operation-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 20px;
}

.table-operation-card {
  background: var(--bg-surface-glass);
  border-radius: 8px;
  border: 1px solid var(--border);
  overflow: hidden;
}
.table-operation-card.success {
  border-left: 4px solid var(--success);
}
.table-operation-card.error {
  border-left: 4px solid var(--error);
}
.table-operation-card.unchanged {
  border-left: 4px solid var(--text-secondary);
}

.table-card-header {
  padding: 15px;
  background: var(--bg-card);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.table-name {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-primary);
}

.operation-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.9em;
}

.text-success {
  color: var(--success);
}

.text-error {
  color: var(--error);
}

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

.text-center {
  text-align: center;
}

.table-card-details {
  padding: 15px;
}

.operation-stats {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.stat-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border-radius: 15px;
  font-size: 0.8em;
  font-weight: 500;
}
.stat-badge.added {
  background: rgba(var(--success-rgb), 0.2);
  color: var(--success);
}
.stat-badge.updated {
  background: rgba(var(--info-rgb), 0.2);
  color: var(--info);
}
.stat-badge.unchanged {
  background: rgba(var(--text-secondary-rgb), 0.2);
  color: var(--text-secondary);
}
.stat-badge.error {
  background: rgba(var(--error-rgb), 0.2);
  color: var(--error);
}

/* Migration Info - Provisional */
.provisional-info {
  background: rgba(var(--warning-rgb), 0.1);
  border: 1px solid rgba(var(--warning-rgb), 0.3);
  border-radius: var(--radius-md);
  padding: 20px;
  margin-top: 20px;
}
.provisional-info h3 {
  color: var(--warning);
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.provisional-info ul {
  margin: 0;
  padding-left: 20px;
}
.provisional-info li {
  margin-bottom: 8px;
  color: var(--warning);
}

/* Cache Info */
.cache-info {
  background: rgba(var(--info-rgb), 0.1);
  border: 1px solid rgba(var(--info-rgb), 0.3);
  border-radius: var(--radius-md);
  padding: 20px;
  margin-top: 20px;
}
.cache-info h3 {
  color: var(--info);
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.cache-info li {
  margin-bottom: 8px;
  color: var(--info);
}

/* DB Test Info */
.info-box {
  background: rgba(var(--info-rgb), 0.1);
  border: 1px solid rgba(var(--info-rgb), 0.3);
  border-radius: 4px;
  padding: 12px;
  margin: 10px 0;
  font-size: 14px;
  color: var(--text-primary);
}
.info-box strong {
  color: var(--primary);
}
