/* =====================================================================
   HABITANSE — Feuille de style de la maquette
   Encode la charte graphique de l'entreprise :
   Couleurs : Nude #cca580 · Beige #f4f1ea · Bleu #006fad · Rouge #770000
   Typo     : Titres = League Spartan (majuscules)
              Sous-titres/en-têtes = Glacial Indifference* (majuscules)
              Corps = Noto Serif (version texte, plus lisible — la charte indiquait Noto Serif Display)
              Citations = Glacial Indifference* (italique)
   * Glacial Indifference n'existe pas sur Google Fonts : Montserrat sert
     ici de police de substitution visuelle. En production, auto-héberger
     le fichier .woff2 de Glacial Indifference (voir dossier stratégie).
   ===================================================================== */

:root{
  /* Palette charte */
  --nude:#cca580;
  --nude-soft:#e3d4c0;
  --beige:#f4f1ea;
  --beige-deep:#ece6da;
  --bleu:#006fad;
  --bleu-700:#025d92;
  --bleu-900:#023a5c;
  --rouge:#770000;
  --rouge-soft:#9a2b2b;
  --white:#ece6da;       /* surfaces (cartes) = beige clair de la charte — aucun blanc pur */
  --sand-deep:#e4dbca;   /* bande chaude plus profonde, pour l'alternance des sections */
  /* Neutres lisibles (corps de texte) */
  --ink:#23201c;       /* texte principal — contraste 12.7:1 sur beige */
  --ink-soft:#544d44;  /* texte secondaire — 7.5:1 sur beige */
  --line:#ddd5c7;

  --container:1180px;
  --radius:4px;
  --shadow:0 18px 50px -28px rgba(35,32,28,.45);
  --shadow-soft:0 10px 30px -20px rgba(35,32,28,.35);
  --font-title:'League Spartan',Impact,sans-serif;
  --font-head:'Montserrat','Glacial Indifference',Arial,sans-serif;
  --font-body:'Noto Serif',Georgia,'Times New Roman',serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--sand-deep);
  font-size:18px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--bleu-700);text-decoration:none}
a:hover{color:var(--bleu-900)}

/* ---------- Typographie ---------- */
h1,h2,h3,h4{font-family:var(--font-title);margin:0;line-height:1.04;
  text-transform:uppercase;letter-spacing:.01em;color:var(--ink);font-weight:700}
h1{font-size:clamp(2.6rem,6vw,4.6rem)}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:clamp(1.25rem,2vw,1.6rem)}
h4{font-size:1.05rem}
p{margin:0 0 1.1rem}
.lead{font-weight:700;font-style:italic;font-size:clamp(1.15rem,1.9vw,1.5rem);
  line-height:1.5;color:var(--ink)}
.eyebrow{font-family:var(--font-head);text-transform:uppercase;
  letter-spacing:.22em;font-size:.78rem;font-weight:600;color:var(--bleu-700);
  margin:0 0 1rem;display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--rouge)}
.eyebrow.center{justify-content:center}
.eyebrow.light{color:var(--beige)}
.eyebrow.light::before{background:var(--nude)}
blockquote{font-family:var(--font-head);font-style:italic;font-weight:500;
  font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.4;margin:0;color:var(--ink)}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:clamp(60px,8vw,110px) 0}
