/*
  Himalaya Pathways — feuille de style principale du thème enfant
  Chargée sur les 5 templates de page via functions.php (wp_enqueue_style).
  Organisation : variables → base → composants communs (header, footer,
  boutons, image-slots, cartes) → styles spécifiques par page.
*/

:root{
  --navy:        #1C2B3A;
  --navy-deep:   #131E29;
  --paper:       #F5F3ED;
  --paper-alt:   #ECE7DA;
  --saffron:     #C67B2E;
  --saffron-deep:#9C5F1F;
  --sage:        #4B6B54;
  --sage-deep:   #37503E;
  --ink:         #22252A;
  --ink-soft:    #55575E;
  --ink-on-navy: #E9E6DC;
  --border:      #DBD5C4;
  --white:       #FFFFFF;

  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'IBM Plex Sans', -apple-system, Segoe UI, sans-serif;
  --font-mono:    'IBM Plex Mono', 'Courier New', monospace;

  --radius: 3px;
  --wrap: 1180px;
}

/* ================= BASE ================= */
.hp-page{ margin:0; font-family:var(--font-body); color:var(--ink); background:var(--paper); line-height:1.55; -webkit-font-smoothing:antialiased; }
.hp-page *,.hp-page *::before,.hp-page *::after{ box-sizing:border-box; }
.hp-page html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  .hp-page{ scroll-behavior:auto; }
  .hp-page *,.hp-page *::before,.hp-page *::after{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; }
}
.hp-page img{ max-width:100%; display:block; }
.hp-page a{ color:inherit; }
.hp-page .wrap{ max-width:var(--wrap); margin:0 auto; padding:0 28px; }
.hp-page a:focus-visible, .hp-page button:focus-visible, .hp-page summary:focus-visible,
.hp-page input:focus-visible, .hp-page select:focus-visible, .hp-page textarea:focus-visible{
  outline:2.5px solid var(--saffron); outline-offset:3px;
}
.hp-page h1, .hp-page h2, .hp-page h3{ font-family:var(--font-display); font-weight:600; margin:0; color:var(--navy); }

/* Neutralise le style "lettrine" (première lettre géante) que le thème
   parent Twenty Twenty-One applique par défaut à certains titres — nos
   titres doivent rester uniformes, sans effet éditorial hérité. */
.hp-page h1::first-letter, .hp-page h2::first-letter, .hp-page h3::first-letter,
.hp-page p::first-letter, .hp-page blockquote::first-letter{
  font-size:inherit; font-weight:inherit; font-family:inherit; float:none;
  line-height:inherit; color:inherit; margin:0; padding:0;
}

.hp-page .eyebrow{
  font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--saffron-deep); display:flex; align-items:center; gap:10px; margin-bottom:14px;
}
.hp-page .eyebrow::before{ content:""; width:22px; height:1px; background:var(--saffron-deep); display:inline-block; }
.hp-page .eyebrow.sage{ color:var(--sage-deep); }
.hp-page .eyebrow.sage::before{ background:var(--sage-deep); }

.hp-page .lede{
  font-family:var(--font-display); font-style:italic; font-weight:400;
  font-size:clamp(1.02rem, 1.5vw, 1.14rem); color:var(--ink-soft); max-width:64ch;
  border-left:3px solid var(--saffron); padding-left:22px; margin:0;
}
.hp-page .lede.sage{ border-left-color:var(--sage); }

.hp-page section{ padding:76px 0; }
.hp-page section.tight{ padding:56px 0; }
.hp-page .section-head{ max-width:660px; margin-bottom:44px; }
.hp-page .section-head h2{ font-size:clamp(1.5rem, 2.6vw, 2rem); line-height:1.2; }

.hp-page .btn-primary{
  font-family:var(--font-body); font-weight:600; font-size:0.98rem;
  background:var(--navy); color:var(--white); padding:15px 30px; border-radius:var(--radius);
  text-decoration:none; display:inline-block; border:1px solid var(--navy); cursor:pointer;
  transition:background 0.2s ease, transform 0.15s ease;
}
.hp-page .btn-primary:hover{ background:var(--navy-deep); transform:translateY(-1px); }
.hp-page .btn-ghost{
  font-family:var(--font-body); font-weight:500; font-size:0.95rem; color:var(--navy);
  text-decoration:none; border-bottom:1px solid var(--saffron); padding-bottom:2px; background:none; border-top:none; border-left:none; border-right:none; cursor:pointer;
}
.hp-page .btn-ghost:hover{ color:var(--saffron-deep); }

