

/* ─── PAGE HERO ─── */
.page-hero{padding-top:78px;min-height:72vh;display:flex;align-items:flex-end;position:relative;overflow:hidden}
.page-hero-bg{position:absolute;inset:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.35) saturate(.8)}
.page-hero-bg::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,20,20,.4) 0%,rgba(20,20,20,.2) 40%,rgba(20,20,20,.95) 100%),
  linear-gradient(90deg,rgba(20,20,20,.5) 0%,transparent 60%)}
.page-hero-content{position:relative;z-index:2;padding:0 0 72px}
.page-hero-content.container{width:min(var(--max),calc(100% - 72px));margin-left:auto;margin-right:auto}
.page-breadcrumb{display:flex;align-items:center;gap:8px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(247,245,240,.92);margin-bottom:20px}
.page-breadcrumb a{color:rgba(211,163,87,.5);transition:color .2s}
.page-breadcrumb a:hover{color:var(--gold)}
.page-breadcrumb span{color:rgba(247,245,240,.2)}
.page-h1{font-family:var(--font-serif);font-size:clamp(38px,5vw,72px);font-weight:600;line-height:1.06;letter-spacing:-.3px;margin-bottom:20px;max-width:800px}
.page-h1 em{font-style:italic;font-weight:300;background:linear-gradient(135deg,#f0d890,#D3A357);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.page-lead{font-size:16px;color:rgba(247,245,240,.95);line-height:1.8;max-width:560px;margin-bottom:32px}

/* ─── DARK HERO (no image) ─── */
.page-hero-dark{padding-top:78px;min-height:68vh;display:flex;align-items:center;
  background:linear-gradient(160deg,#141414 0%,#0d1a12 50%,#141414 100%);position:relative;overflow:hidden}
.page-hero-dark::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 15% 60%,rgba(211,163,87,.07),transparent 55%),
  radial-gradient(ellipse at 85% 20%,rgba(6,64,43,.08),transparent 50%)}
.page-hero-dark::after{content:'';position:absolute;inset:0;opacity:.04;
  background:repeating-linear-gradient(60deg,transparent 0 60px,rgba(247,245,240,.1) 60px 61px,transparent 61px 120px)}
.page-hero-dark .page-hero-content{padding:80px 0}

/* ─── PHASE BADGE (Methodologie) ─── */

.phase-n{font-family:var(--font-serif);font-size:clamp(80px,12vw,140px);font-weight:300;font-style:italic;
  background:linear-gradient(135deg,rgba(211,163,87,.15),rgba(211,163,87,.04));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1;position:absolute;right:5%;bottom:10%;pointer-events:none;z-index:1;user-select:none}

/* ─── PHASE STRIP NAV ─── */
.phase-strip{background:rgba(20,20,20,.95);border-bottom:1px solid rgba(211,163,87,.08);position:sticky;top:78px;z-index:50;overflow-x:auto;scrollbar-width:none}
.phase-strip::-webkit-scrollbar{display:none}
.phase-strip-inner{display:flex;min-width:max-content;padding:0 24px}
.phase-chip{display:inline-flex;align-items:center;gap:8px;padding:18px 22px;font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:rgba(247,245,240,.92);border-bottom:2px solid transparent;transition:all .25s;white-space:nowrap;cursor:pointer;text-decoration:none}
.phase-chip:hover{color:rgba(247,245,240,.96)}
.phase-chip.active{color:var(--gold);border-bottom-color:var(--gold)}
.phase-chip-n{font-family:var(--font-num);font-size:10px;font-weight:600;color:rgba(211,163,87,.4)}
.phase-chip.active .phase-chip-n{color:var(--gold)}

/* ─── PHASE SECTION ─── */
.phase-section{padding:100px 0;position:relative;overflow:hidden}
.phase-section:nth-child(odd){background:var(--charcoal)}
.phase-section:nth-child(even){background:linear-gradient(180deg,#0d1a12,#101610)}
.phase-bg-num{font-family:var(--font-serif);font-size:clamp(160px,22vw,280px);font-weight:700;font-style:italic;
  color:transparent;-webkit-text-stroke:1px rgba(211,163,87,.06);
  position:absolute;right:-2%;bottom:-5%;line-height:1;pointer-events:none;user-select:none;z-index:0}
.phase-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start;position:relative;z-index:2}
.phase-tag{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(211,163,87,.5);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.phase-tag::before{content:'';width:24px;height:1px;background:rgba(211,163,87,.4)}
.phase-title{font-family:var(--font-serif);font-size:clamp(32px,4vw,52px);font-weight:600;color:var(--ivory);line-height:1.1;margin-bottom:12px}
.phase-title em{font-style:italic;font-weight:300;color:var(--gold)}
.phase-duration{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(211,163,87,.4);margin-bottom:24px;display:flex;align-items:center;gap:10px}
.phase-duration::before{content:'';width:18px;height:1px;background:rgba(211,163,87,.3)}
.phase-desc{font-size:15px;color:rgba(247,245,240,.93);line-height:1.9;margin-bottom:32px}
.phase-panel{background:rgba(247,245,240,.03);border:1px solid rgba(211,163,87,.1);border-radius:16px;padding:28px;display:flex;flex-direction:column;gap:14px}
.phase-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(247,245,240,.05);font-size:13px;gap:12px}
.phase-row:last-child{border-bottom:none}
.phase-row-label{color:rgba(247,245,240,.96);letter-spacing:.5px}
.phase-row-val{color:var(--ivory);font-weight:500;text-align:right}
.phase-row-val em{color:var(--gold);font-style:normal}
.phase-checklist{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.phase-check{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;background:rgba(247,245,240,.03);border-radius:10px;border:1px solid rgba(247,245,240,.06)}
.phase-check-icon{width:20px;height:20px;border-radius:50%;border:1.5px solid rgba(211,163,87,.3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--gold);margin-top:1px}
.phase-check-text{font-size:13px;color:rgba(247,245,240,.95);line-height:1.55}
.phase-check-text strong{color:var(--ivory);display:block;font-size:13px;margin-bottom:2px}

/* ─── DIASPORA MAP ─── */
.dmap-section{padding:120px 0;background:linear-gradient(180deg,var(--charcoal),#0e0b09);position:relative;overflow:hidden}
.dmap-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;margin-top:56px}
.dmap-cities{display:flex;flex-direction:column;gap:0}
.dmap-city{display:flex;align-items:center;gap:0;padding:16px 0;border-bottom:1px solid rgba(247,245,240,.05);position:relative}
.dmap-city:last-child{border-bottom:none}
.dmap-name{font-size:12px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:rgba(247,245,240,.96);min-width:110px}
.dmap-line-wrap{flex:1;height:1px;position:relative;margin:0 14px;overflow:hidden}
.dmap-line{position:absolute;top:0;left:0;height:1px;width:0%;background:linear-gradient(to right,transparent,rgba(211,163,87,.6),transparent);transition:width .9s ease}
.dmap-line.go{width:100%}
.dmap-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;box-shadow:0 0 0 0 rgba(211,163,87,.4)}
.dmap-dot.pulse{animation:cityPulse 2s ease-out infinite}
.dmap-dest{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--gold);min-width:100px;text-align:right;font-weight:600}
@keyframes cityPulse{0%{box-shadow:0 0 0 0 rgba(211,163,87,.6)}70%{box-shadow:0 0 0 8px rgba(211,163,87,0)}100%{box-shadow:0 0 0 0 rgba(211,163,87,0)}}
.dmap-panel{background:rgba(247,245,240,.03);border:1px solid rgba(211,163,87,.1);border-radius:16px;padding:32px}
.dmap-panel-title{font-family:var(--font-serif);font-size:26px;font-weight:600;color:var(--ivory);margin-bottom:20px;line-height:1.2}
.dmap-step{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid rgba(247,245,240,.05)}
.dmap-step:last-child{border-bottom:none}
.dmap-step-n{font-family:var(--font-num);font-size:28px;font-weight:600;color:rgba(211,163,87,.2);line-height:1;flex-shrink:0;width:38px}
.dmap-step-content strong{display:block;font-size:14px;color:var(--ivory);margin-bottom:4px}
.dmap-step-content span{font-size:13px;color:rgba(247,245,240,.96);line-height:1.6}

/* ─── GALLERY GRID (Réalisations) ─── */
.gallery-hero{padding-top:78px;background:var(--charcoal);min-height:100svh;display:flex;flex-direction:column}
.gallery-hero-text{padding:56px 0 36px;text-align:center;position:relative;z-index:2}
.gallery-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;flex:1;min-height:400px}
.gs-tile{position:relative;overflow:hidden}
.gs-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.22,1,.36,1)}
.gs-tile:hover img{transform:scale(1.07)}
.gs-tile::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(14,11,9,.75),rgba(14,11,9,0) 60%);pointer-events:none}
.gs-caption{position:absolute;bottom:0;left:0;right:0;padding:24px 20px;z-index:2}
.gs-caption strong{display:block;font-family:var(--font-serif);font-size:19px;color:var(--ivory);line-height:1.2}
.gs-caption span{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(211,163,87,.7);margin-top:4px;display:block}
.gs-stat-bar{background:rgba(0,0,0,.4);border-top:1px solid rgba(255,255,255,.06);padding:28px 0}
.gs-stat-inner{display:flex;justify-content:center;gap:80px}
.gs-stat{text-align:center}
.gs-stat-num{font-family:var(--font-serif);font-size:40px;font-weight:600;color:var(--gold);display:block;line-height:1}
.gs-stat-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(247,245,240,.9);margin-top:5px}

