/* =========================================================
   BASE CSS MODERNE SANS LAYERS
   ---------------------------------------------------------
   Objectif :
   - garder un CSS simple à relire et à maintenir
   - utiliser variables + flex/grid + mobile first
   - éviter les floats sauf si besoin exceptionnel
   - conserver des noms de classes proches de l'existant
   ========================================================= */


/* =========================================================
   VARIABLES GLOBALES
   ---------------------------------------------------------
   Toutes les couleurs, tailles et espacements importants
   sont centralisés ici.
   ========================================================= */

:root {
  /* Couleurs principales */
  --color-bg: #f2f0eb;
  --color-bg-2: #dfdbd1;

  --color-surface: #ffffff;
  --color-surface-alt: #efeeea;
  --color-surface-soft: #e4e0e0;
  --color-surface-muted: #f0efec;

  --color-surface-2: #f8f6f2;
  --color-surface-3: #f4e6d8;
  

  --color-text: #303030;
  --color-text-strong: #323232;
  --color-text-muted: #797979;
  --color-text-soft: #616161;

  --color-text-btn-hover: #929292;


  /* --color-primary: #d14500; */
  --color-primary: #2e358e;
  /* --color-primary-hover: #8E882E; */
  --color-primary-hover: #8E582E;
  
  --color-primary-light: #ffc000;
  --color-primary-dark: #860000;

  --color-secondary: #8E582E;


  --color-dark: #1b1a18;
  --color-border: #d6d1ca;
  --color-border-strong: #b7b7b7;
  --color-line: #403e3f;

  --color-success: #007f00;
  --color-success-border: rgb(140, 190, 65);
  --color-error: #c14120;
  --color-error-bg: #faf9f5;

  --color-footer-text: #8f949b;
  --color-footer-link: #bfc5cd;
  --color-footer-link-hover: #929292;

  --color-note-bg: #f8ecc5;
  --color-note-border: #d8ceae;
  --color-table-hover: #c0bdb8;
  --color-overlay: rgba(0, 0, 0, 0.5);
  /* --color-shadow: rgba(0, 0, 0, 0.2); */
  --color-shadow: rgba(20,18,16,.06);

  /* Typographies */
  --font-body: "Source Sans 3", sans-serif;
  --font-heading: "Barlow Condensed", sans-serif;

  /* Tailles de texte fluides */
  --text-xs: clamp(0.55rem, 0.5rem + 0.15vw, 0.6rem);

  --text-sm: clamp(0.75rem, 0.7rem + 0.2vw, 0.8rem);
  /* --text-sm: 0.8rem; */
  --text-base: clamp(0.9rem, 0.85rem + 0.25vw, 1rem);
  /* --text-base: 1rem; */
  --text-md: clamp(0.95rem, 0.9rem + 0.2vw, 1.05rem);
  /* --text-md: 1.05rem; */
  --text-lg: clamp(1rem, 0.9rem + 0.3vw, 1.25rem);
  /* --text-lg: 1.25rem; */
  --text-xl: clamp(1.5rem, 1.2rem + 1.1vw, 2.3rem);
  /* --text-xl: 2.3rem; */
  --text-2xl: clamp(2rem, 1.6rem + 1.8vw, 3.5rem);
  /* --text-2xl: 3.5rem; */
  --text-3xl: clamp(2.8rem, 2.2rem + 2.5vw, 4.8rem);
  /* --text-3xl: 4.8rem; */

  /* Espacements */
  --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;

  /* Rayons */
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-full: 9999px;

  /* Largeurs / layout */
  --container: min(90vw, 1200px);
  --container-narrow: min(90vw, 800px);
  --header-height-mobile: 50px;
  --header-height-desktop: 160px;
  --header-position_mini: -160px;
  --header-height-mini_desktop: 70px;
  --nav-offset-desktop: 90px;
  --section-padding: clamp(var(--space-8), 5vw, var(--space-12));

  /* Animations / ombres */
  --transition-fast: 180ms ease;
  --transition-medium: 300ms ease;
  --shadow-sm: 0 2px 10px var(--color-shadow);
  --shadow:0 10px 28px rgba(20,18,16,.06);
}


/* =========================================================
   RESET / BASE COMMUNE
   ---------------------------------------------------------
   Mise à plat des comportements navigateur.
   ========================================================= */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  min-height: 100%;
}

html {
  /* scroll-behavior: smooth; */
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: var(--header-height-desktop);
}

/* body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure {
  margin: 0;
} */

