/* ───────────────────────────────────────────────────────────
   KypoLab · Pol QUIMERC'H — Chrome de site
   Aurora, shell, header, motifs partagés (.skill/.tag), section
   article (Veilles), footer, chatbot. À lier APRÈS tokens.css.
   ─────────────────────────────────────────────────────────── */

/* ── Accessibilité clavier : anneau de focus visible ─ */
/* Au clavier uniquement (pas au clic souris) — liseré accent net. */
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 3px; }
:focus:not(:focus-visible) { outline: none; }

/* ── Fond dégradé animé (NeatGradient · WebGL) ──── */
/* Canvas fixe plein écran derrière tout le contenu. Le rendu est
   piloté par gradient.js (lib @firecms/neat). Fallback : si le JS
   ou WebGL échoue, le fond reste le --bg sombre (porté par html). */
/* Hauteur en dvh (viewport dynamique) : sur mobile, la barre d'adresse qui se
   rétracte ne laisse plus de bande non couverte en bas. Fallback vh. */
#gradient { position: fixed; inset: 0; z-index: -1; width: 100%; height: 100vh; height: 100dvh; display: block; pointer-events: none; }
/* Voile (injecté par gradient.js) : assombrit le dégradé sous le contenu pour la lisibilité. */
.bg-scrim { position: fixed; inset: 0; z-index: -1; pointer-events: none; height: 100vh; height: 100dvh;
  background: radial-gradient(135% 115% at 50% 18%, rgba(13,13,13,0.20), rgba(13,13,13,0.48)); }

/* Grain de film (injecté par gradient.js) : casse le banding du dégradé WebGL
   et ajoute une matière « premium ». Toujours présent, même en fallback. */
.bg-grain { position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: 0.05; height: 100vh; height: 100dvh;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ── Reveal au scroll (apparition éditoriale) ───── */
/* La classe .reveal est posée par gradient.js puis .is-visible quand
   l'élément entre dans le viewport (IntersectionObserver). Le délai de
   cascade entre frères est appliqué inline par le JS. */
.reveal { opacity: 0; transform: translateY(18px);
  transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; } }

/* ── Liquid glass (style Apple) — utilitaire ────── */
/* À poser sur n'importe quelle box : <div class="glass">…</div>.
   Translucide + flou d'arrière-plan (capte le dégradé animé) +
   liseré spéculaire. Repli solide si backdrop-filter non supporté. */
.glass {
  background: var(--glass-bg);
  -webkit-backdrop-filter: var(--glass-filter);
  backdrop-filter: var(--glass-filter);
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow), var(--glass-sheen);
}
.glass--strong { background: var(--glass-bg-strong); }
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .glass, .glass--strong { background: var(--bg-elev); }
}

/* Carte de contenu en verre — pour poser les textes sur le dégradé */
.panel {
  background: var(--glass-panel);
  -webkit-backdrop-filter: var(--glass-filter);
  backdrop-filter: var(--glass-filter);
  border: 1px solid var(--glass-border);
  border-radius: var(--r-lg);
  box-shadow: var(--glass-shadow), var(--glass-sheen);
  padding: clamp(1.5rem, 4vw, 2.5rem);
}
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .panel { background: var(--bg-elev); }
}
.panel > :first-child { margin-top: 0; }
.panel > :last-child { margin-bottom: 0; }

/* ── Reflet « liquid glass » (style Apple) ──────── */
/* Le flou seul = verre dépoli. On superpose un REFLET diagonal + un
   LISERÉ SPÉCULAIRE (la lumière qui accroche les bords haut/gauche) :
   c'est ce qui donne l'aspect verre poli plutôt que simple blur.
   Cross-browser, pas de filtre SVG (pas de risque). */
.panel, .nav, .chat, .glass { position: relative; isolation: isolate; }
.panel::after, .nav::after, .chat::after, .glass::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none; z-index: 2;
  /* Une seule traînée spéculaire fine et diagonale (lumière qui glisse sur
     le bord haut-gauche), pas un voile blanc plein. Le reste est laissé au
     backdrop-filter qui, lui, reflète vraiment le dégradé animé du fond. */
  background:
    linear-gradient(133deg,
      rgba(255,255,255,0.18) 0%,
      rgba(255,255,255,0.04) 9%,
      rgba(255,255,255,0) 22%);
  box-shadow:
    inset 1px 1px 0 rgba(255,255,255,0.22),
    inset -1px -1px 0 rgba(255,255,255,0.05);
}
/* Le contenu passe au-dessus du reflet (lisibilité). */
.panel > *, .nav__row, .chat__head, .chat__body { position: relative; z-index: 3; }