/* Project section */
.proj-section{padding:100px 0;background:linear-gradient(180deg,var(--charcoal),#0e1410)}

/* Compliance sections */
.comp-section{padding:100px 0}
.comp-section:nth-child(odd){background:linear-gradient(180deg,var(--charcoal),#0d1a12)}
.comp-section:nth-child(even){background:linear-gradient(180deg,#0d1a12,var(--charcoal))}

/* ─── TEAM ─── */
.team-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:40px}
.team-card{border-radius:20px;overflow:hidden;position:relative;background:rgba(247,245,240,.03);border:1px solid rgba(247,245,240,.07);transition:transform .4s,border-color .4s,background .4s;padding:46px 26px 38px;text-align:center;display:flex;flex-direction:column;align-items:center}
.team-card::before{content:'';position:absolute;inset:0;background:radial-gradient(120% 65% at 50% 0%,rgba(211,163,87,.07),transparent 62%);opacity:0;transition:opacity .4s;pointer-events:none}
.team-card:hover{border-color:rgba(211,163,87,.28);transform:translateY(-4px);background:rgba(247,245,240,.05)}
.team-card:hover::before{opacity:1}
.team-card-photo{position:relative;width:200px;max-width:58%;aspect-ratio:1;margin:0 auto 26px;border-radius:50%}
.team-card-photo img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;background:#11211a;box-shadow:0 20px 46px -20px rgba(0,0,0,.78)}
.team-card-photo::after{content:'';position:absolute;inset:-7px;border-radius:50%;border:1px solid rgba(211,163,87,.42);transition:border-color .4s}
.team-card:hover .team-card-photo::after{border-color:rgba(211,163,87,.72)}
.team-card-body{position:relative;z-index:2;width:100%}
.tc-role{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(211,163,87,.6);margin-bottom:8px}
.tc-name{font-family:var(--font-serif);font-size:28px;font-weight:600;color:var(--ivory);line-height:1.1;margin-bottom:14px}
.tc-creds{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.tc-cred{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:rgba(211,163,87,.5);border:1px solid rgba(211,163,87,.15);padding:4px 10px;border-radius:999px;background:rgba(211,163,87,.04)}

/* Team philosophy */
.team-phil{padding:100px 0;background:linear-gradient(180deg,#0d1a12,var(--charcoal))}
.phil-rows{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:0}
.phil-row{display:grid;grid-template-columns:1fr 1.5fr;gap:40px;padding:32px 0;border-bottom:1px solid rgba(247,245,240,.05);align-items:start}
.phil-row:last-child{border-bottom:none}
.phil-key{font-family:var(--font-serif);font-size:clamp(20px,2.5vw,28px);font-weight:600;font-style:italic;color:var(--ivory);line-height:1.2}
.phil-val{font-size:14px;color:rgba(247,245,240,.96);line-height:1.85}
.phil-val strong{color:var(--ivory)}

/* ─── CONTACT FULL ─── */
.contact-hero-dark{padding-top:78px;min-height:55vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,#141414,#0d1a12,#141414);position:relative;overflow:hidden;text-align:center}
.contact-hero-dark::before{content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 60%,rgba(211,163,87,.07),transparent 55%),
  repeating-linear-gradient(0deg,transparent 0 37px,rgba(247,245,240,.018) 37px 38px,transparent 38px 74px)}
.chd-inner{position:relative;z-index:2;padding:48px 24px}
.chd-big{font-family:var(--font-serif);font-size:clamp(64px,14vw,170px);font-weight:300;font-style:italic;
  background:linear-gradient(180deg,rgba(211,163,87,.9) 0%,rgba(211,163,87,.3) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:.92;display:block;margin-bottom:12px}
.chd-sub{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:rgba(247,245,240,.9);margin-bottom:36px;display:block}

/* ─── CTA BAND ─── */
.cta-band{padding:100px 0;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--charcoal),#1a1510)}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(211,163,87,.06),transparent 60%)}
.cta-band-inner{text-align:center;position:relative;z-index:2}
.cta-band h2{font-family:var(--font-serif);font-size:clamp(28px,4vw,52px);font-weight:600;color:var(--ivory);margin-bottom:14px;line-height:1.08}
.cta-band h2 em{font-style:italic;font-weight:300;background:linear-gradient(90deg,#f0d890,#D3A357);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cta-band p{color:rgba(247,245,240,.93);font-size:15px;line-height:1.8;max-width:480px;margin:0 auto 36px}
.cta-band-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Hero leads & breadcrumbs */
.page-lead{font-family:var(--font-serif);font-size:19px!important;font-weight:300;font-style:italic;color:rgba(247,245,240,.95);line-height:1.75}
.page-breadcrumb{font-family:var(--font-serif);font-style:italic;font-size:12px!important;letter-spacing:.3px!important;text-transform:none!important}
.page-breadcrumb a{font-style:italic}

/* Phase tags & eyebrows */
.phase-tag{font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:14px!important;letter-spacing:.5px!important;text-transform:none!important;color:rgba(211,163,87,.6)}
.phase-tag::before{display:none}

/* Phase descriptive text */
.phase-desc{font-family:var(--font-serif);font-size:17px!important;font-weight:300;color:rgba(247,245,240,.93);line-height:1.9}
.phase-duration{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:14px!important;letter-spacing:.3px!important;text-transform:none!important}
.phase-duration::before{display:none}
.phase-row-label{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:13px!important;color:rgba(247,245,240,.92)}
.phase-row-val{font-family:var(--font-serif);font-size:14px!important;font-weight:400}
.phase-check-text{font-family:var(--font-serif);font-size:14px!important;font-weight:300;line-height:1.6}
.phase-check-text strong{font-weight:600;font-size:14px!important}

/* Phase strip, editorial serif nav */
.phase-chip{font-family:var(--font-serif);font-size:14px!important;font-style:italic;letter-spacing:.2px!important;text-transform:none!important}
.phase-chip-n{font-family:var(--font-num);font-style:normal}

/* Diaspora map */
.dmap-name{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:14px!important;letter-spacing:.3px!important;text-transform:none!important}
.dmap-dest{font-family:var(--font-serif);font-size:13px!important;letter-spacing:.3px!important;text-transform:none!important;font-weight:600}
.dmap-panel-title{font-family:var(--font-serif);font-weight:600}
.dmap-step-content strong{font-family:var(--font-serif);font-size:15px!important;font-weight:600}
.dmap-step-content span{font-family:var(--font-serif);font-size:14px!important;font-weight:300;line-height:1.7}

/* Gallery */
.gs-stat-label{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:12px!important;letter-spacing:.3px!important;text-transform:none!important}
.gs-caption span{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:11px!important;letter-spacing:.2px!important;text-transform:none!important}

/* Team */
.tc-role{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:12px!important;letter-spacing:.3px!important;text-transform:none!important}
.tc-cred{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:10px!important;letter-spacing:.2px!important;text-transform:none!important}
.phil-val{font-family:var(--font-serif);font-size:15px!important;font-weight:300;line-height:1.9}
.phil-val strong{font-weight:600}

/* Contact hero */
.chd-sub{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:15px!important;letter-spacing:.5px!important;text-transform:none!important}

/* CTA band */
.cta-band p{font-family:var(--font-serif);font-size:17px!important;font-weight:300;color:rgba(247,245,240,.93);line-height:1.8}

/* ─── Tablet ─── */
@media(max-width:960px){
  .phase-inner{grid-template-columns:1fr;gap:32px}
  
  
  .dmap-grid{grid-template-columns:1fr;gap:32px}
  .team-hero-grid{grid-template-columns:1fr 1fr;gap:14px}
  .phil-row{grid-template-columns:1fr;gap:10px}
  
  .gallery-strip{grid-template-columns:1fr 1fr}
  .gs-tile{aspect-ratio:4/3}
  .gs-stat-inner{gap:36px}
}

/* ─── Mobile comprehensive ─── */
@media(max-width:768px){

  /* Page hero */
  .page-hero{min-height:85svh;padding-top:60px}
  .page-hero-content{padding:0 0 36px}
  .page-h1{font-size:clamp(32px,7.5vw,52px);margin-bottom:16px}
  .page-lead{font-size:16px!important;margin-bottom:24px}
  .page-breadcrumb{font-size:11px!important;margin-bottom:14px}
  .page-hero-dark{padding-top:60px;min-height:65svh}
  .page-hero-dark .page-hero-content{padding:48px 0 36px}

  /* Phase strip */
  .phase-strip{top:60px}
  .phase-strip-inner{padding:0 16px}
  .phase-chip{padding:16px 14px;font-size:13px!important}

  /* Phase sections */
  .phase-section{padding:64px 0}
  .phase-bg-num{font-size:clamp(100px,28vw,160px);right:-3%;bottom:-2%}
  .phase-inner{grid-template-columns:1fr;gap:28px}
  .phase-title{font-size:clamp(26px,6vw,38px)}
  .phase-desc{font-size:15px!important}
  .phase-panel{padding:20px}
  .phase-row{flex-direction:column;gap:4px;align-items:flex-start}
  .phase-row-label{font-size:12px!important}
  .phase-row-val{font-size:13px!important;text-align:left}
  .phase-checklist{gap:8px}
  .phase-check{padding:10px 12px}
  .phase-check-text{font-size:13px!important}

  /* Diaspora map */
  .dmap-section{padding:72px 0}
  .dmap-grid{grid-template-columns:1fr;gap:36px}
  .dmap-name{min-width:88px;font-size:13px!important}
  .dmap-dest{min-width:80px;font-size:11px!important}
  .dmap-panel{padding:24px 20px}
  .dmap-step-content strong{font-size:14px!important}
  .dmap-step-content span{font-size:13px!important}

  /* Gallery hero */
  .gallery-hero-text{padding:40px 0 24px}
  .gallery-strip{grid-template-columns:1fr 1fr;min-height:0}
  .gs-tile{aspect-ratio:4/3}
  .gs-caption strong{font-size:15px}
  .gs-stat-bar{padding:20px 0}
  .gs-stat-inner{gap:24px;flex-wrap:wrap;justify-content:center}
  .gs-stat-num{font-size:32px}
  .gs-stat-label{font-size:11px!important}

  /* Project cards */
  .proj-section{padding:72px 0}
  
  
  

  /* Compliance */
  .comp-section{padding:72px 0}
  
  
  
  
  
  
  
  
  
  
  

  /* Team */
  .team-hero-grid{grid-template-columns:1fr;gap:16px}
  .team-card{padding:40px 24px 34px}
  .team-card-photo{width:182px;max-width:54%}
  .tc-name{font-size:24px}
  .phil-rows{gap:0}
  .phil-row{grid-template-columns:1fr;gap:8px;padding:24px 0}
  .phil-key{font-size:clamp(18px,4vw,22px)}
  .phil-val{font-size:14px!important}
  .team-phil{padding:72px 0}

  /* Contact hero */
  .contact-hero-dark{min-height:52svh;padding-top:60px}
  .chd-big{font-size:clamp(56px,18vw,110px)}
  .chd-sub{font-size:13px!important;margin-bottom:28px}

  /* CTA band */
  .cta-band{padding:72px 0}
  .cta-band h2{font-size:clamp(24px,6vw,38px)}
  .cta-band p{font-size:15px!important}
  .cta-band-btns{flex-direction:column;align-items:center}
  .cta-band-btns a{width:min(320px,100%);justify-content:center}

  /* Footer safe area */
  footer{padding-bottom:calc(48px + env(safe-area-inset-bottom))}
}

/* ─── Small phones ─── */
@media(max-width:400px){
  .page-h1{font-size:clamp(28px,8vw,40px)}
  .phase-chip{padding:14px 10px;font-size:12px!important}
  .gallery-strip{grid-template-columns:1fr}
  .gs-tile{aspect-ratio:3/2}
  
  
  .dmap-name{min-width:78px}
  .dmap-dest{min-width:70px}
}

/* ─── Landscape phones ─── */
@media(max-height:500px) and (orientation:landscape){
  .page-hero{min-height:auto}
  .page-hero-content{padding:60px 0 28px}
  .contact-hero-dark{min-height:auto;padding:80px 0}
}

/* ─── Text contrast on dark inner pages ─── */
.phase-desc{color:rgba(247,245,240,.9)!important}
.phase-row-label{color:rgba(247,245,240,.95)!important}
.phase-check-text{color:rgba(247,245,240,.96)!important;font-size:14px!important}
.phase-check-text strong{color:var(--ivory)!important}
.page-lead{color:rgba(247,245,240,.96)!important}
.page-breadcrumb{color:rgba(247,245,240,.95)!important}

/* Team bio text */
.phil-val{color:rgba(247,245,240,.96)!important}
.phil-val strong{color:var(--ivory)!important}

/* Phase panel more breathing */
.phase-panel{padding:32px!important}
.phase-row{padding:14px 0!important;font-size:14px!important}

/* CTA band on inner */
.cta-band p{color:rgba(247,245,240,.96)!important}
.cta-band{padding:80px 0!important}

/* ─── Inner pages mobile ─── */
@media(max-width:768px){
  /* Phase sections padding */
  .phase-section{padding:72px 0!important}
  .phase-panel{padding:24px!important}
  .phase-desc{font-size:15px!important}
  
  /* Hero padding */
  .page-hero-content{padding:0 0 48px!important}
  .page-hero-dark .page-hero-content{padding:56px 0 48px!important}
  
  /* Compliance grid */
  .comp-section{padding:72px 0!important}
  
  
  /* Team */
  .team-phil{padding:72px 0!important}
  
  /* Contact dark hero */
  .contact-hero-dark{min-height:50svh}
}

@media(max-width:640px){
  .phase-panel{padding:20px 18px!important}
  .phase-check{padding:12px!important}
}

/* ═══════════════════════════════════════════════════════════════
   INNER PAGES, MOBILE POLISH (HNWI MRE)
   Calm. Clear. Generous breathing. No clever, only legible.
   Mirrors the homepage polish so the experience is consistent
   across Audit, Méthodologie, Pilotage, Conformité, Équipe,
   Diaspora, Réalisations, Contact, Mentions Légales.
   ═══════════════════════════════════════════════════════════════ */

@media(max-width:1024px){
  .page-h1{font-size:clamp(34px,6.5vw,60px)!important}
  .page-lead{font-size:17px!important;line-height:1.8!important}
}

@media(max-width:768px){
  /* ─── Page hero, cinematic but compact ─── */
  .page-hero{min-height:78svh!important;padding-top:62px!important}
  .page-hero-content{padding:0 0 56px!important}
  .page-hero-dark{padding-top:62px!important;min-height:62svh!important}
  .page-hero-dark .page-hero-content{padding:56px 0 48px!important}
  .page-breadcrumb{font-size:11.5px!important;letter-spacing:1.2px!important;margin-bottom:18px!important;color:rgba(247,245,240,.96)!important}
  .page-breadcrumb a{color:rgba(211,163,87,.85)!important}
  .page-h1{font-size:clamp(30px,8vw,44px)!important;line-height:1.08!important;letter-spacing:-.2px!important;margin-bottom:18px!important}
  .page-h1 em{
    -webkit-text-fill-color:var(--gold)!important;
    background:none!important;
    color:var(--gold)!important;
    font-weight:400!important;
  }
  .page-lead{font-size:16.5px!important;line-height:1.75!important;color:rgba(247,245,240,.88)!important;margin-bottom:28px!important;max-width:100%!important}

  /* ─── Phase strip (sticky horizontal scroller) ─── */
  .phase-strip{top:62px!important;background:rgba(20,20,20,.92)!important;backdrop-filter:blur(20px) saturate(140%)!important}
  .phase-strip-inner{padding:0 18px!important}
  .phase-chip{padding:18px 18px!important;font-size:13.5px!important;letter-spacing:1.1px!important;min-height:54px!important;color:rgba(247,245,240,.96)!important}
  .phase-chip.active{color:var(--gold)!important;border-bottom-width:2.5px!important}
  .phase-chip-n{font-size:11px!important;letter-spacing:1.4px!important}

  /* ─── Phase sections, generous, serene ─── */
  .phase-section{padding:64px 0!important}
  .phase-bg-num{font-size:clamp(90px,26vw,150px)!important;right:-4%!important;bottom:-1%!important;opacity:.85}
  .phase-inner{grid-template-columns:1fr!important;gap:32px!important}
  .phase-tag{font-size:11.5px!important;letter-spacing:1.8px!important;margin-bottom:14px!important;color:rgba(211,163,87,.85)!important}
  .phase-title{font-size:clamp(26px,6.5vw,38px)!important;line-height:1.15!important;letter-spacing:-.2px!important;margin-bottom:14px!important}
  .phase-title em{
    -webkit-text-fill-color:var(--gold)!important;
    background:none!important;
    color:var(--gold)!important;
  }
  .phase-duration{font-size:11.5px!important;letter-spacing:1.6px!important;margin-bottom:22px!important;color:rgba(211,163,87,.8)!important}
  .phase-desc{font-size:15.5px!important;line-height:1.85!important;margin-bottom:26px!important;color:rgba(247,245,240,.95)!important}

  /* Phase panel, info card */
  .phase-panel{padding:24px 20px!important;border-radius:16px!important}
  .phase-row{flex-direction:column!important;align-items:flex-start!important;gap:6px!important;padding:14px 0!important;font-size:14.5px!important}
  .phase-row-label{font-size:12.5px!important;letter-spacing:1px!important;color:rgba(247,245,240,.96)!important;text-transform:uppercase}
  .phase-row-val{font-size:14.5px!important;text-align:left!important;line-height:1.5!important;color:var(--ivory)!important}
  .phase-row-val em{color:var(--gold)!important;font-weight:600!important}

  /* Phase checklist, readable bullets */
  .phase-checklist{gap:10px!important;margin-top:8px!important}
  .phase-check{padding:14px 14px!important;border-radius:12px!important;gap:14px!important;align-items:flex-start!important;min-height:auto!important}
  .phase-check-icon{width:22px!important;height:22px!important;margin-top:2px!important}
  .phase-check-text{font-size:14.5px!important;line-height:1.6!important;color:rgba(247,245,240,.96)!important}
  .phase-check-text strong{font-size:14.5px!important;margin-bottom:4px!important}

  /* ─── Diaspora map (Pilotage / Diaspora pages) ─── */
  .dmap-section{padding:64px 0!important}
  .dmap-grid{grid-template-columns:1fr!important;gap:32px!important;margin-top:36px!important}
  .dmap-cities{gap:0!important}
  .dmap-city{padding:18px 0!important;gap:10px!important;flex-wrap:nowrap!important}
  .dmap-name{font-size:13px!important;letter-spacing:1.2px!important;min-width:90px!important;color:rgba(247,245,240,.97)!important}
  .dmap-line-wrap{margin:0 10px!important}
  .dmap-dest{font-size:11.5px!important;letter-spacing:1.2px!important;min-width:84px!important;color:var(--gold)!important;font-weight:600!important}
  .dmap-panel{padding:24px 22px!important;border-radius:16px!important}
  .dmap-panel-title{font-size:22px!important;line-height:1.25!important;margin-bottom:18px!important}
  .dmap-step{padding:18px 0!important;gap:14px!important}
  .dmap-step-n{font-size:24px!important;width:32px!important}
  .dmap-step-content strong{font-size:14.5px!important;line-height:1.35!important;margin-bottom:4px!important}
  .dmap-step-content span{font-size:14px!important;line-height:1.65!important;color:rgba(247,245,240,.95)!important}

  /* ─── Réalisations gallery ─── */
  .gallery-hero{padding-top:62px!important;min-height:auto!important}
  .gallery-hero-text{padding:48px 0 28px!important}
  .gallery-strip{grid-template-columns:1fr 1fr!important;gap:6px!important;min-height:0!important;padding:0 12px!important}
  .gs-tile{aspect-ratio:4/5!important;border-radius:10px!important;overflow:hidden!important}
  .gs-caption{padding:14px 16px!important}
  .gs-caption strong{font-size:14.5px!important}
  .gs-caption span{font-size:11.5px!important;letter-spacing:1px!important}
  .gs-stat-bar{padding:24px 0!important}
  .gs-stat-inner{gap:28px!important;flex-wrap:wrap!important;justify-content:center!important}
  .gs-stat-num{font-size:30px!important}
  .gs-stat-label{font-size:11.5px!important;letter-spacing:1.2px!important}

  /* ─── Project cards ─── */
  .proj-section{padding:64px 0!important}
  
  
  
  

  /* ─── Conformité ─── */
  .comp-section{padding:64px 0!important}
  
  
  
  
  
  
  
  
  

  
  
  
  
  

  /* ─── Équipe ─── */
  .team-hero-grid{grid-template-columns:1fr!important;gap:20px!important}
  .equipe-bio-grid{grid-template-columns:1fr!important;gap:36px!important}
  .team-card{padding:40px 22px 32px!important}
  .team-card-photo{width:172px!important;max-width:56%!important}
  .tc-name{font-size:22px!important;line-height:1.2!important}
  .team-phil{padding:64px 0!important}
  .phil-rows{gap:0!important}
  .phil-row{grid-template-columns:1fr!important;gap:10px!important;padding:26px 0!important}
  .phil-key{font-size:clamp(18px,4.5vw,22px)!important;line-height:1.3!important;letter-spacing:-.1px!important}
  .phil-val{font-size:14.5px!important;line-height:1.75!important}
  .phil-val strong{color:var(--ivory)!important}

  /* ─── Contact dark hero (large quote-style title) ─── */
  .contact-hero-dark{min-height:56svh!important;padding-top:62px!important}
  .chd-big{font-size:clamp(52px,17vw,96px)!important;line-height:1.02!important;letter-spacing:-.5px!important}
  .chd-sub{font-size:14px!important;line-height:1.7!important;margin-bottom:24px!important;color:rgba(247,245,240,.95)!important}

  /* ─── CTA band (inner pages) ─── */
  .cta-band{padding:64px 0!important}
  .cta-band h2{font-size:clamp(24px,6.5vw,34px)!important;line-height:1.15!important;margin-bottom:14px!important}
  .cta-band p{font-size:15.5px!important;line-height:1.7!important;margin-bottom:26px!important;color:rgba(247,245,240,.95)!important}
  .cta-band-btns{flex-direction:column!important;align-items:stretch!important;gap:10px!important}
  .cta-band-btns a{width:100%!important;max-width:none!important;justify-content:center!important;min-height:54px!important}

  /* Footer with safe area inset for iPhone home indicator */
  footer{padding:36px 0 calc(36px + env(safe-area-inset-bottom))!important}
}

/* ─── SMALL PHONES (iPhone SE etc.) ─── */
@media(max-width:400px){
  .page-h1{font-size:clamp(26px,8vw,36px)!important;line-height:1.1!important}
  .page-lead{font-size:16px!important}
  .phase-title{font-size:clamp(22px,6.5vw,30px)!important}
  .phase-chip{padding:16px 14px!important;font-size:12.5px!important;min-height:50px!important}
  .gallery-strip{grid-template-columns:1fr!important;padding:0 10px!important}
  .gs-tile{aspect-ratio:5/4!important}
  
  
  .dmap-name{min-width:82px!important;font-size:12px!important}
  .dmap-dest{min-width:72px!important;font-size:11px!important}
  .chd-big{font-size:clamp(44px,17vw,72px)!important}
  .tc-name{font-size:20px!important}
}

/* ─── LANDSCAPE PHONES, keep hero compact ─── */
@media(max-height:500px) and (orientation:landscape){
  .page-hero{min-height:auto!important;padding:74px 0 28px!important}
  .page-hero-content{padding:0 0 12px!important}
  .page-h1{font-size:28px!important;margin-bottom:10px!important}
  .page-lead{font-size:14.5px!important;margin-bottom:14px!important}
  .contact-hero-dark{min-height:auto!important;padding:80px 0 32px!important}
  .chd-big{font-size:44px!important}
}

/* ─── TOUCH FEEDBACK on inner pages ─── */
@media(hover:none){
  .phase-chip:active{background:rgba(211,163,87,.06)}
  .phase-check:active,.comp-item:active,.proj-card:active,.gs-tile:active{transform:scale(.99);transition:transform .12s ease}
  .gs-tile:hover img,.proj-card:hover .proj-img{transform:none!important}
}

/* ─── REDUCE BACKGROUND NOISE ON SMALL DEVICES ─── */
@media(max-width:768px){
  .page-hero-dark::after{opacity:.025!important}
  .phase-bg-num{-webkit-text-stroke-width:.5px!important}
  /* Calm down large background image filters for legibility */
  .page-hero-bg img{filter:brightness(.32) saturate(.85)!important}
}

/* ─── iOS SAFE AREAS ─── */
@supports(padding:max(0px)){
  .page-hero-content,.contact-hero-dark .container{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}
}

/* ─── REMOVE FLOATING WA ON PHONES (mob-bar carries the action) ─── */
@media(max-width:768px){
  #wa-btn{display:none!important}
}

/* === READABILITY BUMP for dark backgrounds === */
.hero-sub,.page-lead,.founder-quote,.mod-card li,.mod-zafbat li,
.anxiety-a,.faq-a p,.phase-desc,.phil-val,.dmap-step-content span,
.dias-conn-status,.es-text,.method-desc{font-weight:400!important}
.page-lead{color:rgba(247,245,240,.95)!important;font-weight:400!important}
.hero-sub{color:rgba(247,245,240,.96)!important;font-weight:400!important}
.founder-quote{font-weight:400!important;color:rgba(247,245,240,.98)!important}