.hp-page .reveal{ opacity:0; transform:translateY(14px); transition:opacity 0.5s ease, transform 0.5s ease; }
.hp-page .reveal.in{ opacity:1; transform:translateY(0); }
@media (prefers-reduced-motion: reduce){ .hp-page .reveal{ opacity:1; transform:none; } }

/* ================= BRIDGE MOTIF (signature) ================= */
.hp-page .bridge-divider{ width:100%; height:64px; display:block; }
.hp-page .bridge-divider path{ fill:none; stroke:var(--border); stroke-width:1.5; }
.hp-page .bridge-divider .arc{
  stroke:var(--saffron); stroke-dasharray:400; stroke-dashoffset:400;
  animation:hpDrawArc 1.6s ease-out 0.2s forwards;
}
@keyframes hpDrawArc{ to{ stroke-dashoffset:0; } }
@media (prefers-reduced-motion: reduce){ .hp-page .bridge-divider .arc{ animation:none; stroke-dashoffset:0; } }

/* ================= BARRE DE POSITIONNEMENT ================= */
/* Présente sur les 6 pages, juste sous le header. Rappelle en permanence,
   quelle que soit la page d'entrée du visiteur, que le projet est exploratoire. */
.hp-page .positioning-bar{
  background:var(--paper-alt); border-bottom:1px solid var(--border);
  padding:11px 28px; text-align:center;
}
.hp-page .positioning-bar p{
  margin:0; font-family:var(--font-mono); font-size:0.76rem; color:var(--ink-soft);
  letter-spacing:0.01em; max-width:var(--wrap); margin:0 auto; line-height:1.5;
}
.hp-page .positioning-bar strong{ color:var(--sage-deep); font-weight:600; }

/* ================= HEADER / NAV ================= */
.hp-page header.site-header{
  position:sticky; top:0; z-index:50; background:rgba(245,243,237,0.92);
  backdrop-filter:blur(6px); border-bottom:1px solid var(--border);
}
.hp-page .header-inner{ display:flex; align-items:center; justify-content:space-between; padding:16px 28px; max-width:var(--wrap); margin:0 auto; }
.hp-page .logo{ display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:600; font-size:1.12rem; color:var(--navy); text-decoration:none; }
.hp-page .logo svg{ width:26px; height:26px; flex-shrink:0; }
.hp-page nav.main-nav{ display:flex; align-items:center; gap:34px; }
.hp-page nav.main-nav ul{ list-style:none; display:flex; gap:30px; margin:0; padding:0; }
.hp-page nav.main-nav a{ text-decoration:none; font-size:0.95rem; font-weight:500; color:var(--ink); position:relative; padding:4px 0; }
.hp-page nav.main-nav a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:var(--saffron); transition:width 0.2s ease; }
.hp-page nav.main-nav a:hover::after{ width:100%; }
.hp-page nav.main-nav a[aria-current="page"]::after,
.hp-page nav.main-nav li.current-menu-item > a::after,
.hp-page nav.main-nav li.current_page_item > a::after{ width:100%; }
.hp-page .lang-switch{ font-family:var(--font-mono); font-size:0.78rem; letter-spacing:0.03em; display:flex; gap:2px; border:1px solid var(--border); border-radius:20px; padding:3px; }
.hp-page .lang-switch button{ border:none; background:none; padding:5px 11px; border-radius:16px; cursor:pointer; font-family:inherit; font-size:inherit; color:var(--ink-soft); }
.hp-page .lang-switch button.active{ background:var(--navy); color:var(--white); }
.hp-page .nav-toggle{ display:none; }
@media (max-width: 880px){
  .hp-page nav.main-nav ul{
    position:fixed; inset:64px 0 0 0; background:var(--paper); flex-direction:column;
    padding:32px 28px; gap:22px; transform:translateX(100%); transition:transform 0.25s ease;
  }
  .hp-page nav.main-nav ul.open{ transform:translateX(0); }
  .hp-page nav.main-nav{ gap:14px; }
  .hp-page .nav-toggle{ display:block; background:none; border:1px solid var(--border); border-radius:6px; padding:8px 10px; cursor:pointer; }
  .hp-page .nav-toggle span, .hp-page .nav-toggle span::before, .hp-page .nav-toggle span::after{
    content:""; display:block; width:20px; height:2px; background:var(--navy); position:relative; transition:0.2s;
  }
  .hp-page .nav-toggle span::before{ position:absolute; top:-6px; }
  .hp-page .nav-toggle span::after{ position:absolute; top:6px; }
}

