/* ============================================================
   Reprise du redesign (biscuiterie.ac-web.net) : topbar, footer,
   polices, largeur de page. Appliqué par-dessus biscuiterie.css.
   ============================================================ */
:root {
  --noir: #0C0C0C; --noir-2: #161616; --noir-3: #202020; --noir-4: #2A2A2A; --bleu-pale: #7AB8E8; --vert-clair: #6DC49A; --gap: 1.5px;
  --jaune: #E8C84A; --jaune-clair: #F2D96B;
  --blanc: #F0EDE6; --gris: #9C9890; --gris-clair: #C8C4BC;
  --f-titre: 'Bebas Neue', sans-serif;
  --f-serif: 'DM Serif Display', Georgia, serif;
  --f-corps: 'DM Sans', sans-serif;
  --max: 1200px;
  --pad: clamp(1.5rem, 5vw, 4rem);
  --nav-h: 78px;
}

/* Espace sous la topbar fixe */
body { padding-top: var(--nav-h); }

/* Polices : corps + titres (reprise redesign) */
body.custom-font-enabled { font-family: var(--f-corps); }
h1, h2, .sstithome, .entry-title, #titcolfoot { font-family: var(--f-titre); letter-spacing: .03em; }

/* ── TOPBAR ── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100050;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem var(--pad);
  transition: background .35s, border-color .35s;
}
.nav.scrolled {
  background: rgba(12,12,12,.94);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(232,200,74,.1);
}
.nav-logo { display: inline-flex; align-items: center; text-decoration: none; }
.nav-logo img { height: 48px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 1.75rem; list-style: none; margin: 0; padding: 0; }
.nav-links a {
  color: var(--gris-clair); text-decoration: none;
  font-size: .82rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase;
  transition: color .2s;
}
.nav-links a:hover, .nav-links a.active { color: var(--jaune); }
.nav-links .nav-btn {
  background: var(--jaune); color: var(--noir) !important;
  padding: .55rem 1.2rem; border-radius: 2px; font-weight: 600 !important;
  transition: background .2s;
}
.nav-links .nav-btn:hover { background: var(--jaune-clair); }
.nav-burger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 4px; background: none; border: none; }
.nav-burger span { width: 24px; height: 2px; background: var(--blanc); display: block; transition: all .3s; }

.mobile-overlay {
  position: fixed; inset: 0; background: var(--noir); z-index: 100060;
  display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 2rem;
  transform: translateX(100%); transition: transform .4s cubic-bezier(.4,0,.2,1);
}
.mobile-overlay.open { transform: translateX(0); }
.mobile-overlay a { font-family: var(--f-titre); font-size: 2.8rem; letter-spacing: .04em; color: var(--blanc); text-decoration: none; transition: color .2s; }
.mobile-overlay a:hover { color: var(--jaune); }
.mobile-close { position: absolute; top: 1.5rem; right: var(--pad); background: none; border: none; cursor: pointer; color: var(--gris-clair); font-size: 2rem; line-height: 1; }

/* ── LARGEUR DE PAGE ── */
#conthome, .entry-content > #proghome { max-width: var(--max); margin-left: auto; margin-right: auto; }