/* Lisibilité des petits libellés hors panneau, sur les zones claires du dégradé */
.label, .block__index, .about__label, .article__meta, .backlink, .foot__legal {
  text-shadow: 0 1px 8px rgba(0,0,0,0.55);
}

/* ── Shell ──────────────────────────────────────── */
.shell { max-width: var(--max-w); margin-inline: auto; padding-inline: var(--gutter); }

/* ── Header ─────────────────────────────────────── */
.nav {
  position: fixed; top: clamp(0.6rem, 1.8vw, 1.1rem); left: 50%; transform: translateX(-50%);
  z-index: 50; width: min(100% - 2 * var(--gutter), var(--max-w));
  border-radius: var(--r-pill);
  background: var(--glass-bg-strong);
  backdrop-filter: var(--glass-filter); -webkit-backdrop-filter: var(--glass-filter);
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow), var(--glass-sheen);
}
.nav__row { padding: var(--space-3) var(--space-3) var(--space-3) var(--space-5);
  display: flex; align-items: center; justify-content: space-between; }
.brand { display: flex; align-items: center; gap: var(--space-3); font-weight: var(--fw-bold); letter-spacing: var(--track-snug); }
.brand__mark { width: 30px; height: 30px; border-radius: var(--r-sm);
  background: var(--accent); color: var(--accent-ink);
  display: grid; place-items: center; font-weight: var(--fw-black); font-size: 0.9rem; }
.nav__links { display: flex; align-items: center; gap: var(--space-6); }
.nav__links a { font-size: var(--text-sm); color: var(--text-muted); transition: color var(--dur) var(--ease); position: relative; }
.nav__links a:hover, .nav__links a[aria-current="page"] { color: var(--text); }
.nav__links a::after { content: ""; position: absolute; left: 0; bottom: -6px; height: 1px; width: 0;
  background: var(--accent); transition: width var(--dur) var(--ease); }
.nav__links a:hover::after, .nav__links a[aria-current="page"]::after { width: 100%; }
.status { display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-label); letter-spacing: var(--track-label); text-transform: uppercase; color: var(--text-muted);
  padding: 0.4em 0.85em; border: 1px solid var(--glass-border); border-radius: var(--r-pill);
  background: var(--glass-bg); -webkit-backdrop-filter: blur(12px) saturate(160%); backdrop-filter: blur(12px) saturate(160%);
  box-shadow: var(--glass-sheen); }
.dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent);
  box-shadow: 0 0 0 0 var(--accent-glow); animation: pulse 2.4s var(--ease) infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 var(--accent-glow);} 70%{box-shadow:0 0 0 8px transparent;} 100%{box-shadow:0 0 0 0 transparent;} }

/* Hamburger animé (mobile) — masqué en desktop */
.nav__burger { display: none; width: 44px; height: 44px; padding: 0; border: none; background: transparent;
  cursor: pointer; position: relative; -webkit-tap-highlight-color: transparent; }
.nav__burger span { position: absolute; left: 12px; right: 12px; height: 2px; background: var(--text); border-radius: 2px;
  transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease); }
.nav__burger span:nth-child(1) { top: 17px; }
.nav__burger span:nth-child(2) { top: 22px; }
.nav__burger span:nth-child(3) { top: 27px; }
.nav.open .nav__burger span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.nav.open .nav__burger span:nth-child(2) { opacity: 0; }
.nav.open .nav__burger span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }
@media (prefers-reduced-motion: reduce) { .nav__burger span { transition: none; } }

/* Voile derrière le menu mobile (scrim) */
.nav__scrim { position: fixed; inset: 0; z-index: 40; background: color-mix(in srgb, var(--bg) 55%, transparent);
  -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity var(--dur) var(--ease), visibility var(--dur); }
.nav__scrim.is-on { opacity: 1; visibility: visible; pointer-events: auto; }
@media (min-width: 881px) { .nav__scrim { display: none; } }
@media (prefers-reduced-motion: reduce) { .nav__scrim { transition: none; } }

