/* =========================================================
   L'ARGILIÈRE — FEUILLE DE STYLES PRINCIPALE

   Organisation :
   01. PAGE-ALL — tokens, base, typographie, responsive
   02. COMPONENTS — boutons, cartes, blobs, galeries, tableaux, footer
   03. PAGE-COURSE
   04. SHARED PAGES — workshop / profile / contact
   05. PAGE-HOME
   06. PAGE-ALL — internal page hero / reusable banner
   07. PAGE-STAGE
   08. PAGE-WORKSHOP
   09. PAGE-PROFILE
   10. PAGE-CONTACT
   11. PAGE-PROGRESS
   12. PAGE-ERROR-404

   Note :
   Cette version privilégie la lisibilité et la stabilité visuelle
   des pages validées. Les commentaires de migration devenus obsolètes
   ont été retirés.
========================================================= */

/* =========================================
   PAGE-ALL — TOKENS, FONTS & BASE
========================================= */

@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Light"), url("../fonts/Avenir/Avenir-Light.woff2") format("woff2"); font-weight: 300; font-style: normal; font-display: swap; }
@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Light Oblique"), url("../fonts/Avenir/Avenir-LightOblique.woff2") format("woff2"); font-weight: 300; font-style: italic; font-display: swap; }
@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Book"), url("../fonts/Avenir/Avenir-Book.woff2") format("woff2"); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Book Oblique"), url("../fonts/Avenir/Avenir-BookOblique.woff2") format("woff2"); font-weight: 400; font-style: italic; font-display: swap; }

@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Medium"), url("../fonts/Avenir/Avenir-Medium.woff2") format("woff2"); font-weight: 500; font-style: normal; font-display: swap; }
@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Medium Oblique"), url("../fonts/Avenir/Avenir-MediumOblique.woff2") format("woff2"); font-weight: 500; font-style: italic; font-display: swap; }

@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Black"), url("../fonts/Avenir/Avenir-Black.woff2") format("woff2"); font-weight: 800; font-style: normal; font-display: swap; }
@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Black Oblique"), url("../fonts/Avenir/Avenir-BlackOblique.woff2") format("woff2"); font-weight: 800; font-style: italic; font-display: swap; }
@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Heavy"), url("../fonts/Avenir/Avenir-Heavy.woff2") format("woff2"); font-weight: 900; font-style: normal; font-display: swap; }
@font-face { font-family: "Avenir Argiliere"; src: local("Avenir Heavy Oblique"), url("../fonts/Avenir/Avenir-HeavyOblique.woff2") format("woff2"); font-weight: 900; font-style: italic; font-display: swap; }

:root {
  --bg: #FFFDF9;
  --ink: #2D231D;
  --muted: #6D5950;
  --paper: #FFFDF9;
  --white: #FFFFFF;
  --transparent: transparent;

  /* PALETTE ORIGINE */
  --argile: #D28F66; /* bb846a */
  --argile-strong: #D28F66;
  --argile-logo: #BB846A; /* #BB846ACC */
  --ficelle: #CFB69A;
  --sand: #EFC265;
  --lin: #F5E9D9;
  --teint: #BF9474;
  --terracotta: #9F765F;
  --khol: #8A6052;
  --gris: #DEDFE0;

  /* ALIAS HISTORIQUES */
  --terra: var(--terracotta);
  --terra-2: var(--khol);

  /* ÉCHELLES D’ALPHA HARMONISÉES — par paliers lisibles */
  --bg-80: #FFFDF9CC;

  --paper-60: #FFFDF999;
  --paper-80: #FFFDF9CC;
  --paper-90: #FFFDF9E6;
  --paper-95: #FFFDF9F2;

  --white-20: #FFFFFF33;
  --white-40: #FFFFFF66;
  --white-80: #FFFFFFCC;

  --ink-10: #2D231D1A;
  --ink-20: #2D231D33;
  --ink-40: #2D231D66;
  --ink-70: #2D231DB3;
  --ink-80: #2D231DCC;
  --ink-90: #2D231DE6;

  --ink-deep: #1F1B16;
  --ink-deep-10: #1F1B161A;
  --ink-deep-20: #1F1B1633;
  --ink-deep-70: #1F1B16B3;
  --ink-deep-80: #1F1B16CC;

  --argile-10: #D28F661A;
  --argile-20: #D28F6633;
  --argile-80: #D28F66CC;

  --ficelle-20: #CFB69A33;

  --sand-20: #EFC26533;

  --lin-60: #F5E9D999;
  --lin-80: #F5E9D9CC;
  --lin-90: #F5E9D9E6;

  --terracotta-10: #9F765F1A;
  --terracotta-20: #9F765F33;
  --terracotta-40: #9F765F66;

  /* TOKENS SÉMANTIQUES UI */
  --sand-light: var(--sand-20);
  --lin-light: var(--lin-80);

  --shadow: 0 16px 38px var(--ink-10);
  --shadow-soft: 0 12px 28px var(--ink-deep-10);
  --radius: 22px;
  --font-ui: "Avenir Argiliere", "Avenir", "Avenir Next", "Helvetica Neue", Arial, sans-serif;

  --course-line: var(--ink-10);
  --course-shell: var(--paper-80);
  --course-shell-strong: var(--paper-95);
  --course-accent-soft: var(--argile-10);
  --course-muted-bg: var(--lin-80);
  --gallery-hover-overlay: var(--argile-80);

  --text-primary: var(--ink-90);
  --text-secondary: var(--ink-80);
  --text-muted: var(--ink-70);
  --text-on-dark: var(--white);

  --border-soft: var(--ink-10);
  --border-medium: var(--ink-20);
  --border-accent-soft: var(--terracotta-20);

  --surface-glass: var(--paper-80);
  --surface-glass-strong: var(--paper-90);
  --surface-glass-stronger: var(--paper-95);

  --btn-ghost-bg: var(--paper-95);
  --btn-ghost-bg-hover: var(--white);
  --btn-ghost-text: var(--khol);
  --btn-ghost-border: var(--terracotta-20);
  --btn-ghost-border-hover: var(--terracotta-40);
  --btn-ghost-shadow: 0 8px 18px var(--ink-10);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100%;
  margin: 0;
  background: radial-gradient(1200px 600px at 18% 0%, var(--argile-10), var(--transparent) 60%), radial-gradient(1000px 500px at 85% 18%, var(--ficelle-20), var(--transparent) 55%), var(--bg);
  background-repeat: no-repeat;
  color: var(--ink);
  font-family: var(--font-ui);
  line-height: 1.4;
  overflow-x: hidden; 
}

body, button, input, textarea, select { font-family: var(--font-ui); }

strong, b {
  font-weight: 900;
}

.spacer-small {
  display: block;
  height: 8px;
}

a { color: inherit; }
a:hover { text-decoration: none; }
.container { width: min(1120px, calc(100% - 40px)); margin: 0 auto; }

.skip-link { position: absolute; left: -9999px; top: 12px; background: var(--paper); padding: 10px 12px; border-radius: 10px; box-shadow: var(--shadow); }
.skip-link:focus { left: 12px; z-index: 50; }

.site-header { position: sticky; top: 0; z-index: 40; backdrop-filter: blur(10px); background: var(--bg-80); border-bottom: none; }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 14px 0; }
.brand { display: inline-flex; align-items: center; text-decoration: none; }
.brand__logo { display: block; width: clamp(150px, 22vw, 220px); height: auto; }
.site-status { margin: 0; max-width: 32ch; text-align: right; font-size: 15px; font-weight: 400; color: var(--ink-80); }

.hero { position: relative; padding: clamp(36px, 6vw, 36px) 0 0; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.02fr) minmax(430px, .98fr); gap: 38px; align-items: start; }
.hero-copy { padding-top: 8px; }

.pill { display: inline-flex; align-items: center; gap: 10px; padding: 8px 12px; border-radius: 999px; background: var(--argile-10); border: 1px solid var(--terracotta-20); color: var(--ink-90); font-family: var(--font-ui); font-size: 16px; font-weight: 500; letter-spacing: 0.02em; line-height: 2; margin: 0 0 14px 0; }

/* =========================================
   PAGE-ALL — TYPOGRAPHIE, LIENS & BOUTONS
========================================= */

h1, h2, h3, h4, h5, h6, .blob__title, .panel-title, .tech-card h4, .featured-note, .tech-card--visual { font-family: var(--font-ui); }

/* Titres H2 standardisés, sans clamp, taille fixe, tout en majuscules */
h2, .display-caps { 
  font-size: 30px; 
  text-transform: uppercase; 
  letter-spacing: .05em; 
  line-height: 1.4;
  color: var(--argile-strong); 
  margin: 0 0 20px 0; 
  font-weight: 400; 
}

.display-caps .accent { color: var(--khol); }

h3 { margin: 0; }
.accent { color: var(--ink-80); }

.blob__text, .featured-text, .lead, .lead-small, .info-soft { font-family: var(--font-ui); font-size: 12px; font-weight: 500; letter-spacing: 0.02em; line-height: 1.4; }
.lead, .lead-small { font-family: var(--font-ui); font-size: 17px; color: var(--ink-80); margin: 0; max-width: 62ch; }

.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin: 12px 0 10px; }

.btn, .reveal-btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 12px 18px; border-radius: 999px; text-decoration: none; font-family: var(--font-ui); font-size: 16px; font-weight: 500; letter-spacing: 0.02em; line-height: 1.4; border: 1px solid var(--transparent); transition: transform .08s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease; cursor: pointer; }
.btn:active, .reveal-btn:active { transform: translateY(1px); }

.btn-primary { background: var(--terracotta); color: var(--white); border-color: var(--ink-20); }
.btn-primary:hover { background: var(--khol); color: var(--white); border-color: var(--btn-ghost-border-hover); box-shadow: var(--btn-ghost-shadow); }

.btn-ghost { background: var(--btn-ghost-bg); color: var(--btn-ghost-text); border-color: var(--ink-20); }
.btn-ghost:hover { background: var(--btn-ghost-bg-hover); color: var(--btn-ghost-text); border-color: var(--btn-ghost-border-hover); box-shadow: var(--btn-ghost-shadow); }

/* =========================================
   PAGE-CONTACT — LAYOUT / GRID
========================================= */

.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 24px;
  align-items: stretch;
}

.contact-form-card,
.contact-side {
  height: 100%;
}

.contact-form-card {
  display: grid;
}

.contact-form {
  display: grid;
  grid-template-rows: 1fr auto auto;
  height: 100%;
}

.contact-side {
  display: grid;
}

.contact-map-card {
  display: grid;
  grid-template-rows: auto auto 1fr;
  height: 100%;
}

.contact-map-card__media {
  display: block;
}

.contact-map-card__media img {
  display: block;
  width: 100%;
  height: 360px;
  object-fit: cover;
  object-position: center;
}

.contact-map-card__body {
  display: grid;
  align-content: start;
  gap: 10px;
  height: 100%;
}

.contact-map-card__body > .btn {
  width: 100%;
  margin-top: auto;
}

/* Deux encarts du bas alignés sur la même ligne */
.contact-secondary-grid {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  align-items: stretch;
}

.contact-secondary-grid .contact-social-band,
.contact-secondary-grid .contact-direct-band {
  margin: 0;
  width: 100%;
  height: 100%;
}

/* Boutons pleine largeur */
.contact-form__actions .btn-icon:not(.reveal-btn),
.contact-map-card__body .btn-icon:not(.reveal-btn),
.contact-social-band .btn-icon:not(.reveal-btn) {
  width: 100%;
  box-shadow: none;
}

/* Téléphone : même emprise avant/après clic */
.contact-direct-band .contact-form__actions {
  padding: 0;
}

.contact-direct-band .contact-form__actions .reveal-btn,
.contact-direct-band .contact-form__actions .reveal-link {
  width: 100%;
  min-width: 0;
  min-height: 48px;
  padding: 12px 24px;
  line-height: 1.4;
  box-sizing: border-box;
}

.contact-direct-band .contact-form__actions .reveal-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* =========================================
   PAGE-CONTACT — PANELS & ALIGNEMENTS
========================================= */

/* Grille principale */
.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
  gap: 24px;
  align-items: stretch;
}

/* Colonne droite */
.contact-side {
  display: grid;
  gap: 18px;
}

/* Cartes formulaire et plan : même logique de hauteur */
.contact-form-card,
.contact-map-card,
.contact-social-band,
.contact-direct-band {
  box-shadow: var(--shadow-soft);
}

/* Le formulaire pousse naturellement son bouton en bas */
.contact-form {
  display: grid;
  gap: 16px;
  min-height: 100%;
}

.contact-form__actions {
  margin-top: auto;
  padding: 16px 18px 18px;
  display: grid;
  gap: 10px;
  align-items: center;
}

/* Boutons finaux : largeur et centrage cohérents */
.contact-form__actions .btn,
.contact-map-card__body > .btn,
.contact-social-band .contact-form__actions .btn,
.contact-direct-band .contact-form__actions .reveal-btn,
.contact-direct-band .contact-form__actions .reveal-link {
  width: 100%;
  min-height: 48px;
  justify-content: center;
  box-shadow: 0 8px 18px var(--ink-deep-10);
}

/* Icônes SVG */
.btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  /*color: var(--argile);*/
}

.btn-icon__svg {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  display: block;
  color: currentColor;
}

/* Carte plan : format carré, coins arrondis */
.contact-map-card {
  overflow: hidden;
}

.contact-map-card__media {
  display: block;
  width: min(100%, 420px);
  aspect-ratio: 1 / 1;
  margin: 0 auto;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid var(--terracotta-20);
  background: var(--paper-90);
}

.contact-map-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.contact-map-card__body {
  padding: 16px 18px 18px;
  display: grid;
  gap: 10px;
  align-content: start;
}

.contact-map-card__body > .btn {
  margin-top: 8px;
}

/* Deux encarts du bas symétriques */
.contact-secondary-grid {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.contact-secondary-grid > .contact-social-band,
.contact-secondary-grid > .contact-direct-band {
  margin: 0;
  min-height: 146px;
  align-content: start;
}

/* Même espacement au-dessus des boutons des deux derniers blocs */
.contact-social-band .contact-form__actions,
.contact-direct-band .contact-form__actions {
  padding: 16px 18px 18px;
  margin-top: auto;
}

.contact-direct-band .contact-form__actions {
  display: grid;
}

.contact-direct-band .contact-form__actions .reveal-btn,
.contact-direct-band .contact-form__actions .reveal-link {
  width: 100%;
  min-width: 0;
  min-height: 48px;
  padding: 12px 24px;
  line-height: 1.4;
  box-sizing: border-box;
}

.contact-direct-band .contact-form__actions .reveal-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--paper-90);
  border: 1px solid var(--ink-deep-20);
  text-decoration: none;
}

/* Responsive */
@media (max-width: 1080px) {
  .contact-layout,
  .contact-secondary-grid {
    grid-template-columns: 1fr;
  }

  .contact-secondary-grid {
    grid-column: auto;
  }

  .contact-map-card__media {
    width: min(100%, 520px);
  }
}

@media (max-width: 560px) {
  .contact-map-card__media {
    width: 100%;
    max-width: 100%;
    border-radius: 18px;
  }

  .contact-secondary-grid > .contact-social-band,
  .contact-secondary-grid > .contact-direct-band {
    min-height: 0;
  }
}

/* =========================================
   PAGE-CONTACT — CTA / SHADOWS
========================================= */

/* Ombre portée visible à l’état de repos */
.contact-form__actions .btn,
.contact-map-card__body > .btn,
.contact-social-band .contact-form__actions .btn,
.contact-direct-band .contact-form__actions .reveal-btn,
.contact-direct-band .contact-form__actions .reveal-link,
.about-download {
  box-shadow: 0 8px 18px var(--ink-deep-10) !important;
}

/* Largeur et centrage cohérents */
.contact-form__actions .btn,
.contact-map-card__body > .btn,
.contact-social-band .contact-form__actions .btn,
.contact-direct-band .contact-form__actions .reveal-btn,
.contact-direct-band .contact-form__actions .reveal-link {
  width: 100%;
  min-height: 48px;
  justify-content: center;
}

/* =========================================
   COMPONENTS — FEATURE PANELS / INFO LIST
========================================= */

.section { padding: 12px 0 24px; }
.feature-section { padding-top: 12px; }
.featured-shell { position: relative; background: var(--paper-60); border: 1px solid var(--ink-deep-10); border-radius: calc(var(--radius) + 6px); padding: clamp(24px, 4vw, 42px); box-shadow: var(--shadow-soft); overflow: hidden; }
.featured-top { display: grid; grid-template-columns: minmax(0, 1.02fr) minmax(350px, .98fr); gap: 34px; align-items: start; position: relative; z-index: 1; }
.featured-badge { display: inline-block; margin-bottom: 18px; padding: 10px 22px; background: var(--ficelle); color: var(--ink); border-radius: 39% 61% 47% 53% / 53% 45% 55% 47%; font-weight: 400; font-size: 15px; border: 1px solid var(--terracotta-20); }
.featured-text { font-size: 18px; line-height: 1.6; color: var(--ink-deep-80); }
.featured-main { background: var(--paper-60); padding: 32px; margin-top: 40px; border-radius: var(--radius); border: 1px solid var(--ink-deep-10); }
.featured-main--flow { display: grid; gap: 24px; }
.panel-kicker { display: inline-flex; padding: 9px 16px; border-radius: 999px; background: var(--argile-10); border: 1px solid var(--terracotta-20); font-size: 13px; font-weight: 900; text-transform: uppercase; color: var(--ink); }

.tech-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.tech-card { background: var(--lin-light); border: 1px solid var(--terracotta-10); border-radius: 18px; padding: 16px 22px 22px; }
.tech-card h4 { font-family: var(--font-ui); font-size: 22px; font-style: normal; font-weight: 300; margin-top: 0; margin-bottom: 12px; color: var(--terra); }
.tech-card ul { list-style: none; padding: 0; display: grid; gap: 10px; margin: 0; }
.tech-card li { position: relative; padding-left: 18px; color: var(--ink-deep-80); font-size: 15px;}
.tech-card li::before { content: ""; position: absolute; left: 0; top: .6em; width: 6px; height: 6px; border-radius: 50%; background: var(--sand); }

.featured-aside { background: var(--lin-80); padding: 32px; border-radius: var(--radius); border: 1px solid var(--terracotta-20); margin-top: 10px; }
.panel-title { font-size: 14px; text-transform: uppercase; font-weight: 400; letter-spacing: .08em; color: var(--terra); border-bottom: none; padding-bottom: 12px; margin-bottom: 24px; }
.info-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-bottom: 28px; }
.info-item { display: grid; grid-template-columns: 44px 1fr; gap: 14px; align-items: center; }
.info-icon { width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; color: var(--terra); background: var(--argile-10); }
.info-strong { font-weight: 400; margin: 0; font-size: 15px;}
.info-soft { font-size: 15px; color: var(--ink-deep-70); margin: 0; }

/* =========================================
   COMPONENTS — CONTACT CTA / FOOTER
========================================= */

.contact{ background: var(--paper-60); border: 1px solid var(--ink-deep-10); border-radius: calc(var(--radius) + 4px); padding: clamp(22px, 4vw, 36px); box-shadow: 0 14px 30px var(--ink-deep-10); }
.contact-head{ display: grid; gap: 10px; max-width: 70ch; }
.contact-link{ display: inline-block; }
.address-location-icon{ width: 20px; height: auto; }
.reveal-group{ width: 100%; margin: 0 auto; }
.reveal-btn{ appearance: none; width: 80%; cursor: pointer; background: var(--paper-95); color: var(--btn-ghost-text); border-color: var(--btn-ghost-border); box-shadow: var(--btn-ghost-shadow); }
.reveal-btn:hover{ background: var(--btn-ghost-bg-hover); border-color: var(--btn-ghost-border-hover); }
.reveal-link{ display: inline-flex; align-items: center; justify-content: center; width: 80%; padding: 6px 9px; border-radius: 999px; background: var(--paper-95); color: var(--btn-ghost-text); border: 1px solid var(--btn-ghost-border); box-shadow: var(--btn-ghost-shadow); font-family: var(--font-ui); font-size: 16px; font-weight: 500; letter-spacing: 0.03em; line-height: 2; text-decoration: none; }
.reveal-link:hover {  text-decoration: none;  }
.reveal-value a, .contact-link, .reveal-link{ text-decoration: none;  }
.muted{ color: var(--ink-deep-70); }
.site-footer{ border-top: 1px solid var(--ink-deep-10); padding: 22px 0 28px; }
.footer-inner{ display: flex; align-items: baseline; justify-content: space-between; gap: 14px; flex-wrap: wrap; }
.site-footer p{ margin: 0; }

/* =========================================
   COMPONENTS — BACK TO TOP BUTTON
========================================= */

.back-to-top-section {
  padding: 6px 0 30px;
}

.back-to-top-section .container {
  display: flex;
  justify-content: flex-end;
}

.back-to-top-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  max-width: 100%;
  min-height: 46px;
  padding: 10px 18px;
  border: 1px solid var(--btn-ghost-border);
  border-radius: 999px;
  background: var(--btn-ghost-bg);
  color: var(--btn-ghost-text);
  box-shadow: var(--btn-ghost-shadow);
  text-decoration: none;
  font-family: var(--font-ui);
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.4;
  transition: transform .08s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease, color .16s ease;
}

.back-to-top-btn:hover,
.back-to-top-btn:focus-visible {
  background: var(--btn-ghost-bg-hover);
  color: var(--btn-ghost-text);
  border-color: var(--btn-ghost-border-hover);
  box-shadow: var(--gallery-ui-shadow-hover, var(--btn-ghost-shadow));
  outline: none;
}

.back-to-top-btn:focus-visible {
  box-shadow: var(--gallery-ui-focus, 0 0 0 4px var(--argile-10), var(--btn-ghost-shadow));
}

.back-to-top-btn:active {
  transform: translateY(1px);
}

.back-to-top-btn__text {
  display: inline-block;
}

.back-to-top-btn__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  color: currentColor;
}

.back-to-top-btn__icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.back-to-top-btn__icon path {
  vector-effect: non-scaling-stroke;
}

@media (max-width: 680px) {
  .back-to-top-section {
    padding: 4px 0 24px;
  }

  .back-to-top-section .container {
    justify-content: stretch;
  }

  .back-to-top-btn {
    width: 100%;
  }
}


/* =========================================
   COMPONENTS — BLOBS / MEDIA SHAPES
========================================= */

.blob {
  position: relative;
  isolation: isolate;
  width: var(--blob-width, 100%);
  max-width: var(--blob-max-width, none);
  min-height: var(--blob-min-height, 0);
  aspect-ratio: var(--blob-ratio, 1 / 1);
  background: transparent;
  box-shadow: none;
  border: 0;
  border-radius: 0;
  overflow: visible;
}

.blob::before {
  content: "";
  position: absolute;
  inset: var(--blob-bg-inset, 0);
  background-size: var(--blob-bg-size, contain);
  background-position: var(--blob-bg-position, center);
  background-repeat: no-repeat;
  filter: drop-shadow(0 16px 30px var(--ink-10));
  z-index: 0;
  transform: scale(var(--blob-scale, 1));
  transform-origin: center;
}

.blob--image-argile::before { background-image: url("../img/blob/PATATE-ARGILE.png"); }
.blob--image-ficelle::before { background-image: url("../img/blob/FICELLE.png"); }
.blob--image-khol::before { background-image: url("../img/blob/KHOL.png"); }
.blob--image-lin::before { background-image: url("../img/blob/LIN.png"); }
.blob--image-sand::before { background-image: url("../img/blob/SAND-light.png"); }
.blob--image-teint::before { background-image: url("../img/blob/TEINT.png"); }
.blob--image-terracotta::before { background-image: url("../img/blob/TERRACOTA.png"); }

/* Blob hero 1 : liste centrée dans le blob */
.blob--hero-1 .blob__inner {
  justify-content: center;
  align-items: center;
  text-align: center;
  --blob-padding: 3.2rem 2.2rem;
}

.blob--hero-1 .blob__list,
.blob--hero-2 .blob__list {
  list-style: none;
  margin: 0;
  padding: 0;
  width: min(95%, 23rem);
  display: grid;
  gap: 1rem;
}

.blob--hero-1 .blob__list li,
.blob--hero-2 .blob__list li {
  margin: 0;
  font-size: var(--blob-text-size, 1rem);
  line-height: var(--blob-text-line-height, 1);
  font-weight: 400;
  text-align: center;
  color: var(--white);
}

.blob--hero-1 .blob__list strong {
  font-weight: 500;
  color: inherit;
}

.hero-blobs--infos .blob--hero-1 {
  min-height: 18rem;
}

/* =========================================
   PAGE-PROGRESS — sécurisation des blobs larges
   Réduit proportionnellement les blobs qui débordent
========================================= */

.page-progress .hero-blobs--infos .blob--hero-2,
.page-progress .hero-blobs--stage .blob--stage-1,
.page-progress .hero-blobs--stage .blob--stage-3 {
  width: min(var(--blob-max-width, 100%), var(--blob-base-width, 100%));
}

/* Valeurs desktop conservatrices */
.page-progress .hero-blobs--infos .blob--hero-2 {
  --blob-base-width: 60%;
  --blob-max-width: calc(100vw - 32px);
}

.page-progress .hero-blobs--stage .blob--stage-1 {
  --blob-base-width: 32%;
  --blob-max-width: calc(100vw - 32px);
}

.page-progress .hero-blobs--stage .blob--stage-3 {
  --blob-base-width: 40%;
  --blob-max-width: calc(100vw - 32px);
}

@media (max-width: 980px) {

  .page-progress .hero-blobs--infos .blob--hero-1 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.12;
  }

  .page-progress .hero-blobs--infos .blob--hero-2 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.08;
  }

  .page-progress .hero-blobs--infos .blob--hero-3 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.12;
  }

  .page-progress .hero-blobs--stage .blob--stage-1 {
    --blob-base-width: 32%;
    --blob-tablet-scale: 1.20;
  }

  .page-progress .hero-blobs--stage .blob--stage-2 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.12;
  }

  .page-progress .hero-blobs--stage .blob--stage-3 {
    --blob-base-width: 32%;
    --blob-tablet-scale: 1.20;
  }

  .hero-blobs--infos .blob--hero-1 { order: 3; }
  .hero-blobs--infos .blob--hero-2 { order: 2; }
  .hero-blobs--infos .blob--hero-3 { order: 1; }

  .hero-blobs--infos {
    gap: 24px !important;
    padding: 20px 0 30px;
  }

  .blob--hero-1 .blob__inner {
    --blob-padding: 2.4rem 1.8rem;
  }

  .blob--hero-1 .blob__list {
    width: min(95%, 21rem);
    gap: 0.85rem;
  }

  .hero-blobs--infos .blob--hero-1 {
    --blob-text-size: clamp(1rem, 2.8vw, 1.35rem);
    --blob-text-line-height: 1.4;
  }

  .hero-blobs--infos .blob--hero-3 {
    margin-top: -50px;
    margin-bottom: -5px;
  }

  .hero-blobs--infos .blob--hero-2 {
    margin-top: -50px;
    margin-bottom: 5px;
  }

  .hero-blobs--infos .blob--hero-1 {
    margin-top: -16px;
    margin-bottom: 30px;
  }
}

/* Très petits écrans : on réduit encore un peu */
@media (max-width: 680px) {
  /* page-progress */

  .page-progress .hero-blobs--infos .blob--hero-1 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.12;
  }

  .page-progress .hero-blobs--infos .blob--hero-2 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.08;
  }

  .page-progress .hero-blobs--infos .blob--hero-3 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.12;
  }

  .page-progress .hero-blobs--stage .blob--stage-1 {
    --blob-base-width: 32%;
    --blob-tablet-scale: 1.20;
  }

  .page-progress .hero-blobs--stage .blob--stage-2 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.12;
  }

  .page-progress .hero-blobs--stage .blob--stage-3 {
    --blob-base-width: 32%;
    --blob-tablet-scale: 1.20;
  }

  /* page-home */

  .page-home .hero-blobs--infos .blob--hero-1 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.12;
  }

  .page-home .hero-blobs--infos .blob--hero-2 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.08;
  }

  .page-home .hero-blobs--infos .blob--hero-3 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.12;
  }

  /* page-course */
  .page-course .course-signup-blobs .blob--signup-1,
  .page-course .course-signup-blobs .blob--signup-2,
  .page-course .course-signup-blobs .blob--signup-3 {
    width: min(100%, 340px);
  }

  .page-course .course-signup-blobs .blob--signup-1 {
    --blob-tablet-scale: 1.20;
  }

  .page-course .course-signup-blobs .blob--signup-2 {
    --blob-tablet-scale: 1.20;
  }

  .page-course .course-signup-blobs .blob--signup-3 {
    --blob-scale: 1.02;
  }

  /* page-stage */
  .page-stage .hero-blobs--stage .blob--stage-1,
  .page-stage .hero-blobs--stage .blob--stage-2,
  .page-stage .hero-blobs--stage .blob--stage-3 {
    width: min(100%, 340px);
  }

  .page-stage .hero-blobs--stage .blob--stage-1 {
    --blob-base-width: 32%;
    --blob-scale: 1.20;
  }

  .page-stage .hero-blobs--stage .blob--stage-2 {
    --blob-base-width: 28%;
    --blob-tablet-scale: 1.12;
  }

  .page-stage .hero-blobs--stage .blob--stage-3 {
    --blob-base-width: 32%;
    --blob-tablet-scale: 1.20;
  }

  .page-stage .course-signup-blobs .blob--signup-4,
  .page-stage .course-signup-blobs .blob--signup-5,
  .page-stage .course-signup-blobs .blob--signup-6 {
    width: min(100%, 340px);
  }

  .page-stage .course-signup-blobs .blob--signup-4 {
    --blob-tablet-scale: 1.12;
  }

  .page-stage .course-signup-blobs .blob--signup-5 {
    --blob-tablet-scale: 1.36;
  }

  .page-stage .course-signup-blobs .blob--signup-6 {
    --blob-scale: 1.12;
  }

}