body {
  background-color: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 400;
  line-height: 1.7;
  margin: 0;
}

img,
picture,
video,
canvas,
svg,
iframe,
object,
embed {
  display: block;
  max-width: 100%;
  height: auto;
}

input,
textarea,
select,
button {
  font: inherit;
  color: inherit;
}

a {
  color: var(--color-primary-dark);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-primary-hover);
}

section {
  overflow: hidden;
}

h1,
h2,
h3,
.titre_accueil,
.grand_titre_accueil,
.grand_sous_titre_accueil,
nav {
  font-family: var(--font-heading);
  line-height: 1.1;
}

h1 {
  font-size: var(--text-3xl);
  color: var(--color-text-strong);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.03;
  letter-spacing: 0.02em;
  margin: var(--space-4) 0 var(--space-4) 0;
}

h2 {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  text-transform: uppercase;
  color: var(--color-primary);
  text-align: center;
  scroll-margin-top: var(--header-height-desktop);
}

/* h2[id] {
  scroll-margin-top: var(--anchor-offset);
} */

h3 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  text-transform: uppercase;
  color: var(--color-secondary);
  text-align: center;
}

h4 {
  color: var(--color-text-muted);
  font-style: italic;
}

::selection {
  background: rgba(255, 192, 0, 0.35);
}

:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}


/* =========================================================
   UTILITAIRES DE MISE EN PAGE
   ---------------------------------------------------------
   Petites classes réutilisables partout.
   ========================================================= */

.container,
#header_conteneur,
#contenu,
#footer_conteneur,
section {
  width: var(--container);
  margin-inline: auto;
}

.container-narrow,
.sous_contenu {
  width: var(--container-narrow);
  margin-inline: auto;
}

.stack {
  display: grid;
  gap: var(--space-4);
}

.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
}

.grid-2,
.grid-3 {
  display: grid;
  gap: var(--space-4);
}

.grid-2,
.grid-3 {
  grid-template-columns: 1fr;
}

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

.mx-auto {
  margin-inline: auto;
}

.w-full {
  width: 100%;
}

.spacer {
  height: var(--space-12);
}


/* =========================================================
   STRUCTURE GLOBALE DU SITE
   ========================================================= */

header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 10000;
  height: var(--header-height-mobile);
  overflow: hidden;
  text-align: center;
  background-color: var(--color-bg);
  border-bottom: 1px solid var(--color-border);

}

/* .menu_mobile {
  position: absolute;
  top: 15px;
  left: 15px;
  display: block;
} */

.header_mini,
.header_maxi,
.nav_mini,
.nav_maxi,
.menu_ouvert,
.menu_ferme,
footer img,
.bouton_valider,
.categorie,
.tag,
#scroll-down-arrow {
  transition: all var(--transition-medium);
}

.menu_ouvert {
  height: 100dvh;
}

.menu_ferme,
.header_mini,
.header_maxi {
  height: var(--header-height-mobile);
}

.conteneur,
.galerie_societe,
#points_conteneur {
  background-color: var(--color-surface-alt);
}

.conteneur {
  padding-bottom: var(--space-12);
}

.galerie_societe,
#points_conteneur {
  padding: var(--section-padding);
}

.titre_accueil {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-text-strong);
}

.grand_titre_accueil {
  font-size: var(--text-3xl);
  font-weight: 700;
  text-align: center;
  color: var(--color-text-strong);
}

.grand_sous_titre_accueil {
  font-size: var(--text-2xl);
  font-weight: 700;
  text-align: center;
  color: var(--color-primary-light);
}

.titre_actualites,
.titres {
  text-align: center;
}

.titres {
  width: min(70%, 900px);
  margin-inline: auto;
}

.sous_titre {
  font-size: var(--text-md);
}

.souligne {
  width: min(250px, 100%);
  margin: 3em auto;
  border: 0;
  border-top: 3px solid var(--color-border-strong);
}

.paire {
  background-color: var(--color-surface);
}

.impaire {
  background-color: var(--color-surface-alt);
}

.age {
  display: none;
}

/* =========================================================
   TAGS / PETITS ÉLÉMENTS UI
   ========================================================= */

.tag,
.categorie {
  display: inline-block;
  text-transform: uppercase;
}

.tag {
  padding: 0.5em 1em;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  color: #000000;
  white-space: nowrap;
}

.tag:hover {
  color: var(--color-bg);
  background-color: #000000;
}

.neutre {
  background-color: var(--color-primary-light);
}