/* Blocage du défilement de fond quand le menu est ouvert */
html.nav-locked, html.nav-locked body { overflow: hidden; }
/* Le lanceur du chatbot s'efface derrière le menu ouvert */
html.nav-locked .chat-fab { opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity var(--dur) var(--ease), visibility var(--dur); }

/* ── Page head (titre de page secondaire) ───────── */
.page-head { padding-top: clamp(5.5rem, 9vw, 7rem); padding-bottom: var(--section-y); }
.page-head__eyebrow { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-5); }
.page-head__eyebrow .line { height: 1px; width: 48px; background: var(--border-strong); }
.page-head h1 { font-size: var(--text-display); font-weight: var(--fw-black); line-height: var(--lh-tight); letter-spacing: var(--track-tight); }
.page-head h1 .accent { color: var(--accent); }
.page-head__lead { margin-top: var(--space-6); font-size: var(--text-lead); color: var(--text-muted);
  line-height: var(--lh-relaxed); max-width: 58ch;
  background: var(--glass-panel); border: 1px solid var(--glass-border); border-radius: var(--r-lg);
  -webkit-backdrop-filter: blur(14px) saturate(150%); backdrop-filter: blur(14px) saturate(150%);
  box-shadow: var(--glass-shadow), var(--glass-sheen);
  padding: clamp(1.1rem, 3vw, 1.6rem) clamp(1.3rem, 3.5vw, 2rem); }

/* ── Cartouche de section ───────────────────────── */
/* Colonne éditoriale : l'index se pose AU-DESSUS du titre, les deux alignés
   sur la même marge gauche que les panneaux qui suivent (lecture franche). */
.block__head { display: block; }
.block__index { display: inline-block; margin-bottom: var(--space-3); font-size: var(--text-sm);
  color: var(--text-muted); letter-spacing: var(--track-label); }
.block__title { font-size: var(--text-h1); font-weight: var(--fw-bold); letter-spacing: var(--track-snug); }

/* ── Motif « skill / timeline » (partagé Home + CV) ── */
.skills { padding-block: var(--section-y); border-top: 1px solid var(--hairline); }
.skills__list { margin-top: var(--space-8); }
.skill { position: relative; display: grid; grid-template-columns: 56px 1fr auto; gap: var(--space-5);
  align-items: baseline; padding: var(--space-5) 0; border-top: 1px solid var(--hairline); }
.skill:last-child { border-bottom: 1px solid var(--hairline); }
.skill::before { content: ""; position: absolute; inset: var(--space-2) calc(-1 * var(--space-4));
  border-radius: var(--r-md); border: 1px solid var(--glass-border);
  background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 20%, transparent), transparent 82%);
  opacity: 0; transition: opacity var(--dur) var(--ease); pointer-events: none; }
.skill:hover::before { opacity: 1; }
.skill__num { font-size: var(--text-sm); color: var(--text-dim); transition: color var(--dur) var(--ease); }
.skill__name { font-size: var(--text-h3); font-weight: var(--fw-medium); letter-spacing: var(--track-snug);
  transition: color var(--dur) var(--ease), transform var(--dur) var(--ease); }
.skill__sub { display: block; margin-top: var(--space-1); font-size: var(--text-sm); color: var(--text-muted); font-weight: var(--fw-regular); }
.skill:hover .skill__num { color: var(--accent); }
.skill:hover .skill__name { color: var(--accent); transform: translateX(6px); }
@media (prefers-reduced-motion: reduce) { .skill__name { transition: color var(--dur) var(--ease); } .skill:hover .skill__name { transform: none; } }
.skill__tags { display: flex; flex-wrap: wrap; gap: var(--space-2); justify-content: flex-end; max-width: 46ch; }
.skill__date { font-size: var(--text-label); letter-spacing: var(--track-label); text-transform: uppercase; color: var(--text-muted); white-space: nowrap; }
.tag { font-size: var(--text-label); letter-spacing: 0.06em; color: var(--text-muted);
  padding: 0.35em 0.7em; border: 1px solid var(--glass-border); border-radius: var(--r-pill);
  background: var(--glass-bg); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  box-shadow: var(--glass-sheen);
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur) var(--ease); }
.tag:hover { color: var(--text); border-color: var(--border-strong); transform: translateY(-2px); }
@media (prefers-reduced-motion: reduce) { .tag { transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease); } .tag:hover { transform: none; } }