/* ── FOOTER ── */
.footer { background: var(--noir); border-top: 1px solid rgba(232,200,74,.07); padding: 3rem var(--pad) 2rem; }
.footer-inner { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; padding-bottom: 2.5rem; border-bottom: 1px solid var(--noir-4); }
.footer-logo { font-family: var(--f-titre); font-size: 2rem; letter-spacing: .04em; color: var(--blanc); margin-bottom: .9rem; }
.footer-logo em { color: var(--jaune); font-style: normal; }
.footer-desc { font-size: .86rem; color: var(--gris); line-height: 1.7; margin-bottom: 1.25rem; }
.footer-addr { font-size: .82rem; color: var(--gris); line-height: 1.75; font-style: normal; }
.footer-addr strong { color: var(--gris-clair); font-weight: 500; display: block; }
.footer-col-title { font-size: .68rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--jaune); margin-bottom: 1.1rem; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: .6rem; margin: 0; padding: 0; }
.footer-links a { font-size: .86rem; color: var(--gris); text-decoration: none; transition: color .2s; }
.footer-links a:hover { color: var(--blanc); }
.footer-socials { display: flex; gap: .6rem; margin-top: 1.25rem; }
.social-btn { width: 34px; height: 34px; border: 1px solid var(--noir-4); border-radius: 2px; display: flex; align-items: center; justify-content: center; color: var(--gris); text-decoration: none; font-size: .72rem; font-weight: 700; transition: all .2s; }
.social-btn:hover { border-color: var(--jaune); color: var(--jaune); }
.footer-inner-3 { grid-template-columns: 2fr 1fr 1fr; }
.footer-bottom { max-width: var(--max); margin: 1.5rem auto 0; display: flex; justify-content: space-between; font-size: .73rem; color: var(--gris); flex-wrap: wrap; gap: .75rem; }
.footer-bottom-right { display: flex; align-items: center; gap: 1.25rem; }
.footer-credit span[aria-hidden] { color: var(--jaune); }
.footer-bottom a { color: var(--gris); text-decoration: none; }
.footer-bottom a:hover { color: var(--blanc); }

@media (max-width: 960px) {
  .nav-links { display: none; }
  .nav-burger { display: flex; }
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 2rem; }
}
@media (max-width: 600px) {
  .footer-inner { grid-template-columns: 1fr; }
}

/* ===== Reprise redesign : section saison + bloc vidéo (home) ===== */
.section-label { font-size: .7rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--jaune); margin-bottom: .75rem; }
.section-title { font-family: var(--f-titre); font-size: clamp(2.4rem,5vw,4rem); letter-spacing: .02em; color: var(--blanc); margin: .5rem 0 1.4rem; line-height: 1.02; }
.btn { display: inline-flex; align-items: center; gap: .5rem; padding: .85rem 1.7rem; font-family: var(--f-corps); font-size: .82rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; text-decoration: none; border-radius: 2px; transition: all .2s; cursor: pointer; border: none; }
.btn-primary { background: var(--jaune); color: var(--noir); }
.btn-primary:hover { background: var(--jaune-clair); transform: translateY(-1px); }