.section--tight{padding:clamp(46px,5vw,70px) 0}
.bg-beige{background:var(--sand-deep)}
.bg-white{background:var(--sand-deep)}
.bg-deep{background:var(--beige-deep)}
.bg-blue{background:var(--bleu);color:#eaf4fb}
.bg-blue h1,.bg-blue h2,.bg-blue h3{color:var(--white)}
.bg-ink{background:var(--nude);color:#3d3020}
.bg-ink h2,.bg-ink h3{color:var(--ink)}
.bg-ink .eyebrow{color:var(--rouge)}
.bg-ink p{color:#3d3020}
.center{text-align:center}
.measure{max-width:680px}
.measure.center{margin-left:auto;margin-right:auto}

/* --- Justification des textes de redaction (avec cesure FR) --- */
.bio-text p,.founder p,.split p,.card p,.phase p{text-align:justify;-webkit-hyphens:auto;hyphens:auto}
.bio-text .eyebrow,.founder .eyebrow,.split .eyebrow,.split .lead,.bio-text .lead-intro,.bio-text .signature,.phase .placeholder-note,.analyse-grid p{text-align:left;-webkit-hyphens:manual;hyphens:manual}
.page-particuliers .split p,.page-particuliers .card p{text-align:left;-webkit-hyphens:manual;hyphens:manual}
.grid{display:grid;gap:28px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.split--wide-partners{grid-template-columns:.8fr 1.2fr}

/* ---------- Boutons ---------- */
.btn{font-family:var(--font-head);font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;font-size:.82rem;padding:15px 30px;border-radius:var(--radius);
  display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;border:2px solid transparent;
  transition:transform .15s ease,background .2s ease,color .2s ease,box-shadow .2s ease}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--bleu);color:#f4f1ea;box-shadow:var(--shadow-soft)}
.btn-primary:hover{background:var(--bleu-700);color:#f4f1ea}
.btn-outline{background:transparent;color:var(--bleu);border-color:var(--bleu)}
.btn-outline:hover{background:var(--bleu);color:#f4f1ea}
.btn-light{background:var(--beige);color:var(--bleu-700)}
.btn-light:hover{background:var(--beige);color:var(--bleu-700)}
.btn-ghost{padding-left:0;padding-right:0;color:var(--rouge);background:none}
.btn-ghost:hover{color:var(--rouge-soft);transform:translateX(3px)}
.btn .arrow{transition:transform .2s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- En-tête / navigation ---------- */
.site-header{position:sticky;top:0;z-index:50;background:var(--nude);
  border-bottom:1px solid rgba(0,0,0,.12)}
.nav{display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:14px 24px;max-width:var(--container);margin:0 auto}
.nav .logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:18px;list-style:none;margin:0;padding:0}
.nav-links a{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;
  font-size:.78rem;font-weight:600;color:var(--bleu);padding:6px 0;position:relative;white-space:nowrap}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--rouge);transition:width .25s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--rouge)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .btn{padding:13px 24px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.25s}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--sand-deep)}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;
  padding:clamp(48px,7vw,90px) 0 clamp(40px,6vw,70px)}
.hero h1{margin-bottom:18px}
.hero h1 .accent{color:var(--bleu)}
.hero .slogan{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;
  font-size:.86rem;color:var(--rouge);font-weight:600;margin-bottom:22px}
.hero .hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.hero-figure{position:relative;display:flex;justify-content:center}
.hero-figure img{filter:saturate(.96)}
.hero-badge{position:absolute;left:0;bottom:18px;background:var(--beige);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:16px 20px;max-width:230px;border-left:4px solid var(--rouge)}
.hero-badge strong{font-family:var(--font-title);font-size:1.7rem;color:var(--bleu);display:block;line-height:1}
.hero-badge span{font-family:var(--font-head);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft)}
.hero-deco{position:absolute;right:-6%;top:-10%;width:46%;height:120%;
  background:radial-gradient(circle at 50% 40%,rgba(204,165,128,.35),transparent 62%);z-index:0}

/* ---------- Constat (problème) ---------- */
.constat-list{list-style:none;margin:0;padding:0;display:grid;gap:14px}
.constat-list li{display:flex;gap:14px;align-items:flex-start;background:var(--white);
  border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;
  color:var(--ink)}
.constat-list li::before{content:"";flex:none;width:9px;height:9px;margin-top:.55em;
  background:var(--rouge);border-radius:50%}

/* ---------- Cartes ---------- */
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-soft);transition:transform .2s ease,box-shadow .2s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .num{font-family:var(--font-title);font-size:1.1rem;color:#f4f1ea;background:var(--bleu);
  width:42px;height:42px;border-radius:50%;display:grid;place-items:center;margin-bottom:18px}
.card h3{margin-bottom:10px}
.card p{font-size:.96rem;color:var(--ink-soft);margin-bottom:0}
.card .ico{margin-bottom:16px;display:inline-flex;line-height:0;color:var(--bleu);
  background:rgba(0,111,173,.10);width:52px;height:52px;border-radius:50%;align-items:center;justify-content:center}
.card--audience.pro .ico{color:var(--rouge);background:rgba(119,0,0,.09)}
.ico svg{width:26px;height:26px}
.card--audience{border-top:4px solid var(--bleu)}
.card--audience.pro{border-top-color:var(--rouge)}

/* ---------- Méthode / étapes ---------- */
.phase{padding:30px 0;border-top:1px solid var(--line)}
.phase:first-child{border-top:0}
.phase .tag{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;
  font-size:.72rem;color:var(--rouge);font-weight:600}
.phase .step{font-family:var(--font-title);font-size:clamp(2.4rem,4vw,3.4rem);
  color:var(--nude);line-height:.9}