.categorie {
  margin-right: 10px;
  margin-bottom: 3px;
  padding: 5px 10px;
  border-radius: var(--radius-lg);
  font-size: 0.875rem;
  background-color: var(--color-bg);
  transition: background-color var(--transition-medium), color var(--transition-fast);
}

.categorie:hover {
  color: var(--color-bg);
  background-color: rgba(26, 23, 27, 0.8);
}

.eyebrow{
  display: inline-block;
  padding: 7px 11px;
  background: var(--color-surface-3);
  color: var(--color-secondary);
  border-radius: var(--radius-full);
  text-transform: uppercase;
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: .08em;
  width: fit-content;
}

/* =========================================================
   BOUTONS
   ========================================================= */

.btn,
.bouton_valider {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.5rem 1.5rem;
  border: 1px solid var(--color-primary);
  background-color: var(--color-primary);
  color: var(--color-surface);
  font-size: var(--text-base);
  font-family: var(--font-body);
  font-weight: 700;
  border-radius: var(--radius-full);
  /* text-transform: uppercase; */
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--transition-medium);

}

.btn:hover,
.bouton_valider:hover {
  transform: translateY(-3px);
  transition: all var(--transition-fast);
}

.bouton_valider {
  width: 100%;
}

.btn_primary {
  background: var(--color-primary);
  color: var(--color-surface);
}

.btn_primary:hover {
  background: var(--color-primary-hover);
  color: var(--color-bg);
}

.btn_secondary {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  color: var(--color-text);
}

.btn_secondary:hover {
  background: var(--color-bg-2);
}

/* =========================================================
   BLOCS CONTENU / CARTES / COLONNES
   ========================================================= */

.sommaire_voyages,
#points,
#actualites {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

.cadre_voyage,
.cadre_voyage_detail,
.point,
.actualite_cadre,
.card {
  background-color: var(--color-bg);
}

.actualite_cadre {
  padding: var(--space-4);
}

.marge_voyage {
  padding-top: var(--space-12);
}

.cadre_voyage h3 {
  color: var(--color-text-soft);
  font-weight: 400;
}

.sous_titre_voyage {
  color: var(--color-primary);
  font-weight: 900;
}

.cadre_voyage p,
.cadre_voyage h2,
.cadre_voyage h3,
.point p,
.point h2,
.colonne p,
.colonne h2 {
  padding-inline: clamp(1rem, 3vw, 2rem);
}

.colonne {
  columns: 1;
  column-gap: var(--space-4);
}

.photo_accueil {
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  margin-bottom: var(--space-6);
}

.grille {
  display: block;
  /* grid-template-columns: 1.02fr 0.98fr;
  gap: var(--space-6);
  align-items: stretch */
}

.grille_contact {
  display: block;
  /* grid-template-columns: 0.90fr 1.20fr;
  gap: var(--space-6);
  align-items: stretch */
}

.cadre_contenu {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-8);
  padding: var(--space-8);
  box-shadow: var(--shadow);
}

 .cadre_photo {
  margin-bottom: var(--space-8);
  box-shadow: var(--shadow);
 }

 .cadre_photo img {
  border-radius: var(--radius-lg);
  width: 100%;
  height: auto;
}

.cadre_apropos {
  display: block;
  /* grid-template-columns: 0.9fr 1.1fr; */
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  gap: var(--space-8);
  align-items: start;
  box-shadow: var(--shadow);
}

.cadre_apropos img {
  border-radius: var(--radius-lg);
  width: 100%;
  height: auto;
}

.actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 8px;
}

/* =========================================================
   GALERIES / CAROUSEL
   ========================================================= */

/* .main-carousel {
  width: 100%;
  margin-inline: auto;
}

.carousel-cell {
  margin-right: var(--space-2);
}

.in-use-carousel__item__title {
  position: absolute;
  inset: auto 0 0 0;
  width: 100%;
  margin: 0;
  line-height: 50px;
  text-align: center;
  color: var(--color-bg);
  background-color: var(--color-overlay);
}

.gallery,
.gallery img,
.instructions {
  display: none;
}

.gallery {
  clear: both;
  height: 215px;
  overflow: auto;
  white-space: nowrap;
}

.photo_societe img,
.cadre_voyage img,
.point img {
  width: 100%;
} */




.gallery {
  display: block;
  /* grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4); */
}

.gallery img {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-4);
}



/* =========================================================
   FLECHE BAS DE PAGE
   ========================================================= */