/* Structure interne commune des blobs */

.blob__inner {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: var(--blob-content-gap, 0.55rem);
  text-align: center;
  padding: var(--blob-padding, 2rem);
  z-index: 1;
}

.blob__inner > * {
  margin-left: auto;
  margin-right: auto;
}

.blob__title {
  max-width: var(--blob-title-max-width, 85%);
  font-size: var(--blob-title-size, 1.34rem);
  line-height: var(--blob-title-line-height, 1.16);
  color: var(--ink);
  text-transform: uppercase;
  font-weight: 400;
  margin: 0;
  align-items: center;
  text-align: center;
}

.blob__text {
  max-width: var(--blob-text-max-width, 95%);
  font-size: var(--blob-text-size, 1rem);
  line-height: var(--blob-text-line-height, 1);
  margin: 0;
  align-items: center;
  text-align: center;
}

/* =========================================
   COMPONENTS — BLOBS / LAYOUT
========================================= */

.hero-blobs--infos, .hero-blobs--stage { position: relative; }
.hero-blobs--infos { min-height: 560px; }
.hero-blobs--stage { min-height: 320px; }
.hero-blobs--infos .blob, .hero-blobs--stage .blob { position: absolute; height: auto; }

.hero-blobs--infos .blob--hero-1 { width: 45%; aspect-ratio: 1.1; left: -5%; top: 35%; z-index: 3; --blob-scale: 1.55; }
.hero-blobs--infos .blob--hero-2 { width: 60%; aspect-ratio: 1.25; right: -5%; top: 32%; z-index: 1; --blob-scale: 1.45; } 
.hero-blobs--infos .blob--hero-3 { width: 55%; aspect-ratio: 1.1; left: 5%; top: -5%; z-index: 2; --blob-scale: 1.4; }

.hero-blobs--stage .blob--stage-1 { width: 32%; aspect-ratio: 1; left: 0%; top: 42%; z-index: 2; --blob-scale: 1.40; }
.hero-blobs--stage .blob--stage-2 { width: 40%; aspect-ratio: 1.15; left: 44%; transform: translateX(-50%); top: 0; z-index: 1; --blob-scale: 1.60; }
.hero-blobs--stage .blob--stage-3 { width: 40%; aspect-ratio: 1.1; right: 0%; top: 45%; z-index: 3; --blob-scale: 1.80; }

/* SECTION CONTACT */
.contact-blobs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  justify-items: center;
  align-items: center;
  gap: clamp(24px, 3vw, 38px) clamp(18px, 2.4vw, 30px);
  margin-top: 40px;
}

.contact-blobs .blob {
  position: relative;
  width: 100%;
  margin: 0 auto;
}

/* Desktop : la section contact reste en grille 2 x 2.
   Les valeurs mobiles sont gérées plus bas dans les breakpoints existants. */
.blob--contact-1 {
  width: min(100%, 310px);
  aspect-ratio: 1;
  min-height: 300px;
  z-index: 2;
  --blob-scale: 1;
  --blob-bg-size: contain;
  --blob-bg-inset: -17%;
  --blob-bg-position: center;
  --blob-padding: 34px 32px;
  --blob-title-size: 1rem;
  --blob-text-size: 0.9rem;
  --blob-text-line-height: 1.4;
}

.blob--contact-1 .blob__inner > * {
  max-width: 74%;
}

.blob--contact-2 {
  width: min(100%, 310px);
  aspect-ratio: 1;
  min-height: 280px;
  z-index: 2;
  --blob-scale: 1;
  --blob-bg-size: contain;
  --blob-bg-inset: -4%;
  --blob-bg-position: center;
  --blob-padding: 32px 30px;
  --blob-title-size: 0.98rem;
  --blob-text-size: 0.88rem;
  --blob-text-line-height: 1.4;
}

.blob--contact-3 {
  width: min(100%, 310px);
  aspect-ratio: 1.18;
  min-height: 240px;
  z-index: 1;
  --blob-scale: 1.00;
  --blob-bg-size: contain;
  --blob-bg-inset: -14%;
  --blob-bg-position: center;
  --blob-padding: 28px 26px;
  --blob-title-size: 0.9rem;
  --blob-text-size: 0.82rem;
  --blob-text-line-height: 1.4;
}

.blob--contact-4 {
  width: min(100%, 310px);
  aspect-ratio: 1.18;
  min-height: 240px;
  z-index: 1;
  --blob-scale: 1.00;
  --blob-bg-size: contain;
  --blob-bg-inset: -14%;
  --blob-bg-position: center;
  --blob-padding: 28px 26px;
  --blob-title-size: 0.9rem;
  --blob-text-size: 0.82rem;
  --blob-text-line-height: 1.4;
}

.contact-blobs .blob__inner > div:first-child {
  display: grid;
  gap: 8px;
  justify-items: center;
  width: 100%;
}


@media (max-width: 1023px) {
  .contact-blobs .blob--contact-1,
  .contact-blobs .blob--contact-2 {
    left: auto;
    right: auto;
    justify-self: center;
    align-self: center;
    transform: translateX(0);
    margin-left: auto;
    margin-right: auto;
  }
}

@media (min-width: 1024px) {
  .contact-blobs {
    column-gap: 0;
    row-gap: clamp(10px, 1.2vw, 18px);
  }

  .contact-blobs .blob--contact-1 {
    justify-self: end;
    transform: translateX(16px);
    --blob-bg-inset: -12%;
  }

  .contact-blobs .blob--contact-2 {
    justify-self: start;
    transform: translateX(-16px);
    --blob-bg-inset: -8%;
  }

  .contact-blobs .blob--contact-4 {
    justify-self: end;
    transform: translate(18px, -18px);
    --blob-bg-inset: -18%;
  }

  .contact-blobs .blob--contact-3 {
    justify-self: start;
    transform: translate(-18px, -18px);
    --blob-bg-inset: -18%;
  }

  .contact-blobs .blob .btn,
  .contact-blobs .reveal-btn,
  .contact-blobs .reveal-link,
  .contact-blobs .btn-blob {
    width: min(100%, 210px);
    min-height: 34px;
    padding: 7px 12px;
    font-size: 0.82rem;
    line-height: 1.4;
  }
}

@media (max-width: 980px) {
  .contact-blobs {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 28px;
    min-height: auto;
    padding: 24px 0;
  }

  .contact-blobs .blob.blob--contact-1,
  .contact-blobs .blob.blob--contact-2,
  .contact-blobs .blob.blob--contact-3,
  .contact-blobs .blob.blob--contact-4 {
    position: relative;
    inset: auto;
    transform: none;
    margin: 0 auto;
    aspect-ratio: var(--blob-tablet-ratio, 1 / 1);
    --blob-bg-size: contain;
    --blob-padding: 30px 28px;
    --blob-content-gap: 0.55rem;
  }

  .contact-blobs .blob.blob--contact-1 {
    width: var(--blob-tablet-width, min(88vw, 400px));
    max-width: var(--blob-tablet-max-width, 400px);
    min-height: var(--blob-tablet-min-height, 330px);
    --blob-tablet-width: min(88vw, 400px);
    --blob-tablet-max-width: 400px;
    --blob-tablet-min-height: 330px;
    --blob-tablet-scale: 1.06;
    --blob-scale: var(--blob-tablet-scale);
    --blob-bg-inset: -10%;
  }

  .contact-blobs .blob.blob--contact-2 {
    width: var(--blob-tablet-width, min(86vw, 380px));
    max-width: var(--blob-tablet-max-width, 360px);
    min-height: var(--blob-tablet-min-height, 310px);
    --blob-tablet-width: min(86vw, 360px);
    --blob-tablet-max-width: 380px;
    --blob-tablet-min-height: 310px;
    --blob-tablet-scale: 1.08;
    --blob-scale: var(--blob-tablet-scale);
    --blob-bg-inset: -1%;
  }

  .contact-blobs .blob.blob--contact-3,
  .contact-blobs .blob.blob--contact-4 {
    width: var(--blob-tablet-width, min(82vw, 340px));
    max-width: var(--blob-tablet-max-width, 340px);
    min-height: var(--blob-tablet-min-height, 250px);
    --blob-tablet-ratio: 1 / 0.76;
    --blob-tablet-width: min(82vw, 340px);
    --blob-tablet-max-width: 340px;
    --blob-tablet-min-height: 250px;
    --blob-tablet-scale: 1.02;
    --blob-scale: var(--blob-tablet-scale);
    --blob-bg-inset: -17%;
  }
}

@media (max-width: 430px) {
  .contact-blobs {
    gap: 20px;
    padding: 12px 0;
  }

  .contact-blobs .blob.blob--contact-1 {
    justify-self: center;
    transform: translateX(0);
    --blob-mobile-width: min(86vw, 276px);
    --blob-mobile-max-width: 276px;
    --blob-mobile-min-height: 278px;
    --blob-mobile-ratio: 1 / 1;
    --blob-mobile-scale: 1.04;
    --blob-bg-size: contain;
    --blob-bg-inset: -17%;
    --blob-bg-position: center;
    --blob-padding: 24px 22px;
    --blob-content-gap: 0.42rem;
    --blob-title-size: clamp(0.76rem, 4vw, 0.92rem);
    --blob-title-line-height: 1.4;
    --blob-text-size: clamp(0.60rem, 3.16vw, 0.74rem);
    --blob-text-line-height: 1.4;
  }

  .contact-blobs .blob.blob--contact-2 {
    justify-self: center;
    transform: translateX(0);
    --blob-mobile-width: min(86vw, 276px);
    --blob-mobile-max-width: 276px;
    --blob-mobile-min-height: 264px;
    --blob-mobile-ratio: 1 / 1;
    --blob-mobile-scale: 1.05;
    --blob-bg-size: contain;
    --blob-bg-inset: -3%;
    --blob-bg-position: center;
    --blob-padding: 24px 22px;
    --blob-content-gap: 0.42rem;
    --blob-title-size: clamp(0.76rem, 4vw, 0.92rem);
    --blob-title-line-height: 1.4;
    --blob-text-size: clamp(0.60rem, 3.16vw, 0.74rem);
    --blob-text-line-height: 1.4;
  }

  .contact-blobs .blob.blob--contact-3 {
    --blob-mobile-width: min(84vw, 286px);
    --blob-mobile-max-width: 286px;
    --blob-mobile-min-height: 216px;
    --blob-mobile-ratio: 1 / 0.76;
    --blob-mobile-scale: 1.02;
    --blob-bg-size: contain;
    --blob-bg-inset: -22%;
    --blob-padding: 20px 16px;
    --blob-content-gap: 0.3rem;
    --blob-title-size: clamp(0.72rem, 3.82vw, 0.88rem);
    --blob-title-line-height: 1.4;
    --blob-text-size: clamp(0.58rem, 3.05vw, 0.70rem);
    --blob-text-line-height: 1.4;
  }

  .contact-blobs .blob.blob--contact-4 {
    --blob-mobile-width: min(84vw, 286px);
    --blob-mobile-max-width: 286px;
    --blob-mobile-min-height: 216px;
    --blob-mobile-ratio: 1 / 0.76;
    --blob-mobile-scale: 1.02;
    --blob-bg-size: contain;
    --blob-bg-inset: -22%;
    --blob-padding: 20px 16px;
    --blob-content-gap: 0.3rem;
    --blob-title-size: clamp(0.72rem, 3.82vw, 0.88rem);
    --blob-title-line-height: 1.4;
    --blob-text-size: clamp(0.58rem, 3.05vw, 0.70rem);
    --blob-text-line-height: 1.4;
  }

  .contact-blobs .blob.blob--contact-1 .blob__inner > *,
  .contact-blobs .blob.blob--contact-2 .blob__inner > *,
  .contact-blobs .blob.blob--contact-3 .blob__inner > *,
  .contact-blobs .blob.blob--contact-4 .blob__inner > * {
    max-width: 82%;
  }

  .contact-blobs .blob.blob--contact-3 .blob__text,
  .contact-blobs .blob.blob--contact-4 .blob__text {
    max-width: 84%;
  }

  .contact-blobs .blob.blob--contact-3 .address-location-icon {
    width: 17px;
  }

  .contact-blobs .blob.blob--contact-4 svg {
    width: 17px;
    height: 17px;
  }

  .contact-blobs .blob .btn,
  .contact-blobs .reveal-btn,
  .contact-blobs .reveal-link,
  .contact-blobs .btn-blob {
    width: min(100%, 220px);
    min-height: 34px;
    padding: 7px 10px;
    font-size: 0.70rem;
    line-height: 1.4;
  }
}

@media (max-width: 430px) {
  .contact-blobs {
    align-items: center;
    justify-content: center;
  }

  .contact-blobs .blob.blob--contact-1,
  .contact-blobs .blob.blob--contact-2 {
    left: auto;
    right: auto;
    justify-self: center;
    align-self: center;
    transform: translateX(0);
    margin-left: auto;
    margin-right: auto;
    width: var(--blob-mobile-width);
    max-width: var(--blob-mobile-max-width);
  }
}

@media (max-width: 380px) {
  .contact-blobs .blob.blob--contact-1 {
    justify-self: center;
    transform: translateX(0);
    --blob-mobile-width: min(85vw, 260px);
    --blob-mobile-max-width: 260px;
    --blob-mobile-min-height: 264px;
    --blob-mobile-scale: 1.04;
    --blob-bg-inset: -17%;
    --blob-bg-position: center;
    --blob-padding: 22px 18px;
  }

  .contact-blobs .blob.blob--contact-2 {
    justify-self: center;
    transform: translateX(0);
    --blob-mobile-width: min(85vw, 260px);
    --blob-mobile-max-width: 260px;
    --blob-mobile-min-height: 250px;
    --blob-mobile-scale: 1.05;
    --blob-bg-inset: -3%;
    --blob-bg-position: center;
    --blob-padding: 22px 18px;
  }

  .contact-blobs .blob.blob--contact-3,
  .contact-blobs .blob.blob--contact-4 {
    --blob-mobile-width: min(84vw, 268px);
    --blob-mobile-max-width: 268px;
    --blob-mobile-min-height: 204px;
    --blob-bg-inset: -22%;
    --blob-padding: 18px 15px;
  }
}

/* Alignement strict 380px des deux premiers blobs contact. */
@media (max-width: 380px) {
  .contact-blobs .blob.blob--contact-1,
  .contact-blobs .blob.blob--contact-2 {
    left: auto;
    right: auto;
    justify-self: center;
    align-self: center;
    transform: translateX(0);
    margin-left: auto;
    margin-right: auto;
    width: var(--blob-mobile-width);
    max-width: var(--blob-mobile-max-width);
  }
}

@media (max-width: 360px) {
  .contact-blobs .blob.blob--contact-1 {
    --blob-mobile-width: min(84vw, 262px);
    --blob-mobile-max-width: 242px;
    --blob-mobile-min-height: 252px;
    --blob-bg-inset: -15%;
    --blob-title-size: clamp(0.70rem, 3.72vw, 0.82rem);
    --blob-text-size: clamp(0.56rem, 2.95vw, 0.68rem);
  }

  .contact-blobs .blob.blob--contact-2 {
    --blob-mobile-width: min(84vw, 262px);
    --blob-mobile-max-width: 242px;
    --blob-mobile-min-height: 238px;
    --blob-bg-inset: -1%;
    --blob-title-size: clamp(0.70rem, 3.72vw, 0.82rem);
    --blob-text-size: clamp(0.56rem, 2.95vw, 0.68rem);
  }

  .contact-blobs .blob.blob--contact-3,
  .contact-blobs .blob.blob--contact-4 {
    --blob-mobile-width: min(84vw, 256px);
    --blob-mobile-max-width: 256px;
    --blob-mobile-min-height: 194px;
    --blob-bg-inset: -23%;
    --blob-title-size: clamp(0.70rem, 3.72vw, 0.82rem);
    --blob-text-size: clamp(0.56rem, 2.95vw, 0.68rem);
  }
}

@media (max-width: 300px) {
  .contact-blobs .blob.blob--contact-1,
  .contact-blobs .blob.blob--contact-2,
  .contact-blobs .blob.blob--contact-3,
  .contact-blobs .blob.blob--contact-4 {
    --blob-mobile-width: min(78vw, 228px);
    --blob-mobile-max-width: 228px;
    --blob-padding: 17px 13px;
    --blob-content-gap: 0.28rem;
    --blob-title-size: 0.74rem;
    --blob-text-size: 0.56rem;
    --blob-title-line-height: 1.4;
    --blob-text-line-height: 1.4;
  }

  .contact-blobs .blob.blob--contact-1 {
    --blob-mobile-min-height: 218px;
    --blob-bg-inset: -16%;
  }

  .contact-blobs .blob.blob--contact-2 {
    --blob-mobile-min-height: 204px;
    --blob-bg-inset: -1%;
  }

  .contact-blobs .blob.blob--contact-3,
  .contact-blobs .blob.blob--contact-4 {
    --blob-mobile-min-height: 168px;
    --blob-bg-inset: -24%;
  }

  .contact-blobs .blob .btn,
  .contact-blobs .reveal-btn,
  .contact-blobs .reveal-link,
  .contact-blobs .btn-blob {
    width: min(100%, 184px);
    min-width: 0;
    min-height: 0;
    height: auto;
    padding: 5px 8px;
    font-size: 0.60rem;
    line-height: 1.4;
  }
}


/* =========================================
   COMPONENTS — BLOBS / CONTRAST THEMES
========================================= */

/* Sombres => Texte Blanc */
.blob--image-argile .blob__title, .blob--image-argile .blob__text,
.blob--image-terracotta .blob__title, .blob--image-terracotta .blob__text,
.blob--image-khol .blob__title, .blob--image-khol .blob__text,
.blob--image-teint .blob__title, .blob--image-teint .blob__text {
  color: var(--white) !important;
}
.blob--image-argile .muted, .blob--image-terracotta .muted,
.blob--image-khol .muted, .blob--image-teint .muted {
  color: var(--white-80) !important;
}

/* Boutons dans sombres */
.blob--image-terracotta .reveal-btn, .blob--image-argile .reveal-btn,
.blob--image-teint .reveal-btn, .blob--image-khol .reveal-btn,
.blob--image-terracotta .reveal-link, .blob--image-argile .reveal-link,
.blob--image-teint .reveal-link, .blob--image-khol .reveal-link {
  background: var(--white-20) !important;
  border-color: var(--white-20) !important;
  color: var(--white) !important;
  box-shadow: none !important;
}
.blob--image-terracotta .reveal-btn:hover, .blob--image-argile .reveal-btn:hover { background: var(--white-20) !important; }

/* Claires => Texte Khol */
.blob--image-ficelle .blob__title, .blob--image-ficelle .blob__text,
.blob--image-lin .blob__title, .blob--image-lin .blob__text,
.blob--image-sand .blob__title, .blob--image-sand .blob__text {
  color: var(--khol) !important;
}
.blob--contact-1 .reveal-btn, .blob--contact-1 .reveal-link,
.blob--contact-3 .reveal-btn, .blob--contact-3 .reveal-link,
.blob--contact-4 .reveal-btn, .blob--contact-4 .reveal-link{
  background: var(--paper-90); color: var(--ink-90);
}

/* =========================================
   COMPONENTS — VISUAL NOTES / HIGHLIGHTS
========================================= */

.tech-card--visual, .featured-note {
  grid-column: 1 / -1; 
  text-align: center;
  background: var(--argile-strong) !important;
  color: var(--white) !important;
  border: none !important;
  border-left: 4px solid var(--white-40) !important;
  border-radius: 14px;
  padding: 24px 32px !important;
  font-family: var(--font-ui);
  box-shadow: var(--shadow-soft);
  margin-top: 10px;
}

.tech-card--visual .tech-visual-text, .featured-note {
  color: var(--white) !important;
  font-size: clamp(17px, 2vw, 19px);
  font-style: italic;
  font-weight: 400;
  line-height: 1.4;
  margin: 0;
}

/* =========================================
   PAGE-ALL — RESPONSIVE
========================================= */

@media (max-width: 980px) {
  .header-inner, .hero-grid, .featured-top { grid-template-columns: 1fr; }
  .header-inner { align-items: flex-start; }
  .site-status { max-width: none; text-align: left; }
  .tech-grid { grid-template-columns: 1fr; }
  
  .hero-blobs--infos, .hero-blobs--stage, .contact-blobs {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 36px;
    min-height: auto;
    padding: 30px 0;
  }
  
  .hero-blobs--infos .blob, .hero-blobs--stage .blob, .contact-blobs .blob {
    position: relative;
    inset: auto;
    transform: none;
    margin: 0 auto;
    width: var(--blob-tablet-width, min(88vw, 400px));
    max-width: var(--blob-tablet-max-width, 400px);
    min-height: var(--blob-tablet-min-height, 320px);
    aspect-ratio: var(--blob-tablet-ratio, 1 / 1);
    --blob-scale: var(--blob-tablet-scale, 1.14);
  }
}

@media (max-width: 680px) {
  h2, .display-caps { font-size: 26px; } /* Légère adaptation auto sur très petit écran */
  .container { width: min(1120px, calc(100% - 24px)); }
  .hero-actions, .featured-actions { flex-direction: column; align-items: stretch; }
  .btn { width: 100%; }
  .info-list { grid-template-columns: 1fr; }
  .hero-blobs--infos .blob, .hero-blobs--stage .blob, .contact-blobs .blob {
    min-height: var(--blob-tablet-min-height, 280px);
  }
}

@media (max-width: 430px) {
  .hero-blobs--infos,
  .hero-blobs--stage,
  .contact-blobs {
    gap: 18px;
    padding: 12px 0;
  }

  .hero-blobs--infos .blob,
  .hero-blobs--stage .blob,
  .page-home .hero-blobs--infos .blob,
  .page-progress .hero-blobs--infos .blob,
  .page-progress .hero-blobs--stage .blob,
  .page-stage .hero-blobs--stage .blob,
  .contact-blobs .blob {
    width: var(--blob-mobile-width, min(82vw, 270px));
    max-width: var(--blob-mobile-max-width, 270px);
    min-height: var(--blob-mobile-min-height, 230px);
    aspect-ratio: var(--blob-mobile-ratio, 1 / 1);
    --blob-scale: var(--blob-mobile-scale, 1.08);
    --blob-padding: 24px 22px;
    --blob-title-size: clamp(0.95rem, 5vw, 1.15rem);
    --blob-text-size: clamp(0.78rem, 4.1vw, 0.98rem);
  }

  .hero-blobs--infos .blob--hero-2 {
    --blob-mobile-width: min(88vw, 292px);
    --blob-mobile-max-width: 292px;
    --blob-mobile-min-height: 250px;
    --blob-mobile-scale: 1.20;
    --blob-title-size: clamp(1rem, 5.5vw, 1.22rem);
    --blob-text-size: clamp(0.76rem, 4vw, 0.92rem);
  }

  .hero-blobs--infos .blob--hero-3,
  .hero-blobs--stage .blob--stage-3 {
    --blob-mobile-width: min(84vw, 280px);
    --blob-mobile-max-width: 280px;
    --blob-mobile-scale: 1.20;
    --blob-bg-inset: -18%;
  }

  /* Ajustements mobiles ciblant les téléphones autour de 360 px CSS
     (ex. captures 1080 x 2400 px physiques avec DPR élevé). */
  .hero-blobs--infos .blob.blob--hero-1 {
    --blob-title-size: clamp(0.76rem, 4vw, 0.92rem);
    --blob-text-size: clamp(0.62rem, 3.28vw, 0.78rem);
  }

  .hero-blobs--infos .blob.blob--hero-2 {
    --blob-title-size: clamp(0.8rem, 4.4vw, 0.98rem);
    --blob-text-size: clamp(0.61rem, 3.2vw, 0.74rem);
  }

  .hero-blobs--infos .blob.blob--hero-3 {
    --blob-mobile-scale: 1.37;
    --blob-text-size: clamp(0.62rem, 3.28vw, 0.78rem);
  }

  .hero-blobs--stage .blob.blob--stage-1,
  .hero-blobs--stage .blob.blob--stage-2 {
    --blob-mobile-scale: 1.20;
  }
}

@media (max-width: 380px) {
  .hero-blobs--infos .blob,
  .hero-blobs--stage .blob,
  .page-home .hero-blobs--infos .blob,
  .page-progress .hero-blobs--infos .blob,
  .page-progress .hero-blobs--stage .blob,
  .page-stage .hero-blobs--stage .blob,
  .contact-blobs .blob {
    --blob-mobile-width: min(80vw, 252px);
    --blob-mobile-max-width: 252px;
    --blob-mobile-min-height: 218px;
    --blob-padding: 22px 18px;
    --blob-content-gap: 0.45rem;
  }
}

@media (max-width: 360px) {
  .hero-blobs--infos .blob,
  .hero-blobs--stage .blob,
  .page-home .hero-blobs--infos .blob,
  .page-progress .hero-blobs--infos .blob,
  .page-progress .hero-blobs--stage .blob,
  .page-stage .hero-blobs--stage .blob,
  .contact-blobs .blob {
    --blob-mobile-width: min(79vw, 242px);
    --blob-mobile-max-width: 242px;
    --blob-mobile-min-height: 210px;
    --blob-title-size: clamp(0.88rem, 4.8vw, 1.05rem);
    --blob-text-size: clamp(0.74rem, 3.9vw, 0.9rem);
  }
}

/* =========================================
   PAGE-COURSE — CORE
========================================= */

.cours-page {
  position: relative;
}

.cours-page::before,
.cours-page::after {
  content: "";
  position: fixed;
  inset: auto;
  pointer-events: none;
  z-index: -1;
  width: 42vw;
  height: 42vw;
  border-radius: 50%;
  filter: blur(6px);
  opacity: 0.45;
}

.cours-page::before {
  top: 8rem;
  left: -14vw;
  background: radial-gradient(circle, var(--argile-20), var(--transparent) 68%);
}

.cours-page::after {
  right: -16vw;
  top: 26rem;
  background: radial-gradient(circle, var(--ficelle-20), var(--transparent) 70%);
}

.course-header {
  border-bottom: 1px solid var(--ink-10);
}

.course-header .header-inner {
  gap: 24px;
  background: transparent;
}

.course-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
}

.course-nav a {
  padding: 8px 14px;
  border-radius: 999px;
  text-decoration: none;
  font-size: 0.95rem;
  letter-spacing: .05em;
  line-height: 1.4;
  color: var(--argile);
  border: 1px solid var(--transparent);
  text-transform: uppercase; 
  background: var(--paper-80);
  border-color: var(--gris);
}

.course-nav a:hover,
.course-nav a:focus-visible {
  background: var(--paper-80);
  border-color: var(--ink-20);
  box-shadow: var(--btn-ghost-shadow);
}

.course-nav .course-nav__cta {
  background: var(--argile);
  color: var(--white);
  border-color: var(--ink-10);
}

.course-nav .course-nav__cta:hover,
.course-nav .course-nav__cta:focus-visible {
  background: var(--argile);
  border-color: var(--transparent);
  box-shadow: var(--btn-ghost-shadow);
}

.course-nav a:active,
.course-nav .course-nav__cta:active {
  box-shadow: var(--btn-ghost-shadow);
}

.cours-hero {
  padding: clamp(42px, 7vw, 76px) 0 26px;
}

.cours-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(380px, 0.98fr);
  gap: 34px;
  align-items: start;
}

.cours-hero__copy {
  padding-top: 12px;
}

.cours-page h2.display-caps {
  margin-bottom: 18px;
}

