@charset "UTF-8";
/*
	Theme Name: WP Starter
	Theme URI: https://nature-digitale.fr
	Description: Thème de la société Nature Digitale
	Author: Nature Digitale - Agence Web Eco Responsable
	Author URI: https://nature-digitale.fr
	Version: 1.0.0
	License: GNU General Public License v3 or later.
	License URI: https://www.gnu.org/licenses/gpl-3.0.html
	Text Domain: nature-digitale
*/

/* ==========================================================================
   TEELDA - Self-hosted Fonts (fichiers woff2 identiques à Google Fonts)
   ========================================================================== */

/* Outfit - Variable (weight 100-900) */
@font-face {
  font-family: 'Outfit';
  src: url('assets/fonts/outfit/Outfit-Variable.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Fraunces - Variable normal (weight 400-700) */
@font-face {
  font-family: 'Fraunces';
  src: url('assets/fonts/fraunces/Fraunces-Normal-Latin.woff2') format('woff2');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Fraunces - Variable italic (weight 400) */
@font-face {
  font-family: 'Fraunces';
  src: url('assets/fonts/fraunces/Fraunces-Italic-Latin.woff2') format('woff2');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ==========================================================================
   TEELDA - CSS Variables & Design Tokens
   ========================================================================== */
:root {
  /* Couleurs principales */
  --color-yellow: #ffc837;
  --color-yellow-light: #fff3d4;
  --color-yellow-dark: #e6b030;

  --color-coral: #ff5a4a;
  --color-coral-light: #ffe5e3;
  --color-coral-dark: #e64a3a;

  --color-teal: #0297b2;
  --color-teal-light: #e0f4f7;
  --color-teal-dark: #027a91;

  --color-cream: #f8f6f0;
  --color-white: #ffffff;
  --color-black: #222222;
  --color-gray-100: #f5f5f5;
  --color-gray-200: #e5e5e5;
  --color-gray-300: #d4d4d4;
  --color-gray-400: #a3a3a3;
  --color-gray-500: #737373;
  --color-gray-600: #525252;
  --color-gray-700: #404040;

  /* Typography */
  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;

  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;
  --text-6xl: 3.75rem;

  --leading-tight: 1.15;
  --leading-snug: 1.3;
  --leading-normal: 1.5;
  --leading-relaxed: 1.625;

  /* Spacing */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-32: 8rem;

  /* Layout */
  --container-max: 1280px;
  --container-padding: var(--space-6);

  /* Border Radius */
  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-2xl: 1.5rem;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-base: 200ms ease;
  --transition-slow: 300ms ease;
  --transition-slower: 500ms ease;
}

/* ==========================================================================
   Base Styles
   ========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--color-black);
  background-color: var(--color-white);
  margin: 0;
  padding: 0;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

ul,
ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

/* ==========================================================================
   Layout - Container
   ========================================================================== */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-base);
  font-weight: 500;
  border-radius: var(--radius-lg);
  transition: all var(--transition-base);
  white-space: nowrap;
  text-decoration: none;
}

.btn .icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.btn-lg {
  padding: var(--space-4) var(--space-8);
  font-size: var(--text-lg);
}

.btn-lg .icon {
  width: 20px;
  height: 20px;
}

.btn-primary {
  background-color: var(--color-coral);
  color: var(--color-white);
}

.btn-primary:hover {
  background-color: var(--color-coral-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.btn-secondary {
  background-color: var(--color-white);
  color: var(--color-black);
  border: 2px solid var(--color-gray-200);
}

.btn-secondary:hover {
  border-color: var(--color-teal);
  color: var(--color-teal);
}

.btn-ghost {
  background: transparent;
  color: var(--color-gray-600);
}

.btn-ghost:hover {
  color: var(--color-teal);
}

/* Feedback "Copié !" pour le lien tel: sur desktop */
.btn-ghost.copied {
  color: var(--color-teal);
}

.btn-ghost.copied::after {
  content: " — copié !";
  font-size: var(--text-sm);
  font-weight: 500;
}

.btn-yellow {
  background-color: var(--color-yellow);
  color: var(--color-black);
}

.btn-yellow:hover {
  background-color: var(--color-yellow-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

/* ==========================================================================
   Header & Navigation
   ========================================================================== */
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background-color: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-gray-200);
}

.header-scrolled {
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 80px;
}

.logo {
  display: flex;
  align-items: center;
}

.logo img,
.logo-img {
  height: 40px;
  width: auto;
}

/* Navigation Links */
.nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-8);
}

.nav-links li {
  list-style: none;
}

.nav-links a {
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-gray-700);
  transition: color var(--transition-fast);
  position: relative;
  text-decoration: none;
}

.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 2px;
  background-color: var(--color-coral);
  transition: width var(--transition-base);
}

.nav-links a:hover {
  color: var(--color-teal);
}

.nav-links a:hover::after {
  width: 100%;
}

/* Support pour le menu WordPress */
.nav-links .menu {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  margin: 0;
  padding: 0;
}

.nav-links .menu-item {
  list-style: none;
}

.nav-links .menu-item a {
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-gray-700);
  transition: color var(--transition-fast);
  position: relative;
  text-decoration: none;
}

.nav-links .menu-item a::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 2px;
  background-color: var(--color-coral);
  transition: width var(--transition-base);
}

.nav-links .menu-item a:hover {
  color: var(--color-teal);
}

.nav-links .menu-item a:hover::after {
  width: 100%;
}

/* Current menu item */
.nav-links .current-menu-item a,
.nav-links .current_page_item a {
  color: var(--color-teal);
}

.nav-links .current-menu-item a::after,
.nav-links .current_page_item a::after {
  width: 100%;
}

/* ==========================================================================
   SOUS-MENUS DESKTOP
   ========================================================================== */

/* Parent avec sous-menu */
.nav-links .menu-item-has-children {
  position: relative;
}

/* Sous-menu dropdown */
.nav-links .sub-menu {
  position: absolute;
  top: calc(100% + 12px);
  left: 0;
  min-width: 180px;
  background: var(--color-white);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  padding: 8px 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: all 0.2s ease;
  z-index: 1000;
  list-style: none;
  margin: 0;
}

/* Affichage au survol */
.nav-links .menu-item-has-children:hover > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Items du sous-menu */
.nav-links .sub-menu li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-links .sub-menu a {
  display: block;
  padding: 10px 16px;
  color: var(--color-gray-700);
  font-size: var(--font-size-sm);
  font-weight: 400;
  white-space: nowrap;
  transition: all 0.15s ease;
}

.nav-links .sub-menu a::after {
  display: none;
}

.nav-links .sub-menu a:hover {
  background-color: var(--color-gray-50, #f9fafb);
  color: var(--color-teal);
}

/* Navigation Actions (CTA buttons) */
.nav-actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

/* Mobile Navigation Toggle (Hamburger) */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}

.nav-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background-color: var(--color-black);
  transition: all var(--transition-base);
}

.nav-toggle.active span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

.nav-toggle.active span:nth-child(2) {
  opacity: 0;
}

.nav-toggle.active span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}

/* Icon utility class */
.icon {
  display: inline-block;
  flex-shrink: 0;
}

/* Body padding for fixed header */
body {
  padding-top: 80px;
}

/* Landing page - supprime le padding du header fixe */
body.landing-page {
  padding-top: 0;
}

/* Landing page avec admin bar - garde seulement l'espace pour la barre admin */
body.admin-bar.landing-page {
  padding-top: 32px;
}

@media screen and (max-width: 782px) {
  body.admin-bar.landing-page {
    padding-top: 46px;
  }
}

/* Admin bar logged in - décalage du header */
body.admin-bar .header {
  top: 32px;
}

body.admin-bar {
  padding-top: 112px;
  /* 80px header + 32px admin bar */
}

@media screen and (max-width: 782px) {
  body.admin-bar .header {
    top: 46px;
  }

  body.admin-bar {
    padding-top: 126px;
    /* 80px header + 46px admin bar mobile */
  }
}

/* Admin bar + mobile menu offset */
body.admin-bar .mobile-menu {
  top: 32px;
}

@media screen and (max-width: 782px) {
  body.admin-bar .mobile-menu {
    top: 46px;
  }
}

/* Fix: WP admin bar is position:absolute below 600px (scrolls away).
   Force it fixed so the header stays correctly positioned. */
@media screen and (max-width: 600px) {
  #wpadminbar {
    position: fixed !important;
  }
}

/* Body fixed (no scroll when mobile menu open) */
body.body-fixed {
  overflow: hidden;
}

/* ==========================================================================
   Mobile Menu
   ========================================================================== */
.mobile-menu {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-white);
  z-index: 9999;
  padding: 6rem var(--space-6) var(--space-6);
  transform: translateX(100%);
  transition: transform var(--transition-slow);
  overflow-y: auto;
  display: none;
}

.mobile-menu.active {
  transform: translateX(0);
  display: block;
}

.mobile-menu-close {
  position: absolute;
  top: var(--space-6);
  right: var(--space-6);
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  color: var(--color-gray-600);
  transition: color var(--transition-fast);
}

.mobile-menu-close:hover {
  color: var(--color-coral);
}

.mobile-menu-close svg {
  width: 24px;
  height: 24px;
}

.mobile-menu .nav-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

.mobile-menu .nav-links .menu {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.mobile-menu .nav-links a,
.mobile-menu .nav-links .menu-item a {
  font-size: var(--text-xl);
  color: var(--color-gray-700);
}

.mobile-menu .nav-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.mobile-menu .nav-actions .btn {
  width: 100%;
  justify-content: center;
}

/* ==========================================================================
   SOUS-MENUS MOBILE (TOUJOURS VISIBLES)
   ========================================================================== */

/* Masquer le bouton toggle (non utilisé) */
.mobile-menu .submenu-toggle {
  display: none !important;
}

/* Sous-menu toujours visible - override des styles desktop */
.mobile-menu .nav-links .sub-menu {
  display: block !important;
  position: static !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 8px 0 0 0;
  margin: 0 0 0 16px;
  min-width: auto;
}

.mobile-menu .nav-links .sub-menu li {
  list-style: none;
  margin-bottom: 10px;
}

.mobile-menu .nav-links .sub-menu li:last-child {
  margin-bottom: 0;
}

.mobile-menu .nav-links .sub-menu a {
  font-size: var(--font-size-base) !important;
  color: var(--color-gray-500) !important;
  font-weight: 400;
  padding: 0 !important;
}

.mobile-menu .nav-links .sub-menu a:hover {
  color: var(--color-teal) !important;
  background: transparent !important;
}

/* ==========================================================================
   Hero Section
   ========================================================================== */
.hero {
  position: relative;
  min-height: calc(100vh - 80px);
  padding-top: var(--space-16);
  padding-bottom: var(--space-16);
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
}

.hero-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--color-cream) 0%, var(--color-white) 50%, var(--color-teal-light) 100%);
}

.hero-pattern {
  position: absolute;
  inset: 0;
  opacity: 0.4;
  background-image:
    radial-gradient(circle at 20% 80%, var(--color-yellow-light) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, var(--color-coral-light) 0%, transparent 40%);
}

.hero .container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}

.hero-content {
  position: relative;
  z-index: 1;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background-color: var(--color-yellow-light);
  color: var(--color-black);
  font-size: var(--text-sm);
  font-weight: 600;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-6);
}

.hero-badge .icon {
  width: 16px;
  height: 16px;
  color: var(--color-yellow-dark);
}

.hero-title {
  font-family: var(--font-display);
  font-size: var(--text-6xl);
  font-weight: 600;
  line-height: var(--leading-tight);
  margin: 0 0 var(--space-6) 0;
  color: var(--color-black);
}

.text-highlight {
  color: var(--color-coral);
  font-style: italic;
}

.hero-subtitle {
  font-size: var(--text-xl);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-8) 0;
  max-width: 540px;
}

.hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-bottom: var(--space-12);
}

.hero-stats {
  display: flex;
  gap: var(--space-10);
}

.stat {
  display: flex;
  flex-direction: column;
}

.stat-number {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--color-teal);
}

.stat-label {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

.hero-visual {
  position: relative;
}

.hero-image-wrapper {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-2xl);
}

.hero-image {
  width: 100%;
  height: 500px;
  object-fit: cover;
}

.hero-image-accent {
  position: absolute;
  bottom: -20px;
  right: -20px;
  width: 200px;
  height: 200px;
  background-color: var(--color-yellow);
  border-radius: var(--radius-2xl);
  z-index: -1;
}

/* Hero Video Clickable Variant (page témoignages) */
.hero-video-clickable {
  cursor: pointer;
}

.hero-video-clickable .hero-image {
  transition: transform 0.5s ease;
}

.hero-video-clickable:hover .hero-image {
  transform: scale(1.05);
}

.hero-video-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.4) 0%, transparent 50%);
  pointer-events: none;
  z-index: 1;
}

.hero-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  width: 80px;
  height: 80px;
  background-color: var(--color-coral);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  box-shadow: 0 10px 30px rgba(255, 90, 74, 0.4);
}

.hero-play-btn svg {
  width: 32px;
  height: 32px;
  color: var(--color-white);
  margin-left: 4px;
}

.hero-play-btn:hover {
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 15px 40px rgba(255, 90, 74, 0.5);
}

.hero-video-badge {
  position: absolute;
  bottom: var(--space-4);
  left: var(--space-4);
  z-index: 2;
  background-color: var(--color-teal);
  color: var(--color-white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: 500;
}

.hero-floating-card {
  position: absolute;
  bottom: 40px;
  left: -40px;
  z-index: 10;
  background-color: var(--color-white);
  padding: var(--space-5);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  max-width: 280px;
  animation: float 6s ease-in-out infinite;
}

@keyframes float {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-10px);
  }
}

.floating-card-icon {
  width: 40px;
  height: 40px;
  background-color: var(--color-coral-light);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-3);
}

.floating-card-icon svg {
  width: 20px;
  height: 20px;
  color: var(--color-coral);
}

.floating-card-text {
  font-size: var(--text-base);
  font-weight: 500;
  margin: 0 0 var(--space-2) 0;
  color: var(--color-black);
}

.floating-card-author {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

.hero-scroll-indicator {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-gray-500);
  font-size: var(--text-sm);
  animation: bounce 2s infinite;
  cursor: pointer;
  text-decoration: none;
}

.hero-scroll-indicator:hover {
  color: var(--color-teal);
}

.hero-scroll-indicator svg {
  width: 20px;
  height: 20px;
}

@keyframes bounce {

  0%,
  100% {
    transform: translateX(-50%) translateY(0);
  }

  50% {
    transform: translateX(-50%) translateY(8px);
  }
}

/* ==========================================================================
   Sections - Styles généraux
   ========================================================================== */
.section {
  padding-top: var(--space-20);
  padding-bottom: var(--space-20);
}

.section-cream {
  background-color: var(--color-cream);
}