#scroll-down-arrow {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  cursor: pointer;
  background: rgba(255, 192, 0, 0.8);
  box-shadow: var(--shadow-sm);
  animation: pulse 2s infinite;
}

#scroll-down-arrow:hover {
  transform: scale(1.08);
  background: var(--color-primary);
}

#scroll-down-arrow svg {
  width: 24px;
  height: 24px;
  fill: var(--color-bg);
}

@keyframes pulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

#bottom {
  height: 0;
}


/* =========================================================
   TABLEAUX
   ========================================================= */

table {
  width: 100%;
  border: none;
  border-collapse: collapse;
}

th,
td {
  padding: 0.5rem;
  text-align: left;
  vertical-align: top;
}

.message th {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  background-color: var(--color-surface-soft);
}

.message td {
  background-color: var(--color-surface);
}

.categories tr:hover,
.tableau tbody tr:hover {
  background-color: var(--color-table-hover);
}

.tableau {
  font-size: var(--text-sm);
}

.tableau thead th {
  color: var(--color-bg);
  background-color: var(--color-primary);
  border-bottom: 3px solid #535353;
}

.tableau tbody td a {
  color: #4f5051;
}

.tableau tbody td a:hover {
  color: var(--color-bg);
}

.annule {
  background-color: #777777;
}

.entete_tableau {
  display: none;
}


/* =========================================================
   FORMULAIRES
   ========================================================= */

#devis {
  width: var(--container);
  margin-inline: auto;
}

.form-row {
  display: grid;
  gap: var(--space-4);
}

.column-half,
.column-full {
  width: 100%;
  padding: 0;
}

.cadre_contact {
  width: min(100%, 960px);
  margin-inline: auto;
  padding: clamp(1.5rem, 4vw, 3rem);
  background-color: var(--color-bg);
}

#contact .libelle {
  display: block;
  width: 100%;
  margin-bottom: var(--space-2);
}

input.champ_text,
textarea.champ_text,
input.inputform,
textarea.inputform,
select.champ_text,
iframe.champ_text,
input.champ_text_error,
textarea.champ_text_error,
select.champ_text_error,
iframe.champ_text_error {
  width: 100%;
  margin: 0 0 var(--space-4);
  padding: 0.875rem 1rem;
  background-color: var(--color-surface-2);
  font-family: var(--font-body);
  font-size: var(--text-base);
}

input.champ_text,
textarea.champ_text,
input.inputform,
textarea.inputform,
select.champ_text,
iframe.champ_text {
  color: var(--color-text-strong);
  border: 1px solid var(--color-border);
  background-color: var(--color-surface-2);
  border-radius: var(--radius-md);
}

input.champ_text:focus,
textarea.champ_text:focus,
iframe.champ_text:focus,
select.champ_text:focus {
  outline: 0;
  border-color: var(--color-primary);
}

input.champ_text_error,
textarea.champ_text_error,
select.champ_text_error,
iframe.champ_text_error {
  color: #7c7565;
  background-color: var(--color-error-bg);
  border: 1px solid #dddddd;
  border-left: 5px solid var(--color-error);
}

.text_erreur {
  margin: 5px 0;
  color: var(--color-error);
  font-size: var(--text-xs);
}

.recherche {
  width: min(100%, 500px);
}

.cadre_erreur,
.cadre_confirmation,
.cadre_prix_haut,
.cadre_prix_bas,
.cadre_warning {
  width: 100%;
}

.cadre_erreur,
.cadre_confirmation,
.cadre_prix_haut,
.cadre_warning {
  padding: var(--space-4);
  text-align: center;
}

.cadre_erreur {
  margin-bottom: 10px;
  color: var(--color-error);
  background-color: var(--color-error-bg);
  border: 1px solid var(--color-error);
}

.cadre_confirmation {
  color: var(--color-success);
  background-color: var(--color-bg);
  border: 1px solid var(--color-success-border);
}

.cadre_prix_haut,
.cadre_warning {
  margin-top: var(--space-4);
  font-weight: bold;
  color: var(--color-bg);
  background-color: var(--color-primary);
}

.cadre_prix_bas {
  margin-bottom: var(--space-4);
  border: 1px solid var(--color-primary);
}

.cadre_warning {
  width: min(100%, 70%);
  border-radius: var(--radius-sm);
}

.entete_colonne {
  color: var(--color-bg);
  text-align: center;
  font-weight: bold;
  background-color: #aa9881;
}

.edit input {
  font-size: var(--text-xs);
}

.obligatoire {
  text-decoration: underline;
}


/* =========================================================
   ACTUALITES
   ========================================================= */

