/* ============================================================
   style.css - Music Qualité
   Feuille de style globale du site
   Toute modification ici se propage sur l'ensemble des pages.
   ============================================================ */

/* =========================================
   VARIABLES
========================================= */
:root {
  --couleur-principale:   #1a5c8a;
  --couleur-accent:       #f0c040;
  --couleur-texte:        #0d0d0d;
  --couleur-texte-doux:   #555555;
  --couleur-fond:         #ffffff;
  --couleur-fond-doux:    #f9f8f5;
  --couleur-bordure:      #e0ddd6;
  --couleur-texte-faible: #999999;

  --police-titre: Georgia, 'Times New Roman', serif;
  --police-corps: Verdana, Geneva, Tahoma, sans-serif;

  --rayon: 4px;
  --rayon-lg: 6px;
  --ombre: 0 2px 12px rgba(0,0,0,0.07);
  --transition: 0.2s ease;
  --max-largeur: 1100px;
}

/* =========================================
   RESET & BASE
========================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--police-corps);
  font-size: 0.85rem;
  line-height: 1.5;
  color: var(--couleur-texte);
  background: var(--couleur-fond);
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }

h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; margin: 0; }

a { color: var(--couleur-principale); text-decoration: none; }
a:hover { text-decoration: underline; }

.conteneur {
  max-width: var(--max-largeur);
  margin: 0 auto;
  padding: 0 1.25rem;
}

/* =========================================
   BANDE BICHROME SIGNATURE
========================================= */
.bande-bichrome {
  height: 5px;
  background: linear-gradient(90deg,
    var(--couleur-principale) 0%,
    var(--couleur-principale) 62%,
    var(--couleur-accent) 62%,
    var(--couleur-accent) 100%);
}

/* =========================================
   HEADER / NAV
========================================= */
.header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--couleur-fond);
  border-bottom: 1px solid var(--couleur-bordure);
}

.header-interieur {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 60px;
  padding: 0 1.25rem;
  max-width: var(--max-largeur);
  margin: 0 auto;
}

.logo {
  font-family: var(--police-titre);
  font-size: 1.4rem;
  font-weight: normal;
  color: var(--couleur-principale);
  letter-spacing: 0.12em;
  text-decoration: none;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  line-height: 1;
}

.logo:hover,
.logo:hover .logo-line1 {
  color: var(--couleur-principale);
  text-decoration: none;
  opacity: 1;
}

.logo:hover .logo-baseline {
  color: var(--couleur-texte-faible);
  text-decoration: none;
}

.logo-line1 {
  display: flex;
  align-items: center;
}

.logo-point {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--couleur-accent);
  margin: 0 7px;
  flex-shrink: 0;
}

.logo-baseline {
  font-family: var(--police-corps);
  font-size: 0.6rem;
  letter-spacing: 0.05em;
  color: var(--couleur-texte-faible);
  text-transform: uppercase;
  font-weight: normal;
  display: block;
}

.nav-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
}

/* Navigation principale desktop */
.nav-principale {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.nav-principale a,
.nav-principale .nav-dropdown-titre {
  font-family: var(--police-corps);
  font-size: 0.72rem;
  font-weight: normal;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--couleur-principale);
  text-decoration: none;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
  transition: color var(--transition);
}

.nav-principale a:hover,
.nav-principale .nav-dropdown-titre:hover,
.nav-dropdown:hover .nav-dropdown-titre {
  color: var(--couleur-texte);
  text-decoration: none;
}

/* Dropdown Occasions */
.nav-dropdown {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.nav-dropdown-chevron {
  display: inline-block;
  font-size: 0.85rem;
  color: var(--couleur-principale);
  transition: color var(--transition), transform var(--transition);
  line-height: 1;
  margin-top: 1px;
}

.nav-dropdown:hover .nav-dropdown-chevron {
  color: var(--couleur-texte);
  transform: rotate(180deg);
}

.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 0.9rem;
  background: var(--couleur-fond);
  border: 1px solid var(--couleur-bordure);
  border-radius: var(--rayon);
  box-shadow: var(--ombre);
  min-width: 180px;
  z-index: 100;
  overflow: hidden;
}