.section-tag {
  display: inline-block;
  font-size: var(--text-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-teal);
  margin-bottom: var(--space-4);
}

.section-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 600;
  line-height: var(--leading-tight);
  margin-bottom: var(--space-4);
}

.section-description {
  font-size: var(--text-lg);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
}

.text-accent {
  color: var(--color-teal);
}

.text-highlight-light {
  color: var(--color-yellow);
  font-style: italic;
}

/* Section Teal (Comment ça marche) */
.section-teal {
  background-color: var(--color-teal);
  color: var(--color-white);
}

.section-header-light {
  color: var(--color-white);
}

.section-tag-light {
  color: var(--color-yellow);
}

.section-header-light .section-description {
  color: rgba(255, 255, 255, 0.85);
}

.section-teal .btn-secondary {
  background-color: var(--color-white);
  color: var(--color-teal);
  border-color: var(--color-white);
}

.section-teal .btn-secondary:hover {
  background-color: var(--color-teal-light);
  border-color: var(--color-teal-light);
}

.cta-buttons {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

/* ==========================================================================
   Services Section - Notre Accompagnement
   ========================================================================== */
.services-layout {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-16);
  align-items: start;
}

.services-intro {
  position: sticky;
  top: 120px;
}

.services-intro .section-tag {
  margin-bottom: var(--space-4);
}

.services-intro .section-title {
  text-align: left;
  margin-bottom: var(--space-6);
  margin-top: 0;
}

.services-intro .section-description {
  text-align: left;
  margin-bottom: var(--space-8);
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}

.service-card {
  background-color: var(--color-white);
  padding: var(--space-8);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
}

.service-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.service-icon {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-4);
}

.service-icon svg {
  width: 28px;
  height: 28px;
}

.service-icon-yellow {
  background-color: var(--color-yellow-light);
  color: var(--color-yellow-dark);
}

.service-icon-coral {
  background-color: var(--color-coral-light);
  color: var(--color-coral);
}

.service-icon-teal {
  background-color: var(--color-teal-light);
  color: var(--color-teal);
}

.service-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  margin-bottom: var(--space-3);
}

.service-text {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin: 0;
}

/* ==========================================================================
   Partners Section - Ils nous font confiance (Carrousel)
   ========================================================================== */
.partners-section {
  padding-top: var(--space-12);
  padding-bottom: var(--space-16);
  background-color: var(--color-white);
  overflow: hidden;
}

.partners-section .section-header {
  margin-bottom: var(--space-8);
}

.section-header {
  text-align: center;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: var(--space-12);
}

.section-header .section-tag {
  margin-bottom: var(--space-2);
}

.section-header .section-title {
  margin-bottom: var(--space-4);
  margin-top: 0;
}

.section-header .section-description {
  margin: 0;
}

.partners-track-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
}

/* Gradient fade sur les bords gauche et droit */
.partners-track-wrapper::before,
.partners-track-wrapper::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100px;
  z-index: 2;
  pointer-events: none;
}

.partners-track-wrapper::before {
  left: 0;
  background: linear-gradient(to right, var(--color-white) 0%, transparent 100%);
}

.partners-track-wrapper::after {
  right: 0;
  background: linear-gradient(to left, var(--color-white) 0%, transparent 100%);
}

/* Conteneur animé des logos */
.partners-track {
  display: flex;
  gap: var(--space-12);
  animation: scrollLogos 30s linear infinite;
  width: max-content;
}

.partners-track:hover {
  animation-play-state: paused;
}

@keyframes scrollLogos {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

/* Logo individuel */
.partner-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px;
  min-width: 160px;
  padding: 0 var(--space-4);
  filter: grayscale(100%);
  opacity: 0.7;
  transition: all var(--transition-base);
}

.partner-logo:hover {
  filter: grayscale(0%);
  opacity: 1;
}

.partner-logo img {
  max-height: 70px;
  max-width: 180px;
  width: auto;
  height: auto;
  object-fit: contain;
}

/* ==========================================================================
   Destinations Section - Nos destinations
   ========================================================================== */
.destinations-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}

.destinations-main {
  display: flex;
}

.destinations-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* Carte de base */
.destination-card {
  border-radius: var(--radius-xl);
  overflow: hidden;
  background-color: var(--color-white);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-slow);
}

.destination-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
}

.destination-card a {
  text-decoration: none;
  color: inherit;
}

/* Carte Featured (grande) */
.destination-card-featured {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.destination-card-featured .destination-image {
  flex: 1;
  min-height: 350px;
}

.destination-card-featured .destination-content {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.destination-card-featured .destination-location {
  color: var(--color-teal);
  font-weight: 600;
}

.destination-card-featured .destination-title {
  font-size: var(--text-2xl);
}

.destination-card-featured .destination-text {
  -webkit-line-clamp: 3;
}

.destination-card-featured .destination-price {
  font-size: var(--text-lg);
}

/* Carte Horizontal (petite) */
.destination-card-horizontal {
  display: grid;
  grid-template-columns: 180px 1fr;
  min-height: 160px;
}

.destination-card-horizontal a {
  display: contents;
}

.destination-card-horizontal .destination-image {
  height: 100%;
}

.destination-card-horizontal .destination-content {
  padding: var(--space-4);
}

.destination-card-horizontal .destination-text {
  -webkit-line-clamp: 1;
}

/* Image destination */
.destination-image {
  position: relative;
  height: 200px;
  overflow: hidden;
}

.destination-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slower);
}

.destination-card:hover .destination-image img {
  transform: scale(1.05);
}

.destination-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.5) 0%, transparent 60%);
  pointer-events: none;
}

/* Badges sur l'image */
.destination-badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  padding: var(--space-1) var(--space-3);
  background-color: var(--color-yellow);
  color: var(--color-black);
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  z-index: 1;
}

.destination-badge-type {
  left: auto;
  right: var(--space-3);
  background-color: var(--color-teal);
  color: var(--color-white);
}

.destination-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.destination-badge-pmr {
  background-color: var(--color-coral);
  color: var(--color-white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  padding: 0;
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.destination-badge-pmr svg {
  width: 14px;
  height: 14px;
}

/* Contenu de la carte */
.destination-content {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.destination-location {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--color-gray-500);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.destination-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  margin: 0;
  color: var(--color-black);
}

.destination-text {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin: 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-line-clamp: 2;
}

/* Meta (prix + tags) */
.destination-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
  margin-top: var(--space-2);
  padding-top: var(--space-3);
  border-top: 0px;
}

.destination-price {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-coral);
}

.destination-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-left: auto;
}

.destination-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-2);
  background-color: var(--color-gray-100);
  color: var(--color-gray-600);
  font-size: var(--text-xs);
  font-weight: 500;
  border-radius: var(--radius-md);
}

.destination-tag svg {
  width: 14px;
  height: 14px;
}

.destination-tag-pmr {
  background-color: var(--color-teal-light);
  color: var(--color-teal);
}

/* Lien "Découvrir ce séjour" */
.destination-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-coral);
  margin-top: auto;
  padding-top: var(--space-2);
  transition: gap var(--transition-fast);
}

.destination-link:hover {
  gap: var(--space-3);
}

.destination-link svg {
  width: 16px;
  height: 16px;
}

/* Section footer avec CTA */
.section-footer {
  text-align: center;
  margin-top: var(--space-12);
}

/* ==========================================================================
   Zones géographiques - Page d'accueil
   ========================================================================== */
.destinations-zones {
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-gray-200);
}

.destinations-zones-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-6);
  text-align: center;
}

.destinations-zones-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-4);
}

.zone-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-4);
  background: var(--color-white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-gray-200);
  transition: all var(--transition-base);
  text-decoration: none;
}

.zone-card:hover {
  border-color: var(--color-teal);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.zone-card-icon {
  width: 64px;
  height: 64px;
  margin-bottom: var(--space-2);
}

.zone-card-icon svg {
  width: 100%;
  height: 100%;
}

.zone-card-name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-black);
  text-align: center;
}

.zone-card-count {
  font-size: var(--text-xs);
  color: var(--color-gray-500);
  margin-top: var(--space-1);
}

/* Zones géographiques responsive */
@media (max-width: 1024px) {
  .destinations-zones-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 640px) {
  .destinations-zones-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .zone-card-icon {
    width: 56px;
    height: 56px;
  }
}

/* ==========================================================================
   Situations Section - Votre situation
   ========================================================================== */
.situations-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.situation-card {
  background-color: var(--color-white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
}

.situation-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl);
}

.situation-image {
  height: 200px;
  overflow: hidden;
}

.situation-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slower);
}

.situation-card:hover .situation-image img {
  transform: scale(1.05);
}

.situation-content {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  flex: 1;
}

.situation-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  margin-bottom: var(--space-3);
  color: var(--color-black);
}

.situation-text {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-4);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-line-clamp: 3;
}

.situation-link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-coral);
  transition: color var(--transition-fast);
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.situation-card:hover .situation-link {
  color: var(--color-teal);
}

/* ==========================================================================
   Testimonials Section - Témoignages
   ========================================================================== */
.testimonials-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: var(--space-6);
}

.testimonial-card {
  background-color: var(--color-white);
  padding: var(--space-8);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0;
}

.testimonial-card-featured {
  grid-row: span 2;
  background: linear-gradient(135deg, var(--color-teal) 0%, var(--color-teal-dark) 100%);
  color: var(--color-white);
}

.testimonial-quote {
  margin-bottom: var(--space-4);
}

.quote-icon {
  width: 32px;
  height: 32px;
  opacity: 0.3;
}

.testimonial-card-featured .quote-icon {
  color: var(--color-yellow);
  opacity: 0.6;
}

.testimonial-text {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  flex-grow: 1;
  margin-bottom: var(--space-6);
}

.testimonial-card-featured .testimonial-text {
  font-size: var(--text-xl);
}

.testimonial-footer {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.testimonial-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  overflow: hidden;
  flex-shrink: 0;
}

.testimonial-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.testimonial-name {
  display: block;
  font-weight: 600;
  font-style: normal;
}

.testimonial-location {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

.testimonial-card-featured .testimonial-location {
  color: rgba(255, 255, 255, 0.7);
}

/* ==========================================================================
   Testimonials Video - Extension
   ========================================================================== */

/* Video Wrapper dans la carte */
.testimonial-video-wrapper {
  position: relative;
  width: 100%;
  flex-grow: 1;
  margin-bottom: var(--space-6);
  cursor: pointer;
}

.testimonial-thumbnail {
  position: relative;
  width: 100%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 16 / 9;
}

.testimonial-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.testimonial-video-wrapper:hover .testimonial-thumbnail img {
  transform: scale(1.05);
}

.testimonial-thumbnail-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--color-gray-200) 0%, var(--color-gray-300) 100%);
}

/* Bouton Play */
.testimonial-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 64px;
  height: 64px;
  border: none;
  border-radius: var(--radius-full);
  background-color: var(--color-coral);
  color: var(--color-white);
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(255, 90, 74, 0.4);
}

.testimonial-play-btn svg {
  width: 28px;
  height: 28px;
  margin-left: 4px;
}

.testimonial-play-btn:hover {
  background-color: var(--color-teal);
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 6px 25px rgba(13, 148, 136, 0.4);
}

.testimonial-play-btn:focus {
  outline: 3px solid var(--color-yellow);
  outline-offset: 2px;
}

/* Carte video featured - ajustements */
.testimonial-card-featured.testimonial-video .testimonial-thumbnail {
  aspect-ratio: 16 / 9;
}

.testimonial-card-featured.testimonial-video .testimonial-play-btn {
  width: 80px;
  height: 80px;
}

.testimonial-card-featured.testimonial-video .testimonial-play-btn svg {
  width: 36px;
  height: 36px;
}

/* ==========================================================================
   Modal Video Témoignage
   ========================================================================== */
.testimonial-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.testimonial-modal.is-active {
  opacity: 1;
  visibility: visible;
}

.testimonial-modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.85);
  cursor: pointer;
}

.testimonial-modal-content {
  position: relative;
  width: 90%;
  max-width: 900px;
  background-color: var(--color-black);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transform: scale(0.9);
  transition: transform 0.3s ease;
}

.testimonial-modal.is-active .testimonial-modal-content {
  transform: scale(1);
}

.testimonial-modal-close {
  position: absolute;
  top: -48px;
  right: 0;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: var(--radius-full);
  background-color: var(--color-white);
  color: var(--color-black);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  z-index: 10;
}

.testimonial-modal-close svg {
  width: 24px;
  height: 24px;
}

.testimonial-modal-close:hover {
  background-color: var(--color-coral);
  color: var(--color-white);
}

.testimonial-modal-video {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
}

.testimonial-modal-video video {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background-color: var(--color-black);
}

.testimonial-modal-video.video-portrait {
  aspect-ratio: 9/16;
  max-height: 85vh;
  width: auto;
}

@media (max-width: 768px) {
  .testimonial-modal-video.video-portrait {
    max-height: 80vh;
    max-width: 90vw;
  }
}

/* Body fixed quand modal ouverte */
body.modal-open {
  overflow: hidden;
}

/* ==========================================================================
   Themes Section - Thématiques
   ========================================================================== */
.themes-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

.theme-card {
  display: block;
  background-color: var(--color-cream);
  padding: var(--space-8);
  border-radius: var(--radius-xl);
  text-align: center;
  transition: all var(--transition-base);
  border: 2px solid transparent;
  text-decoration: none;
  color: inherit;
}

.theme-card:hover {
  background-color: var(--color-white);
  border-color: var(--color-teal);
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.theme-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-5);
  background-color: var(--color-teal-light);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-base);
}

.theme-card:hover .theme-icon {
  background-color: var(--color-teal);
}

.theme-icon svg {
  width: 28px;
  height: 28px;
  color: var(--color-teal);
  transition: color var(--transition-base);
}

.theme-card:hover .theme-icon svg {
  color: var(--color-white);
}

.theme-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  margin-bottom: var(--space-2);
  color: var(--color-black);
}

.theme-text {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

/* ==========================================================================
   Steps Section - Comment ça marche
   ========================================================================== */
.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8);
}

.step-card {
  text-align: center;
  padding: var(--space-6);
}

.step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  background-color: var(--color-yellow);
  color: var(--color-black);
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-5);
}

.step-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  margin-bottom: var(--space-3);
}

.step-text {
  font-size: var(--text-base);
  color: rgba(255, 255, 255, 0.85);
  line-height: var(--leading-relaxed);
}

/* ==========================================================================
   Blog Section
   ========================================================================== */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.blog-card {
  display: block;
  background-color: var(--color-white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
  text-decoration: none;
  color: inherit;
}

.blog-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl);
}

.blog-image {
  display: block;
  height: 200px;
  overflow: hidden;
}

.blog-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slower);
}

.blog-card:hover .blog-image img {
  transform: scale(1.05);
}

.blog-content {
  padding: var(--space-6);
}

.blog-category {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-teal);
  margin-bottom: var(--space-3);
}