/* ── Article premium (Veilles) ──────────────────── */
.article { max-width: var(--max-w-text); margin-inline: auto; padding-block: var(--section-y); }
.article h1 { font-size: var(--text-h1); font-weight: var(--fw-black); letter-spacing: var(--track-tight);
  line-height: var(--lh-tight); margin-top: var(--space-4); }
.article h1 .accent { color: var(--accent); }
.article__lead { font-size: var(--text-lead); color: var(--text-muted); line-height: var(--lh-relaxed); margin-top: var(--space-6);
  background: var(--glass-panel); border: 1px solid var(--glass-border); border-radius: var(--r-lg);
  -webkit-backdrop-filter: blur(14px) saturate(150%); backdrop-filter: blur(14px) saturate(150%);
  box-shadow: var(--glass-shadow), var(--glass-sheen);
  padding: clamp(1.1rem, 3vw, 1.6rem) clamp(1.3rem, 3.5vw, 2rem); }
.article__body { margin-top: var(--space-8); }
.article__body > * { max-width: 100%; }
.article__body h2 { font-size: var(--text-h2); font-weight: var(--fw-bold); letter-spacing: var(--track-snug);
  margin-top: var(--space-9); margin-bottom: var(--space-4); }
.article__body h3 { font-size: var(--text-h3); font-weight: var(--fw-medium);
  margin-top: var(--space-7); margin-bottom: var(--space-3); }
.article__body p { color: var(--text-muted); line-height: var(--lh-relaxed); margin-bottom: var(--space-4); }
.article__body strong { color: var(--text); font-weight: var(--fw-medium); }
.article__body a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }
.article__body ul, .article__body ol { padding-left: 1.25em; margin-bottom: var(--space-4); color: var(--text-muted); line-height: var(--lh-relaxed); }
.article__body li { margin-bottom: var(--space-2); }
.article__body li::marker { color: var(--accent); }
.article__body blockquote { margin: var(--space-7) 0; padding-left: var(--space-5);
  border-left: 2px solid var(--accent); color: var(--text); font-size: var(--text-lead); line-height: var(--lh-relaxed); }
.article__body figure { margin: var(--space-7) 0; }
.article__body figcaption, .article .caption { font-size: var(--text-label); letter-spacing: var(--track-label);
  text-transform: uppercase; color: var(--text-dim); margin-top: var(--space-3); }
.article__meta { display: flex; flex-wrap: wrap; gap: var(--space-5); margin-top: var(--space-6);
  padding-top: var(--space-5); border-top: 1px solid var(--hairline);
  font-size: var(--text-label); letter-spacing: var(--track-label); text-transform: uppercase; color: var(--text-dim); }
.backlink { display: inline-flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-6);
  font-size: var(--text-sm); color: var(--text-muted); transition: color var(--dur) var(--ease); }
.backlink:hover { color: var(--accent); }

/* ── Footer ─────────────────────────────────────── */
footer { border-top: 1px solid var(--hairline); padding-block: var(--space-9); }
.foot__grid { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: var(--space-6); }
.foot__big { font-size: var(--text-h2); font-weight: var(--fw-bold); letter-spacing: var(--track-snug); }
.foot__big a { color: var(--accent); }
.foot__links { display: flex; gap: var(--space-5); }
.foot__links a { font-size: var(--text-sm); color: var(--text-muted); display: inline-flex; align-items: center; gap: var(--space-2); transition: color var(--dur) var(--ease); }
.foot__links a:hover { color: var(--text); }
.foot__legal { margin-top: var(--space-7); display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-3); font-size: var(--text-sm); color: var(--text-dim); }

/* ── Chatbot dock ───────────────────────────────── */
.chat { position: fixed; right: clamp(1rem, 3vw, 2rem); bottom: clamp(1rem, 3vw, 2rem); z-index: 60;
  width: 320px; max-height: min(72vh, 520px); display: flex; flex-direction: column;
  background: var(--glass-bg-strong);
  -webkit-backdrop-filter: var(--glass-filter); backdrop-filter: var(--glass-filter);
  border: 1px solid var(--glass-border); border-radius: var(--r-lg); overflow: hidden;
  box-shadow: 0 20px 60px -20px rgba(0,0,0,0.7), var(--glass-sheen);
  /* Replié par défaut : on n'affiche que l'icône (.chat-fab). */
  transform-origin: bottom right; transform: translateY(8px) scale(0.96);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility var(--dur); }