.course-intro {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.course-intro p,
.course-section__lead,
.course-editorial p,
.course-note,
.table-footnote,
.course-info-card p,
.course-formula__stack p,
.course-mini-note,
.course-cta p {
  color: var(--ink-80);
}

.course-intro p,
.course-editorial p,
.course-formula__stack p,
.course-cta p {
  margin: 0;
}

.hero-blobs--cours {
  position: relative;
  min-height: 560px;
}

.hero-blobs--cours .blob {
  position: absolute;
  height: auto;
}

.hero-blobs--cours .blob--course-1 {
  width: 34%;
  aspect-ratio: 1.02;
  left: 2%;
  top: 6%;
  z-index: 3;
  --blob-scale: 1.7;
}

.hero-blobs--cours .blob--course-2 {
  width: 47%;
  aspect-ratio: 1.12;
  right: 0%;
  top: 5%;
  z-index: 1;
  --blob-scale: 1.65;
}

.hero-blobs--cours .blob--course-3 {
  width: 42%;
  aspect-ratio: 1.05;
  left: 25%;
  top: 42%;
  z-index: 4;
  --blob-scale: 1.7;
}

.hero-blobs--cours .blob--course-4 {
  width: 40%;
  aspect-ratio: 1.08;
  right: 6%;
  top: 47%;
  z-index: 2;
  --blob-scale: 1.15;
}

.course-main {
  padding: 10px 0 10px;
}

.course-stack {
  display: grid;
  gap: 26px;
}

.course-section {
  background: var(--course-shell);
  border: 1px solid var(--course-line);
  border-radius: 28px;
  padding: clamp(24px, 3.6vw, 38px);
  box-shadow: var(--shadow-soft);
}

.course-feature-header {
  margin-bottom: 12px;
}

.course-section__lead {
  margin: 0 0 22px;
  /*max-width: 65ch;*/
}

.course-two-cols {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.82fr);
  gap: 24px;
  align-items: start;
}

.course-editorial {
  display: grid;
  gap: 16px;
}

.course-aside {
  background: var(--course-muted-bg);
  border: 1px solid var(--terracotta-20);
  border-radius: 22px;
  padding: 22px;
}

.course-aside h3,
.course-info-card h3,
.course-formulas__group h3 {
  margin: 0 0 12px;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
}

.course-aside ul,
.course-formula__list {
  margin: 0;
  padding-left: 1.1rem;
}

.course-aside li,
.course-formula__list li {
  margin-bottom: 0.45rem;
  color: var(--ink-80);
}

.course-visual-banner {
  margin-top: 24px;
}

.course-note {
  margin: 18px 0 0;
  padding: 16px 18px;
  border-radius: 18px;
  background: var(--paper-95);
  border: 1px solid var(--terracotta-20);
  font-style: italic;
}

.course-info-bubbles {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  margin: 18px 0 0;
}

.course-info-bubble {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 0;
  padding: 8px 12px;
  border-radius: 18px;
  background: var(--sand-light);
  /*border: 1px solid var(--terracotta-20);*/
  color: var(--ink-90);
  font-size: 0.88rem;
  font-weight: 400;
  line-height: 1.4;
}

.table-shell {
  overflow-x: auto;
  border-radius: 20px;
  background: var(--course-shell-strong);
  border: 1px solid var(--course-line);
}

.course-table,
.pricing-table {
  width: 100%;
  min-width: 780px;
  border-collapse: collapse;
}

.course-table th,
.course-table td,
.pricing-table th,
.pricing-table td {
  border: 1px solid var(--ink-20);
  padding: 14px 14px;
  text-align: center;
  vertical-align: middle;
}

.course-table thead th,
.pricing-table thead th,
.pricing-table .pricing-table__title {
  background: var(--lin-light);
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
  font-family: var(--font-ui);
}

.course-table tbody th,
.pricing-table tbody th {
  background: var(--lin-light);
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
  white-space: nowrap;
  font-family: var(--font-ui);
}

.course-table td:empty {
  background: var(--lin-light);
}

.course-table .course-table__note td {
  font-size: 0.95rem;
  font-weight: 400;
  background: var(--paper-90);
}

.course-table strong,
.pricing-table strong {
  display: inline-block;
  font-size: 1rem;
  letter-spacing: 0.08em;
  font-family: var(--font-ui);
}

.table-footnote {
  margin: 14px 0 0;
  font-size: 0.96rem;
  font-family: var(--font-ui);
}

.course-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.course-info-card {
  background: var(--course-muted-bg);
  border: 1px solid var(--terracotta-20);
  border-radius: 22px;
  padding: 22px;
  display: grid;
  gap: 12px;
}

.course-info-card p {
  margin: 0;
}

.pricing-table tbody tr:nth-child(3) td,
.pricing-table tbody tr:nth-child(3) th {
  background: var(--lin-light);
}

.pricing-table .pricing-table__muted {
  color: var(--ink-70);
  font-size: 0.95rem;
}

.pricing-table .pricing-table__note td {
  font-size: 0.95rem;
  font-weight: 400;
  background: var(--paper-90);
}

.pricing-info-bubbles {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  margin: 18px 0 0;
}

.pricing-info-bubble {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 0;
  padding: 8px 12px;
  border-radius: 18px;
  background: var(--sand-light);
  /*border: 1px solid var(--terracotta-20);*/
  color: var(--ink-90);
  font-size: 0.88rem;
  font-weight: 400;
  line-height: 1.4;
}

.reserver-info-bubbles {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  margin: 18px 0 0;
}

.reserver-info-bubble {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 0;
  padding: 8px 12px;
  border-radius: 18px;
  background: var(--sand-light);
  /*border: 1px solid var(--terracotta-20);*/
  color: var(--ink-90);
  font-size: 0.88rem;
  font-weight: 400;
  line-height: 1.4;
}

.course-formulas {
  display: grid;
  gap: 20px;
}

.course-formulas__group {
  display: grid;
  gap: 18px;
}

.course-formulas__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.course-formula {
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100%;
  background: var(--course-shell-strong);
  border: 1px solid var(--terracotta-20);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.course-formula__media {
  overflow: hidden;
  display: block;
  background: var(--lin-80);
}

#formules .course-formula__media {
  aspect-ratio: auto;
}

#formules .course-formula__media img {
  display: block;
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: unset;
  object-position: center top;
}

#formules .course-formula__media--gift img {
  width: 100%;
  height: auto;
  object-fit: contain;
  padding: 28px;
}

.course-formula__body {
  display: grid;
  align-content: start;
  gap: 14px;
  height: 100%;
  padding: 20px;
}

.course-formula__body h4 {
  margin: 0;
  font-size: 1.34rem;
  line-height: 1.4;
  color: var(--ink);
  text-transform: uppercase;
  font-weight: 400;
}

.course-formula__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.course-chip {
  display: inline-flex;
  align-items: center;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.88rem;
  font-weight: 400;
  background: var(--lin-light);
  color: var(--ink-90);
}

.course-info-bubbles {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  margin: 18px 0 0;
}

.course-info-bubble {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 0;
  padding: 8px 12px;
  border-radius: 18px;
  background: var(--sand-light);
  color: var(--ink-90);
  font-size: 0.88rem;
  font-weight: 400;
  line-height: 1.4;
}

.course-formula__stack {
  display: grid;
  align-content: start;
  gap: 10px;
}

.course-formula__dates {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border-radius: 18px;
  background: var(--lin-60);
}

.course-formula__dates p {
  margin: 0;
}

.course-cta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 22px;
  align-items: center;
  padding: 24px;
  border-radius: 24px;
  background: linear-gradient(135deg, var(--argile-20), var(--lin-90));
  border: 1px solid var(--terracotta-20);
}

.course-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-end;
}

.course-cta__actions .btn {
  min-width: 190px;
}

.course-mini-note {
  margin-top: 14px;
  font-size: 0.95rem;
}

.course-anchor-offset {
  scroll-margin-top: 7rem;
}

@media (max-width: 1080px) {
  .cours-hero__grid,
  .course-two-cols,
  .course-cta {
    grid-template-columns: 1fr;
  }

  .course-info-grid,
  .course-formulas__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .course-cta__actions {
    justify-content: flex-start;
  }
}

@media (max-width: 980px) {
  .hero-blobs--cours {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 30px;
    min-height: auto;
    padding: 18px 0 0;
  }

  .hero-blobs--cours .blob {
    position: relative;
    inset: auto;
    transform: none;
    margin: 0 auto;
    width: var(--blob-tablet-width, min(88vw, 400px));
    max-width: var(--blob-tablet-max-width, 400px);
    min-height: var(--blob-tablet-min-height, 300px);
    aspect-ratio: var(--blob-tablet-ratio, 1 / 1);
    --blob-scale: var(--blob-tablet-scale, 1.12);
  }

  .hero-blobs--cours .blob--course-1 {
    order: 1;
  }

  .hero-blobs--cours .blob--course-2 {
    order: 2;
    --blob-tablet-scale: 1.08;
  }

  .hero-blobs--cours .blob--course-3 {
    order: 3;
  }

  .hero-blobs--cours .blob--course-4 {
    order: 4;
  }
}

@media (max-width: 860px) {
  .course-header .header-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .course-nav {
    justify-content: flex-start;
  }

  .course-info-grid,
  .course-formulas__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .course-nav a {
    padding: 8px 12px;
    font-size: 0.9rem;
  }

  .course-section,
  .course-info-card,
  .course-cta,
  .course-formula {
    border-radius: 22px;
  }

  .course-table,
  .pricing-table {
    min-width: 660px;
  }

  .course-cta__actions .btn {
    width: 100%;
  }
}

@media (max-width: 430px) {
  .hero-blobs--cours {
    gap: 18px;
    padding: 12px 0 0;
  }

  .hero-blobs--cours .blob {
    width: var(--blob-mobile-width, min(82vw, 270px));
    max-width: var(--blob-mobile-max-width, 270px);
    min-height: var(--blob-mobile-min-height, 230px);
    aspect-ratio: var(--blob-mobile-ratio, 1 / 1);
    --blob-scale: var(--blob-mobile-scale, 1.08);
    --blob-padding: 24px 22px;
    --blob-title-size: clamp(0.95rem, 5vw, 1.15rem);
    --blob-text-size: clamp(0.78rem, 4.1vw, 0.98rem);
  }

  .hero-blobs--cours .blob--course-2 {
    --blob-mobile-width: min(86vw, 286px);
    --blob-mobile-max-width: 286px;
    --blob-mobile-min-height: 242px;
    --blob-mobile-scale: 1.04;
  }

  .hero-blobs--cours .blob.blob--course-1,
  .hero-blobs--cours .blob.blob--course-3 {
    --blob-mobile-scale: 1.30;
    --blob-title-size: clamp(0.76rem, 4vw, 0.92rem);
    --blob-text-size: clamp(0.62rem, 3.28vw, 0.78rem);
  }

  .hero-blobs--cours .blob.blob--course-2 {
    --blob-mobile-scale: 1.25;
    --blob-title-size: clamp(0.76rem, 4vw, 0.92rem);
    --blob-text-size: clamp(0.62rem, 3.28vw, 0.78rem);
  }
}

@media (max-width: 380px) {
  .hero-blobs--cours .blob {
    --blob-mobile-width: min(80vw, 252px);
    --blob-mobile-max-width: 252px;
    --blob-mobile-min-height: 218px;
    --blob-padding: 22px 18px;
    --blob-content-gap: 0.45rem;
  }
}

@media (max-width: 360px) {
  .hero-blobs--cours .blob {
    --blob-mobile-width: min(79vw, 242px);
    --blob-mobile-max-width: 242px;
    --blob-mobile-min-height: 210px;
    --blob-title-size: clamp(0.88rem, 4.8vw, 1.05rem);
    --blob-text-size: clamp(0.74rem, 3.9vw, 0.9rem);
  }
}

/* =========================================
   PAGE-COURSE — MOBILE NAV / STACK
========================================= */

.course-menu-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid var(--ink-20);
  background: var(--paper-90);
  color: var(--ink);
  font-size: 0.95rem;
  font-weight: 400;
  cursor: pointer;
}

.course-menu-toggle__icon,
.course-menu-toggle__icon::before,
.course-menu-toggle__icon::after {
  display: block;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transition: transform .18s ease, opacity .18s ease;
}

.course-menu-toggle__icon {
  position: relative;
}

.course-menu-toggle__icon::before,
.course-menu-toggle__icon::after {
  content: "";
  position: absolute;
  left: 0;
}

.course-menu-toggle__icon::before { top: -6px; }
.course-menu-toggle__icon::after { top: 6px; }

.course-menu-toggle[aria-expanded="true"] .course-menu-toggle__icon {
  background: var(--transparent);
}

.course-menu-toggle[aria-expanded="true"] .course-menu-toggle__icon::before {
  transform: translateY(6px) rotate(45deg);
}

.course-menu-toggle[aria-expanded="true"] .course-menu-toggle__icon::after {
  transform: translateY(-6px) rotate(-45deg);
}

@media (max-width: 820px) {
  .site-header.course-header {
    position: sticky;
    top: 0;
  }

  .course-header .header-inner {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 10px 12px;
    min-height: 108px;
    padding: 10px 0;
  }

  .course-header .brand {
    justify-content: flex-start;
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: center;
  }

  .course-header .brand__logo {
    width: 128px;
  }

  .course-menu-toggle {
    display: inline-flex;
    justify-self: end;
  }

  .course-nav {
    display: none;
    grid-column: 1 / -1;
    width: 100%;
    margin-top: 4px;
    padding: 12px;
    border-radius: 18px;
    border: 1px solid var(--ink-10);
    background: var(--paper-95);
    box-shadow: var(--shadow-soft);
  }

  .course-nav.is-open {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .course-nav a,
  .course-nav .course-nav__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 12px;
  }

  .course-main {
    padding: 8px 0 44px;
  }

  .cours-page #presentation {
    padding-bottom: 18px;
  }

  .hero-blobs--cours {
    margin-bottom: 10px;
  }

  .course-stack {
    gap: 18px;
  }

  .course-section {
    padding: 18px;
    border-radius: 22px;
  }

  .course-formulas,
  .course-formulas__group {
    gap: 14px;
  }

  .course-formulas__grid,
  .course-info-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .course-formula {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    height: auto;
    border-radius: 18px;
  }

  .course-formula__media {
    aspect-ratio: 16 / 10;
    width: 100%;
    height: 100%;
  }

  .course-formula__body {
    gap: 10px;
    padding: 16px;
  }

  .course-formula__body h4 {
    font-size: 1rem;
  }

  .course-chip {
    padding: 6px 10px;
    font-size: 0.8rem;
  }

  .course-formula__stack,
  .course-formula__dates {
    gap: 8px;
  }

  .course-formula__stack p,
  .course-formula__list li,
  .course-formula__dates p,
  .course-info-grid .tech-card p,
  .course-cta p,
  .table-footnote {
    font-size: 0.92rem;
    line-height: 1.4;
  }

  .course-formula__dates {
    padding: 12px 14px;
    border-radius: 14px;
  }

  .course-info-grid .tech-card {
    padding: 14px 16px 16px;
  }

  .course-info-grid .tech-card h4 {
    font-size: 1.02rem;
    margin-bottom: 8px;
  }

  .course-cta {
    grid-template-columns: 1fr;
    padding: 18px;
    gap: 14px;
    border-radius: 20px;
  }

  .course-cta__actions {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .course-cta__actions .btn {
    min-width: 0;
    width: 100%;
  }

  .table-shell {
    border-radius: 16px;
    margin-inline: -2px;
  }

  .course-table,
  .pricing-table {
    min-width: 620px;
  }

  .course-table th,
  .course-table td,
  .pricing-table th,
  .pricing-table td {
    padding: 10px 9px;
    font-size: 0.83rem;
    font-weight: 400;
  }
}

@media (max-width: 560px) {
  .container {
    width: min(1120px, calc(100% - 6px));
  }

  .course-header .brand__logo {
    width: 112px;
  }

  .course-menu-toggle {
    min-height: 40px;
    padding: 9px 14px;
    font-size: 0.88rem;
  }

  .course-main {
    padding: 6px 0 32px;
  }

  .cours-page #presentation {
    padding-bottom: 20px;
  }

  .hero-blobs--cours {
    margin-bottom: 12px;
  }

  .course-stack {
    gap: 14px;
  }

  .course-section {
    padding: 14px;
    border-radius: 18px;
  }

  .course-section__lead {
    margin-bottom: 14px;
    font-size: 0.92rem;
  }

  .course-formulas,
  .course-formulas__group,
  .course-formulas__grid,
  .course-info-grid {
    gap: 12px;
  }

  .course-formula {
    border-radius: 16px;
  }

  .course-formula__media {
    aspect-ratio: 16 / 10;
    width: 100%;
    height: 100%;
  }

  .course-formula__body {
    padding: 13px;
    gap: 8px;
  }

  .course-formula__body h4 {
    font-size: 0.95rem;
  }

  .course-chip {
    font-size: 0.76rem;
    padding: 5px 9px;
  }

  .course-formula__stack,
  .course-formula__dates {
    gap: 6px;
  }

  .course-formula__stack p,
  .course-formula__list li,
  .course-formula__dates p,
  .course-info-grid .tech-card p,
  .course-cta p,
  .table-footnote {
    font-size: 0.88rem;
    line-height: 1.4;
  }

  .course-formula__dates {
    padding: 10px 12px;
    border-radius: 12px;
  }

  .course-info-grid .tech-card {
    padding: 13px 14px 14px;
  }

  .course-info-grid .tech-card h4 {
    font-size: 0.98rem;
    margin-bottom: 7px;
  }

  .course-cta {
    padding: 14px;
    gap: 12px;
    border-radius: 18px;
  }

  .course-table,
  .pricing-table {
    min-width: 560px;
  }
}

/* =========================================
   COMPONENTS — PRICING TABLES
========================================= */

.table-shell--mobile,
.table-mobile-stack {
  display: none;
}

.course-table,
.pricing-table {
  table-layout: fixed;
}

.course-table th,
.course-table td,
.pricing-table th,
.pricing-table td {
  overflow-wrap: anywhere;
}

/* =========================================
   COMPONENTS — PRICING TABLES (MOBILE FIX)
========================================= */

@media (max-width: 820px) {
  .table-shell--desktop {
    display: none;
  }

  .table-shell--mobile {
    display: block;
    width: 100%;
    overflow-x: hidden; /* Évite le scroll horizontal parasite */
  }

  .table-mobile-stack {
    display: grid;
    gap: 12px;
  }

  .course-table--mobile,
  .pricing-table--mobile {
    width: 100% !important;
    min-width: auto !important; /* Annule le forçage à 620px/780px */
    table-layout: auto !important; /* Laisse les colonnes s'ajuster au texte */
  }

  .course-table--mobile th,
  .course-table--mobile td,
  .pricing-table--mobile th,
  .pricing-table--mobile td {
    padding: 8px 4px !important; /* Réduit l'espace interne pour gagner de la place */
    font-size: 0.78rem !important; /* Ajustement pour la lisibilité */
    text-align: center;
    vertical-align: middle;
    font-weight: 400;
    line-height: 1.4;
    word-break: normal;
  }

  /* Style des en-têtes de lignes (Mardi, Mercredi...) */
  .course-table--mobile tbody th {
    background: var(--lin);
    color: var(--ink);
    font-weight: 900;
    text-align: left !important;
    padding-left: 8px !important;
    white-space: nowrap; /* Empêche le nom du jour de passer sur 2 lignes */
  }

  .course-table--mobile thead th:first-child {
    background: var(--lin);
  }

  .course-table--mobile thead th:not(:first-child) {
    background: var(--ficelle);
    font-weight: 900;
  }

  .pricing-table--mobile .pricing-table__title {
    font-size: 0.75rem;
    line-height: 1.4;
    padding: 10px 4px !important;
  }

  .table-footnote--pricing-mobile {
    margin-top: 0;
  }
}

@media (max-width: 560px) {
  .table-mobile-stack {
    gap: 10px;
  }

  .course-table--mobile th,
  .course-table--mobile td,
  .pricing-table--mobile th,
  .pricing-table--mobile td {
    padding: 6px 3px !important; /* Très compact pour les petits écrans */
    font-size: 0.70rem !important; /* Taille minimale pour rester lisible */
    letter-spacing: -0.01em;
  }

  .pricing-table--mobile .pricing-table__title {
    font-size: 0.65rem;
  }
  
  /* Optionnel : réduire l'heure pour qu'elle ne pousse pas la cellule */
  .course-table--mobile strong {
    font-size: 0.70rem !important;
    font-weight: 800;
  }
}

/* =========================================
   COMPONENTS — EDITORIAL HERO / FEATURE
========================================= */

.editorial-feature {
  padding: clamp(34px, 5vw, 56px) 0 18px;
}

.editorial-feature__shell {
  display: grid;
  gap: 24px;
}

.editorial-feature__media {
  margin: 0;
  overflow: hidden;
  border-radius: calc(var(--radius) + 10px);
  border: 1px solid var(--ink-10);
  box-shadow: var(--shadow-soft);
  background: var(--paper-90);
}

.editorial-feature__media img {
  display: block;
  width: 100%;
  height: auto;
  margin-top: -120px;
  margin-bottom: -190px;
}

.editorial-feature__panel {
  position: relative;
  z-index: 2;
  width: min(920px, calc(100% - 32px));
  margin: 0 auto;
  padding: clamp(24px, 3.4vw, 38px);
  text-align: center;
  background: var(--course-shell-strong);
  border: 1px solid var(--course-line);
  border-radius: 28px;
  box-shadow: var(--shadow-soft);
}

.editorial-feature__panel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: min(140px, 28%);
  height: 5px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--argile), var(--ficelle));
  transform: translate(-50%, -50%);
}

.editorial-feature__title {
  margin-bottom: 14px;
}

.editorial-feature__intro {
  display: grid;
  gap: 10px;
  max-width: 58ch;
  margin: 0 auto;
}

.editorial-feature__intro p {
  margin: 0;
  color: var(--ink-80);
}

.editorial-feature__intro p:first-child {
  font-size: clamp(22px, 2.6vw, 34px);
  text-transform: uppercase; 
  line-height: 1.4;
  color: var(--khol);
  font-weight: 500;
}

.editorial-feature__note {
  margin: 18px auto 0;
  max-width: 40ch;
  padding-top: 18px;
  border-top: 1px solid var(--ink-20);
  color: var(--ink-70);
  font-style: italic;
}

.editorial-feature--overlap .editorial-feature__shell {
  gap: 0;
}

.editorial-feature--overlap .editorial-feature__panel {
  margin-top: clamp(-74px, -7vw, -48px);
}

.editorial-feature--stacked .editorial-feature__shell {
  gap: 24px;
}

.editorial-feature--banded .editorial-feature__shell {
  gap: 0;
  overflow: hidden;
  border-radius: calc(var(--radius) + 10px);
  border: 1px solid var(--ink-10);
  box-shadow: var(--shadow-soft);
  background: var(--course-shell-strong);
}

