/* === Variables & thèmes === */
:root{
  --bg: #0b0c10;
  --card: #111318;
  --text: #e9eef3;
  --muted: #a7b0bb;
  --brand: #6ee7ff;
  --brand-2: #9b8cff;
  --accent: #19d3a6;
  --border: #222734;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}

@media (prefers-color-scheme: light){
  :root{
    --bg: #f6f7fb;
    --card: #ffffff;
    --text: #0c1222;
    --muted: #4a5568;
    --brand: #2563eb;
    --brand-2: #7c3aed;
    --accent: #10b981;
    --border: #e6e8ef;
    --shadow: 0 10px 30px rgba(2,12,27,.07);
  }
}

/* === Reset moderne (léger) === */
*{ box-sizing: border-box; }
html:focus-within { scroll-behavior: smooth; }
html,body{ height: 100%; }
:where(html, body){ overflow-x: clip; }
body{
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background: radial-gradient(1200px 600px at 10% -10%, color-mix(in oklab, var(--brand) 15%, transparent), transparent),
              radial-gradient(800px 400px at 110% 0%, color-mix(in oklab, var(--brand-2) 18%, transparent), transparent),
              var(--bg);
  color: var(--text);
  line-height: 1.7;
  font-size: clamp(16px, 1.2vw, 18px);
  text-rendering: optimizeLegibility;
    min-height: 100vh;             /* fallback */
  min-height: 100svh;            /* iOS (UI visible) */
  min-height: 100dvh;            /* viewport dynamique moderne */
  display: flex;                 /* clé n°1 */
  flex-direction: column;        /* colonne */
  /* optionnel: gap entre les blocs si tu veux un espacement global */
  /* gap: 56px; */
}

/* Liens */
a{
  color: var(--brand);
  text-decoration: none;
}
a:hover{ text-decoration: underline; }

/* Containers */
.container{
  width: min(1080px, 90vw);
  margin-inline: auto;
}

/* === Footer du site === */
.site-footer{
  margin-top: auto;              /* clé n°2 : pousse le footer en bas */
  padding: 20px 0 max(20px, env(safe-area-inset-bottom));
  border-top: 1px solid var(--border);
  color: var(--muted);
  font-size: 12px;
}
.site-footer .foot-links{
  display: flex; gap: .6rem; align-items: center; flex-wrap: wrap;
}

/* === Header / Bandeau (inchangé + ajouts) === */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: saturate(160%) blur(10px);
  background: color-mix(in oklab, var(--bg) 80%, transparent);
  border-bottom: 1px solid var(--border);
}
.site-header .container{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 14px 0;
}
.brand{
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  font-weight: 700;
  letter-spacing: .2px;
  color: var(--text);
}
.logo-dot{
  width: 12px; height: 12px; border-radius: 999px;
  background: linear-gradient(135deg, var(--brand), var(--accent));
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--brand) 25%, transparent);
}
.brand-text{ font-size: 1.05rem; }

.site-nav{
  display: flex; gap: 1rem; flex-wrap: wrap;
}
.site-nav a{
  padding: .45rem .8rem;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--brand) 15%, var(--border));
  background: color-mix(in oklab, var(--card) 92%, transparent);
  font-size: 15px;
}
.site-nav a:hover{
  background: color-mix(in oklab, var(--brand) 8%, var(--card));
  text-decoration: none;
}

/* --- Bouton menu mobile --- */
.nav-toggle{
  display: none; /* visible seulement < 550px */
  inline-size: 42px; block-size: 42px;
  border-radius: 12px;
  border: 1px solid color-mix(in oklab, var(--brand) 15%, var(--border));
  background: color-mix(in oklab, var(--card) 94%, transparent);
  color: var(--text);
  display: none;
  align-items: center; justify-content: center;
  transition: transform .2s ease, background-color .2s ease, border-color .2s ease;
}
.nav-toggle:hover{ background: color-mix(in oklab, var(--brand) 8%, var(--card)); }
.nav-toggle:active{ transform: scale(.98); }
.nav-toggle .icon-close{ display: none; }
.nav-toggle[aria-expanded="true"] .icon-burger{ display: none; }
.nav-toggle[aria-expanded="true"] .icon-close{ display: block; }