/* Pont invisible pour maintenir le hover entre le titre et le menu */
.nav-dropdown::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  height: 0.9rem;
}

.nav-dropdown:hover .nav-dropdown-menu {
  display: block;
}

.nav-dropdown-menu a {
  display: block;
  padding: 0.55rem 1rem;
  font-family: var(--police-corps);
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--couleur-principale);
  text-decoration: none;
  transition: background var(--transition), color var(--transition);
}

.nav-dropdown-menu a:hover {
  background: var(--couleur-fond-doux);
  color: var(--couleur-texte);
}

.nav-dropdown-menu a + a {
  border-top: 1px solid var(--couleur-bordure);
}

/* Burger menu */
.burger {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 24px;
  height: 16px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}

.burger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--couleur-texte);
  border-radius: 0;
}



/* Menu mobile */
.menu-mobile {
  display: none;
  flex-direction: column;
  background: var(--couleur-fond);
  border-bottom: 1px solid var(--couleur-bordure);
  padding: 0.75rem 1.25rem;
  max-width: var(--max-largeur);
  margin: 0 auto;
}

.menu-mobile.ouvert { display: flex; }

/* Liens de premier niveau */
.menu-mobile > a,
.menu-mobile-section > .menu-mobile-titre {
  font-family: var(--police-corps);
  font-size: 0.68rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--couleur-principale);
  padding: 0.6rem 0;
  border-bottom: 1px solid var(--couleur-bordure);
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
  width: 100%;
  transition: color var(--transition);
}

.menu-mobile > a:last-child { border-bottom: none; }
.menu-mobile > a:hover,
.menu-mobile-section > .menu-mobile-titre:hover { color: var(--couleur-texte); }

/* Indicateur + / chevron */
.menu-mobile-indicateur {
  font-size: 0.85rem;
  line-height: 1;
  color: var(--couleur-principale);
  transition: transform var(--transition), color var(--transition);
}

.menu-mobile-section.ouvert .menu-mobile-indicateur {
  transform: rotate(45deg);
}

/* Sous-menu mobile */
.menu-mobile-sous-menu {
  display: none;
  flex-direction: column;
  padding-left: 0.75rem;
  border-bottom: 1px solid var(--couleur-bordure);
}

.menu-mobile-section.ouvert .menu-mobile-sous-menu {
  display: flex;
}

.menu-mobile-sous-menu a {
  font-family: var(--police-corps);
  font-size: 0.62rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--couleur-principale);
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--couleur-bordure);
  text-decoration: none;
  transition: color var(--transition);
}

.menu-mobile-sous-menu a:last-child { border-bottom: none; }
.menu-mobile-sous-menu a:hover { color: var(--couleur-texte); }

/* Dernière section sans bordure basse */
.menu-mobile > *:last-child,
.menu-mobile-section:last-child { border-bottom: none; }

/* =========================================
   BOUTONS
========================================= */
.btn-principal {
  display: inline-block;
  background: var(--couleur-principale);
  color: #fff;
  font-family: var(--police-corps);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.8rem 1.4rem;
  border-radius: var(--rayon);
  text-decoration: none;
  transition: background var(--transition);
  border: none;
  cursor: pointer;
  min-height: 44px;
}

.btn-principal:hover {
  background: #154a72;
  text-decoration: none;
}

.btn-secondaire {
  display: inline-block;
  background: transparent;
  color: var(--couleur-principale);
  font-family: var(--police-corps);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.75rem 1.3rem;
  border-radius: var(--rayon);
  border: 2px solid var(--couleur-principale);
  text-decoration: none;
  transition: all var(--transition);
  min-height: 44px;
}

.btn-secondaire:hover {
  background: var(--couleur-principale);
  color: #fff;
  text-decoration: none;
}

.btn-blanc {
  display: inline-block;
  background: #fff;
  color: var(--couleur-principale);
  font-family: var(--police-corps);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.8rem 1.6rem;
  border-radius: var(--rayon);
  text-decoration: none;
  transition: all var(--transition);
  min-height: 44px;
}