.chat.chat--open { opacity: 1; visibility: visible; transform: none; pointer-events: auto; }
@media (prefers-reduced-motion: reduce) { .chat { transition: none; } }

/* Icône lanceur (bulle) — visible quand le chat est replié */
.chat-fab { position: fixed; right: clamp(1rem, 3vw, 2rem); bottom: clamp(1rem, 3vw, 2rem); z-index: 61;
  width: 58px; height: 58px; border-radius: 50%; cursor: pointer;
  border: 1px solid var(--glass-border); background: var(--accent); color: var(--accent-ink);
  display: grid; place-items: center;
  box-shadow: 0 14px 36px -10px rgba(0,0,0,0.6), var(--glass-sheen);
  transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease); }
.chat-fab:hover { transform: translateY(-2px) scale(1.05); }
.chat-fab:active { transform: translateY(0) scale(0.98); }
.chat-fab svg { width: 26px; height: 26px; }
.chat-fab__dot { position: absolute; top: 7px; right: 7px; width: 12px; height: 12px; border-radius: 50%;
  background: #46d27f; border: 2px solid var(--accent); }
.chat-fab.is-hidden { opacity: 0; transform: scale(0.6); pointer-events: none; }

.chat__head { flex: 0 0 auto; display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--hairline); }
.chat__close { margin-left: auto; width: 30px; height: 30px; flex: 0 0 auto; border-radius: 50%; cursor: pointer;
  border: 1px solid var(--glass-border); background: var(--glass-bg); color: var(--text-muted);
  display: grid; place-items: center; transition: color var(--dur) var(--ease), background var(--dur) var(--ease); }
.chat__close:hover { color: var(--text); background: var(--glass-bg-strong); }
.chat__close svg { width: 14px; height: 14px; }
.chat__avatar--mono { width: 32px; height: 32px; border-radius: 50%; background: var(--accent); color: var(--accent-ink); display: grid; place-items: center; font-weight: var(--fw-black); font-size: 0.85rem; }
.chat__who { font-size: var(--text-sm); font-weight: var(--fw-medium); }
.chat__sub { font-size: var(--text-label); color: var(--text-dim); letter-spacing: 0.04em; }
.chat__body { display: flex; flex-direction: column; min-height: 0; gap: var(--space-4); padding: var(--space-4) var(--space-5) var(--space-5); }
.chat__messages { display: flex; flex-direction: column; gap: var(--space-3); flex: 1 1 auto; min-height: 0; overflow-y: auto;
  padding-right: 4px; scrollbar-width: thin; scrollbar-color: color-mix(in srgb, var(--accent) 40%, transparent) transparent; }
.chat__messages::-webkit-scrollbar { width: 6px; }
.chat__messages::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--accent) 35%, transparent); border-radius: 4px; }
.chat__msg { max-width: 88%; padding: var(--space-2) var(--space-4); border-radius: var(--r-md);
  font-size: var(--text-sm); line-height: 1.5; overflow-wrap: anywhere; }
.chat__msg--bot { align-self: flex-start; background: var(--glass-bg); border: 1px solid var(--glass-border); color: var(--text); border-bottom-left-radius: 4px; }
.chat__msg--user { align-self: flex-end; background: var(--accent); color: var(--accent-ink); border-bottom-right-radius: 4px; }
.chat__msg strong { font-weight: var(--fw-bold); }
.chat__msg a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.chat__msg--user a { color: var(--accent-ink); }
.chat__typing { display: inline-flex; gap: 4px; align-items: center; }
.chat__typing span { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); opacity: .5; animation: chatblink 1.2s infinite both; }
.chat__typing span:nth-child(2) { animation-delay: .2s; }
.chat__typing span:nth-child(3) { animation-delay: .4s; }
@keyframes chatblink { 0%, 80%, 100% { opacity: .3; } 40% { opacity: 1; } }
.chat__input { flex: 0 0 auto; display: flex; gap: var(--space-2); }
.chat__input input { flex: 1; background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--r-pill); padding: 0.6em 1em; font-size: var(--text-sm); }
.chat__input input::placeholder { color: var(--text-dim); }
.chat__input input:focus { outline: none; border-color: var(--accent); }
.chat__send { width: 38px; border-radius: 50%; border: none; background: var(--accent); color: var(--accent-ink); cursor: pointer; font-weight: var(--fw-bold); }