/* --- Menu déroulant mobile --- */
.mobile-menu{
  position: absolute;
  right: 0.75rem;
  top: calc(100% + 10px);
  min-inline-size: min(88vw, 320px);
  padding: .5rem;
  border-radius: 16px;
  border: 1px solid color-mix(in oklab, var(--brand) 15%, var(--border));
  background: color-mix(in oklab, var(--card) 96%, transparent);
  box-shadow: 0 10px 30px color-mix(in oklab, var(--text) 12%, transparent);
  opacity: 0;
  transform: translateY(-6px) scale(.98);
  transition: opacity .18s ease, transform .18s ease;
}
.mobile-menu.open{
  opacity: 1;
  transform: translateY(0) scale(1);
}
.mobile-menu nav{
  display: grid; gap: .25rem;
}
.mobile-menu .menu-link{
  display: block;
  padding: .7rem .85rem;
  border-radius: 12px;
  color: var(--text);
  border: 1px solid transparent;
}
.mobile-menu .menu-link:hover{
  background: color-mix(in oklab, var(--brand) 10%, var(--card));
  border-color: color-mix(in oklab, var(--brand) 15%, var(--border));
  text-decoration: none;
}

/* Réduction des animations si demandé */
@media (prefers-reduced-motion: reduce){
  .nav-toggle{ transition: none; }
  .mobile-menu{ transition: none; }
}

/* Supprime tout anneau/halo de focus dans le menu mobile */
.mobile-menu .menu-link:focus,
.mobile-menu .menu-link:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

/* (Optionnel) supprime le flash iOS/Android au tap */
.mobile-menu .menu-link {
  -webkit-tap-highlight-color: transparent;
}

/* --- Points de rupture --- */
@media (max-width: 750px){
  .site-nav{ display: none; }         /* cache la nav desktop */
  .nav-toggle{ display: inline-flex; }/* montre le bouton menu */

  /* s'assurer que le conteneur est contexte pour le menu absolu */
  .site-header .container{ position: relative; }
}
@media (min-width: 751px){
  .nav-toggle{ display: none; }
  .mobile-menu{ display: none !important; }
}

/* ===== 870px ===== */
@media (max-width: 870px){
  .logo-dot{ width: 11.5px; height: 11.5px; box-shadow: 0 0 0 3.5px color-mix(in oklab, var(--brand) 25%, transparent); }
  .brand-text{ font-size: 1rem; }
  .site-nav{ gap: .9rem; }
  .site-nav a{ padding: .42rem .7rem; font-size: .8rem; }
}

/* ===== 800px ===== */
@media (max-width: 800px){
  .logo-dot{ width: 11.5px; height: 11.5px; box-shadow: 0 0 0 3.5px color-mix(in oklab, var(--brand) 25%, transparent); }
  .brand-text{ font-size: 1rem; }
  .site-nav{ gap: .9rem; }
  .site-nav a{ padding: .42rem .7rem; font-size: .7rem; }
}

/* ===== 700px ===== */
@media (max-width: 700px){
  .logo-dot{ width: 11px; height: 11px; box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand) 25%, transparent); }
  .brand-text{ font-size: .95rem; }
}

/* ===== 600px ===== */
@media (max-width: 600px){
  .logo-dot{ width: 10px; height: 10px; }
  .brand-text{ font-size: .8rem; }
  .site-footer{font-size: 11px;}
}
/* ===== 500px ===== */
@media (max-width: 500px){
  .site-footer{font-size: 10px;}
}

/* -------------------- - CORPS - -------------------- */

/* === Main / Article === */
.site-main{
  padding-block: min(6vh, 48px);
  padding-inline: 0;
}

.perso{
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  border-radius: 20px;
  padding: clamp(20px, 4vw, 48px);
  /* largeur qui respecte max 750px ET 10px de marge aux bords */
  inline-size: min(750px, 100% - 20px); /* équiv. width */
  margin-inline: auto;                   /* centre le bloc */
  box-sizing: border-box;                /* padding + bordure inclus */
  margin-block: clamp(24px, 6svh, 72px);
  display: grid;
  grid-template-columns: minmax(140px, 240px) 1fr; /* photo | texte */
  gap: clamp(16px, 3vw, 32px);
  align-items: center;
}

