/* ENTRÉE LIBRE — système de design
   Blanc/crème, encre presque noire, limes (kiwi + secondaire) et noir,
   nav verticale permanente à gauche, filets fins, motif touche Entrée (↵). */

:root{
  --paper:#FBFBF6;
  --ink:#14130E;
  --accent:#CCFF00;        /* kiwi — l'accent d'impact */
  --accent-2:#DFFF00;      /* lime secondaire (tags, variations) */
  --accent-ink:#3d4d00;    /* lime foncé, lisible en texte/lien sur fond clair */
  --line:rgba(20,19,14,0.13);
  --line-strong:rgba(20,19,14,0.26);
  --muted:#8c8c7e;
  --side:248px;            /* largeur de la nav gauche */
  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-sans:"Instrument Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --maxw:1080px;
  --pad:clamp(20px,4vw,56px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--font-sans);font-size:18px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  display:grid;grid-template-columns:var(--side) 1fr;grid-template-rows:1fr auto;
  grid-template-areas:"side main" "side foot";min-height:100vh;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:10px 16px;z-index:100}
.skip:focus{left:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* ---------- Nav gauche permanente ---------- */
#site-header{grid-area:side}
.side{position:sticky;top:0;height:100vh;background:transparent;
  display:flex;flex-direction:column;padding:26px 22px;gap:28px}
.side::after{content:"";position:absolute;top:0;right:0;width:1px;height:100%;
  background:var(--accent);transform-origin:top;transform:scaleY(0);animation:spine .8s ease-out .15s forwards}
@keyframes spine{to{transform:scaleY(1)}}
.side__logo{position:relative;display:inline-flex;align-items:center;min-height:80px}
.side__logo img{height:80px;width:auto;transition:opacity .2s ease}
.side__logo-back{position:absolute;left:0;top:50%;transform:translateY(-50%);opacity:0;
  font-family:var(--font-display);font-size:19px;font-weight:600;color:var(--ink);white-space:nowrap;
  display:inline-flex;align-items:center;gap:8px;transition:opacity .2s ease;pointer-events:none}
.side__logo:hover img{opacity:0}
.side__logo:hover .side__logo-back{opacity:1}
.side__nav{display:flex;flex-direction:column;margin-top:6px}
.side__nav a{display:flex;align-items:center;justify-content:space-between;
  font-size:14px;color:var(--muted);padding:10px 2px;border-bottom:1px solid var(--line);
  transition:padding-left .18s ease,color .18s ease}
.side__nav a .k{font-size:13px;color:var(--muted);opacity:0;transform:translateX(-4px);
  transition:opacity .18s,transform .18s}
.side__nav a:hover{padding-left:9px;color:var(--ink)}
.side__nav a:hover .k{opacity:1;transform:none;color:var(--accent-ink)}
.side__nav a[aria-current="page"]{font-weight:600;color:var(--ink)}
.side__nav a[aria-current="page"] .k{opacity:1;transform:none;color:var(--accent-ink)}
.side__foot{margin-top:auto;display:flex;flex-direction:column;gap:12px}
.side__cta{display:inline-flex;align-items:center;justify-content:space-between;gap:8px;
  background:var(--accent);color:var(--ink);font-size:15px;font-weight:600;
  padding:12px 15px;border-radius:11px;border:1.5px solid var(--ink);transition:transform .15s ease}
.side__cta:hover{transform:translateY(-2px)}
.side__mail{font-size:13px;color:var(--muted)}
.side__mail:hover{color:var(--ink)}
.key{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:22px;
  border:1.5px solid currentColor;border-bottom-width:3px;border-radius:5px;font-size:13px;line-height:1}
.burger{display:none}

/* ---------- Zones principales ---------- */
#main{grid-area:main;min-width:0}
section{padding-block:clamp(32px,4.5vw,60px)}
/* sections de rythme : noir plein, voir .invert */
.invert{background:var(--ink);color:var(--paper)}
.invert .eyebrow{color:#a7a79a}
.invert h2,.invert h3{color:var(--paper)}
.invert .linklist{border-color:rgba(251,251,246,.22)}
.invert .linklist a,.invert .linklist li{border-color:rgba(251,251,246,.18)}
.invert .linklist .t{color:var(--paper)}
.invert .linklist a:hover .t{color:var(--ink)}
.invert .linklist a:hover{background:var(--accent);padding-left:18px;color:var(--ink)}
.invert .linklist a:hover .a{color:var(--accent-ink)}
.invert .linklist a:hover .arrow{color:var(--ink)}
.invert .linklist .a{color:#a7a79a}
.invert .arrow{color:var(--accent)}
.invert .btn--ghost{color:var(--paper);border-color:var(--paper)}
.eyebrow{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.04;letter-spacing:-.01em}
h1{font-size:clamp(40px,6.5vw,78px)}
h2{font-size:clamp(28px,4vw,44px)}
h3{font-size:clamp(20px,2.4vw,26px)}
.lead{font-size:clamp(19px,2.1vw,23px);max-width:46ch}
mark{background:var(--accent);color:var(--ink);padding:0 .12em;border-radius:2px}

/* liens texte fins */
.tlink{color:var(--ink);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;text-decoration-color:var(--accent);transition:text-decoration-thickness .15s}
.tlink:hover{text-decoration-thickness:5px}

/* ---------- Hero (accueil) — pleine page, éditorial ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column}
.hero>.wrap{flex:1;display:flex;align-items:flex-start;padding-block:clamp(40px,6vw,80px)}
.hero__grid{position:relative;display:grid;grid-template-columns:1.45fr .55fr;gap:clamp(28px,5vw,72px);align-items:start;width:100%}
.hero h1{font-size:clamp(48px,9vw,116px);letter-spacing:-.025em;line-height:.98}
.hero h1 mark{display:inline-block;padding:.02em .14em;line-height:1.04;border-radius:2px}
.hero__side{display:flex;flex-direction:column;align-items:flex-start;gap:18px;padding-top:10px;max-width:34ch}
.hero__side .eyebrow{margin:0}
.rule{width:38px;height:3px;background:var(--accent);display:block}
.hero__side .intro{font-size:clamp(17px,1.8vw,21px);line-height:1.45;max-width:30ch}
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:var(--ink);
  font-weight:600;font-size:16px;padding:13px 18px;border-radius:11px;border:1.5px solid var(--ink);transition:transform .15s ease}
.btn:hover{transform:translateY(-2px)}
.btn--ghost{background:transparent}
.btn--dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.rdv-note{font-size:13px;color:var(--muted)}
.actions{margin-top:28px;display:flex;flex-wrap:wrap;gap:14px;align-items:center}

/* bandeau de verbes : fin, texture éditoriale */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap;margin-top:0}
.marquee__track{display:inline-flex;animation:hscroll 50s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--font-sans);font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);padding:11px 0;display:inline-flex;align-items:center}
.marquee__track span::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);margin:0 34px;display:inline-block}
@keyframes hscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Liste de liens ---------- */
.linklist{border-top:1px solid var(--line);margin-top:28px}
.linklist a,.linklist li{display:flex;align-items:baseline;justify-content:space-between;gap:18px;
  padding:20px 4px;border-bottom:1px solid var(--line);list-style:none}