.editorial-feature--banded .editorial-feature__media {
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.editorial-feature--banded .editorial-feature__panel {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: clamp(24px, 3.4vw, 38px) clamp(22px, 4vw, 42px);
  border: 0;
  border-top: 1px solid var(--course-line);
  border-radius: 0;
  box-shadow: none;
  background: var(--paper-90);
}

.editorial-feature--banded .editorial-feature__panel::before {
  display: none;
}

.editorial-feature--banded .editorial-feature__intro,
.editorial-feature--banded .editorial-feature__note {
  max-width: 72ch;
}

.editorial-feature--banded .editorial-feature__note {
  margin-top: 20px;
}

@media (max-width: 820px) {
  .editorial-feature__panel {
    width: min(100%, calc(100% - 20px));
    padding: clamp(20px, 6vw, 28px);
  }

  .editorial-feature--overlap .editorial-feature__panel {
    margin-top: -18px;
  }

  .editorial-feature__intro p:first-child {
    font-size: clamp(20px, 6vw, 28px);
  }

  .editorial-feature--banded .editorial-feature__panel {
    padding: 22px 18px 24px;
  }
}

/* =========================================
   PAGE-COURSE — SIGNUP / MEMBERSHIP
========================================= */

.course-signup-section {
  overflow: hidden;
}

.course-signup-blobs {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 18px;
  margin-top: 16px;
  width: 100%;
}

.course-signup-blobs .blob {
  position: relative;
  flex: 0 0 auto;
}

/* COURS */
.blob--signup-1 {
  width: 31%;
  left: 3%;
  min-height: 360px;
  z-index: 2;
  --blob-scale: 1.50;
}

.blob--signup-2 {
  width: 32%;
  left: -1%;
  min-height: 410px;
  z-index: 3;
  --blob-scale: 1.36;
}

.blob--signup-3 {
  width: 29%;
  left: -4%;
  min-height: 345px;
  z-index: 1;
  --blob-scale: 1.16;
}

/* STAGES */
.blob--signup-4 {
  width: 31%;
  left: 3%;
  min-height: 360px;
  z-index: 3;
  --blob-scale: 1.50;
}

.blob--signup-5 {
  width: 32%;
  left: -1%;
  min-height: 410px;
  z-index: 2;
  --blob-scale: 1.36;
}

.blob--signup-6 {
  width: 29%;
  left: -4%;
  min-height: 345px;
  z-index: 1;
  --blob-scale: 1.12;
}

.course-signup-blobs .blob__inner {
  --blob-padding: 30px 34px;
}

.course-signup-blob__content {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 14px;
  width: 100%;
  max-width: 92%;
  min-height: 100%;
}

.course-signup-blobs .blob__title {
  margin-bottom: 0;
  font-size: var(--blob-title-size, 1.15rem);
  letter-spacing: 0.08em;
}

.course-signup-blobs .blob__text {
  max-width: 95%;
  font-size: var(--blob-text-size, 1rem);
  line-height: var(--blob-text-line-height, 1);
}

.course-signup-blobs .btn {
  margin-top: 4px;
  width: min(100%, 270px);
}

@media (max-width: 1080px) {
  .course-signup-blobs {
    flex-wrap: wrap;
    justify-content: center;
  }

  .blob--signup-1,
  .blob--signup-2,
  .blob--signup-3 {
    width: min(100%, 400px);
    left: auto;
  }

  .blob--signup-2 {
    min-height: 380px;
  }

  .blob--signup-4,
  .blob--signup-5,
  .blob--signup-6 {
    width: min(100%, 400px);
    left: auto;
  }

  .blob--signup-5 {
    min-height: 380px;
  }
}

@media (max-width: 680px) {
  .course-signup-blobs {
    gap: 14px;
    margin-top: 12px;
  }

  .blob--signup-1,
  .blob--signup-2,
  .blob--signup-3 {
    min-height: 280px;
  }

  .blob--signup-4,
  .blob--signup-5,
  .blob--signup-6 {
    min-height: 280px;
  }

  .course-signup-blobs .blob__inner {
    --blob-padding: 26px 24px;
  }

  .course-signup-blob__content {
    max-width: 100%;
    gap: 12px;
  }

  .course-signup-blobs .blob__title {
    --blob-title-size: 1rem;
  }

  .course-signup-blobs .blob__text {
    --blob-text-size: 0.92rem;
    --blob-text-line-height: 1.4;
  }
}

@media (max-width: 430px) {
  .course-signup-blobs {
    flex-direction: column;
    align-items: center;
    gap: 18px;
    padding: 12px 0;
  }

  .course-signup-blobs .blob {
    margin: 0 auto;
    width: var(--blob-mobile-width, min(88vw, 300px));
    max-width: var(--blob-mobile-max-width, 300px);
    min-height: var(--blob-mobile-min-height, 260px);
    aspect-ratio: var(--blob-mobile-ratio, 1 / 1);
    --blob-scale: var(--blob-mobile-scale, 1.08);
    --blob-padding: 24px 22px;
    --blob-title-size: clamp(0.92rem, 4.7vw, 1.08rem);
    --blob-text-size: clamp(0.78rem, 4vw, 0.94rem);
  }

  .page-course .course-signup-blobs .blob,
  .page-stage .course-signup-blobs .blob {
    width: var(--blob-mobile-width, min(88vw, 300px));
    max-width: var(--blob-mobile-max-width, 300px);
    min-height: var(--blob-mobile-min-height, 260px);
    --blob-scale: var(--blob-mobile-scale, 1.08);
  }

  /*.course-signup-blobs .blob--signup-2,
  .course-signup-blobs .blob--signup-5 {
    --blob-mobile-min-height: 275px;
    --blob-mobile-scale: 1.60;
  }*/

  .course-signup-blobs .blob.blob--signup-1,
  .course-signup-blobs .blob.blob--signup-4 {
    --blob-mobile-scale: 1.46;
    --blob-title-size: clamp(0.74rem, 3.76vw, 0.86rem);
    --blob-text-size: clamp(0.62rem, 3.2vw, 0.75rem);
  }

  .course-signup-blobs .blob.blob--signup-3,
  .course-signup-blobs .blob.blob--signup-6 {
    --blob-mobile-scale: 1.26;
    --blob-title-size: clamp(0.74rem, 3.76vw, 0.86rem);
    --blob-text-size: clamp(0.62rem, 3.2vw, 0.75rem);
  }

  .course-signup-blobs .blob.blob--signup-2,
  .course-signup-blobs .blob.blob--signup-5 {
    --blob-mobile-min-height: 275px;
    --blob-mobile-scale: 1.60;
    --blob-title-size: clamp(0.74rem, 3.76vw, 0.86rem);
    --blob-text-size: clamp(0.62rem, 3.2vw, 0.75rem);
  }
}

@media (max-width: 380px) {
  .course-signup-blobs .blob {
    --blob-mobile-width: min(86vw, 278px);
    --blob-mobile-max-width: 278px;
    --blob-mobile-min-height: 244px;
    --blob-padding: 22px 18px;
  }

  .page-course .course-signup-blobs .blob,
  .page-stage .course-signup-blobs .blob {
    width: var(--blob-mobile-width, min(86vw, 278px));
    max-width: var(--blob-mobile-max-width, 278px);
    min-height: var(--blob-mobile-min-height, 244px);
  }
}

@media (max-width: 360px) {
  .course-signup-blobs .blob {
    --blob-mobile-width: min(84vw, 262px);
    --blob-mobile-max-width: 262px;
    --blob-mobile-min-height: 232px;
    --blob-title-size: clamp(0.86rem, 4.6vw, 1rem);
    --blob-text-size: clamp(0.72rem, 3.8vw, 0.86rem);
  }

  .page-course .course-signup-blobs .blob,
  .page-stage .course-signup-blobs .blob {
    width: var(--blob-mobile-width, min(84vw, 262px));
    max-width: var(--blob-mobile-max-width, 262px);
    min-height: var(--blob-mobile-min-height, 232px);
  }
}

/* Sécurité extrême uniquement pour les viewports CSS inférieurs à 300px. */
@media (max-width: 300px) {
  .hero-blobs--infos .blob,
  .hero-blobs--stage .blob,
  .hero-blobs--cours .blob,
  .course-signup-blobs .blob,
  .atelier-practice-blobs .blob,
  .contact-blobs .blob {
    --blob-mobile-width: min(78vw, 228px);
    --blob-mobile-max-width: 228px;
    --blob-mobile-min-height: 204px;
    --blob-mobile-scale: 1.02;
    --blob-padding: 18px 14px;
    --blob-content-gap: 0.35rem;
    --blob-title-size: 0.82rem;
    --blob-text-size: 0.68rem;
  }

  /* Ajustements ciblés 280 px : fonds trop petits sur maintenance/stage.
     On augmente uniquement le fond du pseudo-élément, sans grossir le texte. */
  .hero-blobs--infos .blob.blob--hero-2 {
    --blob-mobile-width: min(84vw, 236px);
    --blob-mobile-max-width: 236px;
    --blob-mobile-min-height: 216px;
    --blob-mobile-scale: 1.12;
    --blob-bg-inset: -8%;
    --blob-bg-size: contain;
  }

  .hero-blobs--infos .blob.blob--hero-1 {
    --blob-mobile-width: min(84vw, 236px);
    --blob-mobile-max-width: 236px;
    --blob-mobile-min-height: 210px;
    --blob-mobile-scale: 1.14;
    --blob-bg-inset: -8%;
    --blob-bg-size: contain;
  }

  .hero-blobs--stage .blob.blob--stage-3 {
    --blob-mobile-width: min(84vw, 236px);
    --blob-mobile-max-width: 236px;
    --blob-mobile-min-height: 204px;
    --blob-mobile-scale: 1.10;
    --blob-bg-inset: -18%;
    --blob-bg-size: contain;
  }

  /* Harmonisation cours <= 300px :
     les 3 blobs d'introduction et les 3 blobs de réservation
     partagent le même ratio texte/fond. */
  .page-course .hero-blobs--cours .blob,
  .cours-page .hero-blobs--cours .blob,
  .page-course .course-signup-blobs .blob,
  .cours-page .course-signup-blobs .blob {
    --blob-title-size: 0.74rem;
    --blob-text-size: 0.60rem;
    --blob-title-line-height: 1.4;
    --blob-text-line-height: 1.4;
    --blob-content-gap: 0.28rem;
  }

  .page-course .hero-blobs--cours .blob__inner > *,
  .cours-page .hero-blobs--cours .blob__inner > *,
  .page-course .course-signup-blobs .course-signup-blob__content,
  .cours-page .course-signup-blobs .course-signup-blob__content {
    max-width: 84%;
  }

  .page-course .hero-blobs--cours .blob__text,
  .cours-page .hero-blobs--cours .blob__text,
  .page-course .course-signup-blobs .blob__text,
  .cours-page .course-signup-blobs .blob__text {
    max-width: 100%;
  }

  .page-course .course-signup-blobs .blob__inner .btn-blob,
  .cours-page .course-signup-blobs .blob__inner .btn-blob {
    padding: 4px 8px;
    font-size: 0.60rem;
    line-height: 1.4;
  }

  .blob__list {
    width: 100%;
    gap: 4px;
  }

  .blob__inner .btn,
  .blob__inner .btn-blob {
    min-height: 0;
    padding: 5px 10px;
    font-size: 0.68rem;
    line-height: 1.4;
  }
}

/* =========================================================
   HEADER / MENU 2 NIVEAUX — VERSION SIMPLIFIÉE
   Remplace les anciens blocs de correction du header ajoutés en bas du fichier.
========================================================= */

/* Header partagé — pages internes */
.course-header {
  border-bottom: 1px solid var(--ink-10);
}

.course-header .header-inner {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 18px 24px;
  padding: 14px 0;
}

.course-header .brand {
  grid-column: 1;
  grid-row: 1 / span 2;
  align-self: center;
}

.course-header .course-nav-group {
  grid-column: 2;
  min-width: 0;
  display: grid;
  align-content: center;
  gap: 12px;
  width: 100%;
  align-self: center;
}

.course-header .course-nav {
  width: 100%;
}

.course-header .course-nav a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  border-radius: 999px;
  border: 1px solid var(--ink-20);
  background: var(--white);
  color: var(--argile);
  text-decoration: none;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.4;
}

.course-header .course-nav a:hover,
.course-header .course-nav a:focus-visible {
  border-color: var(--ink-20);
  background: var(--white);
}

.course-header .course-nav .course-nav__cta,
.course-header .course-nav .is-current {
  background: var(--argile);
  color: var(--white);
  border-color: var(--ink-10);
  box-shadow: none;
}

.course-header .course-nav .course-nav__cta:hover,
.course-header .course-nav .course-nav__cta:focus-visible,
.course-header .course-nav .is-current:hover,
.course-header .course-nav .is-current:focus-visible {
  background: var(--argile);
  border-color: var(--transparent);
}

/* Header interne — version desktop */
@media (min-width: 821px) {
  .course-header .header-inner {
    min-height: 132px;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
  }

  .course-header .brand {
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: center;
  }

  .course-header .course-nav-group {
    grid-column: 2;
    grid-row: 1 / span 2; /* le menu prend toute la hauteur du header */
    min-width: 0;
    display: flex;
    align-items: center;   /* centrage vertical réel */
    width: 100%;
    height: 100%;
    padding-top: 14px;
    align-self: center;
  }

  .course-header .course-nav {
    width: 100%;
    margin: 0;
  }

  .course-header .course-nav--primary,
  .course-header .course-nav--secondary {
    display: grid;
    grid-template-columns: repeat(var(--nav-cols, 5), minmax(0, 1fr));
    align-items: center;
    width: 100%;
  }

  .course-header .course-nav--primary {
    gap: 12px;
  }

  .course-header .course-nav--secondary {
    gap: 10px;
  }

  .course-header .course-nav--primary a {
    min-height: 44px;
    padding: 10px 14px;
    font-size: 0.95rem;
    letter-spacing: 0.05em;
  }

  .course-header .course-nav--secondary a {
    min-height: 34px;
    padding: 6px 10px;
    font-size: 0.82rem;
    letter-spacing: 0.04em;
  }
}

/* Header interne — version mobile */
@media (max-width: 820px) {
  .course-header .header-inner {
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 10px 12px;
    padding: 10px 0;
  }

  .course-header .brand {
    grid-column: 1;
    grid-row: 1;
  }

  .course-header .brand__logo {
    width: 128px;
  }

  .course-header .course-menu-toggle {
    display: inline-flex;
    justify-self: end;
    grid-column: 2;
    grid-row: 1;
  }

  .course-header .course-nav-group {
    display: none;
    grid-column: 1 / -1;
    width: 100%;
    margin-top: 4px;
    padding: 12px;
    border-radius: 18px;
    border: 1px solid var(--ink-10);
    background: var(--paper-95);
    box-shadow: var(--shadow-soft);
    gap: 12px;
  }

  .course-header .course-nav-group.is-open {
    display: grid;
  }

  .course-header .course-nav {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .course-header .course-nav + .course-nav {
    padding-top: 12px;
    border-top: 1px solid var(--ink-10);
  }

  .course-header .course-nav a {
    min-height: 42px;
    padding: 10px 12px;
    font-size: 0.9rem;
    letter-spacing: 0.04em;
  }
}

/* =========================================
   SHARED PAGES — WORKSHOP / PROFILE / CONTACT
========================================= */

.about-download {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.about-download__icon {
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  display: block;
}

.about-page .about-feature__media {
  aspect-ratio: 16 / 7;
}

.about-page .about-feature__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  margin: 0;
}

.about-page .about-feature__media--portrait {
  aspect-ratio: 16 / 8.6;
}

.about-page .about-feature__media--portrait img {
  object-position: center 32%;
}

.about-page .about-feature__media--atelier img {
  object-position: center 46%;
}

.about-page .about-feature__media--contact img {
  object-position: center 38%;
}

.about-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 14px;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--argile-10);
  border: 1px solid var(--terracotta-20);
  color: var(--ink-80);
  font-size: 0.92rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.about-two-cols {
  display: grid;
  /*grid-template-columns: minmax(0, 1.12fr) minmax(290px, 0.88fr);*/
  grid-template-columns: minmax(0, 1.3fr) minmax(260px, 0.7fr);
  gap: 24px;
  align-items: start;
}

.atelier-two-cols {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(290px, 0.88fr);
  /*grid-template-columns: minmax(0, 1.3fr) minmax(260px, 0.7fr);*/
  gap: 24px;
  align-items: start;
}

.about-rich-text {
  display: grid;
  gap: 14px;
}

.about-rich-text p {
  margin: 0;
  /* color: var(--terra); */
  color: var(--ink-80);
}

.about-rich-text h3 {
  margin: 0 0 12px;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
}

.about-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.about-card {
  padding: 22px;
  border-radius: 24px;
  background: var(--course-shell-strong);
  border: 1px solid var(--terracotta-20);
  box-shadow: var(--shadow-soft);
}

.about-card h3,
.about-card h4 {
  margin: 0 0 10px;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
}

.about-card p,
.about-card li {
  color: var(--ink-80);
}

.about-card p:last-child {
  margin-bottom: 0;
}

.about-card ul {
  margin: 0;
  padding-left: 1.1rem;
}

.about-card li + li {
  margin-top: 0.45rem;
}

.about-mission-list {
  display: grid;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.about-mission-list li {
  position: relative;
  margin: 0;
  padding: 18px 18px 18px 54px;
  border-radius: 20px;
  background: var(--paper-90);
  border: 1px solid var(--terracotta-20);
  box-shadow: var(--shadow-soft);
  color: var(--ink-80);
}

.about-mission-list li::before {
  content: counter(about-missions);
  counter-increment: about-missions;
  position: absolute;
  left: 16px;
  top: 16px;
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--argile);
  color: var(--white);
  font-size: 0.82rem;
  font-weight: 900;
}

.about-missions {
  counter-reset: about-missions;
}

.about-download {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
  padding: 12px 16px;
  border-radius: 18px;
  background: var(--lin-80);
  border: 1px solid var(--terracotta-20);
  text-decoration: none;
}

.about-download strong {
  letter-spacing: 0.03em;
}

.about-info-stack {
  display: grid;
  gap: 18px;
}

.about-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
}

.about-stat {
  display: grid;
  gap: 6px;
  padding: 20px;
  border-radius: 22px;
  background: var(--course-muted-bg);
  border: 1px solid var(--terracotta-20);
}

.about-stat__value {
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  line-height: 1.4;
  color: var(--terracotta);
  font-weight: 500;
}

.about-stat__label {
  color: var(--ink-80);
}

.about-gallery-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 18px;
}

.about-gallery-card {
  grid-column: span 4;
  margin: 0;
  overflow: hidden;
  border-radius: 24px;
  background: var(--course-shell-strong);
  border: 1px solid var(--terracotta-20);
  box-shadow: var(--shadow-soft);
}

.about-gallery-card--wide {
  grid-column: span 6;
}

.about-gallery-card img {
  display: block;
  width: 100%;
  height: 100%;
  /*aspect-ratio: 1 / 1;*/
  object-fit: cover;
}

.about-gallery-card--wide img {
  aspect-ratio: 1 / 1;
}

.about-gallery-card figcaption {
  padding: 12px 14px 14px;
  color: var(--ink-80);
  font-size: 0.92rem;
}

.about-split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.about-profil-page #parcours .about-split {
  margin-top: 24px;
}

.about-highlight {
  padding: 24px;
  border-radius: 24px;
  background: linear-gradient(135deg, var(--argile-20), var(--lin-90));
  border: 1px solid var(--terracotta-20);
}

.about-highlight h3 {
  margin: 0 0 10px;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--terra);
  font-weight: 900;
}

.about-highlight p,
.about-highlight li {
  margin: 0;
  color: var(--ink-80);
}

.about-highlight ul {
  margin: 0;
  padding-left: 1.1rem;
  display: grid;
  gap: 0.45rem;
}

.contact-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  align-items: start;
}

.contact-section-intro {
  margin: 0 0 18px;
}

.contact-section-intro p {
  margin: 0;
  color: var(--ink-80);
}

.contact-form-card,
.contact-map-card,
.contact-address-card {
  background: var(--course-shell-strong);
  border: 1px solid var(--terracotta-20);
  border-radius: 24px;
  box-shadow: var(--shadow-soft);
}

.contact-form-card {
  padding: 24px;
}

.contact-form-intro {
  display: grid;
  gap: 8px;
  margin: 0 0 20px;
}

.contact-form-intro p {
  margin: 0;
}

.contact-form-card h3,
.contact-map-card h3,
.contact-address-card h3 {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.4;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
}

.contact-direct-band {
  display: grid;
  gap: 12px;
  margin: 0 0 22px;
  padding: 16px 18px;
  border-radius: 20px;
  background: var(--paper-95);
  border: 1px solid var(--terracotta-20);
}

.contact-direct-band__title {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.4;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
}

.contact-direct-band__text {
  margin: 0;
  color: var(--ink-80);
}

.contact-direct-band .reveal-group,
.contact-direct-band .reveal-btn,
.contact-direct-band .reveal-link {
  width: auto;
  min-width: 180px;
}

.contact-social-band {
  display: grid;
  gap: 12px;
  margin: 0 0 22px;
  padding: 16px 18px;
  border-radius: 20px;
  background: var(--paper-95);
  border: 1px solid var(--terracotta-20);
}

.contact-social-band__title {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.4;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
}

.contact-social-band__links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
}

.contact-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 14px;
  border-radius: 999px;
  text-decoration: none;
  background: var(--lin-light);
  border: 1px solid var(--ink-10);
  color: var(--khol);
}

.contact-social-link:hover,
.contact-social-link:focus-visible {
  background: var(--paper-95);
  border-color: var(--ink-20);
}

.contact-form {
  display: grid;
  gap: 16px;
}

.contact-form__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.contact-form__row--phone-subject {
  grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
}

.contact-field {
  display: grid;
  gap: 7px;
}

.contact-field label {
  font-size: 0.88rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
}

.contact-field input,
.contact-field textarea,
.contact-field select {
  width: 100%;
  appearance: none;
  border: 1px solid var(--terracotta-20);
  border-radius: 16px;
  padding: 13px 14px;
  background: var(--paper-95);
  color: var(--ink);
  font-size: 0.98rem;
  line-height: 1.4;
}

.contact-field textarea {
  min-height: 215px;
  resize: vertical;
}

.contact-field input:focus,
.contact-field textarea:focus,
.contact-field select:focus {
  outline: none;
  border-color: var(--terracotta-40);
  box-shadow: 0 0 0 4px var(--argile-10);
}

.contact-form__actions {
  padding: 16px 18px 18px;
  display: grid;
  gap: 10px;
  align-items: center;
}

.contact-form__actions .reveal-group,
.contact-form__actions .reveal-btn,
.contact-form__actions .reveal-link {
  width: auto;
}

.contact-form__note,
.contact-submit-feedback {
  margin: 0;
  color: var(--ink-70);
  font-size: 0.92rem;
}

.contact-submit-feedback[hidden] {
  display: none;
}

.contact-side {
  display: grid;
  gap: 18px;
}

.contact-map-card {
  overflow: hidden;
}

.contact-map-card__intro {
  padding: 22px 22px 0;
  margin-bottom: 16px;
}

.contact-map-card img {
  display: block;
  width: 100%;
  height: auto;
}

.contact-map-card__body {
  padding: 16px 18px 18px;
  display: grid;
  gap: 10px;
}

.contact-map-card__body p {
  margin: 0;
}

.contact-map-card__meta {
  margin: 0;
  color: var(--ink-70);
  font-size: 0.92rem;
}

.contact-address-card {
  padding: 22px;
  display: grid;
  gap: 14px;
}

.contact-address-card p {
  margin: 0;
}

.contact-address-card .reveal-group,
.contact-address-card .reveal-link,
.contact-address-card .reveal-btn {
  width: 100%;
}

.contact-address-card .reveal-btn,
.contact-address-card .reveal-link {
  justify-content: center;
}

.about-inline-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.about-inline-links .btn,
.about-inline-links .reveal-group {
  width: auto;
}

.about-note-band {
  display: grid;
  gap: 16px;
  padding: 24px;
  border-radius: 24px;
  background: var(--lin-60);
  border: 1px solid var(--terracotta-20);
}

.about-note-band p {
  margin: 0;
}

@media (max-width: 1080px) {
  .about-two-cols,
  .contact-layout,
  .about-card-grid,
  .about-split {
    grid-template-columns: 1fr;
  }

  .about-gallery-card,
  .about-gallery-card--wide {
    grid-column: span 6;
  }
}

@media (max-width: 820px) {
  .about-page .about-feature__media,
  .about-page .about-feature__media--portrait {
    aspect-ratio: 16 / 10;
  }

  .contact-form__row {
    grid-template-columns: 1fr;
  }

  .about-gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-gallery-card,
  .about-gallery-card--wide {
    grid-column: auto;
  }
}

@media (max-width: 560px) {
  .about-card,
  .contact-form-card,
  .contact-address-card,
  .about-highlight,
  .about-note-band {
    padding: 18px;
    border-radius: 18px;
  }

  .contact-direct-band {
    grid-template-columns: 1fr;
  }

  .contact-direct-band .reveal-group,
  .contact-direct-band .reveal-btn,
  .contact-direct-band .reveal-link {
    width: 100%;
  }

  .about-gallery-grid {
    grid-template-columns: 1fr;
  }

  .about-gallery-card img,
  .about-gallery-card--wide img {
    aspect-ratio: 1 / 1;
  }

  .contact-form__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .contact-form__actions .btn {
    margin: 0;
    width: 100%;
  }
}

/* =========================================
   PAGE-CONTACT — ASSOCIATION / VALUES
========================================= */

.about-association-section {
  overflow: hidden;
}

.about-association-stack {
  display: grid;
  gap: 26px;
}

.about-missions-panel {
  display: grid;
  gap: 18px;
}

.about-missions-panel__header {
  display: grid;
  gap: 8px;
}

.about-missions-panel__header p {
  margin: 0;
  color: var(--ink-80);
}

.about-mission-list--split {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
}

.about-download--full {
  width: 100%;
  justify-content: center;
  margin-top: 0;
}

.about-values-panel {
  display: grid;
  gap: 16px;
}

.about-values-panel > h2 {
  margin-bottom: 0;
}

.about-values-blobs {
  margin-top: 0;
}

.about-values-blobs .blob__title {
  max-width: 90%;
}

.about-values-blobs .blob__text {
  max-width: 92%;
}

@media (max-width: 900px) {
  .about-mission-list--split {
    grid-template-columns: 1fr;
  }
}

/* =========================================
   PAGE-HOME — CORE
========================================= */

.home-main {
  padding: 10px 0 10px;
}

.home-stack {
  display: grid;
  gap: 26px;
}

.home-section {
  background: var(--course-shell);
  border: 1px solid var(--course-line);
  border-radius: 28px;
  padding: clamp(24px, 3.6vw, 38px);
  box-shadow: var(--shadow-soft);
}

.home-feature-header {
  margin-bottom: 12px;
}

.home-section__lead {
  margin: 0 0 22px;
  /*max-width: 65ch;*/
}

.home-two-cols {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.82fr);
  gap: 24px;
  align-items: start;
}

.home-editorial {
  display: grid;
  gap: 16px;
}

.home-aside {
  background: var(--course-muted-bg);
  border: 1px solid var(--terracotta-20);
  border-radius: 22px;
  padding: 22px;
}

.home-aside h3,
.home-info-card h3,
.home-formulas__group h3 {
  margin: 0 0 12px;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
}

.home-aside ul,
.home-formula__list {
  margin: 0;
  padding-left: 1.1rem;
}

.home-aside li,
.home-formula__list li {
  margin-bottom: 0.45rem;
  color: var(--ink-80);
}

.home-visual-banner {
  margin-top: 24px;
}

.home-note {
  margin: 18px 0 0;
  padding: 16px 18px;
  border-radius: 18px;
  background: var(--paper-95);
  border: 1px solid var(--terracotta-20);
  font-style: italic;
}

.home-info-bubbles {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  margin: 18px 0 0;
}

.home-info-bubble {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 0;
  padding: 8px 12px;
  border-radius: 18px;
  background: var(--sand-light);
  /*border: 1px solid var(--terracotta-20);*/
  color: var(--ink-90);
  font-size: 0.88rem;
  font-weight: 400;
  line-height: 1.4;
}

.home-formulas {
  display: grid;
  gap: 20px;
}

.home-formulas__group {
  display: grid;
  gap: 18px;
}

.home-formulas__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.home-formula__media {
  grid-column: span 4;
  margin: 0;
  overflow: hidden;
  border-radius: 24px;
  background: var(--course-shell-strong);
  border: 1px solid var(--terracotta-20);
  box-shadow: var(--shadow-soft);
}

.home-formula__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.home-formula__media--gift img {
  object-fit: contain;
  padding: 28px;
}

.home-gallery-card {
  grid-column: span 4;
  margin: 0;
  overflow: hidden;
  border-radius: 24px;
  background: var(--course-shell-strong);
  border: 1px solid var(--terracotta-20);
  box-shadow: var(--shadow-soft);
}

.home-formula__body {
  display: grid;
  align-content: start;
  gap: 14px;
  height: 100%;
  padding: 20px;
}

.home-formula__body h4 {
  margin: 0;
  font-size: 1.34rem;
  line-height: 1.4;
  color: var(--ink);
  text-transform: uppercase;
  font-weight: 400;
}

.home-formula__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.home-chip {
  display: inline-flex;
  align-items: center;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.88rem;
  font-weight: 400;
  background: var(--lin-light);
  color: var(--ink-90);
}

.home-info-bubbles {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  margin: 18px 0 0;
}

.home-info-bubble {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 0;
  padding: 8px 12px;
  border-radius: 18px;
  background: var(--sand-light);
  color: var(--ink-90);
  font-size: 0.88rem;
  font-weight: 400;
  line-height: 1.4;
}

.home-formula__stack {
  display: grid;
  align-content: start;
  gap: 10px;
}

.home-formula__dates {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border-radius: 18px;
  background: var(--lin-60);
}

.home-formula__dates p {
  margin: 0;
}

.home-cta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 22px;
  align-items: center;
  padding: 24px;
  border-radius: 24px;
  background: linear-gradient(135deg, var(--argile-20), var(--lin-90));
  border: 1px solid var(--terracotta-20);
}

.home-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-end;
}

.home-cta__actions .btn {
  min-width: 190px;
}

.home-mini-note {
  margin-top: 14px;
  font-size: 0.95rem;
}

.home-anchor-offset {
  scroll-margin-top: 7rem;
}

/* --- */

.accueil-galerie-intro {
  display: grid;
  gap: 8px;
  margin: 0 0 20px;
}

.accueil-galerie-intro p {
  margin: 0;
}

.accueil-galerie-title {
  font-size: 0.88rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
}

.accueil-news-intro {
  display: grid;
  gap: 8px;
  margin: 0 0 20px;
}

.accueil-news-intro p {
  margin: 0;
}

.accueil-news-title {
  font-size: 0.88rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
}

.accueil-page .about-gallery-card {
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100%;
}

.accueil-page .about-gallery-card figcaption {
  display: grid;
  gap: 6px;
  align-content: start;
  min-height: 132px;
}

.accueil-page .about-gallery-card figcaption strong {
  display: block;
  color: var(--terra);
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.4;
  text-transform: uppercase;
}

.accueil-page .about-gallery-card figcaption p {
  margin: 0;
}

@media (max-width: 900px) {
  .accueil-page .about-gallery-card figcaption {
    min-height: 0;
  }
}

/* =========================================
   PAGE-HOME — NEWS
   Modifie uniquement la rubrique "Actualités"
========================================= */

.home-news-section .display-caps {
  margin-bottom: 18px;
}

.home-news-list {
  display: grid;
  gap: 18px;
}

.home-news-item {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(240px, 300px);
  gap: 0;
  align-items: stretch;
  overflow: hidden;
  background: var(--course-shell-strong);
  border: 1px solid var(--terracotta-20);
  border-radius: 24px;
  box-shadow: var(--shadow-soft);
}

.home-news-item__content {
  display: grid;
  align-content: start;
  gap: 16px;
  min-width: 0;
  padding: 22px 24px;
}

.home-news-item__title {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.4;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
}

.home-news-item__text {
  margin: 0;
  color: var(--ink-80);
}

.home-news-item__text a {
  color: var(--terra);
  font-weight: 500;
  text-decoration: none;
}

.home-news-item__text a:hover,
.home-news-item__text a:focus-visible {
  text-decoration: underline;
}

.home-news-item__media {
  margin: 0;
  height: 100%;
}

.home-news-item__media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
}

@media (max-width: 900px) {
  .home-news-item {
    grid-template-columns: 1fr;
  }

  .home-news-item__content {
    padding: 18px 18px 16px;
  }

  .home-news-item__media {
    height: auto;
  }

  .home-news-item__media img {
    width: 100%;
    height: auto;
    min-height: 0;
    /*aspect-ratio: 1 / 1;*/
  }
}

/* =========================================
   COMPONENTS — GALLERY / HOVER
   Ajustement minimal pour les galeries de l’accueil.
========================================= */

.gallery-hover-grid .about-gallery-card[data-gallery-alt]:not(.gallery-card--no-hover)::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: var(--gallery-hover-overlay);
  opacity: 0;
  pointer-events: none;
  z-index: 1;
  transition: opacity .18s ease;
  backface-visibility: hidden;
}

.gallery-hover-grid .about-gallery-card[data-gallery-alt]:not(.gallery-card--no-hover)::before {
  content: attr(data-gallery-alt);
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  text-align: center;
  text-transform: uppercase;
  color: var(--white);
  font-size: 0.92rem;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.06em;
  opacity: 0;
  pointer-events: none;
  z-index: 2;
  transition: opacity .18s ease;
  text-wrap: balance;
  border-radius: inherit;
  backface-visibility: hidden;
}

.gallery-hover-grid .about-gallery-card[data-gallery-alt]:not(.gallery-card--no-hover):hover::after,
.gallery-hover-grid .about-gallery-card[data-gallery-alt]:not(.gallery-card--no-hover):hover::before,
.gallery-hover-grid .about-gallery-card[data-gallery-alt]:not(.gallery-card--no-hover):focus-within::after,
.gallery-hover-grid .about-gallery-card[data-gallery-alt]:not(.gallery-card--no-hover):focus-within::before {
  opacity: 1;
}

/* =========================================
   COMPONENTS — GALLERY / CAROUSEL NAV
========================================= */

.gallery-carousel-shell {
  position: relative;
  padding-inline: 0;
  --gallery-side-space: clamp(24px, 3.6vw, 38px);
  --gallery-nav-size: min(30px, var(--gallery-side-space));
  --gallery-gap: 18px;
}