.analyse-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:14px}
.analyse-grid .item{background:var(--beige);border-left:3px solid var(--bleu);
  padding:16px 18px;border-radius:0 var(--radius) var(--radius) 0}
.analyse-grid .item h4{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.06em;
  font-size:.82rem;color:var(--bleu);margin-bottom:8px}
.analyse-grid .item p{font-size:.9rem;color:var(--ink-soft);margin:0}
.checklist{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:10px}
.checklist li{display:flex;gap:12px;font-size:.98rem}
.checklist li::before{content:"✔";color:var(--bleu);font-weight:700;font-family:var(--font-head)}
.scenario-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.scenario-tags span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.06em;
  font-size:.74rem;background:var(--beige);border:1px solid var(--line);color:var(--ink);
  padding:8px 14px;border-radius:40px}

/* ---------- Partenaires ---------- */
.partners{display:flex;flex-wrap:wrap;gap:10px}
.partners .pbreak{flex-basis:100%;height:0;padding:0;margin:0;background:none;border:0}
.partners span{font-family:var(--font-head);font-size:.78rem;text-transform:uppercase;
  letter-spacing:.05em;background:var(--beige);border:1px solid #b78f63;
  color:var(--ink);padding:9px 16px;border-radius:40px}

/* ---------- Fondatrice ---------- */
.founder{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,64px);align-items:center}
.founder-photo{position:relative}
.founder-photo img{max-width:330px;margin-inline:auto}
.signature{font-family:var(--font-head);font-style:italic;color:var(--rouge);margin-top:6px}

/* ---------- Bio (page À propos) — portrait encadré, robuste (jamais rogné ni étiré) ---------- */
.bio{display:grid;grid-template-columns:minmax(0,330px) 1fr;gap:clamp(28px,5vw,56px);align-items:center}
.bio-photo{display:flex;justify-content:center;align-items:flex-end}
.bio-photo img{max-height:500px;width:auto;max-width:100%;display:block}
.bio-text .lead-intro{font-weight:700;font-style:italic;font-size:clamp(1.06rem,1.6vw,1.28rem);
  line-height:1.5;color:var(--ink);margin-bottom:16px}
.bio-facts{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 4px}
.bio-facts span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.05em;
  font-size:.72rem;background:var(--beige);border:1px solid var(--line);color:var(--rouge);padding:8px 14px;border-radius:40px}
@media(max-width:860px){
  .bio{grid-template-columns:1fr}
  .bio-photo{order:-1;padding-top:18px}
  .bio-photo img{max-height:360px}
}