.blog-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  line-height: var(--leading-snug);
  margin-bottom: var(--space-3);
  color: var(--color-black);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blog-excerpt {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-4);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blog-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-gray-200);
}

.blog-date {
  font-size: var(--text-xs);
  color: var(--color-gray-500);
}

.blog-link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-coral);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  transition: gap var(--transition-fast);
}

.blog-card:hover .blog-link {
  gap: var(--space-2);
}

.blog-link .icon {
  width: 16px;
  height: 16px;
}

/* ==========================================================================
   Blog Archive Page - Filters & Pagination
   ========================================================================== */

/* Blog Filters - Boutons Pills */
.blog-filters {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: var(--space-10);
}

.blog-filter {
  display: inline-flex;
  align-items: center;
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-gray-600);
  background-color: var(--color-white);
  border: 2px solid var(--color-gray-200);
  border-radius: 9999px;
  text-decoration: none;
  transition: all var(--transition-fast);
  cursor: pointer;
}

.blog-filter:hover {
  color: var(--color-teal);
  border-color: var(--color-teal);
}

.blog-filter.active {
  color: var(--color-white);
  background-color: var(--color-teal);
  border-color: var(--color-teal);
}

/* Blog Pagination */
.blog-pagination {
  display: flex;
  justify-content: center;
  margin-top: var(--space-12);
}

.blog-pagination ul,
.blog-pagination .page-numbers {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
  margin: 0;
}

.blog-pagination li {
  display: inline-flex;
}

.blog-pagination a,
.blog-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 var(--space-3);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-gray-600);
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.blog-pagination a:hover {
  color: var(--color-teal);
  border-color: var(--color-teal);
}

.blog-pagination .current {
  color: var(--color-white);
  background-color: var(--color-teal);
  border-color: var(--color-teal);
}

.blog-pagination a .icon,
.blog-pagination span .icon {
  width: 16px;
  height: 16px;
}

.blog-pagination .prev,
.blog-pagination .next {
  gap: var(--space-2);
}

/* No posts message */
.blog-archive .no-posts {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--space-12);
  color: var(--color-gray-500);
  font-size: var(--text-lg);
}

/* ==========================================================================
   Single Article Page
   ========================================================================== */

/* Article Hero */
.article-hero {
  padding-top: var(--space-12);
  padding-bottom: var(--space-12);
}

.article-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}

.article-hero-content .blog-category {
  display: inline-block;
  margin-bottom: var(--space-4);
  text-decoration: none;
}

.article-hero-content .blog-category:hover {
  color: var(--color-teal-dark);
}

.article-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 600;
  line-height: var(--leading-tight);
  color: var(--color-black);
  margin-bottom: var(--space-6);
}

.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  color: var(--color-gray-600);
  font-size: var(--text-sm);
}

.article-meta span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.article-meta .icon {
  width: 16px;
  height: 16px;
  color: var(--color-teal);
}

.article-hero-image {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

.article-hero-image img {
  width: 100%;
  height: auto;
  display: block;
}

/* Article Content */
.article-content {
  padding-top: var(--space-12);
  padding-bottom: var(--space-8);
}

.article-body {
  max-width: 800px;
  margin: 0 auto;
}

.article-body h2,
.article-body h3,
.article-body h4 {
  font-family: var(--font-display);
  color: var(--color-black);
  margin-top: var(--space-8);
  margin-bottom: var(--space-4);
}

.article-body h2 {
  font-size: var(--text-2xl);
}

.article-body h3 {
  font-size: var(--text-xl);
}

.article-body p {
  margin-bottom: var(--space-4);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
}

.article-body ul {
  list-style: disc;
  margin-bottom: var(--space-4);
  padding-left: var(--space-8);
}

.article-body ol {
  list-style: decimal;
  margin-bottom: var(--space-4);
  padding-left: var(--space-8);
}

.article-body ul ul {
  list-style: circle;
  margin-bottom: 0;
}

.article-body li {
  margin-bottom: var(--space-2);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
}

.article-body blockquote {
  margin: var(--space-8) 0;
  padding: var(--space-6);
  background-color: var(--color-cream);
  border-left: 4px solid var(--color-teal);
  border-radius: var(--radius-lg);
  font-style: italic;
}

.article-body img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  margin: var(--space-6) 0;
}

/* Table of Contents (accordéon fermé par défaut) */
.article-toc {
  background-color: var(--color-cream);
  padding: 0;
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-8);
  border: 1px solid var(--color-gray-200);
}

.article-toc-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.article-toc-toggle::-webkit-details-marker {
  display: none;
}

.article-toc-toggle::after {
  content: '';
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--color-gray-500);
  border-bottom: 2px solid var(--color-gray-500);
  transform: rotate(45deg);
  transition: transform var(--transition-base);
  flex-shrink: 0;
}

.article-toc[open] .article-toc-toggle::after {
  transform: rotate(-135deg);
}

.article-toc-content {
  padding: 0 var(--space-6) var(--space-6);
}

.article-toc h3,
.article-toc h4 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin-bottom: var(--space-4);
}

.article-toc ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.article-toc li {
  margin-bottom: var(--space-2);
}

.article-toc a {
  color: var(--color-gray-600);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.article-toc a:hover {
  color: var(--color-teal);
}

/* Article Share */
.article-share {
  max-width: 800px;
  margin: var(--space-10) auto 0;
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-gray-200);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.article-share-label {
  font-weight: 600;
  color: var(--color-black);
}

.article-share-links {
  display: flex;
  gap: var(--space-3);
}

.article-share-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  color: var(--color-gray-600);
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: all var(--transition-fast);
  cursor: pointer;
}

.article-share-link:hover {
  color: var(--color-white);
  background-color: var(--color-teal);
  border-color: var(--color-teal);
}

.article-share-link svg {
  width: 20px;
  height: 20px;
}

.article-share-link.copied {
  color: var(--color-white);
  background-color: var(--color-teal);
  border-color: var(--color-teal);
}

/* Responsive Single Article */
@media (max-width: 1024px) {
  .article-hero-grid {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .article-hero-content {
    order: 1;
  }

  .article-hero-image {
    order: 2;
  }
}

@media (max-width: 768px) {
  .article-hero {
    padding-top: var(--space-8);
    padding-bottom: var(--space-8);
  }

  .article-title {
    font-size: 1.75rem;
  }

  .article-meta {
    flex-direction: column;
    gap: var(--space-2);
  }

  .article-share {
    flex-direction: column;
    text-align: center;
  }
}

/* ==========================================================================
   Destination Hero Section (Single Page)
   IMPORTANT: Tous les styles sont scopés à .destination-hero pour ne pas
   impacter la section destinations de la page d'accueil
   ========================================================================== */
.destination-hero {
  padding-top: var(--space-12);
  padding-bottom: var(--space-4);  /* Surcharge les 80px de .section */
}

/* Header compact */
.destination-hero .destination-header {
  margin-bottom: var(--space-6);
}

/* Ligne 1 : Badges + Localisation sur même ligne */
.destination-hero .destination-header-row {
  position: relative;  /* Pour le positionnement absolu des thématiques */
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.destination-hero .destination-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.destination-hero .destination-badges .destination-badge {
  position: static;
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: var(--radius-full);
  color: var(--color-white);
}

.destination-hero .destination-badge-a-la-carte {
  background-color: var(--color-coral);
}

.destination-hero .destination-badge-clef-en-main {
  background-color: var(--color-teal);
}

.destination-hero .destination-badges .destination-badge-type {
  background-color: var(--color-teal-dark);
}

.destination-hero .destination-thematiques {
  position: absolute;
  right: 0;
  top: 100%;  /* Juste en dessous de la row */
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: flex-end;
  margin-top: var(--space-1);
}

.destination-hero .thematique-tag {
  display: inline-flex;
  align-items: center;
  font-size: var(--text-xs);
  color: var(--color-teal-dark);
  background: var(--color-teal-light);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-full);
  font-weight: 500;
}

@media (max-width: 768px) {
  .destination-hero .destination-thematiques {
    display: none;
  }
}

.destination-hero .destination-title {
  font-size: var(--text-5xl);
  font-weight: 700;
  color: var(--color-black);
  margin-bottom: var(--space-2);
  line-height: 1.1;
}

.destination-hero .destination-location {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-gray-500);
  font-size: var(--text-base);
}

.destination-hero .destination-location .icon-location {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.destination-hero .destination-accroche {
  font-size: var(--text-lg);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  max-width: 900px;
}

/* Bandeau dates pour séjours Clef en Main */
.destination-hero .destination-dates-banner {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  border: 2px solid var(--color-teal);
  border-radius: var(--radius-full);
  padding: var(--space-2) var(--space-4);
  margin-top: var(--space-3);
  font-size: var(--text-sm);
}

.destination-hero .dates-sejour,
.destination-hero .dates-inscription {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: 500;
}

.destination-hero .dates-sejour {
  color: var(--color-teal-dark);
}

.destination-hero .dates-sejour svg {
  width: 16px;
  height: 16px;
  color: var(--color-teal);
}

.destination-hero .dates-separator {
  color: var(--color-gray-400);
  font-weight: 300;
}

.destination-hero .dates-inscription {
  color: var(--color-coral);
}

.destination-hero .dates-inscription svg {
  width: 16px;
  height: 16px;
  color: var(--color-coral);
}

/* Layout 2 colonnes : Titre/Accroche + Bouton CTA */
.destination-title-cta-wrapper {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-8);
  align-items: start;
  margin-bottom: var(--space-2);
}

.destination-title-content {
  min-width: 0;
}

.destination-cta-sidebar {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding-top: var(--space-8);
}

.destination-cta-sidebar .btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  white-space: nowrap;
}

.destination-cta-sidebar .btn svg {
  width: 20px;
  height: 20px;
}

.destination-cta-sidebar .destination-cta-note {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

/* Galerie - scopée à .destination-hero */
.destination-hero .destination-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.destination-hero .gallery-main {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  cursor: pointer;
}

.destination-hero .gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.destination-hero .gallery-main:hover img {
  transform: scale(1.03);
}

.destination-hero .gallery-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
  border: none;
  border-radius: var(--radius-full);
  background-color: var(--color-coral);
  color: var(--color-white);
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(255, 90, 74, 0.4);
  z-index: 2;
}

.destination-hero .gallery-play-btn svg {
  width: 32px;
  height: 32px;
  margin-left: 4px;
}

.destination-hero .gallery-play-btn:hover {
  background-color: var(--color-teal);
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 6px 25px rgba(13, 148, 136, 0.4);
}

.destination-hero .gallery-expand-btn {
  position: absolute;
  bottom: var(--space-4);
  right: var(--space-4);
  width: 44px;
  height: 44px;
  border: none;
  border-radius: var(--radius-lg);
  background-color: rgba(255, 255, 255, 0.9);
  color: var(--color-black);
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}

.destination-hero .gallery-expand-btn svg {
  width: 20px;
  height: 20px;
}

.destination-hero .gallery-expand-btn:hover {
  background-color: var(--color-white);
  transform: scale(1.1);
}

.destination-hero .gallery-thumbnails {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: var(--space-4);
}

.destination-hero .gallery-thumb {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  cursor: pointer;
}

.destination-hero .gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.destination-hero .gallery-thumb:hover img {
  transform: scale(1.05);
}

.destination-hero .gallery-thumb-empty {
  background: linear-gradient(135deg, var(--color-gray-100) 0%, var(--color-gray-200) 100%);
  cursor: default;
}

.destination-hero .gallery-thumb-more {
  cursor: pointer;
}

.destination-hero .gallery-thumb-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  gap: var(--space-2);
  transition: background 0.3s ease;
}

.destination-hero .gallery-thumb-more:hover .gallery-thumb-overlay {
  background: rgba(0, 0, 0, 0.7);
}

.destination-hero .gallery-thumb-overlay span {
  font-size: var(--text-2xl);
  font-weight: 700;
}

.destination-hero .gallery-thumb-overlay svg {
  width: 24px;
  height: 24px;
}

/* Informations clés - Layout horizontal compact */
.destination-hero .destination-key-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: var(--color-white);
  padding: var(--space-5) var(--space-6);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  gap: var(--space-4);
}

.destination-hero .key-info-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-3);
  flex: 1;
  padding: 0;
}

.destination-hero .key-info-icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
}

.destination-hero .key-info-icon svg {
  width: 22px;
  height: 22px;
}

.destination-hero .key-info-text {
  display: flex;
  flex-direction: column;
}

.destination-hero .key-info-icon-prix {
  background-color: rgba(251, 191, 36, 0.15);
  color: var(--color-yellow-dark, #D97706);
}

.destination-hero .key-info-icon-public {
  background-color: rgba(13, 148, 136, 0.1);
  color: var(--color-teal);
}

.destination-hero .key-info-icon-saison {
  background-color: rgba(255, 90, 74, 0.1);
  color: var(--color-coral);
}

.destination-hero .key-info-icon-pmr {
  background-color: rgba(13, 148, 136, 0.1);
  color: var(--color-teal);
}

.destination-hero .key-info-icon-pmr-yes {
  background-color: rgba(13, 148, 136, 0.15);
  color: var(--color-teal);
}

.destination-hero .key-info-icon-pmr-no {
  background-color: rgba(156, 163, 175, 0.15);
  color: var(--color-gray-500);
}

.destination-hero .key-info-label {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  margin-bottom: var(--space-1);
}

.destination-hero .key-info-value {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-black);
}

/* ==========================================================================
   Destination Gallery Modal
   ========================================================================== */
.gallery-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.gallery-modal.is-active {
  opacity: 1;
  visibility: visible;
}

.gallery-modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.95);
  cursor: pointer;
}

.gallery-modal-content {
  position: relative;
  width: 95%;
  max-width: 1200px;
  height: 90vh;
  display: flex;
  flex-direction: column;
  z-index: 1;
}

.gallery-modal-close {
  position: absolute;
  top: -50px;
  right: 0;
  width: 44px;
  height: 44px;
  border: none;
  border-radius: var(--radius-full);
  background-color: var(--color-white);
  color: var(--color-black);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  z-index: 10;
}

.gallery-modal-close svg {
  width: 24px;
  height: 24px;
}

.gallery-modal-close:hover {
  background-color: var(--color-coral);
  color: var(--color-white);
}

.gallery-modal-main {
  flex: 1;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
}

.gallery-modal-media {
  max-width: 100%;
  max-height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.gallery-modal-media img {
  max-width: 100%;
  max-height: 70vh;
  object-fit: contain;
  border-radius: var(--radius-lg);
}

.gallery-modal-video-container {
  width: 100%;
  max-width: 900px;
  aspect-ratio: 16 / 9;
}

.gallery-modal-video-container video,
.gallery-modal-video-container iframe {
  width: 100%;
  height: 100%;
  border-radius: var(--radius-lg);
}

.gallery-modal-video-container.video-portrait {
  aspect-ratio: 9/16;
  max-height: 85vh;
  width: auto;
}

@media (max-width: 768px) {
  .gallery-modal-video-container.video-portrait {
    max-height: 80vh;
    max-width: 90vw;
  }
}

.gallery-modal-prev,
.gallery-modal-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 50px;
  height: 50px;
  border: none;
  border-radius: var(--radius-full);
  background-color: rgba(255, 255, 255, 0.9);
  color: var(--color-black);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}