.linklist a{transition:padding-left .2s ease,background .2s ease}
.linklist a:hover{padding-left:14px;background:linear-gradient(90deg,rgba(204,255,0,.20),transparent 62%)}
.linklist .t{font-family:var(--font-display);font-size:clamp(22px,3vw,32px);font-weight:600}
.linklist a:hover .t{color:var(--ink)}
.linklist .a{font-size:15px;color:var(--muted);flex:1;text-align:right;max-width:40ch;margin-left:auto}
.linklist .arrow{color:var(--accent-ink);font-size:18px}

/* ---------- Grilles & cartes ---------- */
.grid{display:grid;gap:20px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.card{border:1px solid var(--line);border-radius:14px;padding:24px;background:#fff;
  transition:border-color .2s ease,transform .2s ease}
.card:hover{border-color:var(--ink);transform:translateY(-2px)}
.card h3{margin-bottom:8px}
.card .role{color:var(--muted);font-size:15px}
.card .out{display:inline-block;margin-top:16px;font-size:14px;font-weight:600;color:var(--ink)}
.card .out::after{content:" ↵";color:var(--accent-ink)}
.card .out:hover{text-decoration:underline;text-decoration-color:var(--accent);text-decoration-thickness:3px;text-underline-offset:3px}
.card__logo{height:30px;width:auto;margin-bottom:14px;object-fit:contain}

/* méthode numérotée (alternance kiwi/noir) */
.steps{counter-reset:s;margin-top:28px;border-top:1px solid var(--line)}
.steps li{list-style:none;display:flex;gap:20px;padding:22px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.steps li::before{counter-increment:s;content:"0" counter(s);background:var(--accent);color:var(--ink);
  font-weight:700;font-size:13px;padding:3px 8px;border-radius:6px;border:1.5px solid var(--ink);flex:none}
.steps li:nth-child(even)::before{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* tag champ d'action */
.tag{display:inline-block;font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink);background:var(--accent-2);border-radius:999px;padding:4px 11px;margin-bottom:12px}

.empty{border:1px dashed var(--line-strong);border-radius:14px;padding:40px;text-align:center;color:var(--muted)}

/* page mentions légales */
.legal{max-width:62ch;display:flex;flex-direction:column;gap:26px}
.legal__bloc{border-top:1px solid var(--line);padding-top:18px}
.legal__bloc h3{font-size:18px;margin-bottom:8px}
.legal__bloc p{color:var(--ink);opacity:.85}

/* liste des principes : ancrée, lisible */
.principes{list-style:none;margin-top:18px;border-top:1px solid var(--line)}
.principes li{position:relative;padding:14px 4px 14px 30px;border-bottom:1px solid var(--line);font-size:17px}
.principes li::before{content:"↵";position:absolute;left:2px;top:14px;color:var(--accent-ink);font-size:14px}

/* h2 d'intro (problème) : pas de vide excessif autour */
.statement{padding-block:clamp(28px,4vw,52px)}
.statement h2{max-width:20ch}

/* carte avec visuel plein en haut */
.card--media{padding:0;overflow:hidden}
.rcard__media{width:100%;height:190px;object-fit:cover;display:block}
.card--media .card__body{padding:22px 24px 24px}
.out--off{color:var(--muted);opacity:.7}

/* carte consultant : photo, puis logo centré au survol (sur blanc) */
.mcard__media{position:relative;width:100%;height:230px;overflow:hidden;background:var(--ink)}
.mcard__photo{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .25s ease,transform .4s ease}
.mcard__logo-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:#fff;opacity:0;transition:opacity .25s ease}
.mcard__logo{max-width:62%;max-height:46%;width:auto;height:auto}
.mcard:hover .mcard__photo{opacity:0;transform:scale(1.04)}
.mcard:hover .mcard__logo-wrap{opacity:1}

/* ce qu'on fait / ne fait pas (section noire) */
.dodont{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px)}
.ticks{list-style:none;display:flex;flex-direction:column;gap:12px;margin-top:6px}
.ticks li{position:relative;padding-left:30px;font-size:17px;line-height:1.4}
.ticks li::before{content:"↵";position:absolute;left:0;top:1px;color:var(--accent);font-size:15px}
.ticks--no li::before{content:"×";color:#a7a79a}

/* formulaire de contact (sur blanc) */
.contact__grid{display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(28px,5vw,64px);align-items:start}
.cform{display:flex;flex-direction:column;gap:14px;max-width:40ch}
.cform label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
.cform input,.cform textarea{background:#fff;border:1px solid var(--line-strong);border-radius:9px;
  padding:11px 13px;color:var(--ink);font:inherit;font-size:15px}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--ink)}