#news {
  padding: 0;
  list-style: none;
}

#news li {
  position: relative;
  min-height: 100px;
  margin-bottom: 10px;
  padding: 10px;
  color: #212326;
  border: 1px solid #ddd;
  border-radius: var(--radius-lg);
  background: linear-gradient(#f8f8f8, #e0e0e0);
  text-shadow: 0 1px 1px var(--color-bg);
  line-height: normal;
  cursor: move;
}

.cadre_infos {
  font-size: 16px;
}

.infos {
  margin-right: 5px;
  padding: 0 10px 3px;
  font-size: 14px;
  font-weight: normal;
  background-color: #cccccc;
  border-radius: var(--radius-lg);
}

.icones {
  position: absolute;
  inset: 0 auto auto 0;
  display: none;
  width: 100%;
  height: 110px;
  padding-top: 10px;
  background-image: url('../img-interface/transparent-noir.png');
  border-radius: var(--radius-lg);
}

.icone {
  padding: 7px 15px;
  border: 0;
}

.icone_mini {
  border: 0;
}


/* =========================================================
   NAVIGATION
   ---------------------------------------------------------
   Menu mobile moderne avec vrai bouton + état accessible.
   ========================================================= */

#header_conteneur {
  position: relative;
  display: flex;
  /* align-items: center; */
  /* line-height: var(--header-height-mobile); */
  justify-content: space-between;
  gap: var(--space-4);
  width: var(--container);
  min-height: var(--header-height-mobile);
  margin-inline: auto;
}

/* .logo {
  display: inline-block;
  width: 209px;
  height: 84px;
  margin: 0 auto;
  text-align: center;
} */


.topbar_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  min-width: 100%;
}

.logo_site {
  display: inline-block;
  color: var(--color-dark);
  font-family: var(--font-body);
  font-size: var(--text-md);
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;

    /* min-width: 0;
  flex: 1 1 auto; */

}

#bouton_contact {
  display: none;
}

.menu_mobile {
  position: static;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  
  
  /* margin-left: auto;
  flex: 0 0 44px; */


}

.menu_mobile:hover {
  color: var(--color-text-soft);
}

.menu-toggle-bars {
  position: relative;
  display: block;
  width: 24px;
  height: 18px;
}

.menu-toggle-bars::before,
.menu-toggle-bars::after,
.menu-toggle-bars span {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: currentColor;
  transition: transform var(--transition-medium), opacity var(--transition-medium), top var(--transition-medium);
}

.menu-toggle-bars::before {
  top: 0;
}

.menu-toggle-bars span {
  top: 8px;
}

.menu-toggle-bars::after {
  top: 16px;
}

.menu_mobile[aria-expanded="true"] .menu-toggle-bars::before {
  top: 8px;
  transform: rotate(45deg);
}

.menu_mobile[aria-expanded="true"] .menu-toggle-bars span {
  opacity: 0;
}

.menu_mobile[aria-expanded="true"] .menu-toggle-bars::after {
  top: 8px;
  transform: rotate(-45deg);
}

/* .nav_principal {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  display: none;
  background-color: var(--color-dark);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
} */

.nav_principal {
  position: fixed;
  top: var(--header-height-mobile);
  left: 0;
  width: 100%;
  height: calc(100dvh - var(--header-height-mobile));
  display: none;
  background-color: var(--color-bg);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.nav_principal.is-open {
  display: block;
}

.nav_principal ul {
  display: flex;
  flex-direction: column;
  width: var(--container);
  margin: 0 auto;
  padding: 0;
  list-style: none;
}

.nav_principal li + li {
  /* border-top: 1px solid rgba(255, 255, 255, 0.12); */
  border-top: 1px solid var(--color-border);
}

.nav_principal a {
  display: block;
  width: 100%;
  padding: var(--space-4) 0;
  color: var(--color-text-strong);
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--text-md);
  font-weight: 600;
  /* text-transform: uppercase; */
}

/* .nav_principal a:hover,
.nav_principal #current a,
.nav_principal .is-current {
  color: var(--color-primary-hover);
} */

.nav_principal a:hover,
.nav_principal a.current,
.nav_principal .is-current {
  color: var(--color-primary-hover);
}




/* =========================================================
   PAGINATION
   ========================================================= */

.pagination {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-block: var(--space-2);
}

.pages,
.page_actuelle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0.25rem 0.5rem;
  font-weight: bold;
  line-height: 1;
}

.pages {
  color: var(--color-primary-light);
  background-color: var(--color-text-strong);
}