.gallery-modal-prev {
  left: var(--space-4);
}

.gallery-modal-next {
  right: var(--space-4);
}

.gallery-modal-prev:hover,
.gallery-modal-next:hover {
  background-color: var(--color-white);
  transform: translateY(-50%) scale(1.1);
}

.gallery-modal-prev svg,
.gallery-modal-next svg {
  width: 24px;
  height: 24px;
}

.gallery-modal-counter {
  text-align: center;
  color: var(--color-white);
  font-size: var(--text-sm);
  padding: var(--space-4) 0;
}

.gallery-modal-thumbs {
  display: flex;
  gap: var(--space-2);
  justify-content: center;
  overflow-x: auto;
  padding: var(--space-2) 0;
  max-width: 100%;
}

.gallery-modal-thumb {
  position: relative;
  width: 80px;
  height: 60px;
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  flex-shrink: 0;
  opacity: 0.5;
  transition: opacity 0.3s ease;
  border: 2px solid transparent;
}

.gallery-modal-thumb:hover,
.gallery-modal-thumb.is-active {
  opacity: 1;
}

.gallery-modal-thumb.is-active {
  border-color: var(--color-coral);
}

.gallery-modal-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gallery-modal-thumb-play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.3);
}

.gallery-modal-thumb-play svg {
  width: 20px;
  height: 20px;
  color: var(--color-white);
}

/* ==========================================================================
   DESTINATION - Section Détails (Layout 2 colonnes)
   ========================================================================== */
.destination-details {
  padding: var(--space-4) 0 var(--space-10);  /* 16px top, 40px bottom - surcharge le padding de .section */
}

.details-layout {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--space-8);
  align-items: start;
}

.details-layout.no-sidebar {
  grid-template-columns: 1fr;
}

.details-main {
  min-width: 0;
}

.details-sidebar {
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* Tabs Container */
.tabs-container {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}

.tabs-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  padding: var(--space-3);
  background: var(--color-gray-50);
  border-bottom: 1px solid var(--color-gray-200);
}

.tab-btn {
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-gray-600);
  background: transparent;
  border: none;
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.tab-btn:hover {
  color: var(--color-teal);
  background: var(--color-white);
}

.tab-btn.active {
  color: var(--color-teal);
  background: var(--color-white);
  font-weight: 600;
  box-shadow: var(--shadow-sm);
}

.tabs-content {
  padding: var(--space-6);
}

.tab-panel {
  display: none;
}

.tab-panel.active {
  display: block;
}

.tab-content-inner {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
}

/* Sidebar Cards */
.sidebar-card {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}

/* Host Card Compact */
.host-card-compact {
  display: flex;
  gap: var(--space-4);
  background: var(--color-white);
}

.host-avatar {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-full);
  overflow: hidden;
  flex-shrink: 0;
}

.host-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.host-info {
  flex: 1;
  min-width: 0;
}

.host-label {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-teal);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-1);
}

.host-name {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-black);
  margin-bottom: var(--space-1);
}

.host-bio {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-600);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Services Card Compact (ancien - peut être supprimé si plus utilisé) */
.services-card-compact {
  /* Sans bordure gauche */
}

/* Services Disponibles Card (nouveau style avec 4 pictos) */
.services-disponibles-card {
  /* Style de base hérité de .sidebar-card */
  background: rgba(13, 148, 136, 0.05);
  padding: var(--space-3) var(--space-4);  /* Padding réduit */
}

.services-disponibles-card .services-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  text-transform: none;
  letter-spacing: normal;
  color: var(--color-teal);
  margin-bottom: var(--space-3);
  padding: 0;
  background: none;
  text-align: center;
}

.services-disponibles-card .services-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}

.services-disponibles-card .service-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--color-gray-50);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  transition: opacity 0.2s ease;
}

.services-disponibles-card .service-item.inactive {
  opacity: 0.4;
}

.services-disponibles-card .service-item.inactive .service-icon,
.services-disponibles-card .service-item.inactive .service-name {
  color: var(--color-gray-400);
}

.services-disponibles-card .service-item.active .service-icon {
  color: var(--color-teal);
}

.services-disponibles-card .service-item.active .service-name {
  color: var(--color-black);
  font-weight: 500;
}

.services-disponibles-card .service-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.services-disponibles-card .service-icon svg {
  width: 30px;
  height: 30px;
}

.services-disponibles-card .service-name {
  font-size: 1rem;
  line-height: 1.3;
}

.sidebar-card-title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-black);
  margin-bottom: var(--space-4);
}

.sidebar-card-title svg {
  width: 18px;
  height: 18px;
  color: var(--color-teal);
}

.services-list {
  margin-bottom: var(--space-4);
}

.services-list:last-child {
  margin-bottom: 0;
}

.services-label {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
}

.services-inclus .services-label {
  background: rgba(16, 185, 129, 0.1);
  color: #10b981;
}

.services-optionnels .services-label {
  background: var(--color-yellow-light);
  color: var(--color-yellow-dark);
}

.wysiwyg-content ul {
  list-style: disc;
  padding-left: var(--space-8);
  margin-bottom: var(--space-4);
}

.wysiwyg-content ol {
  list-style: decimal;
  padding-left: var(--space-8);
  margin-bottom: var(--space-4);
}

.wysiwyg-content li {
  margin-bottom: var(--space-2);
  line-height: var(--leading-relaxed);
}

.wysiwyg-compact {
  font-size: var(--text-sm);
}

.wysiwyg-compact ul {
  margin: 0;
  padding-left: var(--space-4);
}

.wysiwyg-compact li {
  margin-bottom: var(--space-1);
}

/* ==========================================================================
   DESTINATION - Section Localisation
   ========================================================================== */
.destination-location-section {
  padding: var(--space-10) 0;
  background: var(--color-white);
}

.location-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: start;
}

.location-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.info-block {
  background: var(--color-cream);
  padding: var(--space-5);
  border-radius: var(--radius-xl);
}

.info-title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-black);
  margin-bottom: var(--space-3);
}

.info-title svg {
  width: 20px;
  height: 20px;
  color: var(--color-teal);
}

/* Accessibilité Block */
.accessibility-block {
  /* Sans bordure gauche */
}

.pmr-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-teal);
  margin-bottom: var(--space-3);
}

.pmr-badge svg {
  width: 20px;
  height: 20px;
}

/* Témoignage Unique */
.testimonial-single {
  background: var(--color-white);
  padding: var(--space-5);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.testimonial-single-header {
  margin-bottom: var(--space-3);
}

.testimonial-single .quote-icon {
  width: 24px;
  height: 24px;
  color: var(--color-coral);
  opacity: 0.5;
}

.testimonial-quote-text {
  font-size: var(--text-base);
  font-style: italic;
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
  margin: 0 0 var(--space-4);
}

.testimonial-video-thumb {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-4);
  cursor: pointer;
}

.testimonial-video-thumb img,
.testimonial-video-thumb video {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  pointer-events: none;
}

.testimonial-video-thumb .play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 48px;
  height: 48px;
  background: var(--color-coral);
  border: none;
  border-radius: var(--radius-full);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.testimonial-video-thumb .play-btn:hover {
  background: var(--color-teal);
  transform: translate(-50%, -50%) scale(1.1);
}

.testimonial-video-thumb .play-btn svg {
  width: 20px;
  height: 20px;
}

.testimonial-author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-gray-100);
}

.author-avatar {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  object-fit: cover;
}

.author-name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-black);
}

/* Carte */
.location-map-wrapper {
  height: 100%;
  min-height: 400px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.location-map {
  width: 100%;
  height: 100%;
}

#destination-map {
  width: 100%;
  height: 100%;
}

.teelda-marker {
  background: none !important;
  border: none !important;
}

/* ==========================================================================
   DESTINATION - Section FAQ (Compact)
   ========================================================================== */
.destination-faq {
  padding: var(--space-10) 0;
}

.faq-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-black);
  margin-bottom: var(--space-6);
}

.faq-accordion {
  max-width: 800px;
  margin: 0 auto;
}

.faq-item {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-3);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-4) var(--space-5);
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-black);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: color var(--transition-fast);
}

.faq-question:hover {
  color: var(--color-teal);
}

.faq-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-teal-light);
  border-radius: var(--radius-full);
  transition: all var(--transition-fast);
}

.faq-icon svg {
  width: 14px;
  height: 14px;
  color: var(--color-teal);
  transition: transform var(--transition-fast);
}

.faq-item.open .faq-icon {
  background: var(--color-teal);
}

.faq-item.open .faq-icon svg {
  color: white;
  transform: rotate(45deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.faq-answer-content {
  padding: 0 var(--space-5) var(--space-5);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
}

/* ==========================================================================
   DESTINATION - Section FAQ + Témoignage (Layout 2 colonnes)
   ========================================================================== */
.destination-faq-testimonial {
  padding: var(--space-10) 0;
}

.faq-testimonial-layout {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--space-8);
  align-items: start;
}

.faq-column .faq-accordion {
  max-width: none;
}

.testimonial-column {
  position: sticky;
  top: 100px;
}

.testimonial-column .testimonial-single {
  background: var(--color-white);
}

/* ==========================================================================
   DESTINATION - Section Témoignage (après contenu, avant carte)
   ========================================================================== */
.destination-testimonial-section {
  padding: var(--space-10) 0;
}

.destination-testimonial-section .testimonial-wrapper {
  max-width: 800px;
  margin: 0 auto;
}

.destination-testimonial-section .testimonial-single-large {
  background: var(--color-cream);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  text-align: center;
}

.destination-testimonial-section .testimonial-single-header {
  margin-bottom: var(--space-4);
}

.destination-testimonial-section .quote-icon {
  width: 48px;
  height: 48px;
  color: var(--color-teal);
  opacity: 0.3;
}

.destination-testimonial-section .testimonial-quote-text {
  font-size: var(--text-xl);
  line-height: var(--leading-relaxed);
  color: var(--color-black);
  font-style: italic;
  margin-bottom: var(--space-6);
}

.destination-testimonial-section .testimonial-author {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
}

.destination-testimonial-section .author-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
}

.destination-testimonial-section .author-name {
  font-weight: 600;
  color: var(--color-black);
}

.destination-testimonial-section .testimonial-video-thumb {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: var(--space-4);
}

.destination-testimonial-section .testimonial-video-thumb img,
.destination-testimonial-section .testimonial-video-thumb video {
  width: 100%;
  height: auto;
  max-height: 500px;
  aspect-ratio: auto;
  object-fit: contain;
  display: block;
  pointer-events: none;
}

.destination-testimonial-section .play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
  background: var(--color-coral);
  border: none;
  border-radius: 50%;
  color: var(--color-white);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s ease, background 0.3s ease;
}

.destination-testimonial-section .play-btn:hover {
  transform: translate(-50%, -50%) scale(1.1);
  background: var(--color-coral-dark);
}

.destination-testimonial-section .play-btn svg {
  width: 32px;
  height: 32px;
  margin-left: 4px;
}

/* ==========================================================================
   DESTINATION - Section FAQ seule
   ========================================================================== */
.destination-faq-section {
  padding: var(--space-10) 0;
}

.destination-faq-section .faq-wrapper {
  max-width: 900px;
  margin: 0 auto;
}

.destination-faq-section .faq-title {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-black);
  margin-bottom: var(--space-6);
  text-align: center;
}

.destination-faq-section .faq-accordion {
  max-width: none;
}

/* ==========================================================================
   Responsive - Tablets & Mobile
   ========================================================================== */