.btn-blanc:hover {
  background: var(--couleur-accent);
  color: var(--couleur-texte);
  text-decoration: none;
}

.btn-accent {
  display: inline-block;
  background: var(--couleur-accent);
  color: #fff;
  font-family: var(--police-corps);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.9rem 1.8rem;
  border-radius: var(--rayon);
  text-decoration: none;
  transition: all var(--transition);
  min-height: 44px;
}

.btn-accent:hover {
  background: #d4a830;
  text-decoration: none;
}

.btn-nav {
  display: inline-block;
  background: var(--couleur-principale);
  color: #fff;
  font-family: var(--police-corps);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.5rem 0.9rem;
  border-radius: var(--rayon);
  text-decoration: none;
  min-height: 44px;
  display: flex;
  align-items: center;
}

.btn-nav:hover { background: #154a72; text-decoration: none; }

/* =========================================
   SURTITRE
========================================= */
.surtitre {
  font-family: var(--police-corps);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--couleur-principale);
  margin-bottom: 0.6rem;
}

/* =========================================
   HERO
========================================= */
.hero {
  padding: 2.5rem 0;
  background: var(--couleur-fond);
  border-bottom: 1px solid var(--couleur-bordure);
}

/* Hero compact : spécifique à devis.html */
.hero-compact {
  padding: 1.5rem 0;
}

.hero-compact .hero-accroche {
  margin-bottom: 0;
}

.hero h1 {
  font-family: var(--police-titre);
  font-size: clamp(1.4rem, 5vw, 2.4rem);
  font-weight: normal;
  line-height: 1.25;
  color: var(--couleur-texte);
  margin-bottom: 1rem;
  hyphens: none;
}

.hero h1 em {
  color: var(--couleur-principale);
  font-style: normal;
}

.hero-accroche {
  font-size: 0.85rem;
  color: var(--couleur-texte-doux);
  line-height: 1.5;
  margin-bottom: 1.25rem;
}

.hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 1.25rem;
}

.hero-tag {
  font-size: 0.68rem;
  font-weight: 400;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--couleur-principale);
  background: var(--couleur-fond);
  border: 1px solid var(--couleur-principale);
  padding: 0.22rem 0.6rem;
  border-radius: 4px;
}

.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}

/* =========================================
   BARRE DE REASSURANCE
========================================= */
.reassurance {
  background: var(--couleur-fond-doux);
  border-bottom: 1px solid var(--couleur-bordure);
  padding: 1.25rem 0;
}

.reassurance-liste {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

@media (min-width: 640px) {
  .reassurance-liste {
    grid-template-columns: repeat(4, 1fr);
  }
}

.reassurance-item {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
}

.reassurance-picto {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--couleur-principale);
  margin-top: 2px;
}

.reassurance-texte {
  font-size: 0.8rem;
  line-height: 1.4;
  color: var(--couleur-texte);
  font-weight: bold;
}

.reassurance-texte span {
  display: block;
  font-weight: normal;
  color: var(--couleur-texte-doux);
}

/* =========================================
   SECTIONS GÉNÉRIQUES
========================================= */
.section {
  padding: 3rem 0;
  border-bottom: 1px solid var(--couleur-bordure);
}

.section:last-of-type { border-bottom: none; }

.section-titre {
  font-family: var(--police-titre);
  font-size: clamp(1.3rem, 4vw, 1.7rem);
  font-weight: normal;
  color: var(--couleur-texte);
  margin-bottom: 0.5rem;
  line-height: 1.3;
}

.section-titre em {
  color: var(--couleur-principale);
  font-style: normal;
}