/* ================= FOOTER ================= */
.hp-page footer.site-footer{ background:var(--navy-deep); color:#A9A79C; padding:44px 0 32px; font-size:0.88rem; }
.hp-page footer.site-footer .wrap{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:18px; align-items:center; }
.hp-page footer.site-footer a{ color:#C7C4B8; text-decoration:none; border-bottom:1px solid rgba(199,196,184,0.35); }
.hp-page footer.site-footer a:hover{ color:var(--white); }
.hp-page footer.site-footer .foot-note{ max-width:520px; line-height:1.6; }

/* ================= IMAGE PLACEHOLDER SLOTS ================= */
.hp-page .img-slot{
  position:relative; background:linear-gradient(120deg, var(--saffron) 0%, var(--saffron) 42%, var(--sage) 58%, var(--sage) 100%);
  background-size:220% 220%; display:flex; align-items:flex-end; overflow:hidden; color:var(--white);
}
.hp-page .img-slot::before{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(28,43,58,0) 40%, rgba(19,30,41,0.75) 100%); }
.hp-page .img-slot .slot-label{ position:relative; z-index:1; padding:18px 22px; font-family:var(--font-mono); font-size:0.74rem; letter-spacing:0.05em; }
.hp-page .img-slot .slot-label strong{ display:block; font-size:0.82rem; margin-bottom:3px; }
/* Variante inversée (Page Territoires ruraux) — même composant, dégradé inverse pour se distinguer de la Page 1 */
.hp-page .img-slot.img-slot--rural{ background:linear-gradient(120deg, var(--sage) 0%, var(--sage) 46%, var(--saffron) 100%); background-size:220% 220%; }

/* ================= STAT CARDS (réutilisé Accueil + Territoires ruraux) ================= */
.hp-page .stat-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:1px; background:var(--border); border:1px solid var(--border); }
.hp-page .stat-grid.stat-grid--4{ grid-template-columns:repeat(4, 1fr); }
.hp-page .stat-card{ background:var(--paper); padding:32px 26px; }
.hp-page .stat-number{ font-family:var(--font-mono); font-weight:600; font-size:clamp(1.6rem, 2.8vw, 2.2rem); color:var(--navy); display:block; margin-bottom:10px; letter-spacing:-0.01em; }
.hp-page .stat-card p{ margin:0; color:var(--ink-soft); font-size:0.94rem; }
.hp-page .stat-source{ font-family:var(--font-mono); font-size:0.72rem; color:var(--sage-deep); }
@media (max-width:900px){ .hp-page .stat-grid.stat-grid--4{ grid-template-columns:1fr 1fr; } }
@media (max-width:760px){ .hp-page .stat-grid{ grid-template-columns:1fr; } }
@media (max-width:520px){ .hp-page .stat-grid.stat-grid--4{ grid-template-columns:1fr; } }