.gallery-carousel-shell .about-gallery-grid {
  margin: 0;
}

.gallery-carousel-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: var(--gallery-nav-size);
  height: var(--gallery-nav-size);
  border: 1px solid var(--transparent);
  border-color: var(--ink-20);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  cursor: pointer;
  color: var(--argile);
  background: var(--paper-90);
  box-shadow: var(--shadow-soft);
  transition: transform .16s ease, background .16s ease, color .16s ease, box-shadow .16s ease;
  z-index: 3;
}

.gallery-carousel-nav:hover,
.gallery-carousel-nav:focus-visible {
  background: var(--white);
  box-shadow: 0 14px 30px var(--terracotta-20);
  border-color: var(--ink-20);
}

.gallery-carousel-nav:active {
  transform: translateY(-50%) scale(0.97);
}

.gallery-carousel-nav svg {
  width: 16px;
  height: 16px;
  display: block;
}

.gallery-carousel-nav--prev {
  left: calc((-1 * var(--gallery-side-space)) + ((var(--gallery-side-space) - var(--gallery-nav-size)) / 2));
}

.gallery-carousel-nav--next {
  right: calc((-1 * var(--gallery-side-space)) + ((var(--gallery-side-space) - var(--gallery-nav-size)) / 2));
}

/* Cas particulier : Céline Lecou -> carte fixe à gauche, navigation sur les 2 images de droite */
.gallery-carousel-shell--fixed-first .gallery-carousel-nav--prev {
  left: calc(33.333% + (var(--gallery-gap) / 3) - (var(--gallery-nav-size) / 2));
}

.gallery-carousel-shell--fixed-first .gallery-carousel-nav--next {
  right: calc((-1 * var(--gallery-side-space)) + ((var(--gallery-side-space) - var(--gallery-nav-size)) / 2));
}

@media (max-width: 820px) {
  .gallery-carousel-nav {
    display: none;
  }
}

/* =========================================
   COMPONENTS — GALLERY / FIXED FIRST CARD
========================================= */

.gallery-carousel-shell--fixed-first {
  --gallery-gap: 18px;
}

.gallery-carousel-shell--fixed-first .gallery-carousel-nav--prev {
  left: calc(33.333% + (var(--gallery-gap) / 3) - (var(--gallery-nav-size) / 2));
}

.gallery-carousel-shell--fixed-first .gallery-carousel-nav--next {
  right: calc((-1 * var(--gallery-side-space)) + ((var(--gallery-side-space) - var(--gallery-nav-size)) / 2));
}

@media (max-width: 820px) {
  .gallery-carousel-shell {
    padding-inline: 0;
  }

  .gallery-carousel-nav {
    display: none;
  }
}

/* =========================================
   COMPONENTS — GALLERY / SQUARE MEDIA
   Objectif :
   - galeries et actualités en vrai carré
   - masque arrondi conservé
   - exception carte de visite à coins carrés
   - aucune modification du contenu HTML
========================================= */

/* Cartes de galeries : carré réel, plus aérées sans créer de bordure */
.about-gallery-grid .about-gallery-card {
  display: block;
  position: relative;
  width: 96%;
  aspect-ratio: 1 / 1;
  justify-self: center;
  align-self: start;
  overflow: hidden;
  border-radius: 24px;
  isolation: isolate;
  padding: 0;
  transform: translateZ(0);
}

.about-gallery-grid .about-gallery-card img {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  object-fit: cover;
  object-position: center;
  border-radius: inherit;
}

.about-gallery-grid .about-gallery-card figcaption {
  display: none;
}

/* Actualités : image carrée alignée sur le gabarit des galeries, sans faux liseré */
.home-news-item {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 352px);
  gap: 18px;
}

.home-news-item__media {
  position: relative;
  width: min(96%, 352px);
  max-width: 352px;
  aspect-ratio: 1 / 1;
  height: auto;
  min-height: 0;
  align-self: center;
  justify-self: end;
  overflow: hidden;
  border-radius: 24px;
  padding: 0;
}

.home-news-item__media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  aspect-ratio: auto;
  object-fit: cover;
  object-position: center;
  border-radius: inherit;
}

/* Profil — image du parcours alignée sur le gabarit des galeries, sans bordure interne */
.about-profil-page #parcours .about-info-stack .about-gallery-card {
  display: block;
  width: min(96%, 352px);
  aspect-ratio: 1 / 1;
  justify-self: end;
  overflow: hidden;
  border-radius: 24px;
  padding: 0;
}

.about-profil-page #parcours .about-info-stack .about-gallery-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: inherit;
}

/* Carte de visite Céline Lecou : coins carrés, sans masque arrondi */
.about-gallery-grid .gallery-card--no-hover,
.about-gallery-grid .gallery-card--no-hover img,
.about-gallery-grid .gallery-card--no-hover::before,
.about-gallery-grid .gallery-card--no-hover::after {
  border-radius: 0 !important;
}

.about-gallery-grid .gallery-card--no-hover {
  overflow: hidden !important;
}

@media (max-width: 900px) {
  .home-news-item {
    grid-template-columns: 1fr;
  }

  .home-news-item__media {
    width: min(96%, 352px);
    max-width: 352px;
    aspect-ratio: 1 / 1;
    justify-self: start;
  }

  .home-news-item__media img {
    width: 100%;
    height: 100%;
  }

  .about-profil-page #parcours .about-info-stack .about-gallery-card {
    width: min(96%, 352px);
  }
}

/* =========================================
   COMPONENTS — GALLERY / CELINE NAV ADJUST
   Modifie uniquement la galerie Céline Lecou céramique :
   - espace entre images réduit de moitié
   - bouton précédent décalé pour ne plus empiéter sur la 1re image de la zone mobile
========================================= */

.gallery-carousel-shell--fixed-first {
  --gallery-gap: 9px;
}

.gallery-carousel-shell--fixed-first .about-gallery-grid {
  gap: 9px;
}

.gallery-carousel-shell--fixed-first .gallery-carousel-nav--prev {
  left: calc(33.333% + (var(--gallery-gap) / 3) - var(--gallery-nav-size));
}

/* =========================================
   COMPONENTS — GALLERY / FIREFOX FIX
   Objectif :
   - supprimer l’artefact du coin carré au rollover
   - conserver le texte en uppercase
   - laisser le carousel et .gallery-card--no-hover intacts
========================================= */

.gallery-hover-grid .about-gallery-card:not(.gallery-card--no-hover) {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  isolation: isolate;
  clip-path: none;
  contain: layout paint;
}

.gallery-hover-grid .about-gallery-card:not(.gallery-card--no-hover) img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

.gallery-hover-grid .about-gallery-card[data-gallery-alt]:not(.gallery-card--no-hover)::before,
.gallery-hover-grid .about-gallery-card[data-gallery-alt]:not(.gallery-card--no-hover)::after {
  inset: 0;
  border-radius: inherit !important;
  clip-path: inset(0 round 24px);
  transform: translateZ(0);
  will-change: opacity;
}

.gallery-hover-grid .about-gallery-card[data-gallery-alt]:not(.gallery-card--no-hover)::after {
  background: var(--gallery-hover-overlay);
}

/* =========================================
   COMPONENTS — ARTIST FEATURE / CELINE
   Objectif :
   - transformer le bloc Céline Lecou en encart éditorial
   - afficher le logo comme illustration
   - conserver une galerie carrousel de 3 visuels juste en dessous
========================================= */

.celine-feature {
  display: grid;
  gap: 18px;
}

.celine-feature__intro {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}

.celine-feature__media {
  margin: 0;
  width: 96%;
  aspect-ratio: 1 / 1;
  justify-self: center;
  align-self: start;
  overflow: hidden;
  border-radius: 24px;
  background: var(--course-shell-strong);
  border: 1px solid var(--terracotta-20);
  box-shadow: var(--shadow-soft);
}

.celine-feature__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.celine-feature__content {
  grid-column: span 2;
  display: grid;
  gap: 12px;
  align-content: start;
  padding-top: 2px;
}

.celine-feature__content .display-caps {
  margin: 0 0 4px;
}

.celine-feature__content p {
  margin: 0;
  color: var(--ink-80);
}

.celine-feature__gallery {
  margin-top: 0;
}

@media (max-width: 900px) {
  .celine-feature__intro {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .celine-feature__content {
    grid-column: auto;
    padding-top: 0;
  }

  .celine-feature__media {
    width: min(96%, 352px);
    justify-self: center;
  }
}

.stages-page .featured-badge--info-bubble {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin-bottom: 18px;
  padding: 9px 14px;
  border-radius: 999px;
  background: var(--ficelle);
  color: var(--ink);
  font-size: 0.92rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.01em;
}

/* =========================================
   ARCHITECTURE — CSS MAP
   website-all      : base, boutons, blobs, composants partagés
   accueil / home   : hero d’accueil, actualités, galeries
   cours / course   : navigation 2 niveaux, sections cours, tableaux
   stages / stage   : bandeau interne stages, listes de possibilités
   atelier / workshop : bandeau interne atelier
   profil / profile : bandeau interne profil
   contact / contact : bandeau interne contact, formulaire et accès
   website-progress : page index / maintenance
   error-404        : réservé pour future page dédiée
========================================= */

/* =========================================
   PAGE-ALL — INTERNAL HERO / PAGE BANNER
========================================= */

.page-hero {
  padding-bottom: 12px;
}

.page-hero .hero-grid {
  align-items: start;
}

.page-hero__copy {
  display: grid;
  gap: 16px;
  padding: 8px 0 0;
  background: none;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  width: 100%;
  max-width: none;
}

/* Bandeau avec visuel */
.page-hero--split .hero-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: start;
}

.page-hero--split .page-hero__copy > * {
  max-width: 62ch;
}

/* Bandeau sans visuel : texte centré */
.page-hero--full .hero-grid {
  grid-template-columns: minmax(0, 1fr);
}

.page-hero--full .page-hero__copy {
  width: min(100%, 840px);
  margin-inline: auto;
  justify-items: center;
  text-align: center;
}

.page-hero--full .page-hero__copy .display-caps,
.page-hero--full .page-hero__copy h3 {
  text-align: center;
}

/* Bandeau sans visuel */

.page-hero--full .page-hero__visual,
.page-hero--full .page-hero__aside,
.page-hero--full .hero-blobs {
  display: none;
}

.page-hero--full .page-hero__copy > * {
  max-width: none;
}

@media (max-width: 980px) {
  .page-hero--split .hero-grid,
  .page-hero--full .hero-grid {
    grid-template-columns: 1fr;
  }

  .page-hero__copy > * {
    max-width: none;
  }
}

.page-hero__copy .pill,
.page-hero__copy .display-caps,
.page-hero__copy .lead,
.page-hero__copy p {
  margin: 0;
}

.page-hero__lead {
  max-width: 58ch;
}

.page-hero__copy .hero-actions {
  margin: 6px 0 0;
}

.page-hero__copy .course-info-bubbles {
  margin-top: 0;
}

.hero-blobs--page {
  position: relative;
  min-height: 520px;
}

.hero-blobs--page .blob {
  position: absolute;
  height: auto;
}

.hero-blobs--page .blob__inner {
  --blob-padding: 28px 26px;
}

.hero-blobs--page .blob__title {
  max-width: 88%;
  margin-bottom: 10px;
  font-size: var(--blob-title-size, 1.08rem);
  letter-spacing: 0.08em;
}

.hero-blobs--page .blob__text {
  max-width: 84%;
  font-size: var(--blob-text-size, 1rem);
  line-height: var(--blob-text-line-height, 1);
}

.hero-blobs--page .blob--page-1 {
  width: 38%;
  aspect-ratio: 1.04;
  left: 0;
  top: 10%;
  z-index: 2;
  --blob-scale: 1.42;
}

.hero-blobs--page .blob--page-2 {
  width: 49%;
  aspect-ratio: 1.14;
  right: 0;
  top: 0;
  z-index: 1;
  --blob-scale: 1.46;
}

.hero-blobs--page .blob--page-3 {
  width: 44%;
  aspect-ratio: 1.06;
  left: 24%;
  top: 47%;
  z-index: 3;
  --blob-scale: 1.42;
}

@media (max-width: 1080px) {
  .page-hero .hero-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 980px) {
  .hero-blobs--page {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 30px;
    min-height: auto;
    padding: 12px 0 0;
  }

  .hero-blobs--page .blob {
    position: relative;
    width: var(--blob-tablet-width, min(88vw, 400px));
    max-width: var(--blob-tablet-max-width, 400px);
    min-height: var(--blob-tablet-min-height, 300px);
    inset: auto;
    transform: none;
    aspect-ratio: var(--blob-tablet-ratio, 1 / 1);
    --blob-scale: var(--blob-tablet-scale, 1.12);
  }
}

@media (max-width: 680px) {
  .page-hero__copy {
    gap: 14px;
    padding: 0;
    border-radius: 0;
  }

  .hero-blobs--page .blob {
    min-height: var(--blob-tablet-min-height, 270px);
  }
}

@media (max-width: 430px) {
  .hero-blobs--page {
    gap: 18px;
  }

  .hero-blobs--page .blob {
    width: var(--blob-mobile-width, min(82vw, 270px));
    max-width: var(--blob-mobile-max-width, 270px);
    min-height: var(--blob-mobile-min-height, 230px);
    --blob-scale: var(--blob-mobile-scale, 1.08);
    --blob-padding: 24px 22px;
    --blob-title-size: clamp(0.95rem, 5vw, 1.15rem);
    --blob-text-size: clamp(0.78rem, 4.1vw, 0.98rem);
  }
}

@media (max-width: 380px) {
  .hero-blobs--page .blob {
    --blob-mobile-width: min(80vw, 252px);
    --blob-mobile-max-width: 252px;
    --blob-mobile-min-height: 218px;
    --blob-padding: 22px 18px;
  }
}

.stages-page h3:not(.blob__title):not(.panel-title),
.about-atelier-page h3:not(.blob__title):not(.panel-title),
.about-profil-page h3:not(.blob__title):not(.panel-title),
.about-contact-page h3:not(.blob__title):not(.panel-title) {
  margin: 0 0 12px;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--terra);
  font-weight: 900;
}

/* =========================================
   PAGE-STAGE — CORE
========================================= */

.stages-page .stages-possibilities__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.stages-page .stages-list-card {
  height: 100%;
}

.stages-page .stages-list-card h4 {
  margin-bottom: 16px;
  font-size: 1rem;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--terra);
}

.stages-page .stages-list {
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 10px;
  color: var(--ink-80);
}

.stages-page .stages-section-note {
  margin-top: 10px;
}

.stages-page .feature-section {
  padding-top: 0;
}

@media (max-width: 1080px) {
  .stages-page .stages-possibilities__grid {
    grid-template-columns: 1fr;
  }
}

/* =========================================
   FIX INTERNE : STAGE VEDETTE (stages.html)
   Cibles : tech-grid, tech-card et asides
========================================= */

@media (max-width: 980px) {
  /* 1. On passe la grille des techniques en 1 colonne (ou 2 selon la place) */
  .tech-grid {
    grid-template-columns: 1fr !important; /* Force l'empilement vertical */
    gap: 15px !important;
  }

  /* 2. Ajustement des cartes de techniques */
  .tech-card {
    padding: 18px !important;
    border-radius: 18px !important;
  }

  .tech-card h4 {
    font-size: 1.1rem !important;
    margin-bottom: 10px !important;
  }

  .tech-card ul li {
    font-size: 14px !important; /* Texte légèrement plus petit pour éviter les retours à la ligne */
  }

  /* 3. Ajustement de l'encart "Infos pratiques" */
  .featured-aside {
    padding: 20px !important;
    margin-top: 20px !important;
  }

  .info-list {
    grid-template-columns: 1fr !important; /* Empile les icônes d'infos pratiques */
    gap: 18px !important;
  }

  .info-item {
    grid-template-columns: 40px 1fr !important; /* Icônes un peu plus petites */
  }
}

@media (max-width: 680px) {
  /* 4. On réduit les marges internes globales pour éviter que le contenu ne soit trop serré */
  .featured-shell {
    padding: 20px 12px !important;
  }

  /* 5. On aligne les bulles d'info pour qu'elles ne flottent pas bizarrement */
  .course-info-bubbles {
    justify-content: center;
    text-align: center;
  }

  .course-info-bubble {
    font-size: 0.8rem !important;
    width: 100% !important; /* Prend toute la largeur pour une meilleure lecture */
  }
}

/* 6. Optimisation ultra-mobile < 300px */
@media (max-width: 300px) {
  .tech-card h4 {
    font-size: 1rem !important;
  }

  .info-strong {
    font-size: 13px !important;
  }

  .info-soft {
    font-size: 12px !important;
  }
}

/* =========================================
   PAGE-WORKSHOP — HERO ADJUSTMENTS
========================================= */

.page-hero--atelier .blob--page-1 {
  top: 12%;
}

/* =========================================
   PAGE-WORKSHOP — ATELIER EN PRATIQUE
   Layout proche de la rubrique stage vedette
========================================= */

.atelier-practice-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(350px, .98fr);
  gap: 34px;
  align-items: start;
}

.atelier-practice-blobs {
  position: relative;
  min-height: 320px;
}

.atelier-practice-blobs .blob {
  position: absolute;
  height: auto;
}

.atelier-practice-blobs .blob--atelier-practice-1 { order: 2; }
.atelier-practice-blobs .blob--atelier-practice-2 { order: 1; }
.atelier-practice-blobs .blob--atelier-practice-3 { order: 3; }

.atelier-practice-blobs .blob--atelier-practice-1 {
  width: 32%;
  aspect-ratio: 1;
  left: 4%;
  top: 42%;
  z-index: 2;
  --blob-scale: 1.45;
}

.atelier-practice-blobs .blob--atelier-practice-2 {
  width: 40%;
  aspect-ratio: 1.15;
  left: 44%;
  top: 0;
  transform: translateX(-50%);
  z-index: 1;
  --blob-scale: 1.60;
}

.atelier-practice-blobs .blob--atelier-practice-3 {
  width: 40%;
  aspect-ratio: 1.1;
  right: 2%;
  top: 45%;
  z-index: 3;
  --blob-scale: 1.8;
}

@media (max-width: 980px) {
  .atelier-practice-layout {
    grid-template-columns: 1fr;
  }

  .atelier-practice-blobs {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 30px;
    min-height: auto;
    padding: 30px 0;
  }

  .atelier-practice-blobs .blob {
    position: relative;
    width: var(--blob-tablet-width, min(88vw, 400px));
    max-width: var(--blob-tablet-max-width, 400px);
    min-height: var(--blob-tablet-min-height, 320px);
    inset: auto;
    transform: none;
    aspect-ratio: var(--blob-tablet-ratio, 1 / 1);
    --blob-scale: var(--blob-tablet-scale, 1.12);
  }
}

@media (max-width: 680px) {
  .atelier-practice-blobs .blob {
    min-height: var(--blob-tablet-min-height, 280px);
  }

  .atelier-practice-blobs .blob--atelier-practice-1 {
    --blob-tablet-scale: 1.10;
  }

  .atelier-practice-blobs .blob--atelier-practice-2 {
    --blob-tablet-scale: 1.10;
  }

  .atelier-practice-blobs .blob--atelier-practice-3 {
    --blob-tablet-scale: 1.10;
  }
}

@media (max-width: 430px) {
  .atelier-practice-blobs {
    gap: 18px;
    padding: 12px 0;
  }

  .atelier-practice-blobs .blob {
    width: var(--blob-mobile-width, min(82vw, 270px));
    max-width: var(--blob-mobile-max-width, 270px);
    min-height: var(--blob-mobile-min-height, 230px);
    --blob-scale: var(--blob-mobile-scale, 1.08);
    --blob-padding: 24px 22px;
    --blob-title-size: clamp(0.95rem, 5vw, 1.15rem);
    --blob-text-size: clamp(0.78rem, 4.1vw, 0.98rem);
  }

  .atelier-practice-blobs .blob--atelier-practice-2 {
    --blob-mobile-width: min(84vw, 280px);
    --blob-mobile-max-width: 280px;
    --blob-mobile-scale: 1.04;
  }

  .atelier-practice-blobs .blob.blob--atelier-practice-1,
  .atelier-practice-blobs .blob.blob--atelier-practice-3 {
    --blob-mobile-scale: 1.30;
    --blob-title-size: clamp(0.76rem, 4vw, 0.92rem);
    --blob-text-size: clamp(0.62rem, 3.28vw, 0.78rem);
  }

  .atelier-practice-blobs .blob.blob--atelier-practice-2 {
    --blob-mobile-scale: 1.25;
    --blob-title-size: clamp(0.76rem, 4vw, 0.92rem);
    --blob-text-size: clamp(0.62rem, 3.28vw, 0.78rem);
  }
}

@media (max-width: 380px) {
  .atelier-practice-blobs .blob {
    --blob-mobile-width: min(80vw, 252px);
    --blob-mobile-max-width: 252px;
    --blob-mobile-min-height: 218px;
    --blob-padding: 22px 18px;
  }
}

/* =========================================
   PAGE-PROFILE — HERO ADJUSTMENTS
========================================= */

.page-hero--profil .blob--page-2 {
  top: 2%;
}

/* =========================================
   PAGE-CONTACT — HERO ADJUSTMENTS
========================================= */

.page-hero--contact .blob--page-3 {
  top: 49%;
}

/* =========================================
   PAGE-PROGRESS
   Note : la page d’attente continue d’utiliser le hero principal existant.
========================================= */

/* =========================================
   ERROR-404
   Réservé pour une future intégration.
========================================= */

/* =========================================
   COMPONENTS — BUTTONS / BTN-BLOB
========================================= */

.btn-blob {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 80%;
  min-width: 0;
  min-height: 35px;
  padding: 8px 10px;
  border-radius: 999px;
  box-sizing: border-box;
  cursor: pointer;
  text-decoration: none;

  font-family: var(--font-ui);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.4;

  border: 1px solid var(--transparent);
  background: var(--white-80);
  color: var(--btn-ghost-text);

  transition:
    transform .08s ease,
    background .16s ease,
    border-color .16s ease,
    box-shadow .16s ease,
    color .16s ease;
}

.btn-blob:active {
  transform: translateY(1px);
}

.btn-blob:hover,
.btn-blob:focus-visible {
  background: var(--btn-ghost-bg-hover);
  border-color: var(--btn-ghost-border-hover);
  color: var(--btn-ghost-text);
  box-shadow: var(--btn-ghost-shadow);
  text-decoration: none;
}

@media (max-width: 680px) {
  .btn-blob {
    width: 100%;
  }
}

.blob--image-terracotta .btn-blob,
.blob--image-argile .btn-blob,
.blob--image-teint .btn-blob,
.blob--image-khol .btn-blob {
  background: var(--white-20) !important;
  border-color: var(--white-20) !important;
  color: var(--white) !important;
  box-shadow: none !important;
}

.blob--image-terracotta .btn-blob:hover,
.blob--image-argile .btn-blob:hover,
.blob--image-teint .btn-blob:hover,
.blob--image-khol .btn-blob:hover,
.blob--image-terracotta .btn-blob:focus-visible,
.blob--image-argile .btn-blob:focus-visible,
.blob--image-teint .btn-blob:focus-visible,
.blob--image-khol .btn-blob:focus-visible {
  background: var(--btn-ghost-bg-hover) !important;
  border-color: var(--btn-ghost-border-hover) !important;
  color: var(--btn-ghost-text) !important;
  box-shadow: var(--btn-ghost-shadow) !important;
  text-decoration: none;
}

/*
.blob--contact-1 .btn-blob,
.blob--contact-3 .btn-blob,
.blob--contact-4 .btn-blob {
  background: var(--paper-90);
  color: var(--ink-90);
}

.contact-direct-band .contact-form__actions .btn-blob,
.contact-social-band .contact-form__actions .btn-blob,
.contact-map-card__body > .btn-blob,
.contact-form__actions .btn-blob {
  width: 100%;
  min-height: 35px;
  justify-content: center;
  box-shadow: 0 8px 18px var(--ink-deep-10);
}*/



/* =========================================================
   FINALISATION PAGES STATIQUES — GALERIES, VISIONNEUSE,
   FORMULAIRE CONTACT, GOOGLE MAPS
   À conserver en fin de fichier pour surcharger sans casser
   les blocs validés précédemment.
========================================================= */

/* ---------- Galeries : états JS ---------- */
.media-gallery .is-carousel-hidden,
.media-gallery .is-gallery-hidden {
  display: none !important;
}

.media-gallery .media-gallery__item {
  cursor: zoom-in;
}

.media-gallery .media-gallery__item:focus-visible {
  outline: 3px solid var(--argile);
  outline-offset: 4px;
}

/* Sur les pages internes, l'aperçu reste à 9 images avant ouverture. */
.media-gallery[data-gallery-expand] {
  align-items: start;
}

.gallery-expand-actions {
  display: flex;
  justify-content: center;
  margin-top: 22px;
}

.gallery-expand-toggle {
  width: auto;
  min-width: min(100%, 260px);
  box-shadow: var(--btn-ghost-shadow);
}

.gallery-expand-toggle__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  line-height: 1.4;
}

/* Les flèches restent disponibles aussi sur mobile. */
.gallery-carousel-shell {
  overflow: visible;
}

.gallery-carousel-nav {
  font-size: 1.05rem;
  line-height: 1.4;
}

.gallery-carousel-nav[hidden] {
  display: none !important;
}

@media (max-width: 820px) {
  .gallery-carousel-shell {
    padding-bottom: 46px;
  }

  .gallery-carousel-nav {
    display: inline-flex;
    top: auto;
    bottom: 0;
    transform: none;
  }

  .gallery-carousel-nav:active {
    transform: scale(0.97);
  }

  .gallery-carousel-nav--prev {
    left: calc(50% - 44px);
  }

  .gallery-carousel-nav--next {
    right: calc(50% - 44px);
  }
}



/* ---------- Visionneuse de galerie ---------- */
.gallery-lightbox[hidden] {
  display: none !important;
}

.gallery-lightbox {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: grid;
  grid-template-columns: minmax(48px, 0.12fr) minmax(0, 1fr) minmax(48px, 0.12fr);
  align-items: center;
  gap: clamp(10px, 2vw, 24px);
  padding: clamp(18px, 4vw, 44px);
  background: var(--ink-deep-80);
  backdrop-filter: blur(8px);
}

.gallery-lightbox-open {
  overflow: hidden;
}

.gallery-lightbox__figure {
  grid-column: 2;
  display: grid;
  justify-items: center;
  gap: 12px;
  margin: 0;
  min-width: 0;
}

.gallery-lightbox__image {
  display: block;
  width: auto;
  max-width: min(100%, 1180px);
  max-height: 78vh;
  object-fit: contain;
  border-radius: 22px;
  box-shadow: 0 22px 60px var(--ink-deep-70);
  background: var(--paper-90);
}

.gallery-lightbox__caption,
.gallery-lightbox__counter {
  margin: 0;
  color: var(--white);
  text-align: center;
}

.gallery-lightbox__caption {
  max-width: min(86vw, 900px);
  font-size: 0.98rem;
  line-height: 1.4;
}

.gallery-lightbox__counter {
  font-size: 0.86rem;
  color: var(--white-80);
}

.gallery-lightbox__close,
.gallery-lightbox__nav {
  appearance: none;
  border: 1px solid var(--white-40);
  border-radius: 999px;
  background: var(--paper-90);
  color: var(--khol);
  box-shadow: var(--shadow-soft);
  cursor: pointer;
  transition: transform .16s ease, background .16s ease, border-color .16s ease;
}

.gallery-lightbox__close:hover,
.gallery-lightbox__nav:hover,
.gallery-lightbox__close:focus-visible,
.gallery-lightbox__nav:focus-visible {
  background: var(--white);
  border-color: var(--white);
}

.gallery-lightbox__close:active,
.gallery-lightbox__nav:active {
  transform: scale(0.97);
}

.gallery-lightbox__close {
  position: absolute;
  top: clamp(14px, 3vw, 24px);
  right: clamp(14px, 3vw, 24px);
  width: 44px;
  height: 44px;
  font-size: 1.8rem;
  line-height: 1.4;
}

.gallery-lightbox__nav {
  width: clamp(44px, 6vw, 58px);
  height: clamp(44px, 6vw, 58px);
  font-size: 1.4rem;
}

.gallery-lightbox__nav--prev {
  grid-column: 1;
  justify-self: center;
}

.gallery-lightbox__nav--next {
  grid-column: 3;
  justify-self: center;
}

@media (max-width: 700px) {
  .gallery-lightbox {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr auto;
    align-items: end;
    padding-top: 68px;
  }

  .gallery-lightbox__figure {
    grid-column: 1 / -1;
    align-self: center;
  }

  .gallery-lightbox__image {
    max-height: 70vh;
    border-radius: 18px;
  }

  .gallery-lightbox__nav--prev,
  .gallery-lightbox__nav--next {
    grid-row: 2;
    margin-top: 8px;
  }

  .gallery-lightbox__nav--prev {
    grid-column: 1;
    justify-self: end;
  }

  .gallery-lightbox__nav--next {
    grid-column: 2;
    justify-self: start;
  }
}