.cform .btn{align-self:flex-start;margin-top:4px}
.cform__note{font-size:12px;color:var(--muted)}
.colist{list-style:none;display:flex;flex-direction:column;gap:18px}
.colist li{display:flex;flex-direction:column;gap:3px;border-top:1px solid var(--line);padding-top:14px}
.co__who{font-weight:600}
.colist a{color:var(--accent-ink);font-size:14px}

/* cartes de prise de RDV (sur section noire) */
.rdvcard{display:flex;flex-direction:column;border:1px solid rgba(251,251,246,.18);border-radius:14px;
  padding:24px;background:rgba(251,251,246,.04);transition:border-color .2s,transform .2s,background .2s}
.rdvcard:hover{border-color:var(--accent);transform:translateY(-3px);background:rgba(204,255,0,.06)}
.rdvcard__who{font-family:var(--font-display);font-size:23px;font-weight:600;color:var(--paper)}
.rdvcard__str{font-size:13px;color:#a7a79a;margin-top:6px;line-height:1.4}
.rdvcard__go{margin-top:20px;display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;
  color:var(--ink);background:var(--accent);padding:9px 13px;border-radius:9px;align-self:flex-start}

/* ---------- Bande RDV ---------- */
.cta{background:var(--ink);color:var(--paper);border-radius:18px;
  padding:clamp(40px,6vw,72px);text-align:center;margin-block:clamp(40px,6vw,72px)}
.cta h2{color:var(--paper)}
.cta__note{color:#a7a79a;max-width:46ch;margin:14px auto 0;font-size:15px}
.cta__rdv{margin-top:26px;display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.cta__who{font-size:11px;color:var(--accent-ink);background:var(--accent);padding:1px 7px;border-radius:5px;margin-left:2px}

/* ---------- Pied de page ---------- */
#site-footer{grid-area:foot}
.ft{background:var(--ink);color:var(--paper);padding:48px var(--pad)}
.ft__in{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px;align-items:flex-start}
.ft img{height:64px}
.ft a{color:var(--paper);opacity:.8;font-size:14px}
.ft a:hover{opacity:1;color:var(--accent)}
.ft__links{display:flex;gap:18px;flex-wrap:wrap}
.ft__small{width:100%;font-size:12px;color:#6f6f63;margin-top:16px}
.ft__credit{color:var(--accent);opacity:1}
.ft__credit:hover{text-decoration:underline}

/* ---------- Transition de page ---------- */
#main{animation:pagein .32s ease both}
@keyframes pagein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
body.is-leaving #main{opacity:0;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease}

/* ---------- Apparition au chargement ---------- */
/* le contenu apparaît après la descente de la ligne verte du menu */
.reveal{opacity:0;transform:translateY(14px);animation:rise .7s cubic-bezier(.2,.7,.2,1) .95s forwards}
.reveal:nth-child(2){animation-delay:1.03s}.reveal:nth-child(3){animation-delay:1.11s}.reveal:nth-child(4){animation-delay:1.19s}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  #main{animation:none}
}

/* ---------- Responsive : la nav passe en barre haute ---------- */
.navclose{display:none}
.navrdv{display:none}

@media (max-width:900px){
  body{grid-template-columns:1fr;grid-template-rows:auto 1fr auto;
    grid-template-areas:"side" "main" "foot"}
  .side{position:sticky;top:0;height:auto;flex-direction:row;align-items:center;
    justify-content:space-between;border-bottom:1px solid var(--line);
    padding:12px var(--pad);gap:16px;z-index:60;background:rgba(251,251,246,.94);backdrop-filter:blur(8px)}
  /* quand le menu est ouvert, la barre ne doit plus piéger le menu fixed */
  body.nav-open .side{position:static;backdrop-filter:none}
  .side::after{top:auto;bottom:0;right:auto;left:0;width:100%;height:2px;transform:scaleX(0);transform-origin:left;
    animation:spineH .8s ease-out .15s forwards}
  @keyframes spineH{to{transform:scaleX(1)}}

  /* logo plus grand, label retour masqué en mobile */
  .side__logo{min-height:0}
  .side__logo img{height:56px}
  .side__logo-back{display:none}

  /* le bouton RDV de la barre disparaît : il vit dans le menu plein écran */
  .side__foot{display:none}

  /* burger */
  .burger{display:inline-flex;align-items:center;gap:8px;background:none;border:1px solid var(--line-strong);
    border-radius:9px;padding:11px 14px;font-size:15px;font-family:inherit;cursor:pointer;order:3}

  /* menu plein écran */
  .side__nav{position:fixed;inset:0;z-index:9000;background:var(--paper);
    display:flex;flex-direction:column;gap:0;margin:0;border:0;
    padding:calc(env(safe-area-inset-top,0px) + 76px) var(--pad) calc(env(safe-area-inset-bottom,0px) + 28px);
    transform:translateY(-100%);transition:transform .32s cubic-bezier(.2,.7,.2,1);
    overflow-y:auto;visibility:hidden}
  .side__nav.open{transform:none;visibility:visible}
  .side__nav a{display:flex;align-items:center;justify-content:space-between;
    font-family:var(--font-display);font-size:32px;font-weight:600;color:var(--ink);
    padding:20px 0;border-bottom:1px solid var(--line)}
  .side__nav a:first-of-type{border-top:1px solid var(--line)}
  .side__nav a .k{border:0;width:auto;height:auto;min-width:0;font-size:26px;color:var(--accent-ink);opacity:1;transform:none}

  /* croix de fermeture, dans le coin haut-droit du menu */
  .navclose{display:flex;position:fixed;top:calc(env(safe-area-inset-top,0px) + 14px);right:var(--pad);
    z-index:9100;width:48px;height:48px;align-items:center;justify-content:center;
    background:var(--ink);border:0;border-radius:12px;cursor:pointer;font-size:0}
  .navclose::before,.navclose::after{content:"";position:absolute;width:20px;height:2.5px;
    background:var(--paper);border-radius:2px}
  .navclose::before{transform:rotate(45deg)}
  .navclose::after{transform:rotate(-45deg)}
  .side__nav:not(.open) .navclose{display:none}

  /* bouton RDV en bas du menu */
  .navrdv{position:relative !important;display:flex !important;align-items:center !important;
    justify-content:space-between !important;gap:14px;margin-top:auto;
    background:var(--accent) !important;color:var(--ink) !important;
    font-family:var(--font-sans) !important;font-weight:600 !important;font-size:19px !important;
    padding:20px 24px !important;border-radius:12px;border:2px solid var(--ink) !important;box-sizing:border-box}
  .navrdv__txt{display:block;font-family:var(--font-sans) !important}
  .navrdv .key{position:static;transform:none;border:0;width:auto;height:auto;min-width:0;font-size:26px;color:var(--ink)}
  body.nav-open{overflow:hidden}

  /* hero mobile : compact, bandeau visible en bas */
  .hero{min-height:auto}
  .hero>.wrap{display:block;padding-block:clamp(28px,7vw,44px)}
  .hero__grid{grid-template-columns:1fr;gap:22px;align-items:start}
  .hero h1{font-size:clamp(44px,13vw,68px)}
  .hero__side{border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:18px;gap:14px}
  .marquee{margin-top:clamp(56px,16vw,96px)}

  .contact__grid{grid-template-columns:1fr;gap:34px}
  .grid--3,.grid--2{grid-template-columns:1fr}
  .linklist .a{display:none}
}