@media (max-width: 1024px) {
  :root {
    --text-6xl: 3rem;
    --text-5xl: 2.5rem;
    --text-4xl: 2rem;
  }

  .hero .container {
    grid-template-columns: 1fr;
    gap: var(--space-12);
  }

  .hero-visual {
    max-width: 600px;
    margin: 0 auto;
  }

  .hero-floating-card {
    left: 20px;
  }

  /* Services responsive 1024px */
  .services-layout {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }

  .services-intro {
    position: static;
    text-align: center;
  }

  .services-intro .section-title,
  .services-intro .section-description {
    text-align: center;
  }

  .services-intro .btn {
    display: inline-flex;
  }

  /* Destinations responsive 1024px */
  .destinations-grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .destination-card-horizontal {
    grid-template-columns: 150px 1fr;
    min-height: 140px;
  }

  /* Situations responsive 1024px */
  .situations-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Testimonials responsive 1024px */
  .testimonials-grid {
    grid-template-columns: 1fr 1fr;
  }

  .testimonial-card-featured {
    grid-column: span 2;
    grid-row: auto;
  }

  /* Testimonials Video responsive 1024px */
  .testimonial-modal-close {
    top: 16px;
    right: 16px;
  }

  /* Themes responsive 1024px */
  .themes-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Steps responsive 1024px */
  .steps-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Blog responsive 1024px */
  .blog-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Destination Title CTA layout responsive 1024px */
  .destination-title-cta-wrapper {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .destination-cta-sidebar {
    flex-direction: row;
    justify-content: center;
    padding: var(--space-3);
  }

  /* Destination Hero responsive 1024px */
  .destination-hero .destination-gallery {
    grid-template-columns: 1fr;
  }

  .destination-hero .gallery-main {
    aspect-ratio: 16 / 9;
  }

  .destination-hero .gallery-thumbnails {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 1fr;
  }

  .gallery-modal .gallery-modal-close {
    top: 16px;
    right: 16px;
  }

  /* Destination Content Sections responsive 1024px */
  .details-layout {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .details-sidebar {
    position: static;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
  }

  .location-layout {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .location-map-wrapper {
    height: 350px;
    order: -1;
  }

  /* FAQ + Témoignage responsive 1024px */
  .faq-testimonial-layout {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }

  .testimonial-column {
    position: static;
  }
}

@media (max-width: 768px) {
  :root {
    --text-6xl: 2.5rem;
    --text-5xl: 2rem;
    --text-4xl: 1.75rem;
    --space-20: 4rem;
    --space-16: 3rem;
    --space-12: 2.5rem;
  }

  .nav-links,
  .nav-actions {
    display: none;
  }

  .nav-toggle {
    display: flex;
  }

  .mobile-menu {
    display: block;
  }

  /* Hero responsive 768px */
  .hero {
    padding-top: var(--space-12);
    min-height: auto;
  }

  .hero-stats {
    flex-wrap: nowrap;
    justify-content: space-between;
    gap: var(--space-4);
    width: 100%;
  }

  .stat-number {
    font-size: var(--text-2xl);
  }

  .stat-label {
    font-size: var(--text-xs);
  }

  .hero-image {
    height: 400px;
  }

  .hero-scroll-indicator {
    display: none;
  }

  /* Services responsive 768px */
  .services-grid {
    grid-template-columns: 1fr;
  }

  /* Destinations responsive 768px */
  .destination-card-horizontal {
    grid-template-columns: 120px 1fr;
    min-height: 130px;
  }

  .destination-card-horizontal .destination-content {
    padding: var(--space-3);
  }

  .destination-card-horizontal .destination-meta {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
  }

  .destination-card-horizontal .destination-tags {
    margin-left: 0;
  }

  /* Situations responsive 768px */
  .situations-grid {
    grid-template-columns: 1fr;
  }

  /* Testimonials responsive 768px */
  .testimonials-grid {
    grid-template-columns: 1fr;
  }

  .testimonial-card-featured {
    grid-column: auto;
  }

  /* Testimonials Video responsive 768px */
  .testimonial-play-btn {
    width: 48px;
    height: 48px;
  }

  .testimonial-play-btn svg {
    width: 20px;
    height: 20px;
  }

  .testimonial-card-featured.testimonial-video .testimonial-play-btn {
    width: 56px;
    height: 56px;
  }

  .testimonial-modal-content {
    width: 95%;
    border-radius: var(--radius-lg);
  }

  /* Themes responsive 768px */
  .themes-grid {
    grid-template-columns: 1fr;
  }

  /* Steps responsive 768px */
  .steps-grid {
    grid-template-columns: 1fr;
  }

  /* Blog responsive 768px */
  .blog-grid {
    grid-template-columns: 1fr;
  }

  /* Destination Title CTA layout responsive 768px */
  .destination-cta-sidebar {
    flex-direction: column;
    width: 100%;
    box-shadow: none;
    background: transparent;
    padding: var(--space-4) 0;
    border-top: 1px solid var(--color-gray-200);
  }

  .destination-cta-sidebar .btn {
    width: 100%;
    justify-content: center;
  }

  /* Destination Testimonial section responsive 768px */
  .destination-testimonial-section .testimonial-single-large {
    padding: var(--space-6);
  }

  .destination-testimonial-section .testimonial-quote-text {
    font-size: var(--text-lg);
  }

  /* Destination Hero responsive 768px */
  .destination-hero .destination-title {
    font-size: var(--text-4xl);
  }

  .destination-hero .destination-accroche {
    font-size: var(--text-lg);
  }

  .destination-hero .gallery-thumbnails {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
  }

  .destination-hero .gallery-play-btn {
    width: 60px;
    height: 60px;
  }

  .destination-hero .gallery-play-btn svg {
    width: 24px;
    height: 24px;
  }

  .destination-hero .destination-key-info {
    flex-wrap: wrap;
    gap: var(--space-4);
    padding: var(--space-4);
  }

  .destination-hero .key-info-item {
    flex: 1 1 45%;
    min-width: 140px;
  }

  .destination-hero .key-info-icon {
    width: 36px;
    height: 36px;
    min-width: 36px;
  }

  .destination-hero .key-info-icon svg {
    width: 18px;
    height: 18px;
  }

  .destination-hero .key-info-label {
    font-size: var(--text-xs);
  }

  .destination-hero .key-info-value {
    font-size: var(--text-sm);
  }

  .gallery-modal .gallery-modal-prev,
  .gallery-modal .gallery-modal-next {
    width: 40px;
    height: 40px;
  }

  .gallery-modal .gallery-modal-prev {
    left: var(--space-2);
  }

  .gallery-modal .gallery-modal-next {
    right: var(--space-2);
  }

  /* Partners responsive 768px */
  .partners-track {
    gap: var(--space-8);
    animation-duration: 20s;
  }

  .partner-logo {
    height: 60px;
    min-width: 120px;
  }

  .partner-logo img {
    max-height: 50px;
    max-width: 120px;
  }

  .partners-track-wrapper::before,
  .partners-track-wrapper::after {
    width: 50px;
  }

  /* Destination Content Sections responsive 768px */
  .tabs-nav {
    gap: var(--space-1);
    padding-bottom: var(--space-3);
    flex-wrap: wrap;
  }

  .tab-btn {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
  }

  .tab-btn svg {
    width: 16px;
    height: 16px;
  }

  .tab-content {
    padding: var(--space-5);
  }

  .details-sidebar {
    grid-template-columns: 1fr;
  }

  .host-card-compact {
    flex-direction: column;
    text-align: center;
  }

  .host-avatar {
    margin: 0 auto;
  }

  .services-card-compact .services-list {
    grid-template-columns: 1fr;
  }

  .location-info .info-block,
  .location-info .accessibility-block {
    padding: var(--space-4);
  }

  .testimonial-single {
    padding: var(--space-4);
  }

  .faq-question {
    padding: var(--space-4) var(--space-5);
    font-size: var(--text-base);
  }

  .faq-answer-content {
    padding: 0 var(--space-5) var(--space-5);
  }
}

@media (max-width: 480px) {
  :root {
    --container-padding: var(--space-4);
    --text-6xl: 2rem;
    --text-5xl: 1.75rem;
    --text-4xl: 1.5rem;
    --text-3xl: 1.375rem;
  }

  /* Hero responsive 480px */
  .hero-cta {
    flex-direction: column;
  }

  .hero-cta .btn-lg {
    width: 100%;
  }

  .hero-image-accent {
    display: none;
  }

  .hero-floating-card {
    position: relative;
    left: 0;
    bottom: 0;
    margin-top: var(--space-6);
    max-width: 100%;
  }
}

/* ================================================
   Section Newsletter
   ================================================ */
.section-newsletter {
  background: linear-gradient(135deg, var(--color-teal) 0%, var(--color-teal-dark) 100%);
  padding: var(--space-12) 0;
}

.newsletter-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-12);
}

.newsletter-content {
  flex: 1;
  max-width: 500px;
}

.newsletter-content .section-tag {
  color: var(--color-yellow);
  margin-bottom: var(--space-2);
}

.newsletter-title {
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--color-white);
  margin-top: 0;
  margin-bottom: var(--space-3);
  line-height: 1.2;
}

.newsletter-description {
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.9);
  margin: 0;
}

.newsletter-form {
  flex: 1.2;
  max-width: 600px;
}

/* Styles formulaire Newsletter */
.newsletter-form-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.newsletter-form-fields {
  display: flex;
  gap: var(--space-3);
  align-items: stretch;
}

.newsletter-field {
  flex: 1;
}

.newsletter-field-email {
  flex: 1.5;
}

.newsletter-field-select {
  flex: 1;
}

.newsletter-field-submit {
  flex: 0 0 auto;
}

.newsletter-form input[type="email"],
.newsletter-form select {
  width: 100%;
  height: 100%;
  padding: var(--space-4) var(--space-5);
  font-size: var(--text-base);
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.1);
  color: var(--color-white);
  transition: all 0.2s ease;
  box-sizing: border-box;
}

.newsletter-form input[type="email"]::placeholder {
  color: rgba(255, 255, 255, 0.6);
}

.newsletter-form input[type="email"]:focus,
.newsletter-form select:focus {
  outline: none;
  border-color: var(--color-white);
  background: rgba(255, 255, 255, 0.15);
}

.newsletter-form select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 20px;
  padding-right: var(--space-10);
  cursor: pointer;
}

.newsletter-form select option {
  background: var(--color-white);
  color: var(--color-black);
}

.newsletter-form .btn {
  height: 100%;
  padding: var(--space-4) var(--space-8);
  white-space: nowrap;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
}

.newsletter-form .btn-loader {
  display: none;
}

.newsletter-form .btn-loader svg {
  width: 20px;
  height: 20px;
  animation: spin 1s linear infinite;
}

.newsletter-form-message {
  display: none;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  text-align: center;
}

.newsletter-form-message.success {
  background: rgba(255, 255, 255, 0.2);
  color: var(--color-white);
}

.newsletter-form-message.error {
  background: rgba(255, 90, 74, 0.3);
  color: var(--color-white);
}

/* Newsletter Responsive */
@media (max-width: 991px) {
  .newsletter-wrapper {
    flex-direction: column;
    text-align: center;
    gap: var(--space-8);
  }

  .newsletter-content {
    max-width: 100%;
  }

  .newsletter-form {
    max-width: 100%;
    width: 100%;
  }
}

@media (max-width: 640px) {
  .section-newsletter {
    padding: var(--space-10) 0;
  }

  .newsletter-title {
    font-size: var(--text-2xl);
  }

  .newsletter-form .newsletter-form-fields {
    flex-direction: column;
    gap: var(--space-3);
  }

  .newsletter-form .newsletter-field {
    width: 100%;
  }

  .newsletter-form .wpcf7-submit {
    width: 100%;
  }
}

/* ================================================
   Section Réassurance
   ================================================ */
.reassurance-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8);
}

.reassurance-card {
  text-align: center;
  padding: var(--space-6);
}

.reassurance-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-5);
  background-color: var(--color-yellow-light);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
}

.reassurance-icon svg {
  width: 28px;
  height: 28px;
  color: var(--color-yellow-dark);
}

.reassurance-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  margin-bottom: var(--space-3);
}

.reassurance-text {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
}

/* ================================================
   Section CTA Formulaire
   ================================================ */
.section-cta {
  position: relative;
  background-color: var(--color-teal);
  color: var(--color-white);
  overflow: hidden;
}

.cta-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.cta-pattern {
  position: absolute;
  inset: 0;
  opacity: 0.1;
  background-image:
    radial-gradient(circle at 10% 90%, var(--color-yellow) 0%, transparent 40%),
    radial-gradient(circle at 90% 10%, var(--color-coral) 0%, transparent 40%);
}

.cta-content {
  position: relative;
  z-index: 1;
  max-width: 700px;
  margin: 0 auto;
  text-align: center;
}

.cta-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 600;
  line-height: var(--leading-tight);
  margin-bottom: var(--space-4);
}

.cta-text {
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.85);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-10);
}

.cta-form-wrapper {
  background-color: var(--color-white);
  padding: var(--space-10);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-2xl);
}

.cta-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.form-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
}

.form-group {
  text-align: left;
}

.form-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-gray-700);
  margin-bottom: var(--space-2);
}

.form-input,
.form-select {
  width: 100%;
  padding: var(--space-4);
  border: 2px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  font-size: var(--text-base);
  color: var(--color-black);
  background-color: var(--color-white);
  transition: all var(--transition-fast);
}

.form-input:focus,
.form-select:focus {
  outline: none;
  border-color: var(--color-teal);
  box-shadow: 0 0 0 3px var(--color-teal-light);
}

.form-input::placeholder {
  color: var(--color-gray-400);
}

.form-textarea {
  min-height: 120px;
  resize: vertical;
}

.form-submit {
  margin-top: var(--space-2);
}

.form-submit .btn-yellow {
  width: 100%;
  position: relative;
}

.form-submit .btn-loader {
  display: none;
}

.form-submit .btn-loader svg {
  width: 20px;
  height: 20px;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.form-message {
  display: none;
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  text-align: center;
  margin-top: var(--space-4);
}

.form-message.success {
  background-color: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
}

.form-message.error {
  background-color: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
}

.cta-alternative {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-gray-200);
  color: var(--color-gray-500);
}

.cta-phone {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-teal);
  font-weight: 600;
  transition: color var(--transition-fast);
}

.cta-phone:hover {
  color: var(--color-teal-dark);
}

.cta-phone .icon {
  width: 18px;
  height: 18px;
}

/* ================================================
   Form - Nouveaux champs (Budget, Dates, Carte cadeau, Destination)
   ================================================ */
.form-group-dates {
  flex: 1;
}

.form-dates-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.form-dates-row .form-input {
  flex: 1;
}

.form-dates-separator {
  color: var(--color-gray-400);
  font-size: var(--text-sm);
  white-space: nowrap;
}

.form-input[readonly] {
  background-color: rgba(255, 255, 255, 0.7);
  cursor: not-allowed;
  color: var(--color-gray-600);
}

/* Date input styling */
.form-date {
  min-height: 48px;
}

.form-date::-webkit-calendar-picker-indicator {
  cursor: pointer;
  filter: opacity(0.6);
}

.form-date::-webkit-calendar-picker-indicator:hover {
  filter: opacity(1);
}

/* Responsive - Nouveaux champs formulaire */
@media (max-width: 768px) {
  .form-dates-row {
    flex-direction: column;
    gap: var(--space-3);
  }

  .form-dates-separator {
    display: none;
  }

  .form-dates-row .form-input {
    width: 100%;
  }
}

/* ================================================
   CTA Flottant
   ================================================ */
.floating-cta {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  z-index: 1000;

  display: flex;
  align-items: center;
  gap: var(--space-3);

  background-color: var(--color-coral);
  color: var(--color-white);
  padding: var(--space-4) var(--space-6);
  border-radius: var(--radius-full);

  font-weight: 600;
  font-size: var(--text-base);
  text-decoration: none;

  box-shadow: 0 4px 20px rgba(255, 90, 74, 0.4);
  transition: all var(--transition-normal);

  /* Caché par défaut, affiché via JS après scroll */
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
}

.floating-cta.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.floating-cta:hover {
  background-color: #e54a3a;
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(255, 90, 74, 0.5);
  color: var(--color-white);
}

.floating-cta-icon {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.floating-cta-icon svg {
  width: 100%;
  height: 100%;
}

.floating-cta-text {
  white-space: nowrap;
}

/* Cacher quand près de la section contact du footer */
.floating-cta.near-footer {
  opacity: 0;
  pointer-events: none;
}

/* Mobile - CTA Flottant */
@media (max-width: 768px) {
  .floating-cta {
    bottom: var(--space-4);
    right: var(--space-4);
    padding: var(--space-3) var(--space-5);
    font-size: var(--text-sm);
  }

  .floating-cta-icon {
    width: 20px;
    height: 20px;
  }
}

@media (max-width: 480px) {
  .floating-cta {
    left: var(--space-4);
    right: var(--space-4);
    justify-content: center;
    border-radius: var(--radius-xl);
  }
}

/* ================================================
   CTA Bouton après hero (page destination)
   ================================================ */
.destination-cta-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-6) 0;
  margin-top: var(--space-4);
  border-top: 1px solid var(--color-gray-200);
}

.destination-cta-action .btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.destination-cta-action .btn svg {
  width: 20px;
  height: 20px;
}

.destination-cta-note {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

/* ================================================
   Footer
   ================================================ */
.site-footer-new {
  background-color: var(--color-black);
  color: var(--color-white);
  padding-top: var(--space-16);
  padding-bottom: var(--space-8);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-12);
  margin-bottom: var(--space-12);
}

.footer-brand {
  display: flex;
  flex-direction: column;
}

.footer-logo {
  height: 36px;
  width: auto;
  margin-bottom: var(--space-4);
  filter: brightness(0) invert(1);
}