/* Image à gauche */
.perso-media{
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  background:
    radial-gradient(120% 120% at 0% 0%, color-mix(in oklab, var(--brand) 10%, transparent), transparent),
    radial-gradient(120% 120% at 100% 0%, color-mix(in oklab, var(--brand-2) 12%, transparent), transparent);
}
.perso-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Texte à droite */
.perso-body{ min-width: 0; }
.perso-name{
  margin: 0 0 .2rem 0;
  font-size: clamp(22px, 3.2vw, 28px);
  line-height: 1.15;
  letter-spacing: -0.01em;
  background: linear-gradient(135deg, var(--text), color-mix(in oklab, var(--brand) 30%, var(--text)));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.perso-bio{
  margin: 0 0 1rem 0;
  color: color-mix(in oklab, var(--text) 92%, var(--muted));
}

/* Actions */
.perso-actions{ display: flex; gap: .6rem; flex-wrap: wrap; }
.btn{
  display: inline-flex; align-items: center; justify-content: center;
  padding: .55rem .9rem; border-radius: 12px; font-weight: 700;
  border: 1px solid color-mix(in oklab, var(--brand) 25%, var(--border));
  background: color-mix(in oklab, var(--brand) 10%, var(--card));
  text-decoration: none; color: var(--text);
}
.btn:hover{ background: color-mix(in oklab, var(--brand) 18%, var(--card)); text-decoration: none; }
.btn-ghost{ background: transparent; }
.btn-ghost:hover{ background: color-mix(in oklab, var(--brand) 10%, var(--card)); }

/* Responsive : empiler sur petit écran et centrer le texte */

@media (max-width: 700px){
  /* Si ta fiche passe en 1 colonne sur mobile */
  .perso{
    /* photo à largeur naturelle contrôlée, texte prend le reste */
    grid-template-columns: auto minmax(0, 1fr);
    justify-items: start;   /* aligne le contenu de chaque cellule à gauche */
    align-items: start;     /* aligne en haut */
    text-align: left;       /* au cas où tu avais centré le texte avant */
    gap: 12px;              /* gap un peu plus serré sur petit écran */
  }
  .perso-bio{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 15px;           /* centre la photo */
  }
  .perso-media{
    /* ← la photo ne prendra jamais toute la largeur */
    width: clamp(160px, 40vw, 70px);  /* min 160px, idéal 60% vw, max 300px */
    margin-inline: auto;               /* centre la photo */
    inline-size: clamp(120px, 35vw, 200px);
    margin: 0;              /* pas de centrage de la photo */
  }
  /* tu peux garder ces règles telles quelles */
  .perso-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .perso-actions .btn{
    /* ← la photo ne prendra jamais toute la largeur */
    padding: .3rem .8rem;
    font-size: 10px;
  }
}
/* Responsive : empiler sur petit écran et centrer le texte */
@media (max-width: 600px){
  /* Si ta fiche passe en 1 colonne sur mobile */
  .perso-name{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 14px;
  }
  .perso-bio{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 13px;           /* centre la photo */
  }
  .perso-media{
    /* ← la photo ne prendra jamais toute la largeur */
    width: clamp(140px, 20vw, 20px);  /* min 160px, idéal 60% vw, max 300px */
    margin-inline: auto;               /* centre la photo */
  }
  /* tu peux garder ces règles telles quelles */
  .perso-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .perso-actions .btn{
    /* ← la photo ne prendra jamais toute la largeur */
    padding: .2rem .6rem
  }
}
/* Responsive : empiler sur petit écran et centrer le texte */
@media (max-width: 550px){
  /* Si ta fiche passe en 1 colonne sur mobile */
  .perso-name{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 13px;
  }
  .perso-bio{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 12px;           /* centre la photo */
  }
  .perso-media{
    /* ← la photo ne prendra jamais toute la largeur */
    width: clamp(120px, 20vw, 20px);  /* min 160px, idéal 60% vw, max 300px */
    margin-inline: auto;               /* centre la photo */
  }
  /* tu peux garder ces règles telles quelles */
  .perso-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .perso-actions .btn{
    /* ← la photo ne prendra jamais toute la largeur */
    padding: .1rem .2rem
  }
}
@media (max-width: 500px){
  /* Si ta fiche passe en 1 colonne sur mobile */
  .perso-name{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 13px;
  }
  .perso-bio{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 12px;           /* centre la photo */
  }
  .perso-media{
    /* ← la photo ne prendra jamais toute la largeur */
    width: clamp(100px, 20vw, 20px);  /* min 160px, idéal 60% vw, max 300px */
    margin-inline: auto;               /* centre la photo */
  }
  /* tu peux garder ces règles telles quelles */
  .perso-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .perso-actions .btn{
    /* ← la photo ne prendra jamais toute la largeur */
    padding: .1rem .2rem
  }
  .site-footer{
    font-size: 10px;
  }
}
@media (max-width: 430px){
  /* Si ta fiche passe en 1 colonne sur mobile */
  .perso-name{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 13px;
  }
  .perso-bio{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 12px;           /* centre la photo */
  }
  .perso-media{
    /* ← la photo ne prendra jamais toute la largeur */
    width: clamp(100px, 20vw, 20px);  /* min 160px, idéal 60% vw, max 300px */
    margin-inline: auto;               /* centre la photo */
  }
  /* tu peux garder ces règles telles quelles */
  .perso-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .perso-actions .btn{
    /* ← la photo ne prendra jamais toute la largeur */
    padding: .1rem .2rem
  }
}
@media (max-width: 400px){
  /* Si ta fiche passe en 1 colonne sur mobile */
  .perso-name{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 13px;
  }
  .perso-bio{
    /* ← la photo ne prendra jamais toute la largeur */
    font-size: 12px;           /* centre la photo */
  }
  .perso-media{
    /* ← la photo ne prendra jamais toute la largeur */
    width: clamp(80px, 20vw, 20px);  /* min 160px, idéal 60% vw, max 300px */
    margin-inline: auto;               /* centre la photo */
  }
  /* tu peux garder ces règles telles quelles */
  .perso-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .perso-actions .btn{
    /* ← la photo ne prendra jamais toute la largeur */
    padding: .1rem .2rem
  }
}

/* === Accessibilité & petits plus === */
:focus-visible{
  outline: 3px solid color-mix(in oklab, var(--brand) 50%, var(--text));
  outline-offset: 2px;
  border-radius: 8px;
}
::selection{
  background: color-mix(in oklab, var(--brand) 30%, transparent);
}

/* Réduction de mouvement */
@media (prefers-reduced-motion: no-preference){
  .post{
    animation: float-in .5s ease both;
  }
  @keyframes float-in{
    from{ opacity: 0; transform: translateY(8px) scale(.99); }
    to  { opacity: 1; transform: translateY(0)   scale(1); }
  }
}

/* Pleine largeur (full-bleed) mais contenu centré et limité */
.hero-slider{
  inline-size: 100vw;
  margin-inline: calc(50% - 50vw);
  max-inline-size: none;
  block-size: auto;                 /* la hauteur sera pilotée par JS */
  position: relative;
  overflow: hidden;
  flex: 0 0 auto;
  /* fond piloté par une variable CSS, avec transition douce */
  background: var(--hero-bg, #000);
  transition: background 400ms ease;
  width: auto;
}

/* La "piste" des slides : centrée et limitée à 860px */
.hero-slides{
  position: relative;
  inline-size: min(860px, 100% - 20px);  /* 10px de marge latérale sur mobile */
  margin-inline: auto;                   /* centrer */
  block-size: 100%;
}

/* Les images occupent toute la piste, superposées */
.hero-slide{
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;     /* remplis la piste */
  object-position: center;
  opacity: 0;
  transition: opacity 600ms ease;
}
.hero-slide.is-active{ opacity: 1; }

/* Dots inchangés… */
.hero-dots{
  position: absolute; left: 0; right: 0; bottom: 16px;
  display: flex; gap: .5rem; justify-content: center;
}
.hero-dots .dot{ width:.7rem; height:.7rem; border-radius:50%; border:0; background:rgba(255,255,255,.6); }
.hero-dots .dot.is-active{ background: rgba(255,255,255,.95); box-shadow:0 0 0 2px rgba(0,0,0,.15); }




/* -------------------- Section "Mentions légales" -------------------- */
.mentions-legales{
  padding-block: clamp(24px, 6svh, 72px);
  padding-inline: 16px;
}

/* Carte */
.mentions-card{
  background: var(--card, #fff);
  color: var(--text, #111);
  border: 1px solid var(--border, #e6e6e6);
  border-radius: 20px;
  box-shadow: var(--shadow, 0 2px 16px rgba(0,0,0,.06));
  padding: clamp(20px, 4vw, 40px);

  /* max 750px, sinon 10px de marge de chaque côté */
  inline-size: min(750px, 100% - 20px);
  margin-inline: auto;

  box-sizing: border-box;
  line-height: 1.7;
  overflow-wrap: anywhere;
}

/* Titres & hiérarchie */
.mentions-card h1{
  margin: 0 0 .6em;
  font-size: clamp(24px, 4.5vw, 34px);
  line-height: 1.2;
  letter-spacing: -0.01em;
}
.mentions-card h2{
  margin: 1.6em 0 .6em;
  font-size: clamp(18px, 3.5vw, 22px);
}

/* Texte et listes */
.mentions-card :where(p, ul, ol){
  margin-block: .75em;
}
.mentions-card :is(ul, ol){
  padding-inline-start: 1.2em;
}

/* Liens */
.mentions-card a{
  color: var(--brand, #0b66ff);
  text-decoration: underline;
  text-underline-offset: .15em;
}

/* Séparateur optionnel */
.mentions-card .sep{
  border: 0;
  height: 1px;
  background: var(--border, #e6e6e6);
  margin: 1rem 0 1.25rem;
}

/* Médias embarqués */
.mentions-card :is(img, iframe){
  max-width: 100%;
  height: auto;
  border-radius: 12px;
}

/* Impression : fond blanc sans ombre */
@media print{
  .mentions-card{
    box-shadow: none;
    border-color: #000;
    margin: 0 auto;
  }
}