/* ---------- Formulaire de contact ---------- */
.contact-submit-feedback {
  min-height: 1.45em;
  padding: 0 2px;
}

.contact-submit-feedback.is-success {
  color: var(--khol);
}

.contact-submit-feedback.is-error {
  color: var(--terracotta);
}

/* ---------- Google Maps Embed API ---------- */
.contact-map-embed {
  position: relative;
  display: grid;
  place-items: stretch;
  width: min(100%, 420px);
  aspect-ratio: 1 / 1;
  margin: 0 auto;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid var(--terracotta-20);
  background: var(--paper-90);
}

.contact-map-embed iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 360px;
  border: 0;
}

.contact-map-fallback {
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  min-height: 360px;
  padding: 24px;
  text-align: center;
  color: var(--ink-80);
  text-decoration: none;
  background:
    radial-gradient(circle at 28% 24%, var(--argile-10), var(--transparent) 45%),
    radial-gradient(circle at 78% 74%, var(--ficelle-20), var(--transparent) 48%),
    var(--paper-90);
}

.contact-map-fallback:hover,
.contact-map-fallback:focus-visible {
  color: var(--khol);
  background: var(--paper-95);
}

.contact-map-card__media.contact-map-embed img {
  display: none;
}

@media (max-width: 560px) {
  .contact-map-embed {
    width: 100%;
    border-radius: 18px;
  }

  .contact-map-embed iframe,
  .contact-map-fallback {
    min-height: 280px;
  }
}

/* =========================================================
   FINALISATION V2 — CONTRÔLES DE GALERIE & VISIONNEUSE
   Ajustements demandés après validation visuelle.
========================================================= */

:root {
  --gallery-control-bg: #f8f3ee;
  --gallery-control-bg-hover: #fffdfa;
  --gallery-control-bg-active: #efe7df;
  --gallery-control-border: rgba(45, 35, 29, 0.12);
  --gallery-control-border-hover: rgba(45, 35, 29, 0.18);
  --gallery-control-shadow: 0 8px 18px rgba(45, 35, 29, 0.08);
  --gallery-control-shadow-hover: 0 12px 22px rgba(45, 35, 29, 0.12);
  --gallery-control-size: 36px;
}

.media-gallery .is-carousel-hidden,
.media-gallery .is-gallery-hidden {
  display: none !important;
}

.media-gallery .media-gallery__item {
  cursor: zoom-in;
}

.media-gallery .media-gallery__item:focus-visible {
  outline: 3px solid var(--argile);
  outline-offset: 4px;
}

.gallery-carousel-shell {
  position: relative;
  overflow: visible;
  --gallery-side-space: clamp(28px, 4vw, 44px);
}

.gallery-carousel-shell .about-gallery-grid {
  margin: 0;
}

.gallery-round-control {
  appearance: none;
  width: var(--gallery-control-size);
  height: var(--gallery-control-size);
  border: 1px solid var(--gallery-control-border);
  border-radius: 999px;
  background: var(--gallery-control-bg);
  box-shadow: var(--gallery-control-shadow);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  color: var(--argile);
  cursor: pointer;
  transition: transform .16s ease, background-color .18s ease, border-color .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.gallery-round-control:hover,
.gallery-round-control:focus-visible {
  background: var(--gallery-control-bg-hover);
  border-color: var(--gallery-control-border-hover);
  box-shadow: var(--gallery-control-shadow-hover);
  outline: none;
}

.gallery-round-control:active {
  background: var(--gallery-control-bg-active);
  transform: translateY(1px) scale(0.98);
}

.gallery-round-control[disabled],
.gallery-round-control[aria-disabled="true"] {
  opacity: .4;
  cursor: default;
  box-shadow: none;
}

.gallery-round-control__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
}

.gallery-icon {
  display: block;
  width: 18px;
  height: 18px;
}

.gallery-carousel-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
}

.gallery-carousel-nav--prev {
  left: calc((-1 * var(--gallery-side-space)) + ((var(--gallery-side-space) - var(--gallery-control-size)) / 2));
}

.gallery-carousel-nav--next {
  right: calc((-1 * var(--gallery-side-space)) + ((var(--gallery-side-space) - var(--gallery-control-size)) / 2));
}

.gallery-carousel-nav[hidden] {
  display: none !important;
}

.gallery-expand-actions {
  display: flex;
  justify-content: center;
  margin-top: 22px;
}

.gallery-expand-toggle {
  appearance: none;
  border: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 0;
  color: var(--khol);
  cursor: pointer;
  font: inherit;
}

.gallery-expand-toggle__label {
  font-size: 0.95rem;
  letter-spacing: .02em;
}

.gallery-expand-toggle__control {
  pointer-events: none;
}

.gallery-expand-toggle:hover .gallery-expand-toggle__label,
.gallery-expand-toggle:focus-visible .gallery-expand-toggle__label {
  color: var(--argile);
}

.gallery-expand-toggle:focus-visible {
  outline: none;
}

.gallery-expand-toggle.is-expanded .gallery-round-control {
  background: var(--gallery-control-bg-hover);
}

/* Visionneuse enrichie */
.gallery-lightbox[hidden] {
  display: none !important;
}

.gallery-lightbox {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: grid;
  place-items: center;
  padding: clamp(16px, 3vw, 28px);
}

.gallery-lightbox-open {
  overflow: hidden;
}

.gallery-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(31, 27, 22, 0.72);
  backdrop-filter: blur(8px);
}

.gallery-lightbox__panel {
  position: relative;
  z-index: 1;
  width: min(1200px, 100%);
  max-height: min(92vh, 980px);
  display: grid;
  gap: 18px;
  padding: clamp(16px, 2vw, 22px);
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255, 253, 249, 0.94);
  box-shadow: 0 28px 70px rgba(31, 27, 22, 0.24);
}

.gallery-lightbox__toolbar {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.gallery-lightbox__meta {
  display: grid;
  gap: 4px;
}

.gallery-lightbox__title,
.gallery-lightbox__counter {
  margin: 0;
}

.gallery-lightbox__title {
  color: var(--argile);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 1rem;
}

.gallery-lightbox__counter {
  color: var(--ink-80);
  font-size: .88rem;
}

.gallery-lightbox__viewport {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
}

.gallery-lightbox__figure {
  margin: 0;
  min-width: 0;
  display: grid;
  gap: 12px;
}

.gallery-lightbox__media-frame {
  display: grid;
  place-items: center;
  min-height: 0;
  padding: clamp(10px, 1.5vw, 16px);
  border-radius: 24px;
  background:
    radial-gradient(circle at 22% 16%, var(--argile-10), transparent 38%),
    radial-gradient(circle at 80% 84%, var(--ficelle-20), transparent 42%),
    var(--paper-90);
  border: 1px solid var(--terracotta-20);
}

.gallery-lightbox__image {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: min(68vh, 760px);
  object-fit: contain;
  border-radius: 18px;
  box-shadow: 0 16px 40px rgba(31, 27, 22, 0.16);
  background: #fff;
}

.gallery-lightbox__caption {
  margin: 0;
  padding: 0 4px;
  color: var(--ink-80);
  font-size: 0.96rem;
  line-height: 1.4;
}

.gallery-lightbox__thumbs {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 74px;
  gap: 10px;
  overflow-x: auto;
  padding: 2px 2px 4px;
  scrollbar-width: thin;
}

.gallery-lightbox__thumb {
  appearance: none;
  margin: 0;
  padding: 0;
  height: 74px;
  border-radius: 16px;
  border: 1px solid var(--gallery-control-border);
  background: var(--paper-95);
  overflow: hidden;
  cursor: pointer;
  box-shadow: var(--gallery-control-shadow);
  transition: transform .16s ease, border-color .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.gallery-lightbox__thumb:hover,
.gallery-lightbox__thumb:focus-visible,
.gallery-lightbox__thumb.is-active {
  border-color: var(--argile);
  box-shadow: 0 10px 24px rgba(210, 143, 102, 0.18);
  outline: none;
}

.gallery-lightbox__thumb.is-active {
  transform: translateY(-1px);
}

.gallery-lightbox__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 900px) {
  .gallery-carousel-shell {
    padding-bottom: 52px;
  }

  .gallery-carousel-nav {
    top: auto;
    bottom: 0;
    transform: none;
  }

  .gallery-carousel-nav:active {
    transform: translateY(1px) scale(0.98);
  }

  .gallery-carousel-nav--prev {
    left: calc(50% - 46px);
  }

  .gallery-carousel-nav--next {
    right: calc(50% - 46px);
  }

  .gallery-lightbox__panel {
    max-height: 94vh;
    border-radius: 22px;
  }

  .gallery-lightbox__viewport {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .gallery-lightbox__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
  }

  .gallery-lightbox__nav--prev {
    left: 10px;
  }

  .gallery-lightbox__nav--next {
    right: 10px;
  }

  .gallery-lightbox__image {
    max-height: 60vh;
  }
}

@media (max-width: 560px) {
  .gallery-control,
  .gallery-round-control {
    --gallery-control-size: 34px;
  }

  .gallery-lightbox {
    padding: 10px;
  }

  .gallery-lightbox__panel {
    gap: 14px;
    padding: 14px;
    border-radius: 20px;
  }

  .gallery-lightbox__toolbar {
    gap: 10px;
  }

  .gallery-lightbox__thumbs {
    grid-auto-columns: 60px;
  }

  .gallery-lightbox__thumb {
    height: 60px;
    border-radius: 12px;
  }

  .gallery-lightbox__nav--prev {
    left: 6px;
  }

  .gallery-lightbox__nav--next {
    right: 6px;
  }
}

/* =========================================================
   FINALISATION V3 — GALERIES PREMIUM, SANS MODIFICATION HTML
   Objectif : coller au style validé sur capture : boutons ronds,
   discrets, ivoire, filet fin, chevrons argile et états complets.
========================================================= */

:root {
  --gallery-ui-size: 30px;
  --gallery-ui-icon-size: 15px;
  --gallery-ui-bg: #fffdfa;
  --gallery-ui-bg-hover: #ffffff;
  --gallery-ui-bg-active: #f3ebe4;
  --gallery-ui-border: rgba(154, 119, 97, 0.20);
  --gallery-ui-border-hover: rgba(154, 119, 97, 0.36);
  --gallery-ui-color: var(--argile);
  --gallery-ui-color-hover: var(--khol);
  --gallery-ui-shadow: 0 8px 18px rgba(45, 35, 29, 0.08);
  --gallery-ui-shadow-hover: 0 12px 24px rgba(45, 35, 29, 0.12);
  --gallery-ui-focus: 0 0 0 4px var(--argile-10), var(--gallery-ui-shadow-hover);
  --gallery-lightbox-panel: rgba(255, 253, 249, 0.96);
}

/* ---------- Boutons ronds communs : galerie + visionneuse ---------- */
.gallery-round-control,
.gallery-carousel-nav,
.gallery-lightbox__close,
.gallery-lightbox__nav {
  appearance: none !important;
  width: var(--gallery-ui-size) !important;
  height: var(--gallery-ui-size) !important;
  min-width: var(--gallery-ui-size) !important;
  min-height: var(--gallery-ui-size) !important;
  border: 1px solid var(--gallery-ui-border) !important;
  border-radius: 999px !important;
  background: var(--gallery-ui-bg) !important;
  color: var(--gallery-ui-color) !important;
  box-shadow: var(--gallery-ui-shadow) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  line-height: 1 !important;
  cursor: pointer !important;
  transition:
    color .18s ease,
    background-color .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    transform .14s ease,
    opacity .18s ease !important;
}

.gallery-round-control:hover,
.gallery-carousel-nav:hover,
.gallery-lightbox__close:hover,
.gallery-lightbox__nav:hover {
  background: var(--gallery-ui-bg-hover) !important;
  border-color: var(--gallery-ui-border-hover) !important;
  color: var(--gallery-ui-color-hover) !important;
  box-shadow: var(--gallery-ui-shadow-hover) !important;
}

.gallery-round-control:focus-visible,
.gallery-carousel-nav:focus-visible,
.gallery-lightbox__close:focus-visible,
.gallery-lightbox__nav:focus-visible {
  outline: none !important;
  background: var(--gallery-ui-bg-hover) !important;
  border-color: var(--gallery-ui-border-hover) !important;
  color: var(--gallery-ui-color-hover) !important;
  box-shadow: var(--gallery-ui-focus) !important;
}

.gallery-round-control:active,
.gallery-carousel-nav:active,
.gallery-lightbox__close:active,
.gallery-lightbox__nav:active {
  background: var(--gallery-ui-bg-active) !important;
  transform: translateY(1px) scale(0.98) !important;
  box-shadow: 0 4px 10px rgba(45, 35, 29, 0.08) !important;
}

.gallery-round-control[disabled],
.gallery-carousel-nav[disabled],
.gallery-lightbox__close[disabled],
.gallery-lightbox__nav[disabled],
.gallery-round-control[aria-disabled="true"],
.gallery-carousel-nav[aria-disabled="true"],
.gallery-lightbox__close[aria-disabled="true"],
.gallery-lightbox__nav[aria-disabled="true"] {
  opacity: .42 !important;
  cursor: default !important;
  pointer-events: none !important;
  box-shadow: none !important;
}

.gallery-round-control[hidden],
.gallery-carousel-nav[hidden],
.gallery-lightbox__nav[hidden] {
  display: none !important;
}

.gallery-round-control__icon,
.gallery-icon {
  width: var(--gallery-ui-icon-size) !important;
  height: var(--gallery-ui-icon-size) !important;
  display: block !important;
  flex: 0 0 var(--gallery-ui-icon-size) !important;
}

.gallery-round-control__icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* ---------- Carrousel accueil : placement fidèle à la capture ---------- */
.gallery-carousel-shell {
  position: relative !important;
  overflow: visible !important;
  --gallery-side-space: clamp(30px, 3.8vw, 42px);
}

.gallery-carousel-shell .about-gallery-grid {
  margin: 0 !important;
}

.gallery-carousel-nav {
  position: absolute !important;
  top: 50% !important;
  z-index: 5 !important;
}

.gallery-carousel-nav--prev {
  left: calc((-1 * var(--gallery-side-space)) + ((var(--gallery-side-space) - var(--gallery-ui-size)) / 2)) !important;
  transform: translateY(-50%) !important;
}

.gallery-carousel-nav--next {
  right: calc((-1 * var(--gallery-side-space)) + ((var(--gallery-side-space) - var(--gallery-ui-size)) / 2)) !important;
  transform: translateY(-50%) !important;
}

.gallery-carousel-nav--prev:active,
.gallery-carousel-nav--next:active {
  transform: translateY(calc(-50% + 1px)) scale(0.98) !important;
}

/* ---------- Flèche du bas : bouton rond seul, texte conservé pour accessibilité ---------- */
.gallery-expand-actions {
  display: flex !important;
  justify-content: center !important;
  margin-top: 22px !important;
}

.gallery-expand-toggle {
  appearance: none !important;
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: var(--gallery-ui-size) !important;
  height: var(--gallery-ui-size) !important;
  min-width: var(--gallery-ui-size) !important;
  min-height: var(--gallery-ui-size) !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: inherit !important;
  cursor: pointer !important;
}

.gallery-expand-toggle__label {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.gallery-expand-toggle__control {
  pointer-events: none !important;
}

.gallery-expand-toggle:hover .gallery-round-control,
.gallery-expand-toggle:focus-visible .gallery-round-control {
  background: var(--gallery-ui-bg-hover) !important;
  border-color: var(--gallery-ui-border-hover) !important;
  color: var(--gallery-ui-color-hover) !important;
  box-shadow: var(--gallery-ui-shadow-hover) !important;
}

.gallery-expand-toggle:focus-visible {
  outline: none !important;
}

.gallery-expand-toggle:focus-visible .gallery-round-control {
  box-shadow: var(--gallery-ui-focus) !important;
}

.gallery-expand-toggle:active .gallery-round-control {
  background: var(--gallery-ui-bg-active) !important;
  transform: translateY(1px) scale(0.98) !important;
  box-shadow: 0 4px 10px rgba(45, 35, 29, 0.08) !important;
}

/* ---------- Galerie interne : 9 images stables sur desktop ---------- */
.media-gallery[data-gallery-expand] {
  align-items: start !important;
}

.media-gallery .is-carousel-hidden,
.media-gallery .is-gallery-hidden {
  display: none !important;
}

.about-gallery-grid .about-gallery-card {
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, opacity .18s ease !important;
}

.about-gallery-grid .about-gallery-card:hover,
.about-gallery-grid .about-gallery-card:focus-visible,
.about-gallery-grid .about-gallery-card:focus-within {
  border-color: var(--terracotta-20) !important;
}

/* ---------- Visionneuse premium, dans la palette du site ---------- */
.gallery-lightbox {
  position: fixed !important;
  inset: 0 !important;
  z-index: 9999 !important;
  display: grid !important;
  place-items: center !important;
  padding: clamp(14px, 3vw, 32px) !important;
}

.gallery-lightbox[hidden] {
  display: none !important;
}

.gallery-lightbox-open {
  overflow: hidden !important;
}

.gallery-lightbox__backdrop {
  position: absolute !important;
  inset: 0 !important;
  background:
    radial-gradient(900px 520px at 18% 10%, rgba(210, 143, 102, .20), transparent 58%),
    radial-gradient(760px 480px at 88% 82%, rgba(207, 182, 154, .18), transparent 56%),
    rgba(31, 27, 22, .74) !important;
  backdrop-filter: blur(10px) !important;
}

.gallery-lightbox__panel {
  position: relative !important;
  z-index: 1 !important;
  width: min(1180px, 100%) !important;
  max-height: min(92vh, 960px) !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) auto !important;
  gap: clamp(12px, 1.8vw, 18px) !important;
  padding: clamp(15px, 2.2vw, 24px) !important;
  border-radius: 30px !important;
  border: 1px solid rgba(255, 255, 255, .22) !important;
  background: var(--gallery-lightbox-panel) !important;
  box-shadow: 0 34px 80px rgba(31, 27, 22, .28) !important;
  overflow: hidden !important;
}

.gallery-lightbox__toolbar {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 16px !important;
  min-width: 0 !important;
}

.gallery-lightbox__meta {
  min-width: 0 !important;
  display: grid !important;
  gap: 3px !important;
}

.gallery-lightbox__title,
.gallery-lightbox__counter {
  margin: 0 !important;
}

.gallery-lightbox__title {
  color: var(--argile-strong) !important;
  font-size: clamp(.95rem, 1.4vw, 1.1rem) !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
  text-transform: uppercase !important;
  letter-spacing: .055em !important;
}

.gallery-lightbox__counter {
  color: var(--ink-70) !important;
  font-size: .85rem !important;
  line-height: 1.4 !important;
}

.gallery-lightbox__viewport {
  min-height: 0 !important;
  display: grid !important;
  grid-template-columns: var(--gallery-ui-size) minmax(0, 1fr) var(--gallery-ui-size) !important;
  align-items: center !important;
  gap: clamp(10px, 1.8vw, 18px) !important;
}

.gallery-lightbox__figure {
  grid-column: 2 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  display: grid !important;
  gap: 10px !important;
  align-content: center !important;
}

.gallery-lightbox__media-frame {
  min-width: 0 !important;
  min-height: 0 !important;
  display: grid !important;
  place-items: center !important;
  padding: clamp(10px, 1.6vw, 18px) !important;
  border-radius: 26px !important;
  border: 1px solid var(--terracotta-20) !important;
  background:
    radial-gradient(circle at 20% 18%, var(--argile-10), transparent 42%),
    radial-gradient(circle at 86% 86%, var(--ficelle-20), transparent 46%),
    var(--paper-95) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72) !important;
}

.gallery-lightbox__image {
  display: block !important;
  width: auto !important;
  max-width: 100% !important;
  max-height: min(66vh, 710px) !important;
  object-fit: contain !important;
  border-radius: 20px !important;
  background: var(--white) !important;
  box-shadow: 0 18px 44px rgba(31, 27, 22, .16) !important;
}

.gallery-lightbox__caption {
  margin: 0 !important;
  padding-inline: 4px !important;
  color: var(--ink-80) !important;
  font-size: .95rem !important;
  line-height: 1.4 !important;
  text-align: center !important;
}

.gallery-lightbox__caption:empty,
.gallery-lightbox__caption[hidden] {
  display: none !important;
}

.gallery-lightbox__thumbs {
  display: grid !important;
  grid-auto-flow: column !important;
  grid-auto-columns: 68px !important;
  gap: 10px !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  padding: 2px 2px 5px !important;
  scrollbar-width: thin !important;
}

.gallery-lightbox__thumbs[hidden] {
  display: none !important;
}

.gallery-lightbox__thumb {
  appearance: none !important;
  height: 68px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: 1px solid var(--gallery-ui-border) !important;
  border-radius: 16px !important;
  background: var(--paper-95) !important;
  box-shadow: var(--gallery-ui-shadow) !important;
  cursor: pointer !important;
  opacity: .72 !important;
  transition: transform .16s ease, opacity .18s ease, border-color .18s ease, box-shadow .18s ease !important;
}

.gallery-lightbox__thumb:hover,
.gallery-lightbox__thumb:focus-visible,
.gallery-lightbox__thumb.is-active {
  opacity: 1 !important;
  border-color: var(--argile) !important;
  box-shadow: 0 10px 22px rgba(210, 143, 102, .18) !important;
  outline: none !important;
}

.gallery-lightbox__thumb.is-active {
  transform: translateY(-1px) !important;
}

.gallery-lightbox__thumb img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.gallery-lightbox__close {
  position: static !important;
  flex: 0 0 var(--gallery-ui-size) !important;
  font-size: 0 !important;
}

.gallery-lightbox__nav {
  position: static !important;
  font-size: 0 !important;
}

.gallery-lightbox__nav--prev {
  grid-column: 1 !important;
  justify-self: center !important;
}

.gallery-lightbox__nav--next {
  grid-column: 3 !important;
  justify-self: center !important;
}

@media (max-width: 900px) {
  .gallery-carousel-shell {
    padding-bottom: 48px !important;
  }

  .gallery-carousel-nav {
    top: auto !important;
    bottom: 0 !important;
    transform: none !important;
  }

  .gallery-carousel-nav--prev {
    left: calc(50% - 42px) !important;
  }

  .gallery-carousel-nav--next {
    right: calc(50% - 42px) !important;
  }

  .gallery-carousel-nav:active {
    transform: translateY(1px) scale(0.98) !important;
  }

  .gallery-lightbox__panel {
    width: 100% !important;
    max-height: 94vh !important;
    border-radius: 24px !important;
  }

  .gallery-lightbox__viewport {
    grid-template-columns: minmax(0, 1fr) !important;
    position: relative !important;
  }

  .gallery-lightbox__figure {
    grid-column: 1 !important;
  }

  .gallery-lightbox__nav {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 3 !important;
  }

  .gallery-lightbox__nav--prev {
    left: 8px !important;
  }

  .gallery-lightbox__nav--next {
    right: 8px !important;
  }

  .gallery-lightbox__nav:active {
    transform: translateY(calc(-50% + 1px)) scale(0.98) !important;
  }

  .gallery-lightbox__image {
    max-height: 58vh !important;
  }
}

@media (max-width: 560px) {
  :root {
    --gallery-ui-size: 30px;
    --gallery-ui-icon-size: 14px;
  }

  .gallery-lightbox {
    padding: 9px !important;
  }

  .gallery-lightbox__panel {
    gap: 12px !important;
    padding: 13px !important;
    border-radius: 20px !important;
  }

  .gallery-lightbox__media-frame {
    padding: 8px !important;
    border-radius: 20px !important;
  }

  .gallery-lightbox__image {
    max-height: 56vh !important;
    border-radius: 16px !important;
  }

  .gallery-lightbox__caption {
    font-size: .88rem !important;
  }

  .gallery-lightbox__thumbs {
    grid-auto-columns: 56px !important;
    gap: 8px !important;
  }

  .gallery-lightbox__thumb {
    height: 56px !important;
    border-radius: 12px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .gallery-round-control,
  .gallery-carousel-nav,
  .gallery-lightbox__close,
  .gallery-lightbox__nav,
  .gallery-lightbox__thumb,
  .about-gallery-grid .about-gallery-card {
    transition: none !important;
  }
}

/* =========================================================
   FINALISATION V4 — VISIONNEUSE FORMAT DIAPORAMA
   Objectif : image centrale réellement grande, proche taille écran,
   sans toucher au contenu HTML validé.
========================================================= */

.gallery-lightbox {
  padding: clamp(10px, 2vw, 24px) !important;
  place-items: center !important;
}

.gallery-lightbox__panel {
  width: min(1500px, calc(100vw - clamp(20px, 4vw, 48px))) !important;
  height: min(940px, calc(100vh - clamp(20px, 4vw, 48px))) !important;
  max-width: none !important;
  max-height: none !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) auto !important;
  align-self: center !important;
  justify-self: center !important;
}

.gallery-lightbox__toolbar {
  min-height: 44px !important;
  align-items: center !important;
}

.gallery-lightbox__viewport {
  min-height: 0 !important;
  height: 100% !important;
  display: grid !important;
  grid-template-columns: var(--gallery-ui-size) minmax(0, 1fr) var(--gallery-ui-size) !important;
  align-items: stretch !important;
}

.gallery-lightbox__figure {
  height: 100% !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  align-content: stretch !important;
}

.gallery-lightbox__media-frame {
  height: 100% !important;
  min-height: clamp(360px, 62vh, 760px) !important;
  display: grid !important;
  place-items: center !important;
}

.gallery-lightbox__image {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  min-width: min(320px, 100%) !important;
  min-height: min(320px, 100%) !important;
  object-fit: contain !important;
}

.gallery-lightbox__caption {
  min-height: 1.45em !important;
  max-width: min(100%, 920px) !important;
  justify-self: center !important;
}

.gallery-lightbox__thumbs {
  min-height: 76px !important;
  align-content: center !important;
}

@media (min-width: 1180px) {
  .gallery-lightbox__panel {
    width: min(1580px, calc(100vw - 56px)) !important;
    height: min(980px, calc(100vh - 56px)) !important;
  }

  .gallery-lightbox__media-frame {
    min-height: clamp(520px, 68vh, 800px) !important;
  }
}

@media (max-width: 900px) {
  .gallery-lightbox__panel {
    width: calc(100vw - 18px) !important;
    height: calc(100vh - 18px) !important;
    max-height: none !important;
  }

  .gallery-lightbox__viewport {
    grid-template-columns: minmax(0, 1fr) !important;
    align-items: stretch !important;
  }

  .gallery-lightbox__figure {
    grid-column: 1 !important;
  }

  .gallery-lightbox__media-frame {
    min-height: 0 !important;
    height: 100% !important;
    padding: 10px !important;
  }

  .gallery-lightbox__image {
    max-height: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
  }
}

@media (max-width: 560px) {
  .gallery-lightbox__panel {
    width: calc(100vw - 12px) !important;
    height: calc(100vh - 12px) !important;
  }

  .gallery-lightbox__toolbar {
    min-height: 38px !important;
  }

  .gallery-lightbox__media-frame {
    padding: 7px !important;
  }

  .gallery-lightbox__thumbs {
    min-height: 62px !important;
  }
}

/* =========================================================
   FINALISATION V5 — CENTRAGE DIAPORAMA & LÉGENDE
   Objectifs :
   - centrer strictement la visionneuse dans la fenêtre ;
   - conserver une image centrale de grand format ;
   - afficher la légende sous l’image dans une infobulle sand-light ;
   - ne pas modifier le contenu HTML validé.
========================================================= */

.gallery-lightbox {
  display: block !important;
  padding: 0 !important;
}

.gallery-lightbox__backdrop {
  position: fixed !important;
  inset: 0 !important;
}

.gallery-lightbox__panel {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  z-index: 2 !important;
  width: min(1560px, calc(100vw - 64px)) !important;
  height: min(940px, calc(100vh - 64px)) !important;
  max-width: none !important;
  max-height: none !important;
  transform: translate(-50%, -50%) !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) auto !important;
  gap: 16px !important;
  overflow: hidden !important;
}

.gallery-lightbox__toolbar {
  min-height: 42px !important;
  padding-inline: 2px !important;
}

.gallery-lightbox__viewport {
  min-height: 0 !important;
  height: 100% !important;
  display: grid !important;
  grid-template-columns: var(--gallery-ui-size) minmax(0, 1fr) var(--gallery-ui-size) !important;
  gap: clamp(12px, 1.5vw, 22px) !important;
  align-items: center !important;
}