/* ---------- Bandeau citation ---------- */
.quote-band{background:var(--bleu);color:#f4f1ea;text-align:center}
.quote-band blockquote{color:var(--nude);max-width:860px;margin:0 auto}
.quote-band .who{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;
  font-size:.78rem;color:var(--nude);margin-top:22px}

/* ---------- Témoignages ---------- */
.testimonial{background:var(--beige);border:1px solid var(--line);border-radius:var(--radius);padding:30px;
  position:relative;box-shadow:var(--shadow-soft)}
.testimonial::before{content:"“";font-family:var(--font-title);position:absolute;top:6px;left:18px;
  font-size:4rem;color:var(--nude);line-height:1}
.testimonial p{font-style:italic;position:relative}
.testimonial .who{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;
  font-size:.76rem;color:var(--bleu);margin-top:14px;font-weight:600}
.placeholder-note{font-family:var(--font-head);font-size:.72rem;letter-spacing:.05em;
  text-transform:uppercase;color:var(--rouge);background:var(--beige);border:1px dashed var(--rouge);
  display:inline-block;padding:4px 10px;border-radius:30px}

/* ---------- Bandeau CTA ---------- */
.cta-band{background:var(--bleu);color:#f4f1ea;text-align:center;position:relative;overflow:hidden}
.cta-band h2{color:#f4f1ea}
.cta-band p{color:#f4f1ea;max-width:620px;margin:14px auto 26px}
.cta-band .btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---------- Newsletter ---------- */
.newsletter{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center;
  background:var(--beige-deep);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(26px,4vw,44px)}
.field-row{display:flex;gap:10px;flex-wrap:wrap}
input,textarea,select{font-family:var(--font-body);font-size:1rem;width:100%;
  padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius);background:var(--beige-deep);color:var(--ink)}
input:focus,textarea:focus,select:focus{outline:3px solid rgba(0,111,173,.35);border-color:var(--bleu)}
label{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;
  font-size:.74rem;font-weight:600;color:var(--ink);display:block;margin:0 0 7px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-grid .full{grid-column:1/-1}
.req{color:var(--rouge)}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.84rem;color:var(--ink-soft);font-style:italic}
.consent input{width:auto;margin-top:5px}

/* ---------- Infos contact ---------- */
.contact-info{list-style:none;margin:0;padding:0;display:grid;gap:18px}
.contact-info li{display:flex;gap:14px;align-items:flex-start}
.contact-info .k{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;
  font-size:.72rem;color:var(--ink-soft);display:block}
.contact-info .v{font-size:1.05rem;color:var(--ink)}
.pill-ph{font-family:var(--font-head);font-size:.7rem;letter-spacing:.04em;color:var(--rouge);
  border:1px dashed var(--rouge);border-radius:20px;padding:1px 8px;text-transform:uppercase}

/* ---------- Pied de page ---------- */
.site-footer{background:var(--nude);color:#3d3020;border-top:4px solid var(--rouge);padding:54px 0 26px;font-size:.92rem}
.site-footer a{color:var(--ink)}
.site-footer a:hover{color:var(--rouge)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px}
.site-footer .logo img{height:30px;margin-bottom:16px}
.site-footer h4{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;
  font-size:.8rem;color:var(--ink);margin-bottom:14px}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.footer-bottom{border-top:1px solid rgba(61,48,32,.30);margin-top:40px;padding-top:20px;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.8rem;color:#3d3020}

/* ---------- Fil d'ariane / page header ---------- */
.page-hero{padding:clamp(50px,7vw,90px) 0 clamp(34px,4vw,54px);background:var(--sand-deep);
  border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.6rem)}
.breadcrumb{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;
  font-size:.72rem;color:var(--ink-soft);margin-bottom:16px}
.breadcrumb a{color:var(--bleu)}

/* ---------- Maquette : étiquette d'annotation ---------- */
/* étiquette « maquette » retirée pour la mise en production */

/* ---------- Reveal ---------- */
.reveal{animation:revealIn .6s ease-out both}
@keyframes revealIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.reveal.in{opacity:1;transform:none}

/* ---------- Utilitaires ---------- */
.mt0{margin-top:0}.mb0{margin-bottom:0}
.divider{height:2px;width:60px;background:var(--rouge);margin:20px 0;border:0}
.divider.center{margin-left:auto;margin-right:auto}
:focus-visible{outline:3px solid var(--rouge);outline-offset:2px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--rouge);color:#fff;
  padding:10px 16px;z-index:100;font-family:var(--font-head);text-transform:uppercase;font-size:.8rem}
.skip-link:focus{left:8px;top:8px}

/* ---------- Responsive ---------- */
@media(max-width:1180px){
  .nav{flex-wrap:wrap}
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:block}
  .nav.open .nav-links{display:flex;flex-basis:100%;order:3;flex-direction:column;gap:2px;
    margin-top:12px;padding-top:10px;border-top:1px solid var(--line)}
  .nav.open .nav-links a{padding:11px 0}
  .nav.open .nav-cta{display:flex;flex-basis:100%;order:4;margin-top:12px}
  .nav.open .nav-cta .btn{width:100%;justify-content:center}
}
@media(max-width:960px){
  .hero-inner,.split,.founder,.newsletter{grid-template-columns:1fr}
  .hero-figure{order:-1;max-width:360px;margin:0 auto}
  .g3,.g4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .founder-photo{max-width:320px;margin:0 auto}
}
@media(max-width:760px){
  body{font-size:17px}
  .g2,.g3,.g4,.form-grid,.analyse-grid,.constat-list{grid-template-columns:1fr}
  .phase{grid-template-columns:1fr;gap:8px}
  .footer-grid{grid-template-columns:1fr}
  .hero-badge{position:static;margin:18px auto 0}
}
@media(max-width:480px){
  .container{padding:0 18px}
  .section{padding:46px 0}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn,.cta-band .btns .btn,.page-hero .btn{width:100%;justify-content:center}
  .cta-band .btns{flex-direction:column}
  h1{font-size:clamp(2.2rem,9vw,2.85rem)}
  .card{padding:24px}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;animation:none}
  .btn:hover{transform:none}
}
@media(min-width:961px){.constat-list li{white-space:nowrap}}
.dot-list{list-style:none;margin:14px 0 0;padding:0;display:grid;gap:8px}
.dot-list li{position:relative;padding-left:1.3em}
.dot-list li::before{content:"•";position:absolute;left:.2em;color:var(--bleu);font-weight:700;font-size:1.1em;line-height:1}