.footer-tagline {
  font-size: var(--text-base);
  color: var(--color-gray-400);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-6);
}

.footer-social {
  display: flex;
  gap: var(--space-3);
}

.social-link {
  width: 40px;
  height: 40px;
  background-color: var(--color-gray-700);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
}

.social-link:hover {
  background-color: var(--color-teal);
}

.social-link svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.footer-column {
  display: flex;
  flex-direction: column;
}

.footer-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  margin-bottom: var(--space-5);
}

.footer-links ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links a {
  font-size: var(--text-base);
  color: var(--color-gray-400);
  transition: color var(--transition-fast);
}

.footer-links a:hover {
  color: var(--color-yellow);
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-gray-700);
}

.footer-copyright {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

.footer-legal {
  display: flex;
  gap: var(--space-6);
}

.footer-legal a {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  transition: color var(--transition-fast);
}

.footer-legal a:hover {
  color: var(--color-white);
}

/* ================================================
   Responsive - Réassurance
   ================================================ */
@media (max-width: 1024px) {
  .reassurance-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .reassurance-grid {
    grid-template-columns: 1fr;
  }
}

/* ================================================
   Responsive - CTA Formulaire
   ================================================ */
@media (max-width: 768px) {
  .form-row {
    grid-template-columns: 1fr;
  }

  .cta-form-wrapper {
    padding: var(--space-6);
  }

  .cta-title {
    font-size: var(--text-3xl);
  }
}

/* ================================================
   Responsive - Footer
   ================================================ */
@media (max-width: 1024px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-8);
  }

  .footer-brand {
    grid-column: span 2;
  }
}

@media (max-width: 768px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .footer-brand {
    grid-column: span 1;
  }

  .footer-bottom {
    flex-direction: column;
    gap: var(--space-4);
    text-align: center;
  }

  .footer-legal {
    flex-wrap: wrap;
    justify-content: center;
  }
}

/* ==========================================================================
   Archive Destinations - Page listing avec filtres
   ========================================================================== */

/* Layout principal */
.destinations-archive {
  background-color: var(--color-cream);
}

.archive-header {
  text-align: center;
  margin-bottom: var(--space-10);
}

.archive-header .section-header {
  margin-bottom: var(--space-4);
}

.results-count {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
}

.results-count .count-number {
  font-weight: 600;
  color: var(--color-teal);
}

/* Layout 2 colonnes */
.archive-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--space-8);
  align-items: start;
}

/* ==========================================================================
   Sidebar Filtres
   ========================================================================== */
.filters-sidebar {
  position: sticky;
  top: 100px;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Bouton toggle filtres (visible uniquement sur mobile) */
.filters-mobile-toggle {
  display: none;
}

.filters-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* Groupes de filtres */
.filter-group {
  border-bottom: 1px solid var(--color-gray-200);
  padding-bottom: var(--space-4);
}

.filter-group:last-of-type {
  border-bottom: none;
  padding-bottom: 0;
}

.filter-group-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-black);
  margin-bottom: var(--space-3);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Header collapsible */
.filter-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  margin-bottom: var(--space-3);
}

.filter-group-header .filter-group-title {
  margin: 0;
  line-height: 1;
}

.filter-collapse-icon {
  width: 16px;
  height: 16px;
  color: var(--color-gray-500);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}

.filter-group-header[aria-expanded="false"] .filter-collapse-icon {
  transform: rotate(-90deg);
}

/* Options de filtre */
.filter-options {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.filter-options-radio,
.filter-options-checkbox {
  max-height: 200px;
  overflow-y: auto;
}

/* Option individuelle */
.filter-option {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  padding: var(--space-1) 0;
}

.filter-option:hover .filter-label {
  color: var(--color-teal);
}

/* Checkbox custom */
.filter-option input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.filter-checkbox {
  width: 18px;
  height: 18px;
  border: 2px solid var(--color-gray-300);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  flex-shrink: 0;
}

.filter-option input[type="checkbox"]:checked + .filter-checkbox {
  background-color: var(--color-teal);
  border-color: var(--color-teal);
}

.filter-option input[type="checkbox"]:checked + .filter-checkbox::after {
  content: '';
  width: 10px;
  height: 10px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}

.filter-option input[type="checkbox"]:focus + .filter-checkbox {
  box-shadow: 0 0 0 3px var(--color-teal-light);
}

/* Radio custom */
.filter-option input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-teal);
  cursor: pointer;
}

/* Label */
.filter-label {
  font-size: var(--text-sm);
  color: var(--color-gray-700);
  transition: color 0.2s ease;
  flex: 1;
}

/* Compteur */
.filter-count {
  font-size: var(--text-xs);
  color: var(--color-gray-400);
}

/* Toggle switch pour PMR */
.filter-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  cursor: pointer;
}

.filter-toggle input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-switch {
  position: relative;
  width: 44px;
  height: 24px;
  background-color: var(--color-gray-300);
  border-radius: var(--radius-full);
  transition: background-color 0.2s ease;
  flex-shrink: 0;
}

.toggle-switch::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  background-color: var(--color-white);
  border-radius: 50%;
  transition: transform 0.2s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

.filter-toggle input[type="checkbox"]:checked + .toggle-switch {
  background-color: var(--color-teal);
}

.filter-toggle input[type="checkbox"]:checked + .toggle-switch::after {
  transform: translateX(20px);
}

.filter-toggle input[type="checkbox"]:focus + .toggle-switch {
  box-shadow: 0 0 0 3px var(--color-teal-light);
}

/* Bouton reset */
.btn-reset-filters {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  width: 100%;
  margin-bottom: var(--space-4);
}

.btn-reset-filters[hidden] {
  display: none;
}

.btn-reset-filters svg {
  width: 16px;
  height: 16px;
}

/* ==========================================================================
   Grille des destinations
   ========================================================================== */
.destinations-results {
  position: relative;
  min-height: 400px;
}

.destinations-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  transition: opacity 0.3s ease;
}

.destinations-grid.is-loading {
  opacity: 0.5;
  pointer-events: none;
}

/* Loading overlay */
.loading-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.8);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  z-index: 10;
  border-radius: var(--radius-lg);
}

.loading-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid var(--color-gray-200);
  border-top-color: var(--color-teal);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.loading-overlay span {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
}

.loading-overlay[hidden] {
  display: none;
}

/* ==========================================================================
   Carte destination (listing)
   ========================================================================== */
.destination-card-listing {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.destination-card-listing:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}

.destination-card-listing a {
  display: block;
  text-decoration: none;
  color: inherit;
}

/* Image */
.destination-card-listing .destination-image {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  overflow: hidden;
}

.destination-card-listing .destination-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.destination-card-listing:hover .destination-image img {
  transform: scale(1.05);
}

.destination-card-listing .destination-image-placeholder {
  width: 100%;
  height: 100%;
  background: var(--color-gray-200);
}

/* Badges sur l'image */
.destination-card-listing .destination-badges {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.destination-card-listing .destination-badge {
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: var(--radius-full);
  color: var(--color-white);
  white-space: nowrap;
}

.destination-card-listing .destination-badge-clef-en-main {
  background-color: var(--color-teal);
}

.destination-card-listing .destination-badge-a-la-carte {
  background-color: var(--color-coral);
}

/* Badge PMR */
.destination-card-listing .destination-badge-pmr {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  width: 32px;
  height: 32px;
  background: var(--color-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.destination-card-listing .destination-badge-pmr svg {
  width: 18px;
  height: 18px;
  color: var(--color-teal);
}

/* Contenu */
.destination-card-listing .destination-content {
  padding: var(--space-4);
}

.destination-card-listing .destination-region {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-teal);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-1);
}

.destination-card-listing .destination-title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-black);
  margin-bottom: var(--space-1);
  line-height: 1.3;
}

.destination-card-listing .destination-location {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  margin-bottom: var(--space-2);
}

.destination-card-listing .destination-location svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.destination-card-listing .destination-accroche {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  line-height: 1.5;
  margin-bottom: var(--space-3);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Dates (Clef en Main) */
.destination-card-listing .destination-dates {
  background: var(--color-cream);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
}

.destination-card-listing .dates-sejour {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-black);
}

.destination-card-listing .dates-sejour svg {
  width: 16px;
  height: 16px;
  color: var(--color-teal);
  flex-shrink: 0;
}

.destination-card-listing .date-limite {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-coral);
  font-weight: 500;
  margin-top: var(--space-1);
  padding-left: 24px;
}

/* Meta (prix + public) */
.destination-card-listing .destination-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-gray-200);
}

.destination-card-listing .destination-price {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-teal-dark);
}

.destination-card-listing .destination-public {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-gray-500);
}

.destination-card-listing .destination-public svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

/* ==========================================================================
   No Results
   ========================================================================== */
.no-results {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--space-16) var(--space-8);
  background: var(--color-white);
  border-radius: var(--radius-lg);
}

.no-results svg {
  width: 64px;
  height: 64px;
  color: var(--color-gray-300);
  margin-bottom: var(--space-4);
}

.no-results h3 {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-black);
  margin-bottom: var(--space-2);
}

.no-results p {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  margin-bottom: var(--space-6);
}

/* ==========================================================================
   Pagination Archive
   ========================================================================== */
#destinations-pagination {
  margin-top: var(--space-10);
  display: flex;
  justify-content: center;
}

#destinations-pagination ul {
  display: flex;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
  margin: 0;
}

#destinations-pagination li {
  margin: 0;
}

#destinations-pagination a,
#destinations-pagination span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-3);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-gray-700);
  background: var(--color-white);
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: all 0.2s ease;
}

#destinations-pagination a:hover {
  background: var(--color-teal-light);
  border-color: var(--color-teal);
  color: var(--color-teal-dark);
}

#destinations-pagination .current {
  background: var(--color-teal);
  border-color: var(--color-teal);
  color: var(--color-white);
}

#destinations-pagination a svg {
  width: 16px;
  height: 16px;
}

/* ==========================================================================
   Responsive Archive
   ========================================================================== */
@media (max-width: 1024px) {
  .archive-layout {
    grid-template-columns: 240px 1fr;
    gap: var(--space-6);
  }

  .filters-sidebar {
    padding: var(--space-4);
  }
}

@media (max-width: 900px) {
  .archive-layout {
    grid-template-columns: 1fr;
  }

  .filters-sidebar {
    position: static;
    max-height: none;
    margin-bottom: var(--space-6);
    padding: 0;
    box-shadow: none;
    background: transparent;
  }

  .filters-mobile-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    width: 100%;
    padding: var(--space-3) var(--space-4);
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--color-teal);
    background: var(--color-white);
    border: 2px solid var(--color-teal);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: all 0.2s ease;
  }

  .filters-mobile-toggle svg {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
  }

  .filters-mobile-toggle .filters-toggle-chevron {
    transition: transform 0.2s ease;
  }

  .filters-mobile-toggle[aria-expanded="true"] .filters-toggle-chevron {
    transform: rotate(180deg);
  }

  .filters-mobile-toggle:hover {
    background: var(--color-teal-light);
  }

  /* Cacher le formulaire par défaut sur mobile */
  .filters-form {
    display: none;
    margin-top: var(--space-4);
  }

  .filters-form.filters-open {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  }

  .filter-group {
    border-bottom: none;
    padding-bottom: 0;
  }

  .btn-reset-filters {
    grid-column: 1 / -1;
  }
}

@media (max-width: 768px) {
  .destinations-grid {
    grid-template-columns: 1fr;
  }

  .filters-form {
    grid-template-columns: 1fr;
  }

  .destination-card-listing .destination-title {
    font-size: var(--text-base);
  }

  .destination-card-listing .destination-content {
    padding: var(--space-3);
  }
}

@media (max-width: 480px) {
  .filters-sidebar {
    padding: var(--space-3);
  }

  .filter-group-title {
    font-size: var(--text-xs);
  }

  #destinations-pagination a,
  #destinations-pagination span {
    min-width: 36px;
    height: 36px;
    font-size: var(--text-xs);
  }
}

/* ================================================
   PAGE TÉMOIGNAGES
   ================================================ */

/* Large Play Button (grille témoignages) */
.testimonial-play-btn-lg {
  width: 80px;
  height: 80px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--color-coral);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  box-shadow: 0 10px 30px rgba(255, 90, 74, 0.4);
}

.testimonial-play-btn-lg svg {
  width: 32px;
  height: 32px;
  color: var(--color-white);
  margin-left: 4px;
}

.testimonial-play-btn-lg:hover {
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 15px 40px rgba(255, 90, 74, 0.5);
}

/* Remove old unused styles */
.testimonial-hero-location {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-teal);
  font-weight: 500;
}

/* Grille Témoignages Page */
.testimonials-grid-page {
  grid-template-columns: repeat(3, 1fr);
}

/* Section Témoignage Enrichi */
.testimonial-enriched-section {
  padding: var(--space-16) 0;
}

.testimonial-enriched {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-12);
  align-items: center;
}

.testimonial-enriched-reverse {
  grid-template-columns: 1.5fr 1fr;
}

.testimonial-enriched-reverse .testimonial-enriched-content {
  order: -1;
}

.testimonial-enriched-media {
  position: relative;
}

.testimonial-enriched-image {
  border-radius: var(--radius-2xl);
  overflow: hidden;
  aspect-ratio: 1;
}

.testimonial-enriched-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Gallery for Enriched Testimonial */
.testimonial-enriched-gallery {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.testimonial-gallery-main {
  border-radius: var(--radius-2xl);
  overflow: hidden;
}

.testimonial-gallery-main img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.testimonial-gallery-secondary {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.testimonial-gallery-secondary img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-xl);
}

/* Content for Enriched Testimonial */
.testimonial-enriched-content {
  position: relative;
}

.testimonial-enriched-quote {
  margin-bottom: var(--space-6);
}

.quote-icon-large {
  width: 48px;
  height: 48px;
  color: var(--color-teal);
  opacity: 0.3;
}

.testimonial-enriched-text {
  margin: 0;
  padding: 0;
  border: none;
}

.testimonial-enriched-text p {
  font-size: var(--text-lg);
  color: var(--color-gray-700);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-4);
}

.testimonial-enriched-text p:last-of-type {
  margin-bottom: 0;
}

.testimonial-enriched-text strong {
  color: var(--color-black);
}

.testimonial-enriched-highlight {
  font-size: var(--text-xl) !important;
  font-weight: 500;
  color: var(--color-teal) !important;
  font-style: italic;
  margin-top: var(--space-6) !important;
  padding-left: var(--space-6);
  border-left: 4px solid var(--color-coral);
}

.testimonial-enriched-footer {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-gray-200);
}

.testimonial-enriched-name {
  display: block;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  font-style: normal;
  color: var(--color-black);
  margin-bottom: var(--space-3);
}

.testimonial-enriched-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-teal);
  font-size: var(--text-base);
  font-weight: 500;
  text-decoration: none;
  transition: color 0.2s ease;
}