.gallery-lightbox__figure {
  grid-column: 2 !important;
  height: 100% !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  gap: 12px !important;
  align-items: stretch !important;
}

.gallery-lightbox__media-frame {
  height: 100% !important;
  min-height: 0 !important;
  padding: clamp(10px, 1.2vw, 18px) !important;
  display: grid !important;
  place-items: center !important;
  overflow: hidden !important;
}

.gallery-lightbox__image {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  object-fit: contain !important;
  object-position: center center !important;
}

.gallery-lightbox__caption {
  position: static !important;
  z-index: auto !important;
  display: block !important;
  width: fit-content !important;
  max-width: min(920px, 100%) !important;
  min-height: 0 !important;
  margin: 0 auto !important;
  padding: 10px 16px !important;
  border: 1px solid var(--sand-20) !important;
  border-radius: 999px !important;
  background: var(--sand-light) !important;
  box-shadow: 0 10px 22px var(--ink-10) !important;
  color: var(--ink-80) !important;
  text-align: center !important;
  font-size: .92rem !important;
  line-height: 1.4 !important;
}

.gallery-lightbox__caption[hidden] {
  display: none !important;
}

.gallery-lightbox__nav--prev {
  grid-column: 1 !important;
  justify-self: center !important;
}

.gallery-lightbox__nav--next {
  grid-column: 3 !important;
  justify-self: center !important;
}

.gallery-lightbox__thumbs {
  min-height: 72px !important;
  padding-bottom: 2px !important;
}

@media (max-width: 900px) {
  .gallery-lightbox__panel {
    width: calc(100vw - 24px) !important;
    height: calc(100vh - 24px) !important;
    gap: 12px !important;
  }

  .gallery-lightbox__viewport {
    grid-template-columns: minmax(0, 1fr) !important;
    position: relative !important;
  }

  .gallery-lightbox__figure {
    grid-column: 1 !important;
  }

  .gallery-lightbox__nav {
    position: absolute !important;
    top: 50% !important;
    z-index: 4 !important;
    transform: translateY(-50%) !important;
  }

  .gallery-lightbox__nav--prev {
    left: 10px !important;
  }

  .gallery-lightbox__nav--next {
    right: 10px !important;
  }

  .gallery-lightbox__caption {
    max-width: calc(100% - 20px) !important;
    padding: 9px 14px !important;
    border-radius: 18px !important;
  }
}

@media (max-width: 560px) {
  .gallery-lightbox__panel {
    width: calc(100vw - 12px) !important;
    height: calc(100vh - 12px) !important;
    padding: 12px !important;
  }

  .gallery-lightbox__media-frame {
    padding: 7px !important;
  }

  .gallery-lightbox__caption {
    font-size: .86rem !important;
  }
}

/* =========================================================
   FINALISATION V6 — VISIONNEUSE GRAND FORMAT RESPONSIVE
   - panneau quasi plein écran
   - suppression du halo lumineux bas droite
   - navigation horizontale des miniatures
========================================================= */

.gallery-lightbox {
  padding: clamp(8px, 1.2vw, 18px) !important;
}

.gallery-lightbox__backdrop {
  background: rgba(31, 27, 22, 0.78) !important;
  backdrop-filter: blur(12px) !important;
}

.gallery-lightbox__panel {
  position: relative !important;
  width: min(96vw, 1720px) !important;
  max-width: none !important;
  height: min(95vh, 1120px) !important;
  max-height: 95vh !important;
  margin: 0 auto !important;
  padding: clamp(14px, 1.4vw, 22px) !important;
  border-radius: 28px !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) auto !important;
  gap: clamp(12px, 1.2vw, 18px) !important;
  overflow: hidden !important;
}

.gallery-lightbox__toolbar {
  align-items: start !important;
  min-height: 28px;
}

.gallery-lightbox__viewport {
  min-height: 0 !important;
  height: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(44px, 64px) minmax(0, 1fr) minmax(44px, 64px) !important;
  gap: clamp(12px, 1.4vw, 22px) !important;
  align-items: center !important;
}

.gallery-lightbox__figure {
  min-width: 0 !important;
  min-height: 0 !important;
  height: 100% !important;
  display: grid !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  gap: 12px !important;
  align-items: center !important;
}

.gallery-lightbox__media-frame {
  min-height: 0 !important;
  height: 100% !important;
  display: grid !important;
  place-items: center !important;
  padding: clamp(10px, 1vw, 18px) !important;
  background: var(--paper-95) !important;
}

.gallery-lightbox__image {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: min(76vh, 920px) !important;
  object-fit: contain !important;
}

.gallery-lightbox__caption {
  justify-self: center !important;
  max-width: min(92%, 760px) !important;
  margin: 0 auto !important;
  padding: 10px 18px !important;
  border-radius: 999px !important;
  background: var(--sand-light) !important;
  border: 1px solid var(--terracotta-20) !important;
  box-shadow: 0 10px 24px rgba(31, 27, 22, 0.08) !important;
  text-align: center !important;
  line-height: 1.4 !important;
}

.gallery-lightbox__thumbs-scroller {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 74px;
}

.gallery-lightbox__thumbs-viewport {
  min-width: 0 !important;
  overflow: hidden !important;
}

.gallery-lightbox__thumbs {
  display: grid !important;
  grid-auto-flow: column !important;
  grid-auto-columns: 62px !important;
  gap: 10px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  padding: 4px 2px 6px !important;
  scroll-behavior: smooth !important;
  scrollbar-width: thin;
}

.gallery-lightbox__thumbs::-webkit-scrollbar {
  height: 8px;
}

.gallery-lightbox__thumbs::-webkit-scrollbar-thumb {
  background: rgba(45, 35, 29, 0.18);
  border-radius: 999px;
}

.gallery-lightbox__thumbs-nav {
  flex: 0 0 auto;
}

.gallery-lightbox__thumbs-scroller:not(.has-overflow) .gallery-lightbox__thumbs-nav {
  display: none !important;
}

.gallery-lightbox__thumb {
  width: 62px !important;
  height: 62px !important;
}

@media (min-width: 1400px) {
  .gallery-lightbox__panel {
    width: min(97vw, 1820px) !important;
    height: min(96vh, 1180px) !important;
  }

  .gallery-lightbox__image {
    max-height: min(79vh, 980px) !important;
  }

  .gallery-lightbox__thumbs {
    grid-auto-columns: 68px !important;
  }

  .gallery-lightbox__thumb {
    width: 68px !important;
    height: 68px !important;
  }
}

@media (max-width: 1024px) {
  .gallery-lightbox__panel {
    width: min(97vw, 1400px) !important;
    height: min(96vh, 1000px) !important;
  }

  .gallery-lightbox__image {
    max-height: min(72vh, 760px) !important;
  }
}

@media (max-width: 820px) {
  .gallery-lightbox {
    padding: 8px !important;
  }

  .gallery-lightbox__panel {
    width: 100% !important;
    height: min(96vh, 980px) !important;
    border-radius: 22px !important;
    padding: 12px !important;
  }

  .gallery-lightbox__viewport {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .gallery-lightbox__figure {
    grid-template-rows: minmax(0, 1fr) auto !important;
  }

  .gallery-lightbox__media-frame {
    min-height: min(58vh, 560px) !important;
  }

  .gallery-lightbox__image {
    max-height: min(62vh, 620px) !important;
  }

  .gallery-lightbox__nav {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 3 !important;
  }

  .gallery-lightbox__nav--prev {
    left: 8px !important;
  }

  .gallery-lightbox__nav--next {
    right: 8px !important;
  }

  .gallery-lightbox__caption {
    max-width: 96% !important;
    border-radius: 18px !important;
    padding: 10px 14px !important;
  }

  .gallery-lightbox__thumbs {
    grid-auto-columns: 58px !important;
  }

  .gallery-lightbox__thumb {
    width: 58px !important;
    height: 58px !important;
  }
}

@media (max-width: 560px) {
  .gallery-lightbox__panel {
    height: 97vh !important;
    border-radius: 18px !important;
    padding: 10px !important;
    gap: 10px !important;
  }

  .gallery-lightbox__title {
    font-size: 0.9rem !important;
  }

  .gallery-lightbox__counter {
    font-size: 0.8rem !important;
  }

  .gallery-lightbox__media-frame {
    min-height: min(54vh, 470px) !important;
    padding: 8px !important;
  }

  .gallery-lightbox__image {
    max-height: min(58vh, 520px) !important;
  }

  .gallery-lightbox__thumbs-scroller {
    gap: 6px !important;
    min-height: 60px;
  }

  .gallery-lightbox__thumbs {
    grid-auto-columns: 52px !important;
    gap: 8px !important;
  }

  .gallery-lightbox__thumb {
    width: 52px !important;
    height: 52px !important;
    border-radius: 12px !important;
  }
}

/* =========================================================
   FINALISATION V7 — AJUSTEMENTS DE CADRAGE VISIONNEUSE
   - suppression du fond blanc intermédiaire derrière l’image
   - recentrage visuel de l’image et de son bloc
   - infobulle de légende sans contour
========================================================= */

.gallery-lightbox__viewport {
  align-items: center !important;
}

.gallery-lightbox__figure {
  justify-self: center !important;
  align-self: center !important;
  width: auto !important;
  max-width: 100% !important;
}

.gallery-lightbox__media-frame {
  justify-self: center !important;
  align-self: center !important;
  width: auto !important;
  max-width: 100% !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.gallery-lightbox__image {
  justify-self: center !important;
  align-self: center !important;
  margin: 0 auto !important;
  border-radius: 18px !important;
  box-shadow: 0 18px 44px rgba(31, 27, 22, 0.12) !important;
}

.gallery-lightbox__caption {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: 0 8px 18px rgba(31, 27, 22, 0.06) !important;
}

@media (min-width: 821px) {
  .gallery-lightbox__figure {
    width: fit-content !important;
  }

  .gallery-lightbox__media-frame {
    width: fit-content !important;
  }
}

@media (max-width: 820px) {
  .gallery-lightbox__figure {
    width: 100% !important;
  }

  .gallery-lightbox__media-frame {
    width: 100% !important;
  }
}

/* =========================================================
   FINALISATION V8 — RECENTRAGE GRAND ÉCRAN
   - recentrage forcé de la visionneuse sur desktop
   - panneau centré par left/top + transform
   - boutons précédent/suivant en overlay pour éviter le décalage
========================================================= */

.gallery-lightbox {
  position: fixed !important;
  inset: 0 !important;
  display: block !important;
  padding: 0 !important;
}

.gallery-lightbox__panel {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: min(calc(100vw - 32px), 1720px) !important;
  height: min(calc(100vh - 32px), 1120px) !important;
  max-width: none !important;
  max-height: none !important;
  margin: 0 !important;
}

.gallery-lightbox__viewport {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
}

.gallery-lightbox__figure {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  justify-items: center !important;
  align-items: center !important;
  margin: 0 auto !important;
}

.gallery-lightbox__media-frame {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  display: grid !important;
  place-items: center !important;
}

.gallery-lightbox__image {
  display: block !important;
  margin: 0 auto !important;
  max-width: 100% !important;
  max-height: min(calc(100vh - 210px), 900px) !important;
  width: auto !important;
  height: auto !important;
}

.gallery-lightbox__nav {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 4 !important;
}

.gallery-lightbox__nav--prev {
  left: clamp(10px, 1.2vw, 18px) !important;
}

.gallery-lightbox__nav--next {
  right: clamp(10px, 1.2vw, 18px) !important;
}

@media (min-width: 1500px) {
  .gallery-lightbox__panel {
    width: min(calc(100vw - 40px), 1820px) !important;
    height: min(calc(100vh - 40px), 1180px) !important;
  }

  .gallery-lightbox__image {
    max-height: min(calc(100vh - 220px), 980px) !important;
  }
}

@media (max-width: 820px) {
  .gallery-lightbox__panel {
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: calc(100vw - 16px) !important;
    height: calc(100vh - 16px) !important;
  }

  .gallery-lightbox__image {
    max-height: min(calc(100vh - 220px), 620px) !important;
  }

  .gallery-lightbox__nav--prev {
    left: 8px !important;
  }

  .gallery-lightbox__nav--next {
    right: 8px !important;
  }
}


/* =========================================
   FIX V9 — bouton bas galerie sans ombre carrée
========================================= */

.gallery-expand-toggle,
.gallery-expand-toggle:hover,
.gallery-expand-toggle:focus,
.gallery-expand-toggle:focus-visible,
.gallery-expand-toggle:active {
  box-shadow: none !important;
  filter: none !important;
  background: transparent !important;
  border-radius: 999px !important;
  overflow: visible !important;
}

.gallery-expand-toggle::before,
.gallery-expand-toggle::after {
  display: none !important;
  content: none !important;
  box-shadow: none !important;
  filter: none !important;
}

.gallery-expand-toggle__control,
.gallery-expand-toggle .gallery-round-control {
  position: relative !important;
  isolation: isolate !important;
  overflow: visible !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  filter: none !important;
}

.gallery-expand-toggle__control::before,
.gallery-expand-toggle .gallery-round-control::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: -1 !important;
  border-radius: 999px !important;
  background: transparent !important;
  box-shadow: 0 10px 18px rgba(45, 35, 29, 0.10) !important;
}

.gallery-expand-toggle:hover .gallery-expand-toggle__control::before,
.gallery-expand-toggle:hover .gallery-round-control::before,
.gallery-expand-toggle:focus-visible .gallery-expand-toggle__control::before,
.gallery-expand-toggle:focus-visible .gallery-round-control::before {
  box-shadow: 0 12px 22px rgba(45, 35, 29, 0.13) !important;
}

.gallery-expand-toggle:active .gallery-expand-toggle__control::before,
.gallery-expand-toggle:active .gallery-round-control::before {
  box-shadow: 0 6px 12px rgba(45, 35, 29, 0.10) !important;
}

/* =========================================================
   FORMULAIRE CONTACT PHP — champ anti-spam invisible
   Chemin : ./assets/css/styles.css
========================================================= */
.contact-field--website {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.contact-form button[disabled],
.contact-form button[aria-busy="true"] {
  opacity: .72;
  cursor: wait;
}

/* =========================================================
   FIX MENU WORDPRESS — neutralisation UL / LI / container
========================================================= */

.course-nav .menu,
.course-nav .sub-menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

.course-nav .menu {
  display: grid;
  grid-template-columns: repeat(var(--nav-cols, 6), minmax(0, 1fr));
  gap: 12px;
  align-items: center;
  width: 100%;
}

.course-nav .menu-item {
  margin: 0;
  padding: 0;
  min-width: 0;
}

.course-nav .menu-item a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 44px;
  margin: 0;
  padding: 10px 14px;
  border-radius: 999px;
  text-decoration: none;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.4;
  font-size: 0.95rem;
  letter-spacing: 0.05em;
  background: var(--white);
  color: var(--argile);
  border: 1px solid var(--gris);
  box-sizing: border-box;
}

.course-nav .menu-item a:hover,
.course-nav .menu-item a:focus-visible {
  background: var(--white);
  border-color: var(--ink-20);
  box-shadow: var(--btn-ghost-shadow);
}

.course-nav .current-menu-item > a,
.course-nav .current_page_item > a,
.course-nav .current-menu-ancestor > a {
  background: var(--argile);
  color: var(--white);
  border-color: var(--ink-10);
  box-shadow: none;
}

/* Supprime les marges parasites du wrapper de navigation WordPress */
.course-nav > div,
.course-nav > .menu-menu-principal-container,
.course-nav > .menu-container {
  width: 100%;
  margin: 0;
  padding: 0;
}

/* =========================================================
   FIX HEADER WORDPRESS — bandeau du haut
========================================================= */

/* Cibler les liens dans la structure de liste WordPress */
/* Style de base pour tous les boutons du menu WordPress */
/* 1. On réinitialise la liste WordPress pour qu'elle soit invisible visuellement */
.course-nav--primary ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: row !important; /* Force l'alignement horizontal */
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 12px !important;
}

/* 2. On s'assure que le LI n'a AUCUN style (couleur, bordure ou ombre) */
.course-nav--primary ul li {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* 3. On applique tout le design UNIQUEMENT sur le lien <a> */
.course-nav--primary ul li a {
    display: flex !important;
    align-items: center;
    justify-content: center;
    padding: 10px 18px !important; /* Ajustez pour la forme du bouton */
    border-radius: 999px !important;
    text-decoration: none !important;
    transition: all .2s ease;
    
    /* Styles par défaut (Bouton Fantôme) */
    background: var(--white) !important;
    border: 1px solid var(--ink-20) !important;
    color: var(--argile) !important;
}

/* 4. Gestion de la couleur pleine pour le CTA et la page active */
.course-nav--primary ul li.course-nav__cta a,
.course-nav--primary ul li.current-menu-item a {
    background: var(--argile) !important;
    color: var(--white) !important;
    border-color: var(--ink-10) !important;
    box-shadow: none !important; /* Supprime l'ombre portée si elle crée un artefact */
}

/* 5. Hover : on évite que le background du LI ne réapparaisse */
.course-nav--primary ul li a:hover {
    background: var(--paper-80) !important;
    border-color: var(--ink-20) !important;
}

/* Style spécifique pour le bouton ACCUEIL (la classe .course-nav__cta sur le LI) */
.course-nav--primary ul li.course-nav__cta a {
    background: var(--argile) !important;
    color: var(--white) !important;
    border-color: var(--ink-10) !important;
    box-shadow: none;
}

/* Style pour la page active (automatique via WordPress) */
.course-nav--primary ul li.current-menu-item a {
    background: var(--argile);
    color: var(--white);
    border-color: var(--ink-10);
}

/* Effets au survol */
.course-nav--primary ul li a:hover {
    background: var(--paper-80);
    border-color: var(--ink-20);
    box-shadow: var(--btn-ghost-shadow);
    color: var(--argile);
}

/* S'assurer que le bouton actif écrase bien le style fantôme */
.course-nav--primary ul li.current-menu-item a {
    background: var(--argile) !important;
    color: var(--white) !important;
    border-color: var(--ink-10) !important;
}

/* Supplément

.brand__link,
.custom-logo-link.brand__link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.custom-logo-link.brand__link img,
.brand__logo,
.custom-logo {
  display: block;
  width: clamp(150px, 22vw, 220px);
  height: auto;
}

.course-nav {
  display: block;
}

.course-nav .menu {
  width: 100%;
}

.course-nav-group {
  min-width: 0;
} */

/* Forcer la largeur maximale du site */
/* Supprimer les contraintes du thème parent sur les wrappers principaux */
#page, #content, #primary, #theme-main {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
}

/* Forcer le header à utiliser toute la largeur disponible */
.site-header {
    width: 100% !important;
    left: 0 !important;
}