/* ================= SPLIT COLUMNS (réutilisé Accueil + Notre démarche) ================= */
.hp-page .split{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.hp-page .split-col h3{ font-size:1.08rem; margin-bottom:12px; }
.hp-page .split-col p{ color:var(--ink-soft); margin:0; }
@media (max-width:760px){ .hp-page .split{ grid-template-columns:1fr; gap:34px; } }

/* ================= ACCORDÉONS (réutilisé Livre blanc + FAQ) ================= */
.hp-page .accordion-list{ border-top:1px solid var(--border); }
.hp-page .accordion-item{ border-bottom:1px solid var(--border); }
.hp-page .accordion-item summary{
  list-style:none; cursor:pointer; padding:20px 4px; display:flex; align-items:center; gap:16px; justify-content:space-between;
}
.hp-page .accordion-item summary::-webkit-details-marker{ display:none; }
.hp-page .accordion-num{ font-family:var(--font-mono); font-size:0.85rem; color:var(--saffron-deep); flex-shrink:0; width:26px; }
.hp-page .accordion-title{ font-family:var(--font-body); font-weight:600; color:var(--navy); flex-grow:1; font-size:0.98rem; }
.hp-page .accordion-toggle-icon{
  width:20px; height:20px; border:1px solid var(--border); border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; color:var(--ink-soft); font-family:var(--font-mono); font-size:0.9rem;
}
.hp-page .accordion-item[open] .accordion-toggle-icon{ background:var(--saffron); color:var(--white); border-color:var(--saffron); }
.hp-page .accordion-item[open] .accordion-toggle-icon::before{ content:"–"; }
.hp-page .accordion-item:not([open]) .accordion-toggle-icon::before{ content:"+"; }
.hp-page .accordion-body{ padding:0 4px 24px 4px; color:var(--ink-soft); max-width:70ch; }
.hp-page .accordion-body.indent{ padding-left:44px; }

/* ================= PAGE : ACCUEIL ================= */
.hp-home .hero-media.img-slot{ height:min(56vw, 460px); min-height:280px; }
.hp-home .hero-content{ max-width:var(--wrap); margin:0 auto; padding:56px 28px 40px; }
.hp-home .hero-content h1{ font-size:clamp(2rem, 4vw, 3rem); line-height:1.12; max-width:16ch; margin-bottom:28px; }
.hp-home .hero-content .lede{ max-width:64ch; margin-bottom:36px; }
.hp-home .cta-row{ display:flex; align-items:center; gap:26px; flex-wrap:wrap; }

.hp-home .stylized-map{ margin-top:52px; border:1px solid var(--border); background:var(--paper-alt); padding:30px 20px; }

.hp-home .steps{ display:grid; grid-template-columns:repeat(5, 1fr); gap:0; counter-reset:step; border-top:1px solid var(--border); }
.hp-home .step{ position:relative; padding:28px 20px 0 0; border-right:1px solid var(--border); }
.hp-home .step:last-child{ border-right:none; }
.hp-home .step::before{ counter-increment:step; content:counter(step, decimal-leading-zero); font-family:var(--font-mono); font-size:0.78rem; color:var(--saffron-deep); display:block; margin-bottom:10px; }
.hp-home .step h4{ font-family:var(--font-body); font-weight:600; font-size:0.98rem; margin:0; color:var(--navy); }
@media (max-width:900px){ .hp-home .steps{ grid-template-columns:1fr; border-top:none; } .hp-home .step{ border-right:none; border-top:1px solid var(--border); padding:22px 0 0; } }

.hp-home .honest-block{ background:var(--paper-alt); }
.hp-home .honest-block .split-col{ background:var(--white); border:1px solid var(--border); padding:30px 28px; }

.hp-home .status-frise{ display:grid; grid-template-columns:repeat(4, 1fr); gap:14px; margin-top:36px; }
.hp-home .phase{ border:1px solid var(--border); background:var(--paper); padding:20px 18px; }
.hp-home .phase .phase-tag{ font-family:var(--font-mono); font-size:0.68rem; letter-spacing:0.06em; text-transform:uppercase; padding:3px 9px; border-radius:12px; display:inline-block; margin-bottom:12px; }
.hp-home .phase.done .phase-tag{ background:var(--sage); color:var(--white); }
.hp-home .phase.active .phase-tag{ background:var(--saffron); color:var(--white); }
.hp-home .phase.upcoming .phase-tag{ background:var(--paper-alt); color:var(--ink-soft); border:1px solid var(--border); }
.hp-home .phase h4{ margin:0; font-size:0.92rem; color:var(--navy); font-weight:600; font-family:var(--font-body); }
@media (max-width:760px){ .hp-home .status-frise{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .hp-home .status-frise{ grid-template-columns:1fr; } }
.hp-home .status-note{ background:var(--white); border:1px solid var(--border); border-left:3px solid var(--sage); padding:20px 24px; color:var(--ink-soft); font-size:0.96rem; }
.hp-home .roadmap-link{ margin-top:22px; display:inline-block; }

.hp-home .whitepaper-band{ background:var(--navy); color:var(--ink-on-navy); }
.hp-home .whitepaper-band .wrap{ display:flex; align-items:center; justify-content:space-between; gap:40px; padding:56px 28px; }
.hp-home .whitepaper-band h2{ color:var(--white); font-size:clamp(1.4rem,2.4vw,1.9rem); margin-bottom:14px; }
.hp-home .whitepaper-band p{ color:#C7C4B8; max-width:56ch; margin:0; }
.hp-home .whitepaper-text{ max-width:640px; }
.hp-home .whitepaper-band .btn-primary{ background:var(--saffron); border-color:var(--saffron); color:var(--navy-deep); font-weight:600; white-space:nowrap; }
.hp-home .whitepaper-band .btn-primary:hover{ background:var(--saffron-deep); color:var(--white); }
@media (max-width:760px){ .hp-home .whitepaper-band .wrap{ flex-direction:column; align-items:flex-start; } }

.hp-home .join-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:1px; background:var(--border); border:1px solid var(--border); }
.hp-home .join-card{ background:var(--paper); padding:30px 24px; text-decoration:none; color:var(--ink); display:flex; flex-direction:column; gap:14px; min-height:190px; transition:background 0.18s ease; }
.hp-home .join-card:hover{ background:var(--white); }
.hp-home .join-card .icon{ width:38px; height:38px; border-radius:50%; background:var(--paper-alt); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--sage-deep); }
.hp-home .join-card h4{ font-family:var(--font-body); font-weight:600; font-size:1rem; color:var(--navy); margin:0; }
.hp-home .join-card p{ margin:0; font-size:0.9rem; color:var(--ink-soft); flex-grow:1; }
.hp-home .join-card .go{ font-family:var(--font-mono); font-size:0.75rem; color:var(--saffron-deep); }
@media (max-width:900px){ .hp-home .join-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .hp-home .join-grid{ grid-template-columns:1fr; } }

/* ================= PAGE : LIVRE BLANC ================= */
.hp-whitepaper .intro-layout{ display:grid; grid-template-columns:320px 1fr; gap:56px; align-items:start; }
.hp-whitepaper .cover-media.img-slot{ height:420px; align-self:start; }
.hp-whitepaper .intro-text h1{ font-size:clamp(1.9rem, 3.4vw, 2.6rem); line-height:1.16; margin-bottom:24px; max-width:20ch; }
.hp-whitepaper .intro-text .lede{ max-width:60ch; margin:0 0 32px; }
@media (max-width:820px){ .hp-whitepaper .intro-layout{ grid-template-columns:1fr; } .hp-whitepaper .cover-media.img-slot{ height:280px; } }

.hp-whitepaper .limits-block{ background:var(--paper-alt); }
.hp-whitepaper .limits-card{ background:var(--white); border:1px solid var(--border); border-left:3px solid var(--sage); padding:32px 30px; max-width:760px; }
.hp-whitepaper .limits-card p{ margin:0; color:var(--ink-soft); font-size:1.02rem; font-style:italic; font-family:var(--font-display); }

.hp-whitepaper .download-panel{ background:var(--navy); color:var(--ink-on-navy); padding:52px 44px; display:grid; grid-template-columns:1.1fr 0.9fr; gap:48px; align-items:center; }
.hp-whitepaper .download-panel h2{ color:var(--white); font-size:clamp(1.3rem,2.2vw,1.7rem); margin-bottom:12px; }
.hp-whitepaper .download-panel p{ color:#C7C4B8; margin:0 0 6px; }
.hp-whitepaper .update-note{ font-family:var(--font-mono); font-size:0.76rem; color:#9A98A0; margin-top:14px; }
.hp-whitepaper .download-form{ background:rgba(255,255,255,0.04); border:1px solid rgba(233,230,220,0.18); padding:26px; border-radius:var(--radius); }
.hp-whitepaper .download-form label{ display:block; font-size:0.86rem; margin-bottom:8px; color:var(--ink-on-navy); }
.hp-whitepaper .download-form input[type="email"]{
  width:100%; padding:12px 14px; border-radius:var(--radius); border:1px solid rgba(233,230,220,0.3);
  background:rgba(255,255,255,0.06); color:var(--white); font-family:var(--font-body); font-size:0.95rem; margin-bottom:8px;
}
.hp-whitepaper .download-form .field-note{ font-size:0.78rem; color:#9A98A0; margin-bottom:18px; }
.hp-whitepaper .download-form .btn-primary{ background:var(--saffron); border-color:var(--saffron); color:var(--navy-deep); width:100%; text-align:center; }
.hp-whitepaper .download-form .btn-primary:hover{ background:var(--saffron-deep); color:var(--white); }
@media (max-width:820px){ .hp-whitepaper .download-panel{ grid-template-columns:1fr; padding:38px 26px; } }

/* ================= PAGE : NOTRE DÉMARCHE ================= */
.hp-approach .page-hero, .hp-faq .page-hero{ padding-top:52px; padding-bottom:20px; }
.hp-approach .page-hero h1, .hp-faq .page-hero h1{ font-size:clamp(2rem,3.6vw,2.7rem); max-width:20ch; }
.hp-approach .page-hero .lede, .hp-faq .page-hero .lede{ margin-top:22px; max-width:66ch; }

.hp-approach .precedent-list{ display:grid; grid-template-columns:repeat(3, 1fr); gap:1px; background:var(--border); border:1px solid var(--border); }
.hp-approach .precedent{ background:var(--paper); padding:30px 26px; }
.hp-approach .precedent .flag{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--sage-deep); margin-bottom:10px; display:block; }
.hp-approach .precedent p{ margin:0; color:var(--ink-soft); font-size:0.95rem; }
@media (max-width:820px){ .hp-approach .precedent-list{ grid-template-columns:1fr; } }

.hp-approach .guardrails{ background:var(--paper-alt); }
.hp-approach .guardrail-list{ list-style:none; margin:0; padding:0; max-width:780px; }
.hp-approach .guardrail-list li{ display:flex; gap:16px; padding:18px 0; border-bottom:1px solid var(--border); align-items:flex-start; }
.hp-approach .guardrail-list li:first-child{ border-top:1px solid var(--border); }
.hp-approach .guardrail-list .check{ flex-shrink:0; width:22px; height:22px; border-radius:50%; background:var(--sage); color:var(--white); display:flex; align-items:center; justify-content:center; font-size:0.7rem; margin-top:2px; }
.hp-approach .guardrail-list p{ margin:0; color:var(--ink); }

.hp-approach .risk-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); border:1px solid var(--border); }
.hp-approach .risk-card{ background:var(--paper); padding:28px 24px; }
.hp-approach .risk-card .risk-tag{ font-family:var(--font-mono); font-size:0.72rem; color:var(--saffron-deep); text-transform:uppercase; letter-spacing:0.06em; display:block; margin-bottom:10px; }
.hp-approach .risk-card p{ margin:0; color:var(--ink-soft); font-size:0.94rem; }
@media (max-width:820px){ .hp-approach .risk-grid{ grid-template-columns:1fr; } }

.hp-approach .roadmap-full{ counter-reset:phase; }
.hp-approach .roadmap-item{ display:grid; grid-template-columns:96px 1fr; gap:28px; padding:30px 0; border-top:1px solid var(--border); }
.hp-approach .roadmap-item:last-child{ border-bottom:1px solid var(--border); }
.hp-approach .roadmap-item .r-status{ font-family:var(--font-mono); font-size:0.7rem; letter-spacing:0.05em; text-transform:uppercase; padding:4px 10px; border-radius:12px; display:inline-block; height:fit-content; }
.hp-approach .roadmap-item.done .r-status{ background:var(--sage); color:var(--white); }
.hp-approach .roadmap-item.active .r-status{ background:var(--saffron); color:var(--white); }
.hp-approach .roadmap-item.upcoming .r-status{ background:var(--paper-alt); color:var(--ink-soft); border:1px solid var(--border); }
.hp-approach .roadmap-item h3{ font-size:1.08rem; margin-bottom:8px; }
.hp-approach .roadmap-item p{ margin:0; color:var(--ink-soft); max-width:64ch; }
@media (max-width:640px){ .hp-approach .roadmap-item{ grid-template-columns:1fr; gap:12px; } }

.hp-approach .faq-block, .hp-faq .faq-block{ background:var(--paper-alt); }
.hp-approach .faq-block .accordion-list, .hp-faq .faq-block .accordion-list{ max-width:840px; }
.hp-approach .faq-block .accordion-item summary, .hp-faq .faq-block .accordion-item summary{ font-family:var(--font-body); font-weight:600; color:var(--navy); font-size:0.98rem; }

/* Teaser FAQ conservé sur "Notre approche", qui renvoie vers la page FAQ complète */
.hp-approach .faq-teaser{
  background:var(--white); border:1px solid var(--border); border-left:3px solid var(--saffron);
  padding:26px 28px; max-width:640px; display:flex; flex-direction:column; gap:12px;
}
.hp-approach .faq-teaser p{ margin:0; color:var(--ink-soft); }

.hp-approach .profile-block{ display:flex; justify-content:center; }
.hp-approach .profile-card{ background:var(--white); border:1px solid var(--border); max-width:420px; width:100%; overflow:hidden; }
.hp-approach .profile-flag{ background:var(--sage); color:var(--white); font-family:var(--font-mono); font-size:0.7rem; letter-spacing:0.04em; text-transform:uppercase; padding:9px 20px; text-align:center; }
.hp-approach .profile-body{ padding:28px 26px; }
.hp-approach .profile-avatar{ width:56px; height:56px; border-radius:50%; background:var(--paper-alt); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; margin-bottom:18px; color:var(--ink-soft); }
.hp-approach .profile-fields{ list-style:none; margin:0 0 18px; padding:0; }
.hp-approach .profile-fields li{ display:flex; gap:8px; padding:9px 0; border-bottom:1px solid var(--border); font-size:0.92rem; }
.hp-approach .profile-fields li:last-child{ border-bottom:none; }
.hp-approach .profile-fields .f-label{ font-family:var(--font-mono); font-size:0.72rem; color:var(--saffron-deep); text-transform:uppercase; letter-spacing:0.04em; width:110px; flex-shrink:0; padding-top:1px; }
.hp-approach .profile-footnote{ font-size:0.82rem; color:var(--ink-soft); font-style:italic; margin:0; }

/* ================= PAGE : REJOIGNEZ-NOUS ================= */
.hp-join .page-hero{ padding-top:52px; padding-bottom:16px; }
.hp-join .page-hero h1{ font-size:clamp(2rem,3.6vw,2.7rem); max-width:16ch; }
.hp-join .page-hero .lede{ margin:22px 0 0; max-width:64ch; }

.hp-join .profile-jump{ display:flex; gap:1px; background:var(--border); border:1px solid var(--border); margin-top:40px; flex-wrap:wrap; }
.hp-join .profile-jump a{ flex:1; min-width:160px; background:var(--paper); text-decoration:none; color:var(--ink); padding:18px 20px; font-size:0.9rem; font-weight:500; display:flex; flex-direction:column; gap:4px; transition:background 0.15s ease; }
.hp-join .profile-jump a:hover{ background:var(--white); }
.hp-join .profile-jump a .tag{ font-family:var(--font-mono); font-size:0.68rem; color:var(--saffron-deep); text-transform:uppercase; letter-spacing:0.05em; }

.hp-join .form-section{ border-top:1px solid var(--border); scroll-margin-top:90px; }
.hp-join .form-section.alt{ background:var(--paper-alt); }
.hp-join .form-layout{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:56px; align-items:start; }
.hp-join .form-intro h2{ font-size:clamp(1.35rem,2.2vw,1.7rem); line-height:1.22; margin-bottom:14px; }
.hp-join .form-intro p{ color:var(--ink-soft); margin:0; max-width:44ch; }
.hp-join .form-intro .num{ font-family:var(--font-mono); font-size:0.78rem; color:var(--sage-deep); display:block; margin-bottom:12px; }

.hp-join form.hp-form{ background:var(--white); border:1px solid var(--border); padding:32px 30px; }
.hp-join .field{ margin-bottom:20px; }
.hp-join .field:last-of-type{ margin-bottom:26px; }
.hp-join .field label{ display:block; font-size:0.86rem; font-weight:500; color:var(--navy); margin-bottom:7px; }
.hp-join .field label .opt{ font-family:var(--font-mono); font-size:0.7rem; color:var(--ink-soft); font-weight:400; text-transform:uppercase; margin-left:6px; }
.hp-join .field label .req{ color:var(--saffron-deep); margin-left:3px; }
.hp-join .field .hint{ font-size:0.78rem; color:var(--ink-soft); margin-top:5px; }
.hp-join .field input[type="text"], .hp-join .field input[type="email"], .hp-join .field input[type="tel"], .hp-join .field select, .hp-join .field textarea{
  width:100%; padding:11px 13px; border:1px solid var(--border); border-radius:var(--radius);
  background:var(--paper); font-family:var(--font-body); font-size:0.95rem; color:var(--ink);
}
.hp-join .field textarea{ resize:vertical; min-height:88px; }
.hp-join .field select{ appearance:none; background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" fill="%2355575E"><path d="M5 8l5 5 5-5H5z"/></svg>'); background-repeat:no-repeat; background-position:right 12px center; }

.hp-join .general-contact{ text-align:center; padding-top:64px; padding-bottom:80px; }
.hp-join .general-contact h2{ margin-bottom:16px; }
.hp-join .general-contact a.mail{ font-family:var(--font-mono); font-size:1.1rem; color:var(--navy); text-decoration:none; border-bottom:1px solid var(--saffron); padding-bottom:3px; }
.hp-join .general-contact a.mail:hover{ color:var(--saffron-deep); }

.hp-join .confirm-note{ display:none; font-size:0.82rem; color:var(--sage-deep); margin-top:10px; font-family:var(--font-mono); }

@media (max-width:900px){ .hp-join .form-layout{ grid-template-columns:1fr; gap:28px; } }

/* ================= LIEN DISCRET VERS TERRITOIRES RURAUX (Accueil uniquement) ================= */
.hp-home .rural-teaser{
  margin-top:28px; padding-top:24px; border-top:1px solid var(--border);
  font-size:0.92rem; color:var(--ink-soft);
}
.hp-home .rural-teaser a{ color:var(--sage-deep); border-bottom:1px solid var(--sage); text-decoration:none; }
.hp-home .rural-teaser a:hover{ color:var(--sage); }

/* ================= PAGE : TERRITOIRES RURAUX ================= */
.hp-rural .rural-hero-media{ height:min(46vw, 380px); min-height:240px; }
.hp-rural .rural-hero-content{ max-width:var(--wrap); margin:0 auto; padding:52px 28px 12px; }
.hp-rural .rural-hero-content h1{ font-size:clamp(1.9rem, 3.6vw, 2.7rem); line-height:1.16; max-width:22ch; margin-bottom:22px; }
.hp-rural .rural-hero-content .lede{ max-width:66ch; }

.hp-rural .cohort-block{ background:var(--paper-alt); }
.hp-rural .cohort-text{ max-width:820px; }
.hp-rural .cohort-text p{ color:var(--ink); margin:0 0 22px; font-size:1.02rem; }
.hp-rural .cohort-text .caveat{ font-family:var(--font-display); font-style:italic; color:var(--ink-soft); border-left:3px solid var(--sage); padding-left:20px; margin:0; }

.hp-rural .rural-cta{ background:var(--navy); color:var(--ink-on-navy); text-align:center; }
.hp-rural .rural-cta h2{ color:var(--white); font-size:clamp(1.4rem,2.4vw,1.9rem); margin-bottom:14px; }
.hp-rural .rural-cta p{ color:#C7C4B8; max-width:56ch; margin:0 auto 28px; }
.hp-rural .rural-cta .btn-primary{ background:var(--saffron); border-color:var(--saffron); color:var(--navy-deep); font-weight:600; }
.hp-rural .rural-cta .btn-primary:hover{ background:var(--saffron-deep); color:var(--white); }