.testimonial-enriched-link:hover {
  color: var(--color-teal-dark);
}

.testimonial-enriched-link svg {
  flex-shrink: 0;
}

/* ================================================
   PAGE TÉMOIGNAGES - Responsive
   ================================================ */

@media (max-width: 1024px) {
  .testimonials-grid-page {
    grid-template-columns: repeat(2, 1fr);
  }

  .testimonial-enriched {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .testimonial-enriched-reverse {
    grid-template-columns: 1fr;
  }

  .testimonial-enriched-reverse .testimonial-enriched-content {
    order: 1;
  }

  .testimonial-enriched-image {
    aspect-ratio: 16/9;
    max-width: 500px;
    margin: 0 auto;
  }
}

@media (max-width: 768px) {
  .hero-play-btn {
    width: 64px;
    height: 64px;
  }

  .hero-play-btn svg {
    width: 24px;
    height: 24px;
  }

  .testimonials-grid-page {
    grid-template-columns: 1fr;
  }

  .testimonial-play-btn-lg {
    width: 64px;
    height: 64px;
  }

  .testimonial-play-btn-lg svg {
    width: 24px;
    height: 24px;
  }

  .testimonial-enriched-text p {
    font-size: var(--text-base);
  }

  .testimonial-enriched-highlight {
    font-size: var(--text-lg) !important;
    padding-left: var(--space-4);
  }
}

@media (max-width: 480px) {
  .testimonial-gallery-secondary {
    grid-template-columns: 1fr;
  }

  .quote-icon-large {
    width: 36px;
    height: 36px;
  }
}

/* ==========================================================================
   FAQ Article (Shortcode) - Accordion Style
   ========================================================================== */
.block-faq-article {
  max-width: 800px;
  margin: var(--space-12) auto;
  padding: var(--space-8);
  background: var(--color-cream);
  border-radius: var(--radius-xl);
}

.block-faq-article .faq-category-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--color-black);
  margin-bottom: var(--space-6);
  text-align: center;
}

.block-faq-article .block-faqs {
  list-style: none;
  padding: 0;
  margin: 0;
}

.block-faq-article .faq-item {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-3);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.block-faq-article .faq-item .question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.block-faq-article .faq-item .question:hover {
  background-color: var(--color-gray-50);
}

.block-faq-article .faq-item .question h3 {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-black);
  margin: 0;
  flex: 1;
  transition: color var(--transition-fast);
}

.block-faq-article .faq-item .question:hover h3 {
  color: var(--color-teal);
}

/* Icône accordion (ajoutée via CSS) */
.block-faq-article .faq-item .question::after {
  content: '';
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  background: var(--color-teal-light);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230D9488' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='5' x2='12' y2='19'%3E%3C/line%3E%3Cline x1='5' y1='12' x2='19' y2='12'%3E%3C/line%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  transition: all var(--transition-fast);
}

.block-faq-article .faq-item.open .question::after {
  background-color: var(--color-teal);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='5' y1='12' x2='19' y2='12'%3E%3C/line%3E%3C/svg%3E");
}

.block-faq-article .faq-item .answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.block-faq-article .faq-item.open .answer {
  max-height: 1000px;
}

.block-faq-article .faq-item .answer .text-wrapper {
  padding: 0 var(--space-5) var(--space-5);
}

.block-faq-article .faq-item .answer p {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
  margin: 0;
}

/* ==========================================================================
   Author Card (Shortcode) - Article Single
   ========================================================================== */
.block-author-article {
  max-width: 800px;
  margin: var(--space-8) auto var(--space-12);
}

.block-author-article .author-card {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-6);
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-gray-100);
}

.block-author-article .author-card .image {
  flex-shrink: 0;
}

.block-author-article .author-card .image img {
  width: 100px;
  height: 100px;
  border-radius: var(--radius-full);
  object-fit: cover;
  border: 3px solid var(--color-teal-light);
}

.block-author-article .author-card .content {
  flex: 1;
}

.block-author-article .author-card .nickname {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-2);
}

.block-author-article .author-card .social-links {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.block-author-article .author-card .social-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--color-gray-100);
  border-radius: var(--radius-full);
  transition: all var(--transition-fast);
}

.block-author-article .author-card .social-links a:hover {
  background: var(--color-teal);
}

.block-author-article .author-card .social-links a img {
  width: 18px;
  height: 18px;
  transition: filter var(--transition-fast);
}

.block-author-article .author-card .social-links a:hover img {
  filter: brightness(0) invert(1);
}

.block-author-article .author-card .description {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-600);
  margin: 0;
}

/* Responsive Author Card */
@media (max-width: 640px) {
  .block-author-article .author-card {
    flex-direction: column;
    text-align: center;
  }

  .block-author-article .author-card .social-links {
    justify-content: center;
  }
}

/* ==========================================================================
   PAGE HEADER INTERNAL - Header pages internes (réutilisable)
   ========================================================================== */
.page-header-internal {
  position: relative;
  padding: var(--space-16) 0 var(--space-12);
  background: linear-gradient(180deg, var(--color-cream) 0%, var(--color-white) 100%);
  text-align: center;
  overflow: hidden;
}

/* Titre */
.page-header-title {
  font-family: var(--font-display);
  font-size: var(--text-5xl);
  font-weight: 600;
  line-height: var(--leading-tight);
  color: var(--color-black);
  margin: 0 0 var(--space-4);
}

/* Description */
.page-header-description {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-600);
  max-width: 600px;
  margin: 0 auto;
}

/* Responsive */
@media (max-width: 768px) {
  .page-header-internal {
    padding: var(--space-12) 0 var(--space-8);
  }

  .page-header-title {
    font-size: var(--text-4xl);
  }

  .page-header-description {
    font-size: var(--text-base);
  }
}

/* ==========================================================================
   PAGE ABOUT - Styles spécifiques page Qui sommes-nous
   ========================================================================== */

/* Section Pourquoi Teelda */
.about-why {
  padding-top: var(--space-16);
  padding-bottom: var(--space-16);
}

.about-why .container {
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

/* Collage d'images */
.about-collage {
  display: grid;
  grid-template-columns: 1fr 1.2fr 1fr;
  gap: var(--space-4);
  max-width: 900px;
  margin: 0 auto;
}

.collage-item {
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.collage-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.collage-item:hover img {
  transform: scale(1.05);
}

.collage-item-1 {
  height: 280px;
  align-self: end;
}

.collage-item-2 {
  height: 320px;
  margin-top: -40px;
}

.collage-item-3 {
  height: 260px;
  align-self: start;
}

/* Contenu texte Pourquoi */
.about-why-content {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

.about-why-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-4);
}

.about-why-subtitle {
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--color-teal);
  margin: 0 0 var(--space-6);
}

.about-why-text {
  text-align: left;
}

.about-why-text p {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
  margin: 0 0 var(--space-4);
}

.about-why-text p:last-child {
  margin-bottom: 0;
}

/* Section Mission */
.about-mission {
  padding: var(--space-16) 0;
}

.about-mission-content {
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
}

.about-mission-quote {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 500;
  line-height: var(--leading-snug);
  color: var(--color-white);
  margin: 0;
  font-style: italic;
}

/* Section L'équipe */
.about-team {
  padding: var(--space-16) 0;
}

.about-team-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}

.about-team-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-6);
}

.about-team-text p {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
  margin: 0 0 var(--space-4);
}

.about-team-text p:last-child {
  margin-bottom: 0;
}

.about-team-image {
  position: relative;
}

.about-team-image img {
  width: 100%;
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-xl);
}

.about-team-image-accent {
  position: absolute;
  bottom: -20px;
  right: -20px;
  width: 120px;
  height: 120px;
  background: var(--color-coral);
  border-radius: var(--radius-2xl);
  z-index: -1;
  opacity: 0.3;
}

/* Section Valeurs */
.about-values {
  padding: var(--space-16) 0;
}

.values-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-10);
}

.values-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-10);
}

.values-card {
  background: var(--color-white);
  padding: var(--space-8);
  border-radius: var(--radius-2xl);
  text-align: center;
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
}

.values-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
}

.values-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  background: var(--color-coral-light);
  border-radius: var(--radius-xl);
  margin: 0 auto var(--space-4);
}

.values-card-icon svg {
  width: 32px;
  height: 32px;
  stroke: var(--color-coral);
}

.values-card-icon-coral {
  background: var(--color-coral-light);
}

.values-card-icon-coral svg {
  stroke: var(--color-coral);
}

.values-card-icon-yellow {
  background: var(--color-yellow-light);
}

.values-card-icon-yellow svg {
  stroke: var(--color-yellow-dark);
}

.values-card-icon-teal {
  background: var(--color-teal-light);
}

.values-card-icon-teal svg {
  stroke: var(--color-teal);
}

.values-card-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-3);
}

.values-card-text {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-600);
  margin: 0;
}

/* Section Distinctions */
.about-distinctions {
  padding: var(--space-16) 0;
}

.distinction-card {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-10);
  align-items: center;
  max-width: 900px;
  margin: var(--space-10) auto 0;
}

.distinction-image {
  border-radius: var(--radius-2xl);
  overflow: hidden;
}

.distinction-image img {
  width: 100%;
  height: auto;
}

.distinction-content {
  position: relative;
}

.distinction-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  background: var(--color-yellow);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-4);
}

.distinction-badge svg {
  width: 32px;
  height: 32px;
  fill: var(--color-white);
}

.distinction-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-4);
}

.distinction-text {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
  margin: 0;
}

/* Responsive About Page */
@media (max-width: 1024px) {
  .values-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .values-grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }

  .about-team-grid {
    gap: var(--space-8);
  }
}

@media (max-width: 768px) {
  .about-collage {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
  }

  .collage-item-1,
  .collage-item-2,
  .collage-item-3 {
    height: 200px;
    margin-top: 0;
  }

  .collage-item-3 {
    grid-column: span 2;
    height: 180px;
  }

  .about-why-title,
  .about-team-title {
    font-size: var(--text-3xl);
  }

  .about-mission-quote {
    font-size: var(--text-2xl);
  }

  .about-team-grid {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .about-team-image {
    order: -1;
  }

  .values-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .values-grid-3 {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .distinction-card {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
}

/* ========================================
   Page Nos Services - V2
   ======================================== */

/* Section Intro avec Collage */
.page-template-page-nos-services .services-intro {
  padding-top: 0;
  padding-bottom: var(--space-12);
  position: relative;
  z-index: 1;
  background: var(--color-white);
}

.services-collage {
  display: grid;
  grid-template-columns: 1fr 1.3fr 1fr;
  gap: var(--space-4);
  max-width: 1000px;
  margin: 0 auto;
  align-items: end;
}

/* Section Pillars */
.services-pillars {
  position: relative;
  z-index: 2;
}

.services-collage-item {
  overflow: hidden;
  border-radius: var(--radius-xl);
}

.services-collage-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-normal);
}

.services-collage-item:hover img {
  transform: scale(1.05);
}

.services-collage-item-1 {
  height: 300px;
}

.services-collage-item-2 {
  height: 340px;
}

.services-collage-item-3 {
  height: 280px;
}

.services-intro-content {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}

.services-intro-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-4);
}

.services-intro-subtitle {
  font-size: var(--text-lg);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin: 0;
}

/* Section 3 Piliers (cartes horizontales) */
.services-pillars-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.services-pillar {
  display: flex;
  align-items: flex-start;
  gap: var(--space-5);
  background: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.services-pillar-icon {
  width: 56px;
  height: 56px;
  min-width: 56px;
  background: var(--color-teal-light);
  color: var(--color-teal);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.services-pillar-icon svg {
  width: 28px;
  height: 28px;
}

.services-pillar-icon-coral {
  background: rgba(255, 90, 74, 0.1);
  color: var(--color-coral);
}

.services-pillar-icon-yellow {
  background: var(--color-yellow-light);
  color: #B45309;
}

.services-pillar-content {
  flex: 1;
}

.services-pillar-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-2);
}

.services-pillar-text {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-600);
  margin: 0;
}

/* Section Formules (A la Carte / Clef en Main) */
.services-formula {
  padding: var(--space-16) 0;
}

.services-formula-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}

.services-formula-grid-reverse {
  direction: rtl;
}

.services-formula-grid-reverse > * {
  direction: ltr;
}

.services-formula-image {
  position: relative;
}

.services-formula-image img {
  width: 100%;
  height: 480px;
  object-fit: cover;
  border-radius: var(--radius-xl);
}

.services-formula-badge {
  position: absolute;
  bottom: var(--space-4);
  left: var(--space-4);
  background: var(--color-coral);
  color: var(--color-white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: 600;
}

.services-formula-badge-right {
  left: auto;
  right: var(--space-4);
  background: var(--color-teal);
}

.services-formula-title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-4);
}

.services-formula-lead {
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--color-teal);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-4);
}

.services-formula-text {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
  margin: 0 0 var(--space-4);
}

.services-formula-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-6);
}

.services-formula-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  font-size: var(--text-base);
  color: var(--color-gray-700);
}

.services-formula-list li svg {
  width: 20px;
  height: 20px;
  min-width: 20px;
  color: var(--color-teal);
  margin-top: 2px;
}

/* Benefits grid (Clef en Main) */
.services-formula-benefits {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin: var(--space-6) 0;
}

.services-formula-benefit {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.services-formula-benefit-icon {
  width: 40px;
  height: 40px;
  min-width: 40px;
  background: var(--color-teal-light);
  color: var(--color-teal);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
}

.services-formula-benefit-icon svg {
  width: 20px;
  height: 20px;
}

.services-formula-benefit strong {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-black);
}

.services-formula-benefit span {
  font-size: var(--text-xs);
  color: var(--color-gray-600);
}

/* CTA intermédiaire */
.services-cta-content {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

.services-cta-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 600;
  color: var(--color-white);
  margin: var(--space-4) 0;
}

.services-cta-text {
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.9);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-6);
}

/* Section Comparatif avec images */
.services-compare-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  max-width: 900px;
  margin: 0 auto;
}

.services-compare-card {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.services-compare-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
}

.services-compare-card-highlight {
  border: 2px solid var(--color-teal);
}

.services-compare-image {
  position: relative;
  height: 200px;
  overflow: hidden;
}

.services-compare-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.services-compare-popular {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  background: var(--color-teal);
  color: var(--color-white);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.services-compare-content {
  padding: var(--space-6);
}

.services-compare-label {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-teal);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-2);
}

.services-compare-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-3);
}

.services-compare-text {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-600);
  margin: 0 0 var(--space-4);
}

.services-compare-features {
  list-style: none;
  padding: 0;
  margin: 0;
}

.services-compare-features li {
  padding: var(--space-2) 0;
  padding-left: var(--space-6);
  position: relative;
  font-size: var(--text-sm);
  color: var(--color-gray-700);
}

.services-compare-features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: var(--color-teal-light);
  border-radius: 50%;
}