.saison-section { padding: clamp(3.5rem,8vw,6rem) var(--pad); background: var(--noir); }
.saison-inner { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.saison-poster { aspect-ratio: 3/4; background: var(--noir-3); position: relative; overflow: hidden; }
.saison-poster img { width: 100%; height: 100%; object-fit: cover; display: block; }
.saison-badge { position: absolute; top: 1.25rem; left: 1.25rem; background: var(--jaune); color: var(--noir); padding: .3rem .7rem; font-size: .65rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.saison-text { font-size: 1rem; color: var(--gris-clair); line-height: 1.78; margin-bottom: 1.75rem; }
.saison-hl { display: flex; flex-direction: column; gap: .65rem; margin-bottom: 2.25rem; }
.saison-hl-item { display: flex; align-items: center; gap: .9rem; font-size: .88rem; color: var(--gris-clair); }
.saison-hl-item::before { content: ''; width: 7px; height: 7px; background: var(--jaune); border-radius: 50%; flex-shrink: 0; }

.video-section { background: var(--noir); padding: clamp(3.5rem,7vw,5.5rem) var(--pad); }
.video-inner { max-width: var(--max); margin: 0 auto; }
.video-wrap { position: relative; margin-top: 2rem; cursor: pointer; overflow: hidden; aspect-ratio: 16/9; }
.video-thumb { position: absolute; inset: 0; background: var(--noir-3); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.video-thumb-bg { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: .6; }
.play-btn { position: relative; z-index: 2; width: 80px; height: 80px; border-radius: 50%; background: var(--jaune); display: flex; align-items: center; justify-content: center; transition: transform .3s, background .2s; }
.video-wrap:hover .play-btn { transform: scale(1.08); background: var(--jaune-clair); }
.play-btn svg { margin-left: 4px; }
.video-caption { position: absolute; left: 0; bottom: 0; z-index: 2; padding: 1.5rem 1.75rem; color: var(--blanc); font-family: var(--f-titre); font-size: 1.6rem; letter-spacing: .03em; line-height: 1; }
.video-caption small { display: block; font-family: var(--f-corps); font-size: .8rem; font-weight: 400; letter-spacing: 0; color: var(--gris-clair); margin-top: .45rem; text-transform: none; }
.video-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; z-index: 3; }

@media (max-width: 768px) { .saison-inner { grid-template-columns: 1fr; gap: 2rem; } }

/* ── Largeur de page alignée sur la topbar/footer (1200px) ──
   Les pages event gardent leur pleine largeur via event.css (chargé après). */
#main.wrapper { max-width: var(--max); margin-left: auto; margin-right: auto; }
.recapevt { max-width: var(--max); }
header.entry-header { max-width: var(--max); }

/* ── Documentaire : fond sombre (override de l'alternance .home) ── */
.home section.video-section, .video-section { background: var(--noir); color: var(--blanc); }
.home section.video-section .section-title { color: var(--blanc); }

/* ===== Bloc header de page (reprise maquette) ===== */
.page-header { padding: 7rem var(--pad) clamp(2.5rem,5vw,4rem); background: var(--noir-2); border-bottom: 1px solid rgba(232,200,74,.07); position: relative; overflow: hidden; }
.page-header::before { content: ''; position: absolute; top: 0; bottom: 0; left: 0; width: 2px; background: linear-gradient(to bottom, transparent, var(--jaune), transparent); opacity: .4; }
.page-header-inner { max-width: var(--max); margin: 0 auto; display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.page-header-title { font-family: var(--f-titre); font-size: clamp(3rem,8vw,6.5rem); letter-spacing: .02em; line-height: .9; color: var(--blanc); margin: 0; }
.page-header-meta { font-size: .9rem; color: var(--gris); max-width: 360px; }
.page-header-meta strong { color: var(--jaune); font-weight: 500; }

/* ===== Page Pro (reprise maquette) ===== */
.pro-hero { padding: 7rem var(--pad) clamp(3rem,6vw,5rem); }
.pro-hero-inner { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
.pro-title { font-family: var(--f-titre); font-size: clamp(3rem,7vw,5.5rem); line-height: .9; letter-spacing: .02em; color: var(--blanc); margin-bottom: 1rem; }
.pro-title span { color: var(--gris); }
.pro-sub { font-size: .98rem; color: var(--gris-clair); line-height: 1.72; }
.pro-contacts { display: flex; flex-direction: column; gap: 1rem; }
.pro-contacts-label { font-size: .68rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--jaune); margin-bottom: 1.25rem; }
.pro-contact-card { background: var(--noir-2); border: 1px solid var(--noir-4); padding: 1.2rem 1.4rem; }
.pro-contact-role { font-size: .67rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--gris); margin-bottom: .25rem; }
.pro-contact-name { font-weight: 600; color: var(--blanc); margin-bottom: .2rem; }
.pro-contact-email { font-size: .86rem; color: var(--jaune); text-decoration: none; }
.ressources-section { background: var(--noir-2); padding: clamp(3rem,6vw,5rem) var(--pad); }
.ressources-inner { max-width: var(--max); margin: 0 auto; }
.ressources-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5px; margin-top: 2.5rem; }
.ressource { background: var(--noir-3); padding: 2rem; display: flex; flex-direction: column; gap: .9rem; transition: background .2s; }
.ressource:hover { background: var(--noir-4); }
.res-type { display: inline-flex; align-items: center; gap: .35rem; padding: .18rem .5rem; font-size: .6rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; border-radius: 1px; width: fit-content; }
.res-pdf { background: rgba(192,48,48,.15); color: #E88080; border: 1px solid rgba(192,48,48,.2); }
.res-zip { background: rgba(232,200,74,.12); color: var(--jaune); border: 1px solid rgba(232,200,74,.18); }
.res-doc { background: rgba(74,144,212,.12); color: var(--bleu-pale); border: 1px solid rgba(74,144,212,.18); }
.res-title { font-family: var(--f-titre); font-size: 1.35rem; letter-spacing: .04em; color: var(--blanc); line-height: 1.1; }
.res-desc { font-size: .84rem; color: var(--gris); line-height: 1.65; flex: 1; }
.res-meta { font-size: .7rem; color: var(--gris); display: flex; gap: 1rem; }
.dl-btn { display: inline-flex; align-items: center; gap: .35rem; padding: .55rem 1rem; font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; background: var(--noir-4); color: var(--gris-clair); border: none; cursor: pointer; border-radius: 2px; text-decoration: none; transition: all .2s; }
.dl-btn:hover { background: var(--jaune); color: var(--noir); }
@media (max-width: 860px) { .pro-hero-inner { grid-template-columns: 1fr; gap: 2.5rem; } .ressources-grid { grid-template-columns: 1fr; } }

/* ===== Mentions légales (reprise maquette) ===== */
.legal-section { padding: clamp(2.5rem,5vw,4rem) var(--pad) 5rem; }
.legal-inner { max-width: 820px; margin: 0 auto; }
.legal-inner h2 { font-family: var(--f-titre); font-size: 1.7rem; letter-spacing: .03em; color: var(--jaune); margin: 2.5rem 0 .8rem; }
.legal-inner h2:first-child { margin-top: 0; }
.legal-inner p, .legal-inner address { font-size: .92rem; color: var(--gris-clair); line-height: 1.8; font-style: normal; margin-bottom: .6rem; }
.legal-inner a { color: var(--jaune); }

/* ===== En-tête des pages de contenu (adaptation maquette) ===== */
/* .entry-title sur pages event est géré par event.css (#headerevt h1) — non impacté ici */
.entry-header { position: relative; padding: .5rem 0 1.4rem 1.6rem; margin: 0 0 2.5rem; border-bottom: 1px solid var(--noir-4); }
.entry-header::before { content: ''; position: absolute; left: 0; top: .4rem; bottom: 1rem; width: 3px; background: linear-gradient(to bottom, var(--jaune), transparent); }
.entry-header .entry-title { font-family: var(--f-titre); font-size: clamp(2.6rem, 6vw, 5rem); line-height: .92; letter-spacing: .02em; color: var(--blanc); margin: 0; }

/* ===== Newsletter (reprise maquette) ===== */
.nl-section { background: var(--noir-2); border-top: 1px solid rgba(232,200,74,.08); padding: clamp(3.5rem,7vw,5.5rem) var(--pad); }
.nl-inner { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.nl-text .section-title { margin: .5rem 0 1rem; }
.nl-desc { font-size: .98rem; color: var(--gris-clair); line-height: 1.7; }
.nl-form { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: 1.5rem; }
.nl-input { flex: 1; min-width: 220px; background: var(--noir); border: 1px solid var(--noir-4); color: var(--blanc); padding: .85rem 1rem; font-family: var(--f-corps); font-size: .95rem; border-radius: 2px; }
.nl-input::placeholder { color: var(--gris); }
.nl-input:focus { border-color: var(--jaune); outline: none; }
.nl-note { font-size: .72rem; color: var(--gris); margin-top: .75rem; }
.nl-msg { font-size: .92rem; color: var(--jaune); margin-top: 1rem; font-weight: 600; }
.nl-sink { display: none; }
@media (max-width: 768px) { .nl-inner { grid-template-columns: 1fr; gap: 2rem; } }

/* ===== Galerie vidéo EAC (click-to-play) ===== */
.video-thumb { position: relative; }
.video-thumb iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; z-index: 3; }
.eac-section { max-width: var(--max); margin: 0 auto; padding: clamp(2rem,4vw,3.5rem) var(--pad); }
.eac-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5px; margin-top: 1.5rem; }
.eac-vid { cursor: pointer; background: var(--noir-3); display: flex; flex-direction: column; }
.eac-vid .video-thumb { aspect-ratio: 16/9; background: var(--noir-3); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.eac-vid .play-btn { position: relative; z-index: 2; width: 52px; height: 52px; border-radius: 50%; background: var(--jaune); display: flex; align-items: center; justify-content: center; transition: transform .25s, background .2s; }
.eac-vid:hover .play-btn { transform: scale(1.08); background: var(--jaune-clair); }
.eac-vid-title { padding: .85rem 1rem; font-size: .85rem; color: var(--gris-clair); line-height: 1.4; }
.eac-vid:hover .eac-vid-title { color: var(--blanc); }
@media (max-width: 860px) { .eac-gallery { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .eac-gallery { grid-template-columns: 1fr; } }
