/* =====================================================
   NEURO-LAYOUT — charge cognitive, parcours, mobile = desktop
   Principes : blocs limités, verticalité maîtrisée, même cartographie que la nav.
   Pinapp Studio · 2026
   ===================================================== */

@import url('pinapp-neurodiversite.css');
@import url('pinapp-futur-cinema.css');

:root {
  --neuro-band-gap: clamp(1.75rem, 4vw, 3rem);
  --neuro-section-pad-y-mobile: clamp(1.25rem, 3.5vw, 2rem);
}

/* ── Accueil : bande « pour qui + parcours » = un seul bloc mental (desktop 2 col) ── */
.neuro-home-band__wrap {
  display: grid;
  gap: var(--neuro-band-gap);
  max-width: 1120px;
  margin: 0 auto;
  min-width: 0; /* évite débordement horizontal grid / flex enfants */
}

.neuro-home-band__audience,
.neuro-home-band__process {
  min-width: 0;
}

.neuro-home-band__process > div {
  min-width: 0;
  max-width: 100%;
}

@media (min-width: 960px) {
  .neuro-home-band__wrap {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr);
    align-items: start;
    column-gap: clamp(2rem, 4vw, 3.5rem);
  }

  .neuro-home-band__audience .grid.grid-3 {
    grid-template-columns: 1fr;
    max-width: 100%;
  }
}

@media (min-width: 1100px) {
  .neuro-home-band__audience .grid.grid-3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Moins de scroll sur mobile : sections accueil plus serrées */
@media (max-width: 767px) {
  main.home-landing > .section:not(.pinapp-hero-viewport) {
    padding-top: var(--neuro-section-pad-y-mobile);
    padding-bottom: var(--neuro-section-pad-y-mobile);
  }

  main.home-landing > .section-separator {
    margin-top: var(--space-3, 12px);
    margin-bottom: var(--space-3, 12px);
  }

  .neuro-home-band__audience h2,
  .neuro-home-band__process h2 {
    font-size: clamp(1.5rem, 6vw, 2rem) !important;
  }

  /* Même logique sur les autres pages : moins de vide vertical, parcours plus court */
  main:not(.prose) .section {
    padding-top: var(--neuro-section-pad-y-mobile);
    padding-bottom: var(--neuro-section-pad-y-mobile);
  }

  main:not(.prose) .section-separator {
    margin-top: var(--space-3, 12px);
    margin-bottom: var(--space-3, 12px);
  }
}

/* Rendu différé : sections profondes (perception de vitesse, pas de layout shift majeur) */
@media (min-width: 768px) and (prefers-reduced-motion: no-preference) {
  main.home-landing .section-enter:nth-of-type(n + 6) {
    content-visibility: auto;
    contain-intrinsic-size: auto 420px;
  }
}

/* ── Accueil : bandeau « preuve par l'exemple » (vente par le livrable) ── */
.home-proof-section .container {
  padding-left: max(16px, env(safe-area-inset-left, 0px));
  padding-right: max(16px, env(safe-area-inset-right, 0px));
}

.home-proof-strip {
  padding: clamp(1.35rem, 3.5vw, 2rem) clamp(1.25rem, 3vw, 2rem);
  border-radius: var(--radius-card-lg, 20px);
  text-align: left;
}

.home-proof-points {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-5, 1.5rem);
  display: grid;
  gap: var(--space-3, 12px);
  max-width: 32rem;
  margin-left: auto;
  margin-right: auto;
}

.home-proof-points li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.55;
  opacity: 0.88;
  text-align: left;
}

.home-proof-check {
  color: var(--accent-teal, #00e5cc);
  flex-shrink: 0;
  font-weight: 700;
  margin-top: 1px;
}

.home-proof-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3, 12px);
  justify-content: center;
  align-items: center;
}

@media (max-width: 480px) {
  .home-proof-ctas .btn {
    width: 100%;
    justify-content: center;
    text-align: center;
  }
}

/* Barre du bas : même grille 5 zones sur tout le site */
.bottom-bar.bottom-bar--site {
  justify-content: space-between;
  padding-left: max(8px, env(safe-area-inset-left, 0px));
  padding-right: max(8px, env(safe-area-inset-right, 0px));
  gap: 2px;
}

.bottom-bar.bottom-bar--site a {
  flex: 1 1 0;
  min-width: 0;
  padding-left: 4px;
  padding-right: 4px;
  font-size: 9px;
  letter-spacing: 0.05em;
}

.bottom-bar.bottom-bar--site .bottom-bar-cta {
  flex: 1.15 1 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 34vw;
}

@media (max-width: 767px) {
  .bottom-bar.bottom-bar--site .bottom-bar-cta {
    font-size: 10px !important;
    padding: 8px 10px !important;
    text-transform: none;
    letter-spacing: 0.03em;
  }
}

/* Barre du bas — 6 zones (ajout Formations) */
.bottom-bar.bottom-bar--site.bottom-bar--six a {
  font-size: 8px;
  letter-spacing: 0.04em;
}

@media (min-width: 380px) {
  .bottom-bar.bottom-bar--site.bottom-bar--six a {
    font-size: 9px;
    letter-spacing: 0.05em;
  }
}

.bottom-bar.bottom-bar--site.bottom-bar--six .bottom-bar-cta {
  max-width: 28vw;
}

/* Hub formations : mini-nav ancres sous la nav principale */
body.formation-hub .formation-toc {
  position: sticky;
  top: calc(5.125rem + env(safe-area-inset-top, 0px));
  z-index: calc(var(--z-nav, 100) - 1);
  margin: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(2, 8, 20, 0.82);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  backdrop-filter: blur(16px) saturate(160%);
}

html[data-theme='light'] body.formation-hub .formation-toc,
body.mode-jour.formation-hub .formation-toc {
  background: rgba(255, 248, 238, 0.92);
  border-bottom-color: rgba(26, 10, 46, 0.08);
}

body.formation-hub .formation-toc-inner {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 8px 0 10px;
  align-items: center;
}

body.formation-hub .formation-toc-inner::-webkit-scrollbar {
  display: none;
}

body.formation-hub .formation-toc-inner a {
  flex: 0 0 auto;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  opacity: 0.72;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  white-space: nowrap;
  transition:
    opacity 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease;
}

body.formation-hub .formation-toc-inner a:hover {
  opacity: 1;
  border-color: rgba(0, 229, 204, 0.35);
}

html[data-theme='light'] body.formation-hub .formation-toc-inner a,
body.mode-jour.formation-hub .formation-toc-inner a {
  border-color: rgba(26, 10, 46, 0.1);
  background: rgba(255, 255, 255, 0.65);
}

body.formation-hub main .section[id] {
  scroll-margin-top: calc(6.75rem + env(safe-area-inset-top, 0px));
}

@media (prefers-reduced-motion: reduce) {
  body.formation-hub .formation-toc-inner a {
    transition: none;
  }
}