.services-compare-features li::after {
  content: '';
  position: absolute;
  left: 5px;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  background: var(--color-teal);
  border-radius: 50%;
}

/* Responsive - Page Services V2 */
@media (max-width: 1024px) {
  .services-collage {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
  }

  .services-collage-item-1,
  .services-collage-item-2,
  .services-collage-item-3 {
    height: 220px;
    margin-top: 0;
  }

  .services-collage-item-3 {
    grid-column: span 2;
    height: 180px;
  }

  .services-formula-grid {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .services-formula-grid-reverse {
    direction: ltr;
  }

  .services-formula-image img {
    height: 350px;
  }

  .services-formula-benefits {
    grid-template-columns: 1fr;
  }

  .services-compare-cards {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .services-collage {
    grid-template-columns: 1fr;
  }

  .services-collage-item-1,
  .services-collage-item-2,
  .services-collage-item-3 {
    height: 200px;
    grid-column: auto;
  }

  .services-intro-title,
  .services-formula-title {
    font-size: var(--text-3xl);
  }

  .services-pillar {
    flex-direction: column;
    text-align: center;
  }

  .services-pillar-icon {
    margin: 0 auto;
  }

  .services-cta-title {
    font-size: var(--text-2xl);
  }

  .services-formula-image img {
    height: 280px;
  }
}

/* ==========================================================================
   PAGE FAQ - Tabs & Accordion
   ========================================================================== */

/* Section FAQ */
.faq-section {
  padding-top: var(--space-8);
  padding-bottom: var(--space-16);
}

/* Tabs Navigation */
.faq-tabs {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  margin-bottom: var(--space-10);
  flex-wrap: wrap;
}

.faq-tab {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  background: var(--color-white);
  border: 2px solid var(--color-gray-200);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-gray-600);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.faq-tab svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
}

.faq-tab:hover {
  border-color: var(--color-teal);
  color: var(--color-teal);
}

.faq-tab.active {
  background: var(--color-teal);
  border-color: var(--color-teal);
  color: var(--color-white);
}

/* Tab Panels */
.faq-panels {
  max-width: 800px;
  margin: 0 auto;
}

.faq-panel {
  display: none;
}

.faq-panel.active {
  display: block;
}

/* Accordion */
.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.faq-item {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  overflow: hidden;
  border: 1px solid var(--color-gray-100);
  transition: all var(--transition-fast);
}

.faq-item:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  width: 100%;
  padding: var(--space-5) var(--space-6);
  background: none;
  border: none;
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-black);
  text-align: left;
  cursor: pointer;
  transition: color var(--transition-fast);
}

.faq-question:hover {
  color: var(--color-teal);
}

.faq-question span {
  flex: 1;
}

.faq-chevron {
  width: 20px;
  height: 20px;
  stroke: var(--color-gray-400);
  transition: transform 0.3s ease, stroke 0.2s ease;
  flex-shrink: 0;
}

.faq-item.open .faq-chevron {
  transform: rotate(180deg);
  stroke: var(--color-teal);
}

/* Answer */
.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.faq-item.open .faq-answer {
  max-height: 1000px;
}

.faq-answer p,
.faq-answer ul,
.faq-answer ol {
  padding: 0 var(--space-6) var(--space-5);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-gray-700);
  margin: 0;
}

.faq-answer p + p {
  margin-top: var(--space-3);
}

.faq-answer ul,
.faq-answer ol {
  padding-left: calc(var(--space-6) + var(--space-4));
}

.faq-answer li {
  margin-bottom: var(--space-2);
}

.faq-answer ul {
  list-style: disc;
}

.faq-answer ol {
  list-style: decimal;
}

/* CTA Section */
.faq-cta {
  padding: var(--space-16) 0;
}

.faq-cta-content {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

.faq-cta-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 600;
  color: var(--color-white);
  margin: 0 0 var(--space-4);
}

.faq-cta-text {
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.9);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-6);
}

/* Responsive FAQ */
@media (max-width: 768px) {
  .faq-tabs {
    gap: var(--space-2);
  }

  .faq-tab {
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-xs);
  }

  .faq-tab span {
    display: none;
  }

  .faq-tab svg {
    width: 20px;
    height: 20px;
  }

  .faq-question {
    padding: var(--space-4) var(--space-4);
    font-size: var(--text-sm);
  }

  .faq-answer p,
  .faq-answer ul,
  .faq-answer ol {
    padding: 0 var(--space-4) var(--space-4);
    font-size: var(--text-sm);
  }

  .faq-cta-title {
    font-size: var(--text-2xl);
  }
}

@media (max-width: 480px) {
  .faq-tab {
    padding: var(--space-3);
    border-radius: var(--radius-lg);
  }
}

/* ==========================================================================
   PAGE CONTACT
   ========================================================================== */

.contact-section {
  padding-top: var(--space-8);
  padding-bottom: var(--space-16);
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-10);
  align-items: start;
}

/* -- Colonne Info -- */
.contact-info {
  position: sticky;
  top: 120px;
}

.contact-info-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-3);
}

.contact-info-description {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-8);
}

.contact-cards {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-cream);
  border-radius: var(--radius-xl);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  text-decoration: none;
  color: inherit;
}

a.contact-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.contact-card-icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-card-icon svg {
  width: 24px;
  height: 24px;
}

.contact-card-icon-teal {
  background: rgba(13, 148, 136, 0.1);
  color: var(--color-teal);
}

.contact-card-icon-teal svg {
  stroke: var(--color-teal);
}

.contact-card-icon-coral {
  background: rgba(255, 90, 74, 0.1);
  color: var(--color-coral);
}

.contact-card-icon-coral svg {
  stroke: var(--color-coral);
}

.contact-card-icon-yellow {
  background: rgba(251, 191, 36, 0.15);
  color: var(--color-yellow);
}

.contact-card-icon-yellow svg {
  stroke: #D97706;
}

.contact-card-content {
  flex: 1;
  min-width: 0;
}

.contact-card-title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-gray-500);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0 0 var(--space-1);
}

.contact-card-value {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-black);
  margin: 0;
  line-height: var(--leading-relaxed);
}

.contact-card-detail {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  margin: var(--space-1) 0 0;
}

/* -- Colonne Formulaire -- */
.contact-form-card {
  background: var(--color-white);
  padding: var(--space-8) var(--space-8);
  border-radius: var(--radius-2xl);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
}

.contact-form-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-6);
}

.contact-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.contact-form .form-group {
  margin-bottom: 0;
}

.contact-form .form-group:last-child {
  margin-bottom: 0;
}

.contact-form > .form-group {
  margin-bottom: var(--space-4);
}

.contact-form .form-submit {
  margin-top: var(--space-6);
}

/* -- CTA FAQ Section -- */
.contact-faq-cta {
  padding: var(--space-16) 0;
}

.contact-faq-cta-content {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

.contact-faq-cta-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 600;
  color: var(--color-white);
  margin: 0 0 var(--space-4);
}

.contact-faq-cta-text {
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.9);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-6);
}

/* -- Responsive Contact -- */
@media (max-width: 1024px) {
  .contact-grid {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .contact-info {
    position: static;
  }
}

@media (max-width: 768px) {
  .contact-section {
    padding-top: var(--space-4);
    padding-bottom: var(--space-10);
  }

  .contact-form-card {
    padding: var(--space-6) var(--space-5);
  }

  .contact-form .form-row {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  .contact-faq-cta-title {
    font-size: var(--text-2xl);
  }

  .contact-info-title {
    font-size: var(--text-xl);
  }
}

/* ==========================================================================
   BLOC PRESSE
   ========================================================================== */

.presse-section {
  padding: var(--space-16) 0;
}

.presse-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-10);
}

.presse-card {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.presse-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
}

.presse-card-link,
.presse-card-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
}

.presse-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-gray-200);
}

.presse-card-logo {
  height: 40px;
  max-width: 120px;
}

.presse-card-logo img {
  height: 100%;
  width: auto;
  object-fit: contain;
}

.presse-card-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-1);
}

.presse-card-date {
  font-size: var(--text-xs);
  color: var(--color-gray-500);
}

.presse-card-type {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
}

.presse-card-type-pdf {
  background: var(--color-coral-light);
  color: var(--color-coral-dark);
}

.presse-card-type-link {
  background: var(--color-teal-light);
  color: var(--color-teal-dark);
}

.presse-card-content {
  padding: var(--space-5);
  flex: 1;
}

.presse-card-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-2);
  line-height: var(--leading-snug);
}

.presse-card-excerpt {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.presse-card-video {
  padding: 0 var(--space-5) var(--space-4);
}

.presse-card-video-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-teal);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.presse-card-video-link:hover {
  color: var(--color-teal-dark);
}

.presse-card-footer {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--color-gray-200);
}

.presse-card-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-teal);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.presse-card-cta:hover {
  color: var(--color-teal-dark);
}

.presse-card-cta svg {
  transition: transform var(--transition-fast);
}

.presse-card:hover .presse-card-cta svg {
  transform: translateX(4px);
}

/* Responsive Presse */
@media (max-width: 992px) {
  .presse-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .presse-grid {
    grid-template-columns: 1fr;
  }

  .presse-card-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .presse-card-meta {
    flex-direction: row;
    align-items: center;
    width: 100%;
    justify-content: space-between;
  }
}

/* ==========================================================================
   BLOC ÉQUIPE / INTERVENANTS
   ========================================================================== */

.equipe-section {
  padding: var(--space-16) 0;
}

.equipe-grid {
  display: grid;
  gap: var(--space-6);
  margin-top: var(--space-10);
}

.equipe-grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

.equipe-grid-4 {
  grid-template-columns: repeat(4, 1fr);
}

.equipe-card {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  text-align: center;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.equipe-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
}

.equipe-card-photo {
  width: 100%;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--color-gray-100);
}

.equipe-card-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.equipe-card:hover .equipe-card-photo img {
  transform: scale(1.05);
}

.equipe-card-photo-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-gray-100);
}

.equipe-card-photo-placeholder svg {
  width: 60%;
  height: 60%;
  color: var(--color-gray-300);
}

.equipe-card-content {
  padding: var(--space-5);
}

.equipe-card-name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-1);
}

.equipe-card-role {
  display: inline-block;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-teal);
  margin-bottom: var(--space-3);
}

.equipe-card-bio {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin: 0;
}

/* Responsive Équipe */
@media (max-width: 992px) {
  .equipe-grid-3,
  .equipe-grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .equipe-grid-3,
  .equipe-grid-4 {
    grid-template-columns: 1fr;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ==========================================================================
   STYLES ADDITIONNELS POUR BLOCS FLEXIBLES
   ========================================================================== */

/* Grille services avec colonnes variables */
.services-grid-2 {
  grid-template-columns: repeat(2, 1fr);
}

.services-grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

.services-grid-4 {
  grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 992px) {
  .services-grid-3,
  .services-grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .services-grid-2,
  .services-grid-3,
  .services-grid-4 {
    grid-template-columns: 1fr;
  }
}

/* Lien service optionnel */
.service-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-teal);
  margin-top: var(--space-3);
  transition: color var(--transition-fast);
}

.service-link:hover {
  color: var(--color-teal-dark);
}

.service-link svg {
  transition: transform var(--transition-fast);
}

.service-link:hover svg {
  transform: translateX(4px);
}

/* Titre pour bloc texte-media */
.testimonial-enriched-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 600;
  color: var(--color-black);
  margin: 0 0 var(--space-6);
  line-height: var(--leading-tight);
}

/* Grille partenaires (mode non-carousel) */
.partners-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-6);
  align-items: center;
  justify-items: center;
  padding: var(--space-8) 0;
}

.partners-grid .partner-logo {
  opacity: 0.7;
  transition: opacity var(--transition-base);
}

.partners-grid .partner-logo:hover {
  opacity: 1;
}

/* ==========================================================================
   Bouton flottant "Offrir ce séjour" - Pages destinations
   ========================================================================== */
.floating-gift-btn {
  position: fixed;
  bottom: var(--space-6);
  left: var(--space-6);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  background-color: var(--color-yellow);
  color: var(--color-black);
  font-weight: 600;
  font-size: var(--text-sm);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-lg);
  z-index: 999;
  transition: all var(--transition-base);
  text-decoration: none;
}

.floating-gift-btn:hover {
  background-color: var(--color-yellow-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-xl);
}

.floating-gift-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
}

.floating-gift-icon svg {
  width: 100%;
  height: 100%;
}

@media (max-width: 768px) {
  .floating-gift-btn {
    bottom: var(--space-4);
    left: var(--space-4);
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-xs);
  }
}

/* ==========================================================================
   Modal Vidéo Témoignage - Pages destinations
   ========================================================================== */
.testimonial-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition-slow);
}

.testimonial-modal.is-active {
  opacity: 1;
  visibility: visible;
}

.testimonial-modal-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.85);
}

.testimonial-modal-content {
  position: relative;
  width: 90%;
  max-width: 900px;
  z-index: 1;
}

.testimonial-modal-close {
  position: absolute;
  top: -40px;
  right: 0;
  width: 32px;
  height: 32px;
  color: white;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 2;
}

.testimonial-modal-close svg {
  width: 100%;
  height: 100%;
}

.testimonial-modal-content .testimonial-modal-video {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.testimonial-modal-content .testimonial-modal-video video {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background-color: var(--color-black);
  border-radius: var(--radius-lg);
}

.testimonial-modal-content .testimonial-modal-video.video-portrait {
  aspect-ratio: 9/16;
  max-height: 85vh;
  width: auto;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .testimonial-modal-content .testimonial-modal-video.video-portrait {
    max-height: 80vh;
    max-width: 90vw;
  }
}

/* ================================================
   Bouton retour en haut de page
   ================================================ */
.back-to-top {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  z-index: 999;

  display: flex;
  align-items: center;
  justify-content: center;

  width: 48px;
  height: 48px;
  padding: 0;
  border: none;
  border-radius: 50%;

  background-color: var(--color-teal);
  color: var(--color-white);
  cursor: pointer;

  box-shadow: 0 4px 15px rgba(13, 148, 136, 0.3);
  transition: all var(--transition-normal);

  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
}

.back-to-top.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.back-to-top:hover {
  background-color: var(--color-teal-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(13, 148, 136, 0.4);
}

.back-to-top svg {
  width: 24px;
  height: 24px;
}

/* Quand le floating CTA est visible, decaler le back-to-top au-dessus */
.floating-cta.visible ~ .back-to-top.visible,
.back-to-top.visible {
  bottom: calc(var(--space-6) + 70px);
}

@media (max-width: 768px) {
  .back-to-top {
    width: 42px;
    height: 42px;
    right: var(--space-4);
  }

  .back-to-top.visible {
    bottom: calc(var(--space-4) + 65px);
  }
}

@media (max-width: 480px) {
  .back-to-top.visible {
    bottom: calc(var(--space-4) + 70px);
    right: var(--space-4);
  }
}