.separateur {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.separateur-trait {
  width: 36px;
  height: 3px;
  background: var(--couleur-principale);
  border-radius: 2px;
}

.separateur-trait-or {
  width: 16px;
  height: 3px;
  background: var(--couleur-accent);
  border-radius: 2px;
}

.texte-editorial p {
  margin-bottom: 1.1rem;
  color: var(--couleur-texte-doux);
  font-size: 0.85rem;
  line-height: 1.6;
}

.texte-editorial p:last-child { margin-bottom: 0; }

.texte-editorial strong { color: var(--couleur-texte); }

/* Espacement entre blocs successifs dans le corps éditorial (pages édito/guide) */
.texte-editorial + .section-titre,
.texte-editorial + h2,
.arguments + .section-titre,
.arguments + h2,
.grille-formations + .section-titre,
.grille-formations + h2,
.cartes-arguments + .section-titre,
.cartes-arguments + h2 {
  margin-top: 3rem;
}

/* =========================================
   CARTES ARGUMENTS (section prestation)
========================================= */
.cartes-arguments {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 2rem;
}

@media (min-width: 640px) {
  .cartes-arguments {
    grid-template-columns: repeat(3, 1fr);
  }
}

.carte-argument {
  background: var(--couleur-fond-doux);
  border: 1px solid var(--couleur-bordure);
  border-radius: var(--rayon-lg);
  padding: 1.25rem;
  transition: box-shadow var(--transition);
}

.carte-argument:hover {
  box-shadow: var(--ombre);
}

.carte-argument-numero {
  font-family: var(--police-titre);
  font-size: 2.2rem;
  color: var(--couleur-principale);
  line-height: 1;
  margin-bottom: 0.5rem;
}

.carte-argument-trait {
  width: 20px;
  height: 1px;
  background: var(--couleur-accent);
  margin-bottom: 0.5rem;
}

.carte-argument h3 {
  font-family: var(--police-corps);
  font-size: 0.8rem;
  font-weight: bold;
  color: var(--couleur-texte);
  margin-bottom: 0.4rem;
}

.carte-argument p {
  font-size: 0.8rem;
  color: var(--couleur-texte-doux);
  line-height: 1.5;
  margin: 0;
}

/* =========================================
   CARTES FORMATIONS
========================================= */
.grille-formations {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 1.5rem;
}

.carte-formation {
  background: var(--couleur-fond);
  border: 1px solid var(--couleur-bordure);
  border-radius: var(--rayon-lg);
  padding: 0.9rem;
  position: relative;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.carte-formation-etiquette {
  display: inline-block;
  font-size: 0.62rem;
  font-weight: normal;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--couleur-texte-faible);
  margin-bottom: 0.3rem;
}

.carte-formation h3 {
  font-family: var(--police-titre);
  font-size: 1.25rem;
  font-weight: normal;
  color: var(--couleur-principale);
  margin-bottom: 0.35rem;
}

.carte-formation p {
  font-size: 0.8rem;
  color: var(--couleur-texte-doux);
  line-height: 1.5;
  margin-bottom: 0.5rem;
}

.carte-formation-meta {
  font-size: 0.78rem;
  color: var(--couleur-texte-faible);
  border-top: 1px solid var(--couleur-bordure);
  padding-top: 0.6rem;
  margin-top: 0.5rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.carte-formation-meta-point {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--couleur-accent);
  flex-shrink: 0;
}


/* =========================================
   FORMULES TARIFS
========================================= */
.formules {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 1.5rem;
}

.formule-item {
  background: var(--couleur-fond);
  border: 1px solid var(--couleur-bordure);
  border-radius: var(--rayon-lg);
  padding: 1rem;
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.formule-item:nth-child(even) { background: var(--couleur-fond-doux); }

.formule-item.formule-populaire {
  border-color: var(--couleur-bordure);
}

.formule-contenu {
  border-left: 3px solid var(--couleur-accent);
  padding-left: 1rem;
  flex: 1;
}

.formule-entete {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 0.3rem;
}

.formule-nom {
  font-family: var(--police-titre);
  font-size: 1.05rem;
  color: var(--couleur-texte);
}

.formule-tag {
  font-size: 0.7rem;
  color: var(--couleur-texte-faible);
  font-family: var(--police-corps);
}

.formule-tag-bleu { color: var(--couleur-principale); }

.formule-points {
  display: flex;
  gap: 4px;
  margin-bottom: 0.5rem;
}

.formule-point {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--couleur-bordure);
}

.formule-point.actif { background: var(--couleur-principale); }

.formule-desc {
  font-size: 0.8rem;
  color: var(--couleur-texte-doux);
  line-height: 1.5;
  margin: 0;
}

/* =========================================
   LISTE EVENEMENTS
========================================= */
.liste-evenements {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 1.5rem;
}

.evenement-item {
  display: flex;
  gap: 1rem;
  padding: 1rem;
  border: 1px solid var(--couleur-bordure);
  border-radius: var(--rayon-lg);
  align-items: flex-start;
}

.evenement-item:nth-child(odd)  { background: var(--couleur-fond); }
.evenement-item:nth-child(even) { background: var(--couleur-fond-doux); }

.evenement-trait {
  width: 3px;
  background: var(--couleur-principale);
  border-radius: 2px;
  flex-shrink: 0;
  align-self: stretch;
}

.evenement-contenu h3 {
  font-family: var(--police-titre);
  font-size: 1.05rem;
  font-weight: normal;
  color: var(--couleur-texte);
  margin-bottom: 0.25rem;
}

.evenement-contenu p {
  font-size: 0.8rem;
  color: var(--couleur-texte-doux);
  line-height: 1.5;
  margin: 0;
}

/* =========================================
   ETAPES (Comment ça se passe)
========================================= */
/* =========================================
   ARGUMENTS (Notre différence)
========================================= */
.arguments {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin-top: 1.5rem;
}

.argument {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.argument-picto {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  background: #e8f2f9;
  border-radius: var(--rayon);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--couleur-principale);
}

.argument-picto svg { width: 18px; height: 18px; }

.argument-texte h3 {
  font-family: var(--police-titre);
  font-size: 1.05rem;
  font-weight: normal;
  color: var(--couleur-texte);
  margin-bottom: 0.3rem;
}

.argument-texte p {
  font-size: 0.8rem;
  color: var(--couleur-texte-doux);
  line-height: 1.5;
  margin: 0;
}

/* =========================================
   TEMOIGNAGES
========================================= */
.temoignages {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 1.5rem;
}

@media (min-width: 640px) {
  .temoignages {
    grid-template-columns: repeat(3, 1fr);
  }
}

.temoignage {
  background: var(--couleur-fond);
  border: 1px solid var(--couleur-bordure);
  border-radius: var(--rayon-lg);
  padding: 1rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.temoignage-guillemet {
  font-family: var(--police-titre);
  font-size: 2.5rem;
  color: var(--couleur-accent);
  line-height: 0.7;
  margin-bottom: 0.6rem;
  opacity: 0.6;
}

.temoignage-texte {
  font-size: 0.8rem;
  color: var(--couleur-texte-doux);
  line-height: 1.5;
  font-style: italic;
  margin-bottom: 0.9rem;
  flex: 1;
}

.temoignage-auteur {
  border-top: 1px solid var(--couleur-bordure);
  padding-top: 0.6rem;
  font-size: 0.8rem;
  color: var(--couleur-texte);
  font-weight: normal;
}

.temoignage-auteur span {
  display: block;
  font-size: 0.78rem;
  color: var(--couleur-texte-faible);
}

/* =========================================
   FAQ
========================================= */
.faq {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 1.5rem;
}

.faq-item {
  border-bottom: 1px solid var(--couleur-bordure);
}

.faq-question {
  width: 100%;
  background: none;
  border: none;
  padding: 1rem 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  cursor: pointer;
  text-align: left;
  font-family: var(--police-corps);
  font-size: 0.8rem;
  font-weight: bold;
  color: var(--couleur-texte);
  line-height: 1.4;
}

.faq-question:hover { color: var(--couleur-principale); }

.faq-icone {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--couleur-principale);
  transition: transform var(--transition);
}

.faq-item.ouvert .faq-icone { transform: rotate(45deg); }

.faq-reponse {
  display: none;
  padding: 0 0 1rem;
  font-size: 0.8rem;
  color: var(--couleur-texte-doux);
  line-height: 1.5;
}

.faq-item.ouvert .faq-reponse { display: block; }

/* =========================================
   MAILLAGE INTERNE
========================================= */
.maillage {
  padding: 3rem 0;
  background: var(--couleur-fond-doux);
  border-top: 1px solid var(--couleur-bordure);
  border-bottom: 1px solid var(--couleur-bordure);
}

.maillage-hub {
  background: var(--couleur-fond);
}

.grille-maillage {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

.carte-maillage {
  background: var(--couleur-fond);
  border: 0.5px solid var(--couleur-bordure);
  border-radius: var(--rayon-lg);
  padding: 1rem 1.1rem;
  text-decoration: none;
  display: block;
  transition: border-color var(--transition);
}

a.carte-maillage:hover {
  border-color: var(--couleur-principale);
  text-decoration: none;
}

.carte-maillage-tag {
  display: block;
  font-size: 0.62rem;
  font-weight: normal;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--couleur-texte-faible);
  margin-bottom: 0.35rem;
}

.carte-maillage h3 {
  font-family: var(--police-titre);
  font-size: 1rem;
  font-weight: normal;
  color: var(--couleur-principale);
  line-height: 1.3;
  margin-bottom: 0.45rem;
}

.carte-maillage-sep {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.carte-maillage-sep-bleu {
  width: 36px;
  height: 3px;
  background: var(--couleur-principale);
  border-radius: 2px;
}

.carte-maillage-sep-or {
  width: 16px;
  height: 3px;
  background: var(--couleur-accent);
  border-radius: 2px;
}

.carte-maillage p {
  font-size: 0.75rem;
  color: var(--couleur-texte-faible);
  line-height: 1.45;
  margin: 0;
}

/* =========================================
   CTA FINAL
========================================= */
.cta-final {
  background: var(--couleur-principale);
  padding: 3rem 0;
  text-align: center;
}

.cta-final h2 {
  font-family: var(--police-titre);
  font-size: clamp(1.3rem, 4vw, 1.8rem);
  font-weight: normal;
  color: #fff;
  margin-bottom: 0.75rem;
  line-height: 1.3;
}

.cta-final h2 em {
  color: var(--couleur-accent);
  font-style: normal;
}

.cta-final p {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.8);
  margin-bottom: 1.5rem;
  line-height: 1.5;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

/* =========================================
   FOOTER
========================================= */
.footer {
  background: var(--couleur-principale);
  border-top: 1px solid rgba(255,255,255,0.15);
  padding: 1.1rem 0;
  text-align: center;
}

.footer-ligne {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.5;
}

.footer-ligne a {
  color: rgba(255,255,255,0.6);
  text-decoration: none;
}

.footer-ligne a:hover { color: #fff; }

/* =========================================
   RESPONSIVE
========================================= */
@media (min-width: 540px) {
  .grille-formations {
    grid-template-columns: 1fr 1fr;
  }
}

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

/* =========================================
   CTA FORMULES
========================================= */
.formules-cta {
  text-align: center;
  margin-top: 2rem;
}

/* =========================================
   PAGE 404
========================================= */
.portee-wrapper {
  display: flex;
  justify-content: center;
  margin-bottom: 2rem;
}

/* Nav liens inactifs (pages non encore créées) */
.nav-inactif {
  font-size: 0.85rem;
  color: var(--couleur-texte-faible);
  cursor: default;
  padding: 0.6rem 0;
  border-bottom: 1px solid var(--couleur-bordure);
  display: block;
}


/* =========================================
   FORMULAIRE DEVIS
========================================= */

/* Compensation scroll ancre #coordonnees */
#coordonnees {
  scroll-margin-top: 4.5rem;
}

.section-formulaire {
  background: var(--couleur-fond);
}

.formulaire-wrap {
  width: 75%;
  margin: 0 auto;
  background: var(--couleur-fond-doux);
  border: 1px solid var(--couleur-bordure);
  border-radius: var(--rayon-lg);
  padding: 2rem 2.5rem;
}

.formulaire-titre {
  font-family: var(--police-titre);
  font-size: clamp(1.2rem, 3vw, 1.5rem);
  font-weight: normal;
  color: var(--couleur-texte);
  margin-bottom: 1rem;
  text-align: center;
}

.form-message {
  display: none;
  padding: 1rem 1.25rem;
  border-radius: var(--rayon);
  margin-bottom: 1.5rem;
  font-size: 0.85rem;
  line-height: 1.5;
}

.form-message.succes {
  display: block;
  background: #e8f5e9;
  color: #2e7d32;
  border: 1px solid #a5d6a7;
}

.form-message.erreur {
  display: block;
  background: #fdecea;
  color: #c62828;
  border: 1px solid #ef9a9a;
}

.form-groupe {
  border: none;
  padding: 0;
  margin: 0 0 1.5rem;
}

.form-groupe:last-of-type {
  margin-bottom: 0;
}

.form-legend {
  font-family: var(--police-titre);
  font-size: 1.05rem;
  color: var(--couleur-texte);
  margin-bottom: 1.25rem;
  padding: 0;
  width: 100%;
  border-bottom: 2px solid var(--couleur-accent);
  padding-bottom: 0.4rem;
}

.form-champ {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  margin-bottom: 1rem;
}

.form-ligne {
  display: grid;
  gap: 1rem;
  margin-bottom: 0;
}

.form-ligne-2 {
  grid-template-columns: 1fr 1fr;
}

.form-champ label {
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: var(--couleur-texte);
  text-transform: none;
}

.form-requis {
  color: var(--couleur-principale);
  font-weight: 500;
}

.form-optionnel {
  color: var(--couleur-texte-faible);
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.75rem;
}

.form-champ input,
.form-champ textarea {
  font-family: var(--police-corps);
  font-size: 0.85rem;
  color: var(--couleur-texte);
  background: var(--couleur-fond);
  border: 1px solid var(--couleur-bordure);
  border-radius: var(--rayon);
  padding: 0.65rem 0.85rem;
  width: 100%;
  transition: border-color var(--transition);
  outline: none;
  -webkit-appearance: none;
}

.form-champ input:focus,
.form-champ textarea:focus {
  border-color: var(--couleur-principale);
}

.form-champ input::placeholder,
.form-champ textarea::placeholder {
  color: var(--couleur-texte-faible);
  font-style: italic;
}

.form-champ textarea {
  resize: vertical;
  min-height: 130px;
  line-height: 1.5;
}

.form-footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  margin-top: 0.75rem;
}

.form-footer .form-message {
  margin-bottom: 0;
  width: 100%;
  text-align: center;
}

.form-cnil {
  font-size: 0.65rem;
  color: var(--couleur-texte-faible);
  text-align: center;
  line-height: 1.5;
  margin: 0;
  width: 100%;
}

@media (max-width: 700px) {
  /* Nav principale et dropdown : masqués sur mobile */
  .nav-principale { display: none; }
  .nav-dropdown-menu { display: none !important; }
  .nav-dropdown::after { display: none; }

  /* Burger : visible sur mobile uniquement */
  .burger { display: flex; }

  /* Logo mobile : plus petit */
  .logo { font-size: 0.95rem; gap: 3px; }
  .logo-point { width: 5px; height: 5px; margin: 0 5px; }
  .logo-baseline { font-size: 0.48rem; }

  /* H1 hero : plus grand en mobile */
  .hero h1 { font-size: clamp(1.5rem, 7vw, 2rem); }

  /* Formulaire : fond blanc, zéro marge, 2 champs par ligne conservés */
  .section-formulaire { padding-left: 0; padding-right: 0; padding-top: 0.6rem; }
  .section-formulaire .conteneur { padding: 0; }
  .formulaire-wrap {
    width: 100%;
    padding: 1.25rem 1rem;
    background: var(--couleur-fond);
    border-radius: 0;
    border: none;
  }
  .form-champ label { font-size: 0.68rem; }
  .form-ligne-2 { grid-template-columns: 1fr 1fr; gap: 0.6rem; }
  .form-footer { flex-direction: column; align-items: center; }

  /* Mention CNIL pleine largeur */
  .form-cnil { max-width: 100%; }

  /* Empêcher le zoom iOS sur les champs : font-size minimum 16px */
  .form-champ input,
  .form-champ select,
  .form-champ textarea {
    font-size: 16px;
  }
}