.pages:hover {
  color: #f2f2f2;
  background-color: #444444;
}

.page_actuelle {
  color: var(--color-bg);
  background-color: var(--color-primary-light);
}

.page_actuelle:hover {
  color: #000000;
  background-color: #e8e8e8;
}


/* =========================================================
   FOOTER
   ========================================================= */

footer {
  padding: var(--space-4);
  /* font-size: var(--text-sm); */
  /* font-weight: 300; */
  text-align: center;
  /* color: var(--color-footer-text); */
  background-color: var(--color-bg);
  border-top: 1px solid var(--color-border);

}



/* #footer_conteneur {
  display: grid;
  gap: var(--space-8);
}

#footer_left,
#footer_right {
  width: 100%;
}

footer a {
  color: var(--color-footer-link);
}

footer a:hover {
  color: var(--color-footer-link-hover);
}

footer img {
  border: 0;
  opacity: 0.6;
}

footer img:hover {
  opacity: 0.2;
}

.footer_contenu {
  width: min(50%, 900px);
  margin-inline: auto;
}

.ligne {
  max-width: 1040px;
  margin: var(--space-8) auto;
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-line);
} */


/* =========================================================
   DIVERS
   ========================================================= */

.note_dev {
  background-color: #ffcc00;
}

.note {
  margin-bottom: 1em;
  padding: 1em;
  font-style: italic;
  background-color: var(--color-note-bg);
  border: 1px solid var(--color-note-border);
  border-radius: var(--radius-lg);
}

.tel {
  font-size: 30px;
  color: var(--color-bg);
}

.droite {
  width: 100%;
}

.ligne_num {
  width: 20%;
}

.ligne_libelle {
  width: 70%;
}

.ligne_horaires {
  width: 10%;
}


/* =========================================================
   RESPONSIVE - TABLETTE
   ========================================================= */

@media (min-width: 768px) {
  .grid-2,
  .sommaire_voyages,
  #actualites,
  .form-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grid-3,
  #points {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .colonne {
    columns: 2;
  }

  #footer_conteneur {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }
}


/* =========================================================
   RESPONSIVE - DESKTOP
   ========================================================= */

@media (min-width: 1024px) {
  header {
    height: var(--header-height-desktop);
    background-image: url('../img/header.webp');
    background-position: top center;
    background-repeat: no-repeat;
  }

  .header_mini {
    height: var(--header-height-mini_desktop);
    background-image: url('../img/header.webp');
    background-position: center var(--header-position_mini);
    background-repeat: no-repeat;
  }

  .header_maxi {
    height: var(--header-height-desktop);
    background-image: url('../img/header.webp');
    background-position: top center;
    background-repeat: no-repeat;
  }

  #bouton_contact {
    display: inline-block;
  }

  main {
    padding-top: var(--nav-offset-desktop);
  }

  .nav_mini {
    padding-top: 35px !important;
    height: 0px !important;
  }

  .nav_maxi {
    padding-top: var(--nav-offset-desktop);
  }

  #header_conteneur {
    min-height: var(--header-height-desktop);
  }

  .menu_mobile {
    display: none;
  }

  .nav_principal {
    position: static;
    display: inline-block;
    height: auto;
    background: transparent;
    border-top: 0;
    line-height: 1;
    overflow: hidden; 
  }

  .nav_principal ul {
    width: auto;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .nav_principal li + li {
    border-top: 0;
  }

  .nav_principal a {
    width: auto;
    padding: 0 var(--space-3);
  }

  .topbar_inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: var(--header-height-desktop);
    width: var(--container);
    padding-top: var(--nav-offset-desktop);

      /* flex: 1 1 auto;
  min-width: 0; */

  }

  .entete_tableau {
    display: table-row;
  }

  .cadre_apropos {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    /* background-color: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
    gap: var(--space-8);
    align-items: start;
    box-shadow: var(--shadow);   */
  }

  .grille {
    display: grid;
    grid-template-columns: 1.02fr 0.98fr;
    gap: var(--space-6);
    align-items: stretch
  }

  .grille_contact {
    display: grid;
    grid-template-columns: 0.90fr 1.20fr;
    gap: var(--space-6);
    align-items: stretch
  }

  .gallery {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-4);
  }

  .gallery img {
    /* position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: var(--radius-lg); */
    margin-bottom: 0;
  }


}


/* =========================================================
   ACCESSIBILITE / REDUCTION DES ANIMATIONS
   ========================================================= */

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