.container, 
.header-inner, 
.hero-grid, 
.course-stack {
    width: min(1120px, calc(100% - 40px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: none !important; /* Annule les limites par défaut de Picostrap */
}

/* Aligner strictement le logo à gauche et le menu à droite du container de 1120px */
.header-inner {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.brand__link {
    margin-left: -5px; /* Petit ajustement optique pour le logo arrondi */
}

.brand {
    padding-left: 0 !important;
    margin-left: 0 !important;
}

html, body {
    overflow-x: hidden !important;
    width: 100% !important;
    position: relative !important;
}

/* Autoriser le contenu à s'afficher mais masquer le scroll horizontal global */
body {
    overflow-x: hidden !important;
}

/* Forcer les sections LiveCanvas à respecter votre largeur de 1120px */
section .container {
    width: min(1120px, calc(100% - 40px)) !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

#theme-main, 
section {
    width: 100% !important;
    position: relative !important;
}

/* Stabiliser la grille Hero */
/*.hero-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1.02fr) minmax(430px, .98fr) !important;
    gap: 38px !important;
    width: 100% !important;
    max-width: 1120px !important;
    margin: 0 auto !important;
}*/

/* Empêcher le texte de couper les blobs qui dépassent sur la gauche */
.hero-copy {
    z-index: 2;
    position: relative;
}

.hero-blobs {
    z-index: 1;
    overflow: visible !important; /* Crucial pour que les blobs respirent */
}

/* Ajustement précis de la grille pour laisser de la place aux blobs */
/* Optimisation de la grille pour l'équilibre texte/blobs */
/*.hero-grid {
    grid-template-columns: minmax(0, 1fr) minmax(450px, 1fr) !important;
    gap: 60px !important; 
    padding: 20px 0 !important;
}*/

/* S'assurer que rien ne vient rogner les ombres des blobs */
.hero {
    overflow: visible !important;
}

/* Sécurité anti-débordement pour les mobiles */
.hero-blobs {
    max-width: 100%;
}

@media (min-width: 992px) {
    .lc_sections_wrapper .hero-blobs--infos .blob--hero-1 {
        left: -10% !important; /* Ajustement desktop WordPress du blob argile. */
    }

    .lc_sections_wrapper .hero-blobs--infos .blob--hero-2 {
        right: -2% !important; /* Ajustement desktop WordPress du blob terracotta. */
    }
}

.row {
    margin-right: 0 !important;
    margin-left: 0 !important;
}

/* Supprimer les contraintes de colonnes de WordPress/Picostrap */
#content, 
#primary, 
.site-main, 
article.page {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* S'assurer que le wrapper LiveCanvas ne limite pas le contenu */
.lc_sections_wrapper {
    width: 100% !important;
    overflow: visible !important;
}

.home-news-item {
    display: grid !important;
    /* On s'assure que la colonne de l'image ne pousse pas le texte hors de l'écran */
    grid-template-columns: minmax(0, 1fr) minmax(200px, 300px) !important; 
}

/* Adaptations mobiles indispensables */
@media (max-width: 991px) {
    /*.hero-grid {
        grid-template-columns: minmax(0, 1fr) minmax(450px, 1fr) !important;
        text-align: center;
    }*/
    
    .lc_sections_wrapper .hero-blobs:not(.hero-blobs--infos):not(.hero-blobs--cours):not(.hero-blobs--stage):not(.hero-blobs--page) {
        display: flex;
        flex-direction: column;
        align-items: center;
        min-height: auto !important;
        gap: 24px;
    }
    
    .lc_sections_wrapper .hero-blobs:not(.hero-blobs--infos):not(.hero-blobs--cours):not(.hero-blobs--stage):not(.hero-blobs--page) .blob {
        position: relative !important;
        inset: auto !important;
        width: min(82vw, 320px) !important;
        max-width: 320px !important;
        min-height: 260px;
        margin: 0 auto;
        --blob-scale: 1.08;
    }

    .home-news-item {
        grid-template-columns: 1fr !important;
    }
}

/* =========================================================
   FIX HEADER WORDPRESS — bandeau du haut
   V7 — ajustement Picostrap5 / LiveCanvas / WordPress
   Objectifs :
   - conserver le bandeau sticky flouté d'origine
   - garder le logo à la bonne taille
   - centrer verticalement les boutons du menu
   - styler le menu uniquement sur le <a>
   - maintenir l'état actif au hover/focus
   - éviter les débordements horizontaux sans couper les blobs
========================================================= */

/* -----------------------------------------
   Wrappers WordPress / Picostrap / LiveCanvas
------------------------------------------ */
#page,
#content,
#primary,
#theme-main,
.site-main,
article.page {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

html,
body {
  width: 100% !important;
  overflow-x: hidden !important;
  position: relative !important;
}

.lc_sections_wrapper {
  width: 100% !important;
  overflow: visible !important;
}

section,
.hero,
.hero-grid,
.hero-copy,
.hero-blobs,
.hero-visual,
.course-stack {
  overflow: visible !important;
}

.hero-copy {
  position: relative;
  z-index: 2;
}

.hero-blobs {
  position: relative;
  z-index: 1;
  max-width: 100%;
}

.row {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* -----------------------------------------
   Header WordPress — structure générale
------------------------------------------ */
.site-header.course-header,
.course-header.site-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 40 !important;
  width: 100% !important;
  left: 0 !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  background: var(--bg-80) !important;
  border-bottom: 1px solid var(--ink-10) !important;
}

.site-header.course-header .container.header-inner,
.course-header.site-header .container.header-inner {
  width: min(1120px, calc(100% - 40px)) !important;
  max-width: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 10px 0 !important;
  min-height: 88px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 24px !important;
}

.site-header.course-header .brand,
.course-header.site-header .brand {
  display: flex !important;
  align-items: center !important;
  flex: 0 0 auto !important;
  min-width: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}

.brand__link,
.custom-logo-link.brand__link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-decoration: none !important;
  line-height: 0 !important;
  margin: 0 !important;
}

.site-header.course-header .custom-logo-link.brand__link img,
.site-header.course-header .brand__logo,
.site-header.course-header .custom-logo,
.course-header.site-header .custom-logo-link.brand__link img,
.course-header.site-header .brand__logo,
.course-header.site-header .custom-logo {
  display: block !important;
  width: clamp(148px, 11vw, 175px) !important;
  height: auto !important;
  max-width: none !important;
}

.site-header.course-header .course-nav-group,
.course-header.site-header .course-nav-group {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  width: auto !important;
  height: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* -----------------------------------------
   Menu desktop — on cible le NAV réel
   Important : ne pas cibler .course-nav seul,
   car cette classe existe aussi sur le <li>.
------------------------------------------ */
nav.course-nav.course-nav--primary {
  display: block !important;
  width: auto !important;
  margin: 0 !important;
}

nav.course-nav.course-nav--primary > ul,
nav.course-nav.course-nav--primary > ul.course-nav__list,
nav.course-nav.course-nav--primary > div > ul,
nav.course-nav.course-nav--primary > .menu,
nav.course-nav.course-nav--primary > .menu-menu-container > ul {
  list-style: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex-wrap: nowrap !important;
  gap: 14px !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

nav.course-nav.course-nav--primary > div,
nav.course-nav.course-nav--primary > .menu-menu-container,
nav.course-nav.course-nav--primary > .menu-container {
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

nav.course-nav.course-nav--primary li,
nav.course-nav.course-nav--primary .menu-item {
  list-style: none !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  min-width: 0 !important;
  display: block !important;
}

nav.course-nav.course-nav--primary li > a,
nav.course-nav.course-nav--primary .menu-item > a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 44px !important;
  padding: 0 22px !important;
  margin: 0 !important;
  border-radius: 999px !important;
  border: 1px solid var(--ink-20) !important;
  background: var(--white) !important;
  box-shadow: none !important;
  color: var(--argile) !important;
  text-decoration: none !important;
  text-align: center !important;
  white-space: nowrap !important;
  line-height: 1 !important;
  font-family: var(--font-ui) !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  vertical-align: middle !important;
  transition:
    background .18s ease,
    border-color .18s ease,
    color .18s ease,
    box-shadow .18s ease !important;
}

nav.course-nav.course-nav--primary li > a:hover,
nav.course-nav.course-nav--primary li > a:focus-visible,
nav.course-nav.course-nav--primary .menu-item > a:hover,
nav.course-nav.course-nav--primary .menu-item > a:focus-visible {
  background: var(--paper-80) !important;
  border-color: var(--ink-20) !important;
  color: var(--argile) !important;
  box-shadow: var(--btn-ghost-shadow) !important;
}

/* -----------------------------------------
   État actif / rubrique courante
------------------------------------------ */
nav.course-nav.course-nav--primary li.course-nav__cta > a,
nav.course-nav.course-nav--primary li.current-menu-item > a,
nav.course-nav.course-nav--primary li.current_page_item > a,
nav.course-nav.course-nav--primary li.current-menu-parent > a,
nav.course-nav.course-nav--primary li.current_page_parent > a,
nav.course-nav.course-nav--primary li.current-menu-ancestor > a,
nav.course-nav.course-nav--primary li.active > a,
nav.course-nav.course-nav--primary a[aria-current="page"] {
  background: var(--argile) !important;
  color: var(--white) !important;
  border-color: var(--ink-10) !important;
  box-shadow: none !important;
}

nav.course-nav.course-nav--primary li.course-nav__cta > a:hover,
nav.course-nav.course-nav--primary li.course-nav__cta > a:focus-visible,
nav.course-nav.course-nav--primary li.current-menu-item > a:hover,
nav.course-nav.course-nav--primary li.current-menu-item > a:focus-visible,
nav.course-nav.course-nav--primary li.current_page_item > a:hover,
nav.course-nav.course-nav--primary li.current_page_item > a:focus-visible,
nav.course-nav.course-nav--primary li.current-menu-parent > a:hover,
nav.course-nav.course-nav--primary li.current-menu-parent > a:focus-visible,
nav.course-nav.course-nav--primary li.current_page_parent > a:hover,
nav.course-nav.course-nav--primary li.current_page_parent > a:focus-visible,
nav.course-nav.course-nav--primary li.current-menu-ancestor > a:hover,
nav.course-nav.course-nav--primary li.current-menu-ancestor > a:focus-visible,
nav.course-nav.course-nav--primary li.active > a:hover,
nav.course-nav.course-nav--primary li.active > a:focus-visible,
nav.course-nav.course-nav--primary a[aria-current="page"]:hover,
nav.course-nav.course-nav--primary a[aria-current="page"]:focus-visible {
  background: var(--argile) !important;
  color: var(--white) !important;
  border-color: var(--ink-10) !important;
  box-shadow: none !important;
}

/* -----------------------------------------
   Mobile
------------------------------------------ */
@media (max-width: 820px) {
  .site-header.course-header .container.header-inner,
  .course-header.site-header .container.header-inner {
    min-height: 72px !important;
    padding: 8px 0 !important;
    gap: 12px !important;
  }

  .site-header.course-header .custom-logo-link.brand__link img,
  .site-header.course-header .brand__logo,
  .site-header.course-header .custom-logo,
  .course-header.site-header .custom-logo-link.brand__link img,
  .course-header.site-header .brand__logo,
  .course-header.site-header .custom-logo {
    width: 136px !important;
  }

  .course-menu-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .site-header.course-header .course-nav-group,
  .course-header.site-header .course-nav-group {
    display: none !important;
    position: absolute !important;
    top: calc(100% + 8px) !important;
    left: 20px !important;
    right: 20px !important;
    height: auto !important;
    padding: 12px !important;
    border-radius: 18px !important;
    border: 1px solid var(--ink-10) !important;
    background: var(--paper-95) !important;
    box-shadow: var(--shadow-soft) !important;
  }

  .site-header.course-header .course-nav-group.is-open,
  .course-header.site-header .course-nav-group.is-open {
    display: block !important;
  }

  nav.course-nav.course-nav--primary > ul,
  nav.course-nav.course-nav--primary > ul.course-nav__list,
  nav.course-nav.course-nav--primary > div > ul,
  nav.course-nav.course-nav--primary > .menu,
  nav.course-nav.course-nav--primary > .menu-menu-container > ul {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    width: 100% !important;
  }

  nav.course-nav.course-nav--primary li > a,
  nav.course-nav.course-nav--primary .menu-item > a {
    width: 100% !important;
    min-height: 42px !important;
    padding: 10px 14px !important;
  }
}

/* =========================================================
   ARTICLES WORDPRESS — présentation chartée
========================================================= */
/*
 * L'Argilière — Actualités WordPress déroulantes
 * Chemin : ./wp-content/themes/picostrap5-child-base/assets/css/argiliere-articles-deroulants.css
 *
 * Complément non destructif :
 * - réutilise .home-news-section, .home-news-list, .home-news-item
 * - réutilise la flèche ronde déjà chartée des galeries
 */

/*
 * L'Argilière — Actualités WordPress compatibles LiveCanvas
 * Chemin : ./wp-content/themes/picostrap5-child-base/assets/css/argiliere-actualites-livecanvas.css
 */

.argiliere-home-news-main {
  margin-top: 0;
}

.argiliere-home-news-section {
  overflow: visible;
}

.argiliere-home-news-list {
  display: grid;
  gap: 18px;
}

.argiliere-home-news-item {
  transition:
    opacity .18s ease,
    transform .18s ease,
    border-color .18s ease,
    box-shadow .18s ease;
}

.argiliere-home-news-item[hidden],
.argiliere-home-news-item.is-news-hidden {
  display: none !important;
}

.argiliere-home-news-item .home-news-item__title a {
  color: inherit;
  text-decoration: none;
}

.argiliere-home-news-item .home-news-item__title a:hover,
.argiliere-home-news-item .home-news-item__title a:focus-visible {
  color: var(--khol);
  text-decoration: none;
}

.argiliere-home-news-item .home-news-item__text {
  display: grid;
  gap: 8px;
}

.argiliere-home-news-item .home-news-item__text p {
  margin: 0;
}

.argiliere-home-news-actions {
  margin-top: 2px;
}

.argiliere-home-news-item .home-news-item__media a {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  overflow: hidden;
  text-decoration: none;
}

.argiliere-home-news-image {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  object-fit: cover;
  object-position: center;
}

.argiliere-home-news-item--no-media {
  grid-template-columns: 1fr !important;
}

.argiliere-home-news-item--no-media .home-news-item__content {
  max-width: 76ch;
}

.argiliere-news-expand-actions {
  margin-top: 22px !important;
}

.argiliere-news-expand-toggle .argiliere-news-expand__icon {
  transition: transform .18s ease;
  transform-origin: center;
}

.argiliere-news-expand-toggle.is-expanded .argiliere-news-expand__icon {
  transform: rotate(180deg);
}

.argiliere-actualites-lc {
  min-height: 1px;
}

@media (prefers-reduced-motion: reduce) {
  .argiliere-home-news-item,
  .argiliere-news-expand-toggle .argiliere-news-expand__icon {
    transition: none !important;
  }
}



/* =========================================================
   GALERIES WORDPRESS / LIVECANVAS — boutons précédent/suivant
========================================================= */

.js-argiliere-gallery,
.gallery-carousel-shell[data-argiliere-gallery="true"] {
  position: relative;
  overflow: visible;
}

.js-argiliere-gallery .about-gallery-grid,
.gallery-carousel-shell[data-argiliere-gallery="true"] .about-gallery-grid {
  margin: 0;
}

.js-argiliere-gallery .is-carousel-hidden,
.gallery-carousel-shell[data-argiliere-gallery="true"] .is-carousel-hidden {
  display: none !important;
}

.js-argiliere-gallery .gallery-carousel-nav,
.gallery-carousel-shell[data-argiliere-gallery="true"] .gallery-carousel-nav {
  z-index: 6;
}

.js-argiliere-gallery .gallery-carousel-nav[hidden],
.gallery-carousel-shell[data-argiliere-gallery="true"] .gallery-carousel-nav[hidden] {
  display: none !important;
}

.gallery-carousel-nav svg,
.gallery-icon {
  display: block;
  width: var(--gallery-ui-icon-size, 15px);
  height: var(--gallery-ui-icon-size, 15px);
}

/* Les boutons restent hors du cadre sur desktop, puis passent en bas sur mobile
   selon les règles déjà présentes dans styles.css. */
@media (max-width: 900px) {
  .js-argiliere-gallery,
  .gallery-carousel-shell[data-argiliere-gallery="true"] {
    padding-bottom: 48px;
  }
}

/* =========================================================
   NAVIGATION INTERNE — SOLUTION DE FORCE BRUTE (RESET COMPLET)
========================================================= */

/* 1. DESKTOP (Écrans > 820px) : On force l'alignement en ligne sans concession */
@media (min-width: 821px) {
    /* On cible le conteneur NAV et TOUTES les listes qu'il pourrait contenir */
    header.course-header nav.course-nav--primary,
    header.course-header nav.course-nav--primary div,
    header.course-header nav.course-nav--primary ul {
        display: flex !important;
        flex-direction: row !important; /* Force la ligne */
        flex-wrap: nowrap !important;
        grid-template-columns: none !important; /* Annule toute grille résiduelle */
        align-items: center !important;
        justify-content: flex-end !important;
        width: auto !important;
        height: auto !important;
        min-height: 0 !important;
        gap: 12px !important;
    }

    /* On neutralise les éléments de liste pour qu'ils ne bloquent pas le flux */
    header.course-header nav.course-nav--primary li {
        display: inline-block !important;
        margin: 0 !important;
        padding: 0 !important;
        width: auto !important;
        background: transparent !important;
    }

    /* On s'assure que les liens sont des boutons côte à côte */
    header.course-header nav.course-nav--primary li a {
        display: inline-flex !important;
        white-space: nowrap !important; /* Interdit le retour à la ligne du texte */
        padding: 10px 20px !important;
        width: auto !important;
    }
}

/* 2. MOBILE (Écrans <= 820px) : On restaure votre affichage vertical propre */
@media (max-width: 820px) {
    header.course-header .course-nav-group.is-open,
    header.course-header .course-nav-group[style*="display: block"] {
        display: block !important;
    }

    header.course-header nav.course-nav--primary ul {
        display: flex !important;
        flex-direction: column !important; /* Force la colonne */
        align-items: stretch !important;
        gap: 8px !important;
        width: 100% !important;
    }

    header.course-header nav.course-nav--primary li a {
        width: 100% !important;
        justify-content: center !important;
    }
}

/* =========================================================
   FIX VISIBILITÉ TOTALE : RÉVÉLATION CONTACT (ROLLOVER)
========================================================= */

/* On cible le lien de révélation dans le groupe concerné */
.reveal-group a[href^="tel:"], 
.reveal-group a[href^="mailto:"],
.reveal-group .reveal-link {
    color: var(--ink) !important; /* Couleur sombre initiale */
    opacity: 1 !important;
    text-decoration: none !important;
    transition: all 0.2s ease-in-out !important;
}

/* FORCE L'AFFICHAGE AU ROLLOVER (SURVOL) */
/* On écrase TOUT ce qui pourrait rendre le lien blanc ou transparent */
.reveal-group a[href^="tel:"]:hover, 
.reveal-group a[href^="mailto:"]:hover,
.reveal-group .reveal-link:hover,
.reveal-group a:focus,
.reveal-group a:active {
    color: var(--argile) !important; /* Couleur terre cuite au survol */
    background: transparent !important; /* Évite un fond blanc qui masquerait le texte */
    opacity: 1 !important;
    text-decoration: underline !important;
    visibility: visible !important;
}

/* Si le script injecte le numéro dans un conteneur spécifique ligne 5082 */
.reveal-group span[data-reveal-display] a:hover {
    color: var(--argile) !important;
}

/* =========================================================
   FIX CONTACT — révélation téléphone stable au clic / hover
   Chemin : ./assets/css/styles.css
   À conserver tout en bas du fichier.
========================================================= */

.contact-direct-band [data-reveal="phone"],
.contact-direct-band .contact-form__actions[data-reveal="phone"] {
  width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
}

.contact-direct-band [data-reveal="phone"] .btn,
.contact-direct-band [data-reveal="phone"] .reveal-link,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .btn,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 48px !important;
  padding: 12px 24px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  border-radius: 999px !important;
  box-sizing: border-box !important;
  font-family: var(--font-ui) !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em !important;
  line-height: 1.4 !important;
  text-align: center !important;
  text-decoration: none !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.contact-direct-band [data-reveal="phone"] .reveal-link,
.contact-direct-band [data-reveal="phone"] .reveal-link:link,
.contact-direct-band [data-reveal="phone"] .reveal-link:visited,
.contact-direct-band [data-reveal="phone"] .reveal-link:hover,
.contact-direct-band [data-reveal="phone"] .reveal-link:focus,
.contact-direct-band [data-reveal="phone"] .reveal-link:focus-visible,
.contact-direct-band [data-reveal="phone"] .reveal-link:active,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link:link,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link:visited,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link:hover,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link:focus,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link:focus-visible,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link:active {
  background: var(--terracotta) !important;
  border: 1px solid var(--ink-20) !important;
  color: var(--white) !important;
  box-shadow: 0 8px 18px var(--ink-deep-10) !important;
  text-shadow: none !important;
  -webkit-text-fill-color: var(--white) !important;
}

.contact-direct-band [data-reveal="phone"] .reveal-link:hover,
.contact-direct-band [data-reveal="phone"] .reveal-link:focus-visible,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link:hover,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link:focus-visible {
  background: var(--khol) !important;
  border-color: var(--btn-ghost-border-hover) !important;
  color: var(--white) !important;
  -webkit-text-fill-color: var(--white) !important;
}

.contact-direct-band [data-reveal="phone"] .reveal-link:active,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link:active {
  transform: translateY(1px) !important;
  color: var(--white) !important;
  -webkit-text-fill-color: var(--white) !important;
}

.contact-direct-band [data-reveal="phone"] .reveal-link *,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link *,
.contact-direct-band [data-reveal="phone"] .reveal-link__text,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link__text {
  color: inherit !important;
  -webkit-text-fill-color: currentColor !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.contact-direct-band [data-reveal="phone"] .reveal-link__text,
.contact-direct-band .contact-form__actions[data-reveal="phone"] .reveal-link__text {
  display: inline-block !important;
  min-width: 0 !important;
  white-space: nowrap !important;
}

/* =========================================================
   FIX GALERIE — stabilisation des boutons précédent / suivant
   Chemin : ./assets/css/styles.css
   À conserver tout en bas du fichier.
   Objectif : supprimer le décalage vertical au clic tout en gardant
   le retour visuel par réduction légère.
========================================================= */

/* État actif commun : plus de translation verticale parasite */
.gallery-round-control:active {
  transform: scale(0.98) !important;
}

/* Carrousel de galerie : les boutons sont centrés avec translateY(-50%).
   On conserve ce centrage au clic et on supprime le +1px vertical. */
.gallery-carousel-nav:active,
.gallery-carousel-nav--prev:active,
.gallery-carousel-nav--next:active {
  transform: translateY(-50%) scale(0.98) !important;
}

/* Visionneuse / lightbox : même principe, les flèches restent strictement
   centrées verticalement pendant le clic. */
.gallery-lightbox__nav:active,
.gallery-lightbox__nav--prev:active,
.gallery-lightbox__nav--next:active {
  transform: translateY(-50%) scale(0.98) !important;
}

/* Boutons de défilement des miniatures : pas de descente au clic. */
.gallery-lightbox__thumbs-nav:active {
  transform: scale(0.98) !important;
}

/* Bouton d’ouverture/fermeture de galerie étendue : stabilisé aussi,
   au cas où il réutilise .gallery-round-control. */
.gallery-expand-toggle:active .gallery-round-control,
.gallery-expand-toggle:active .gallery-expand-toggle__control {
  transform: scale(0.98) !important;
}

/* Variante mobile : les boutons de carrousel ne sont plus centrés par top:50%,
   ils sont placés en bas ; il ne faut donc pas réinjecter translateY(-50%). */
@media (max-width: 900px) {
  .gallery-carousel-nav:active,
  .gallery-carousel-nav--prev:active,
  .gallery-carousel-nav--next:active {
    transform: scale(0.98) !important;
  }
}

/* Sécurité accessibilité : en réduction de mouvement, on conserve les positions
   strictement stables sans animation. */
@media (prefers-reduced-motion: reduce) {
  .gallery-round-control:active,
  .gallery-carousel-nav:active,
  .gallery-lightbox__nav:active,
  .gallery-lightbox__thumbs-nav:active,
  .gallery-expand-toggle:active .gallery-round-control,
  .gallery-expand-toggle:active .gallery-expand-toggle__control {
    transition: none !important;
  }
}


/* =========================================================
   PATCH RESPONSIVE — TITRE HEADER MAINTENANCE
   Objectif : éviter que "Site internet en construction ..."
   soit coupé sur mobile sans modifier le HTML validé.
========================================================= */

@media (max-width: 680px) {
  .page-progress .site-header .header-inner {
    gap: 12px;
  }

  .page-progress .site-header .header-inner > h2 {
    max-width: min(54vw, 18ch);
    font-size: clamp(0.72rem, 3.4vw, 0.9rem);
    line-height: 1.4;
    letter-spacing: 0.03em;
  }
}

@media (max-width: 360px) {
  .page-progress .site-header .header-inner {
    gap: 8px;
  }

  .page-progress .site-header .brand__logo {
    width: clamp(118px, 40vw, 150px);
  }

  .page-progress .site-header .header-inner > h2 {
    max-width: calc(100vw - 150px);
    font-size: 0.68rem;
    line-height: 1.4;
    letter-spacing: 0.02em;
  }
}


/* =========================================================
   FIX PROFIL — libellés fixes des catégories Céline Lecou
   Chemin : ./assets/css/styles.css
   Objectif : afficher les 3 titres de catégories par défaut,
   sans effet de rollover, tout en conservant le comportement
   normal des autres vignettes de galerie.
========================================================= */

.accueil-page .celine-feature__gallery .gallery-card--fixed-label,
.about-profil-page .celine-feature__gallery .gallery-card--fixed-label {
  position: relative;
}

/* Les cartes de catégories ne doivent pas hériter du voile/texte de rollover. */
.gallery-hover-grid .about-gallery-card.gallery-card--fixed-label::before,
.gallery-hover-grid .about-gallery-card.gallery-card--fixed-label::after,
.gallery-hover-grid .about-gallery-card.gallery-card--fixed-label:hover::before,
.gallery-hover-grid .about-gallery-card.gallery-card--fixed-label:hover::after,
.gallery-hover-grid .about-gallery-card.gallery-card--fixed-label:focus-within::before,
.gallery-hover-grid .about-gallery-card.gallery-card--fixed-label:focus-within::after {
  content: none !important;
  display: none !important;
  opacity: 0 !important;
}

/* On réaffiche uniquement le figcaption de ces 3 cartes, masqué ailleurs. */
.accueil-page .celine-feature__gallery .gallery-card--fixed-label figcaption,
.about-profil-page .celine-feature__gallery .gallery-card--fixed-label figcaption {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: grid !important;
  place-items: center;
  place-content: center;
  align-content: center !important;
  justify-content: center !important;
  padding: 18px;
  border-radius: inherit;
  background: var(--argile-logo); /*--gallery-hover-overlay*/
  color: var(--white);
  text-align: center;
  text-transform: uppercase;
  font-size: clamp(0.82rem, 1.4vw, 0.98rem);
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.06em;
  pointer-events: none;
  text-wrap: balance;
}

@media (max-width: 560px) {
  .accueil-page .celine-feature__gallery .gallery-card--fixed-label figcaption,
  .about-profil-page .celine-feature__gallery .gallery-card--fixed-label figcaption {
    padding: 14px;
    font-size: 0.82rem;
  }
}

/* =========================================================
   PATCH RESPONSIVE — MICRO ÉCRANS <= 300 PX — VERSION 3
   Chemin : ./assets/css/styles.css
   Objectif : réduire les marges droites/gauches d'au moins 2/3
   sur les très petites résolutions, sans modifier le HTML, le PHP ni le JS.

   Correction v2 : prise en compte explicite de .course-stack et
   des règles plus spécifiques section .container / .container.course-stack
   présentes plus bas dans la feuille.

   Correction v3 : prise en compte explicite de .home-stack,
   .home-section, .home-news-section et .home-news-item__content,
   afin de supprimer les retraits restants dans la zone Actualités.

   Base existante <= 560px : .container = calc(100% - 18px)
   Reset WP existant       : section .container / .course-stack = calc(100% - 40px)
   Nouveau <= 300px        : conteneurs principaux = calc(100% - 6px)
   Gain horizontal         : -12px vs mobile, -34px vs reset WP.
========================================================= */

@media (max-width: 300px) {
  :root {
    --micro-page-gutter: 10px;
    --micro-panel-gutter: 10px;
    --micro-component-gutter: 12px;
  }

  /*
   * Conteneurs principaux.
   * Important : section .container, .container.course-stack et .container.home-stack
   * sont inclus pour surclasser le reset plus spécifique qui force calc(100% - 40px).
   */
  .container,
  section .container,
  .container.course-stack,
  .container.home-stack,
  .course-main > .container,
  .course-main > .container.course-stack,
  .home-main > .container,
  .home-main > .container.home-stack,
  .hero > .container,
  .section > .container {
    width: min(1120px, calc(100% - var(--micro-page-gutter))) !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /*
   * .course-stack / .home-stack peuvent recevoir une largeur propre via le reset WP
   * ou via .container. On l'annule lorsqu'ils sont utilisés comme conteneurs,
   * sans changer leur rôle de grille.
   */
  .course-stack,
  .home-stack,
  .container.course-stack,
  .container.home-stack {
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .container.course-stack,
  .container.home-stack {
    width: min(1120px, calc(100% - var(--micro-page-gutter))) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Grilles internes : elles remplissent le conteneur au lieu de recréer une marge interne. */
  .hero-grid:not(.container),
  .featured-top:not(.container),
  .course-stack:not(.container),
  .home-stack:not(.container),
  .contact-layout:not(.container),
  .contact-secondary-grid:not(.container) {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Header : garde le logo/menu alignés avec la nouvelle largeur utile. */
  .header-inner,
  .container.header-inner,
  .site-header.course-header .container.header-inner,
  .course-header.site-header .container.header-inner {
    width: min(1120px, calc(100% - var(--micro-page-gutter))) !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Neutralisation des retraits horizontaux sur les wrappers principaux. */
  .hero,
  .section,
  .course-main,
  .home-main,
  .editorial-feature {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Espacements entre blocs resserrés pour éviter l'effet de grandes gouttières. */
  .hero-grid,
  .featured-top,
  .course-stack,
  .home-stack,
  .contact-layout,
  .contact-secondary-grid,
  .course-formulas,
  .course-formulas__group,
  .course-formulas__grid,
  .course-info-grid,
  .tech-grid,
  .about-card-grid,
  .info-card-grid,
  .about-two-cols,
  .page-columns,
  .atelier-practice-layout,
  .home-news-list {
    gap: 10px !important;
  }

  /* Panneaux principaux : les contenus gagnent de la largeur utile. */
  .course-section,
  .home-section,
  .home-news-section,
  .featured-shell,
  .featured-main,
  .featured-aside,
  .contact,
  .course-cta,
  .tech-card,
  .course-info-card,
  .about-card,
  .info-card,
  .about-highlight,
  .contact-form-card,
  .contact-map-card,
  .contact-social-band,
  .contact-direct-band,
  .home-news-item,
  .celine-feature,
  .artist-feature {
    padding-left: var(--micro-panel-gutter) !important;
    padding-right: var(--micro-panel-gutter) !important;
  }

  /*
   * Actualités : correction spécifique demandée.
   * .home-section.home-news-section gardait son padding de carte,
   * et .home-news-item__content ajoutait encore 22/24px en interne.
   */
  .home-section.home-news-section {
    padding-left: var(--micro-panel-gutter) !important;
    padding-right: var(--micro-panel-gutter) !important;
  }

  .home-news-item__content {
    padding-left: var(--micro-panel-gutter) !important;
    padding-right: var(--micro-panel-gutter) !important;
  }

  .home-news-item__media {
    width: 100% !important;
    max-width: 100% !important;
    justify-self: stretch !important;
  }

  /* Corps internes déjà très paddés : réduction sans toucher à la logique des composants. */
  .course-formula__body,
  .contact-map-card__body,
  .contact-form__actions,
  .contact-social-band .contact-form__actions,
  .contact-direct-band .contact-form__actions {
    padding-left: var(--micro-panel-gutter) !important;
    padding-right: var(--micro-panel-gutter) !important;
  }

  /* Petits composants : retrait horizontal diminué, hauteur et comportements conservés. */
  .btn,
  .reveal-btn,
  .reveal-link {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .course-info-bubble,
  .pricing-info-bubble,
  .reserver-info-bubble,
  .course-chip,
  .featured-badge {
    padding-left: var(--micro-component-gutter) !important;
    padding-right: var(--micro-component-gutter) !important;
  }

  /* Les blocs visuels gardent leur fonctionnement, mais ne dépassent plus la largeur utile. */
  .hero-blobs--infos,
  .hero-blobs--stage,
  .hero-blobs--cours,
  .course-signup-blobs,
  .atelier-practice-blobs {
    padding-left: 0 !important;
    padding-right: 0 !important;
    gap: 18px !important;
  }

  .hero-blobs--infos .blob,
  .hero-blobs--stage .blob,
  .hero-blobs--cours .blob,
  .course-signup-blobs .blob,
  .atelier-practice-blobs .blob {
    width: var(--blob-mobile-width, min(78vw, 228px)) !important;
    max-width: min(var(--blob-mobile-max-width, 228px), calc(100vw - var(--micro-page-gutter))) !important;
    min-height: var(--blob-mobile-min-height, 204px) !important;
    --blob-scale: var(--blob-mobile-scale, 1.02);
  }

  /* Tableaux : aucune suppression du scroll, uniquement suppression de marge parasite. */
  .table-shell {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

/* =========================================
   DOCUMENTS LÉGAUX — pages publiques
========================================= */
.page-legal .legal-doc-content {
  display: grid;
  gap: 18px;
}

.page-legal .legal-doc-block {
  padding: 16px 18px;
  border-radius: 18px;
  background: var(--paper-95);
  border: 1px solid var(--ink-10);
}

.page-legal .legal-doc-block h3 {
  margin: 0 0 8px;
  color: var(--terra);
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 900;
}

.page-legal .legal-doc-block p {
  margin: 0;
  color: var(--ink-80);
}

.contact-privacy-note {
  margin: 0;
  padding: 0 18px 18px;
  color: var(--ink-70);
  font-size: 0.88rem;
  line-height: 1.5;
}

.contact-privacy-note a,
.footer-legal-links a {
  color: var(--khol);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.footer-legal-links {
  margin: 0;
  color: var(--ink-70);
}

/* =========================================================
   FIX GALERIE — catégories à fond uni piloté par CSS
   Chemin : ./assets/css/styles.css
   Objectif : ne plus dépendre de la couleur du fichier vide.webp.
========================================================= */

.accueil-page .celine-feature__gallery .gallery-card--fixed-label,
.about-profil-page .celine-feature__gallery .gallery-card--fixed-label {
  aspect-ratio: 1 / 1 !important;
  background: var(--argile-logo, var(--argile)) !important;
  border-color: var(--terracotta-20) !important;
}

.accueil-page .celine-feature__gallery .gallery-card--fixed-label > img,
.about-profil-page .celine-feature__gallery .gallery-card--fixed-label > img {
  opacity: 0 !important;
}

.accueil-page .celine-feature__gallery .gallery-card--fixed-label figcaption,
.about-profil-page .celine-feature__gallery .gallery-card--fixed-label figcaption {
  background: var(--argile-logo, var(--argile)) !important;
  color: var(--white) !important;
}

.gallery-lightbox__label-card {
  display: none !important;
}

.gallery-lightbox.is-gallery-label-slide .gallery-lightbox__viewport {
  align-items: center !important;
}

.gallery-lightbox.is-gallery-label-slide .gallery-lightbox__figure {
  height: 100% !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-rows: minmax(0, 1fr) !important;
  align-content: center !important;
  align-items: center !important;
  justify-items: center !important;
}

.gallery-lightbox.is-gallery-label-slide .gallery-lightbox__media-frame {
  --gallery-label-card-size: min(600px, calc(100vw - 220px), calc(100vh - 250px));
  width: var(--gallery-label-card-size) !important;
  height: var(--gallery-label-card-size) !important;
  max-width: 600px !important;
  max-height: 600px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  align-self: center !important;
  justify-self: center !important;
  display: grid !important;
  place-items: center !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  border: 1px solid var(--terracotta-20) !important;
  background: var(--argile-logo, var(--argile)) !important;
  box-shadow: 0 18px 44px rgba(31, 27, 22, .16) !important;
}

.gallery-lightbox.is-gallery-label-slide .gallery-lightbox__image {
  display: none !important;
}

.gallery-lightbox.is-gallery-label-slide .gallery-lightbox__caption {
  display: none !important;
}

.gallery-lightbox.is-gallery-label-slide .gallery-lightbox__label-card {
  display: grid !important;
  place-items: center !important;
  width: 100% !important;
  height: 100% !important;
  padding: clamp(22px, 4vw, 48px) !important;
  background: var(--argile-logo, var(--argile)) !important;
  color: var(--white) !important;
  text-align: center !important;
  text-transform: uppercase !important;
  font-size: clamp(1.15rem, 3vw, 2.1rem) !important;
  line-height: 1.25 !important;
  font-weight: 500 !important;
  letter-spacing: .08em !important;
  text-wrap: balance !important;
}

.gallery-lightbox__thumb.is-gallery-label-thumb {
  display: grid !important;
  place-items: center !important;
  background: var(--argile-logo, var(--argile)) !important;
}

.gallery-lightbox__thumb.is-gallery-label-thumb img {
  display: none !important;
}

.gallery-lightbox__thumb-label {
  display: grid !important;
  place-items: center !important;
  width: 100% !important;
  height: 100% !important;
  padding: 7px !important;
  color: var(--white) !important;
  text-align: center !important;
  text-transform: uppercase !important;
  font-size: .52rem !important;
  line-height: 1.15 !important;
  font-weight: 500 !important;
  letter-spacing: .045em !important;
  overflow: hidden !important;
}

@media (max-width: 900px) {
  .gallery-lightbox.is-gallery-label-slide .gallery-lightbox__media-frame {
    --gallery-label-card-size: min(600px, calc(100vw - 92px), calc(100vh - 245px));
  }
}

@media (max-width: 560px) {
  .gallery-lightbox.is-gallery-label-slide .gallery-lightbox__media-frame {
    --gallery-label-card-size: min(600px, calc(100vw - 42px), calc(100vh - 218px));
    border-radius: 18px !important;
  }

  .gallery-lightbox.is-gallery-label-slide .gallery-lightbox__label-card {
    padding: 20px !important;
    font-size: clamp(1rem, 6vw, 1.45rem) !important;
    letter-spacing: .06em !important;
  }
}

