/* ============================================================
   Side to Side — Feuille de style partagée (design system)
   Tout ce qui est commun aux 5 pages vit ICI, une seule fois.
   Le CSS propre à chaque page reste dans son <style> en ligne.
   ============================================================ */

/* --- Variables de couleur (source unique de vérité) --- */
:root{
  --b-50:#F4EFEA;--b-100:#E8DED5;--b-200:#D6C6B8;--b-300:#C1AC9A;
  --b-400:#9A7E6A;--b-500:#6B4F3F;--b-600:#5A4032;--b-700:#4A3429;
  --b-800:#3A2820;--b-900:#2A1D18;
  --o-100:#F2DFC2;--o-300:#DBAF6A;--o-400:#CE9850;--o-500:#C48A3A;
  --sep:rgba(244,239,234,0.08);
}

/* --- Reset & bases --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--b-900);color:var(--b-50);overflow-x:hidden;line-height:1.6}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* --- Navigation (desktop) --- */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;justify-content:flex-end;align-items:center;padding:18px 52px;background:var(--b-900);border-bottom:1px solid var(--sep)}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{font-family:'Inter',sans-serif;font-size:0.7rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--b-50);transition:color .2s}
/* Retour visuel au survol et sur la page active (corrige l'absence d'effet d'avant) */
.nav-links a:hover{color:var(--o-300)}
.nav-links a.active{color:var(--o-300)}

/* --- Bouton hamburger : invisible sur desktop, affiché en mobile --- */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:30px;height:30px;padding:0;background:none;border:none;cursor:pointer;z-index:210}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--b-50);border-radius:2px;transition:transform .3s ease,opacity .2s ease}

/* --- Boutons --- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Inter',sans-serif;font-size:0.73rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;padding:14px 28px;transition:all .2s;cursor:pointer;border:none;text-decoration:none}
.btn-acc{background:var(--o-500);color:var(--b-900)}
.btn-acc:hover{background:var(--o-400);transform:translateY(-1px)}
.btn-out{background:transparent;border:1px solid rgba(244,239,234,0.28);color:var(--b-50)}
.btn-out:hover{border-color:var(--b-100);background:rgba(244,239,234,0.05)}

/* --- Typo & séparateurs partagés --- */
.label{font-family:'Inter',sans-serif;font-size:0.68rem;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--o-500)}
.divider{height:1px;background:var(--sep);margin:0 52px}
section{padding:80px 52px}

/* --- Footer --- */
footer{background:var(--b-900);padding:48px 52px 28px;border-top:1px solid var(--sep)}
.footer-entites{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-bottom:36px}
.entite-block{background:var(--b-800);padding:16px 18px}
.entite-block h6{font-family:'Inter',sans-serif;font-size:0.63rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--o-500);margin-bottom:5px}
.entite-block p{font-size:0.79rem;font-weight:300;color:var(--b-400);line-height:1.5}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:44px;margin-bottom:28px}
.footer-brand .fb-name{font-family:'Lora',serif;font-size:1.3rem;font-weight:700;color:var(--b-100);margin-bottom:10px}
.footer-brand p{font-size:0.83rem;font-weight:300;line-height:1.7;color:var(--b-400);max-width:240px}
.footer-col h5{font-family:'Inter',sans-serif;font-size:0.64rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--b-400);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--sep)}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:5px}
.footer-col ul li a{font-size:0.83rem;font-weight:300;color:var(--b-300);transition:color .2s}
.footer-col ul li a:hover{color:var(--b-50)}
.footer-contact-btn{display:inline-block;background:var(--o-500);color:var(--b-900)!important;padding:8px 16px;font-size:0.72rem!important;font-weight:500;letter-spacing:0.08em;transition:background .2s}
.footer-contact-btn:hover{background:var(--o-400)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--sep);padding-top:18px}
.footer-bottom p{font-size:0.71rem;color:var(--b-600)}
.footer-bottom a{color:var(--b-400);transition:color .2s}
.footer-bottom a:hover{color:var(--o-300)}

/* --- Animations d'apparition --- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}

/* ============================================================
   RESPONSIVE — passage en mode mobile sous 900px
   ============================================================ */
@media(max-width:900px){
  nav{padding:14px 20px}
  section{padding:52px 20px}
  .divider{margin:0 20px}

  /* On affiche le hamburger */
  .nav-toggle{display:flex}

  /* Les liens deviennent un overlay plein écran, masqué par défaut */
  .nav-links{
    position:fixed;inset:0;
    flex-direction:column;justify-content:center;align-items:center;gap:30px;
    background:var(--b-900);
    z-index:150;                 /* sous la barre (200) : la barre + le X restent visibles */
    opacity:0;visibility:hidden;transform:translateY(-12px);
    transition:opacity .3s ease,transform .3s ease,visibility .3s ease;
  }
  .nav-links a{font-size:1.05rem;letter-spacing:.18em}

  /* Quand le menu est ouvert : overlay visible + scroll de la page bloqué */
  body.nav-open .nav-links{opacity:1;visibility:visible;transform:none}
  body.nav-open{overflow:hidden}

  /* Hamburger -> croix (X) à l'ouverture */
  body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.nav-open .nav-toggle span:nth-child(2){opacity:0}
  body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* Respect des préférences de réduction d'animation */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