/* ── Responsive (chrome + motifs partagés) ──────── */
@media (max-width: 880px) {
  .skill { grid-template-columns: 1fr; gap: var(--space-3); }
  .skill__tags, .skill__date { justify-content: flex-start; text-align: left; }
  /* Chatbot sur mobile : l'icône reste visible (lanceur), le panneau
     s'adapte à la largeur de l'écran une fois ouvert. */
  .chat-fab { right: 1rem; bottom: 1rem; }
  .chat { right: 1rem; left: 1rem; bottom: 1rem; width: auto; max-height: min(72vh, 460px); }

  /* Menu mobile : hamburger + panneau déroulant en verre */
  .nav__burger { display: block; }
  .nav__links {
    position: absolute; top: calc(100% + 10px); left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: var(--space-1); padding: var(--space-3);
    /* Quasi-opaque : le menu est imbriqué dans la nav (déjà en backdrop-filter),
       le flou ne s'applique donc pas au contenu derrière → fond solide lisible. */
    background: color-mix(in srgb, var(--glass-tint) 96%, transparent);
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(165%); backdrop-filter: blur(var(--glass-blur)) saturate(165%);
    border: 1px solid var(--glass-border); border-radius: var(--r-lg);
    box-shadow: var(--glass-shadow), var(--glass-sheen);
    opacity: 0; visibility: hidden; transform: translateY(-10px) scale(0.98); transform-origin: top center;
    transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility var(--dur);
  }
  .nav.open .nav__links { opacity: 1; visibility: visible; transform: translateY(0) scale(1); }
  .nav__links a { padding: var(--space-3) var(--space-4); font-size: var(--text-body); color: var(--text); border-radius: var(--r-md); }
  .nav__links a:hover { background: var(--glass-bg); }
  .nav__links a::after { display: none; }
  .nav__links a[aria-current="page"] { color: var(--accent); }
  .nav__links .status { margin-top: var(--space-2); align-self: flex-start; }

  /* Apparition en cascade des liens à l'ouverture */
  .nav.open .nav__links > * { animation: nav-item-in var(--dur) var(--ease) both; }
  .nav.open .nav__links > *:nth-child(1) { animation-delay: 0.03s; }
  .nav.open .nav__links > *:nth-child(2) { animation-delay: 0.07s; }
  .nav.open .nav__links > *:nth-child(3) { animation-delay: 0.11s; }
  .nav.open .nav__links > *:nth-child(4) { animation-delay: 0.15s; }
  .nav.open .nav__links > *:nth-child(5) { animation-delay: 0.19s; }
  .nav.open .nav__links > *:nth-child(6) { animation-delay: 0.23s; }
}
@keyframes nav-item-in { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) {
  .nav__links { transition: none !important; }
  .nav.open .nav__links > * { animation: none !important; }
}

/* ── Bandeau de consentement cookies (CNIL / RGPD) ── */
.consent {
  position: fixed; z-index: 200;
  left: clamp(1rem, 3vw, 2rem); bottom: clamp(1rem, 3vw, 2rem);
  width: min(420px, calc(100vw - 2rem));
  padding: var(--space-5);
  border-radius: var(--r-lg);
  display: flex; flex-direction: column; gap: var(--space-4);
  animation: consent-in var(--dur) var(--ease);
}
@keyframes consent-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .consent { animation: none; } }
.consent__text { font-size: var(--text-sm); color: var(--text-muted); line-height: var(--lh-relaxed); }
.consent__text b { color: var(--text); font-weight: var(--fw-medium); }
.consent__actions { display: flex; gap: var(--space-3); }
.consent__actions .btn { flex: 1; justify-content: center; }

/* Lien « Gérer les cookies » dans le footer */
.consent-link {
  background: none; border: 0; padding: 0; cursor: pointer;
  font: inherit; font-size: var(--text-sm); color: var(--text-dim);
  text-decoration: underline; text-underline-offset: 3px;
  transition: color var(--dur) var(--ease);
}
.consent-link:hover { color: var(--text-muted); }
