/* ================================================
   WAKINDA PROJECT — styles partagés
   ================================================ */
:root{
  --brick:#B83220;
  --brick-dark:#8E2616;
  --olive:#5A7A2E;
  --olive-dark:#3F5520;
  --ochre:#D4621A;
  --ink:#1A1A1A;
  --paper:#FAFAF7;
  --paper-2:#F2F0EA;
  --cream:#FFF7E8;
  --line:#E4E1D8;
  --muted:#6B675E;
  --r:14px;
  --maxw:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
  font-size:16px;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
h1,h2,h3,h4{margin:0;letter-spacing:-0.02em;line-height:1.08;font-weight:600}
.serif{font-family:'Newsreader',Georgia,serif;font-weight:500;letter-spacing:-0.015em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{
  font-size:12px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--muted);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--ink);opacity:0.5}

/* ====== HEADER (bandeau transparent / glassy) ====== */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:transparent;
  border-bottom:1px solid transparent;
  color:#2a1a08;
  transition:background .35s ease, border-color .35s ease, color .35s ease, backdrop-filter .35s ease, box-shadow .35s ease;
}
/* État scrollé : verre dépoli translucide */
header.nav.solid{
  background:rgba(250,250,247,0.72);
  -webkit-backdrop-filter:saturate(160%) blur(16px);
  backdrop-filter:saturate(160%) blur(16px);
  color:var(--ink);
  border-bottom-color:var(--line);
  box-shadow:0 6px 28px -16px rgba(70,40,10,0.30);
}
/* Header transparent sur hero sombre (page d'accueil) : texte blanc avant scroll */
body.has-hero header.nav:not(.solid){color:#fff}
body.has-hero header.nav:not(.solid) nav a{opacity:.85}
body.has-hero header.nav:not(.solid) nav a:hover{color:#ffd9a1;opacity:1}
body.has-hero header.nav:not(.solid) nav a::after{background:#ffd9a1}
/* Menu mobile ouvert : header opaque pour lisibilité */
body.menu-open header.nav{
  background:var(--paper);
  -webkit-backdrop-filter:none;backdrop-filter:none;
  color:var(--ink);border-bottom-color:var(--line);
}
header.nav .row{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;
  max-width:var(--maxw);margin:0 auto;
}
header.nav .logo{display:flex;align-items:center;gap:12px}
header.nav .logo img{display:block;height:38px;width:auto;transition:filter .35s ease}
header.nav nav{display:flex;align-items:center;gap:30px}
header.nav nav a{font-size:14px;font-weight:500;opacity:.78;position:relative;padding:6px 0;transition:opacity .2s ease, color .2s ease}
header.nav nav a:hover{opacity:1;color:var(--brick)}
header.nav nav a[aria-current="page"]{opacity:1;color:var(--brick)}
header.nav nav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:currentColor;transition:right .25s ease}
header.nav nav a:hover::after, header.nav nav a[aria-current="page"]::after{right:0}
header.nav nav a[aria-current="page"]::after{background:var(--brick)}
header.nav .cta,
header.nav .cta[aria-current="page"],
header.nav nav a.cta,
header.nav nav a.cta[aria-current="page"]{
  background:var(--brick);color:#fff!important;padding:11px 18px;border-radius:999px;
  font-weight:600;font-size:14px;border:0;opacity:1;
  transition:background .2s ease, transform .2s ease;
}
header.nav .cta:hover,
header.nav nav a.cta:hover{background:var(--brick-dark);transform:translateY(-1px);color:#fff!important}
header.nav .cta::after,
header.nav nav a.cta::after{display:none!important}
.burger{display:none;background:none;border:0;color:inherit;width:42px;height:42px}
.burger svg{width:24px;height:24px}
.mobile-menu{
  position:fixed;inset:0;background:var(--paper);z-index:48;color:var(--ink);
  transform:translateX(100%);transition:transform .35s ease;
  padding:96px 28px 40px;display:flex;flex-direction:column;gap:8px;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.mobile-menu.open{transform:none}
/* Couleur explicite : texte foncé sur fond clair, quel que soit l'état du header */
.mobile-menu a{color:var(--ink);font-size:24px;font-weight:500;padding:14px 0;border-bottom:1px solid var(--line);font-family:'Newsreader',serif;transition:color .2s ease}
.mobile-menu a:hover{color:var(--brick)}
.mobile-menu a[aria-current="page"]{color:var(--brick)}
.mobile-menu .cta{margin-top:24px;background:var(--brick);color:#fff;text-align:center;padding:18px;border-radius:999px;font-weight:600;font-size:15px;font-family:'Inter',sans-serif;border-bottom:0}
.mobile-menu .cta:hover{color:#fff}
/* Burger foncé quand le menu est ouvert (sert de bouton fermer, lisible sur fond clair) */
body.menu-open .burger{color:var(--ink)}

/* ====== BUTTONS ====== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;border-radius:999px;
  font-weight:600;font-size:15px;
  border:1px solid transparent;cursor:pointer;
  transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--brick);color:#fff}
.btn-primary:hover{background:var(--brick-dark);color:#fff}
.btn-ghost{background:rgba(255,255,255,0.7);color:var(--ink);border-color:rgba(70,40,10,0.25);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:#fff;color:var(--ink);border-color:var(--ink)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;color:#fff}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn .arrow{width:18px;height:18px;transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(3px)}

/* ====== PAGE HEADER (sous-pages) ====== */
.page-head{
  padding:160px 0 80px;position:relative;overflow:hidden;
  background:linear-gradient(180deg, #FFF4DC 0%, #FAFAF7 100%);
  border-bottom:1px solid var(--line);
}
.page-head .crumb{font-size:13px;color:var(--muted);margin-bottom:20px;display:flex;gap:8px;align-items:center}
.page-head .crumb a:hover{color:var(--brick)}
.page-head .crumb svg{width:12px;height:12px;opacity:.5}
.page-head h1{
  font-family:'Newsreader',Georgia,serif;font-weight:500;letter-spacing:-0.025em;
  font-size:clamp(44px,6vw,84px);max-width:18ch;margin-bottom:24px;
}
.page-head h1 em{font-style:italic;color:var(--brick);font-weight:400}
.page-head .lede{font-size:19px;color:#3a2a1c;max-width:60ch;margin:0}
.page-head .deco{
  position:absolute;right:-80px;top:80px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle, rgba(212,98,26,0.18) 0%, rgba(212,98,26,0) 70%);
  pointer-events:none;
}

/* ====== SECTIONS ====== */
section{padding:120px 0;position:relative}
section.tight{padding:96px 0}
.section-head{display:grid;grid-template-columns:1fr 1.6fr;gap:60px;margin-bottom:64px;align-items:end}
.section-head h2{font-size:clamp(36px,4.5vw,60px);font-weight:500;font-family:'Newsreader',Georgia,serif;letter-spacing:-0.02em}
.section-head p{font-size:18px;color:var(--muted);max-width:60ch;margin:0}

/* ====== PLACEHOLDERS PHOTO ====== */
.ph{
  background-color:#e8d8b8;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,0.35) 0 2px, transparent 2px 18px),
    repeating-linear-gradient(-45deg, rgba(70,40,10,0.06) 0 2px, transparent 2px 18px);
  display:grid;place-items:center;
  color:rgba(70,40,10,0.55);
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;letter-spacing:.05em;
  text-align:center;padding:14px;
}
.ph.olive{background-color:#d3dcb4}
.ph.brick{background-color:#f0c4b8}
.ph.ochre{background-color:#f5cba0}
.ph.sand{background-color:#ecd9b0}
.ph.sky{background-color:#c8d8e0}
.ph.cream{background-color:#f5e8c8}
.ph.dust{background-color:#dec8a8}
.ph .lbl{
  border:1px dashed currentColor;padding:6px 10px;border-radius:3px;max-width:80%;
  background:rgba(255,255,255,0.4);
}

/* Justification du corps de texte (titres, boutons, cartes et méta restent alignés) */
.lede,.mission .col p,.ap-grid p,.apropos-mission p,.map-grid .col-text p,.pt-grid p,
.prose p,.pjt-hero p,.projet-detail p,.legal-page p,.cta-band p{text-align:justify;text-justify:inter-word}

/* ====== FOOTER ====== */
footer{background:var(--cream);color:var(--muted);padding:80px 0 32px;border-top:1px solid rgba(70,40,10,0.1)}
footer .top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid rgba(70,40,10,0.1)}
footer .brand .logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
footer .brand .logo img{display:block;height:42px;width:auto}
footer .brand p{margin:0;max-width:36ch;font-size:14.5px;line-height:1.6}
footer h4{color:var(--ink);font-size:13px;text-transform:uppercase;letter-spacing:0.14em;margin-bottom:18px;font-weight:600}
footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
footer ul a{font-size:14.5px;transition:color .2s ease}
footer ul a:hover{color:var(--brick)}
footer .bottom{display:flex;justify-content:space-between;align-items:center;padding-top:32px;font-size:13px;flex-wrap:wrap;gap:16px}
.socials{display:flex;gap:10px}
.socials a{
  width:42px;height:42px;border-radius:50%;border:1px solid var(--line);
  display:grid;place-items:center;color:var(--ink);transition:all .2s ease;
}
.socials a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.socials a svg{width:18px;height:18px}
footer .bottom .socials a{border-color:rgba(70,40,10,0.2);color:var(--ink)}

/* ====== REVEAL ANIM ====== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(28px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal-stagger.in > *{opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(2){transition-delay:.08s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.16s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.24s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.32s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.4s}

.num{font-variant-numeric:tabular-nums}

/* ====== CARDS partagées ====== */
.pillar{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:32px;position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.pillar:hover{transform:translateY(-4px);box-shadow:0 16px 48px -16px rgba(26,26,26,0.12);border-color:transparent}
.pillar .num-l{font-family:'Newsreader',Georgia,serif;font-style:italic;font-size:14px;color:var(--muted)}
.pillar h3{font-size:24px;margin:14px 0 12px;font-weight:600;letter-spacing:-0.02em}
.pillar p{margin:0;color:var(--muted);font-size:15px;line-height:1.55}
.pillar .swatch{position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;opacity:0.12}

.projet{
  background:#fff;border-radius:var(--r);overflow:hidden;
  border:1px solid rgba(70,40,10,0.10);
  display:flex;flex-direction:column;
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.projet:hover{transform:translateY(-6px);border-color:rgba(70,40,10,0.18);box-shadow:0 22px 50px -22px rgba(120,60,20,0.18)}
.projet .ph{aspect-ratio:4/3;position:relative;overflow:hidden}
.projet .body{padding:28px 26px 30px;display:flex;flex-direction:column;gap:14px;flex:1}
.projet .status{
  align-self:flex-start;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:5px 10px;border-radius:999px;
}
.status-ec{background:rgba(212,98,26,0.15);color:#9c4710}
.status-av{background:rgba(90,122,46,0.18);color:var(--olive-dark)}
.status-tm{background:rgba(70,40,10,0.08);color:var(--muted)}
.projet h3{font-size:22px;font-weight:600;letter-spacing:-0.015em;color:var(--ink)}
.projet p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.55;flex:1}
.progress{margin-top:6px}
.progress .bar{height:4px;background:rgba(70,40,10,0.08);border-radius:999px;overflow:hidden}
.progress .fill{height:100%;background:linear-gradient(90deg,var(--ochre),var(--brick));border-radius:999px;transform-origin:left;transform:scaleX(0);transition:transform 1.2s cubic-bezier(.2,.7,.2,1)}
.progress .meta{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:8px;font-variant-numeric:tabular-nums}
.projet .galerie-link{
  display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--brick);
  border-top:1px solid rgba(70,40,10,0.08);padding-top:18px;margin-top:6px;
  transition:gap .2s ease, color .2s ease;
}
.projet .galerie-link:hover{color:var(--brick-dark);gap:12px}
.projet .galerie-link svg{width:14px;height:14px}

/* ====== CTA BAND (réutilisable) ====== */
.cta-band{
  background:linear-gradient(135deg, var(--brick) 0%, #c14222 50%, var(--ochre) 100%);
  color:#fff;padding:96px 0;position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 22px);
  pointer-events:none;
}
.cta-band .wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;position:relative}
.cta-band h2{font-family:'Newsreader',serif;font-size:clamp(36px,4.5vw,56px);font-weight:500;letter-spacing:-0.02em;max-width:18ch}
.cta-band p{max-width:38ch;font-size:17px;color:rgba(255,255,255,0.88);margin:18px 0 0}
.cta-band .actions{display:flex;flex-direction:column;gap:12px;justify-self:end}
.cta-band .actions .btn{justify-content:center}
.cta-band .actions .btn-primary{background:#fff;color:var(--brick)}
.cta-band .actions .btn-primary:hover{background:var(--brick);color:#fff}
.cta-band .actions .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,0.5)}
.cta-band .actions .btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}

/* ====== RESPONSIVE ====== */
@media (max-width:980px){
  header.nav nav{display:none}
  header.nav > .row > .cta{display:none}
  .burger{display:grid;place-items:center}
  section{padding:80px 0}
  .section-head{grid-template-columns:1fr;gap:20px;margin-bottom:40px}
  .page-head{padding:120px 0 60px}
  footer .top{grid-template-columns:1fr 1fr;gap:40px}
  footer .brand{grid-column:span 2}
  .cta-band{padding:64px 0}
  .cta-band .wrap{grid-template-columns:1fr;gap:32px}
  .cta-band .actions{justify-self:stretch}
}
@media (max-width:560px){
  footer .top{grid-template-columns:1fr}
  footer .brand{grid-column:span 1}
}

/* ====== ACCESSIBILITÉ : mouvement réduit ======
   Respecte le réglage système "réduire les animations".
   Garantit aussi que le contenu .reveal reste visible sans JS. */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
    scroll-behavior:auto!important;
  }
  .reveal,.reveal-stagger>*{opacity:1!important;transform:none!important}
  .btn:hover,.pillar:hover,.projet:hover{transform:none!important}
}
