:root{
  --sable: #E8DCC8;
  --sable-pale: #F5F0E6;
  --terracotta: #B5562D;
  --terracotta-deep: #8F4322;
  --carbone: #1A1714;
  --carbone-soft: #25211C;
  --mer: #4A6B6B;
  --line: rgba(232,220,200,0.14);
  --line-strong: rgba(232,220,200,0.28);

  --display: 'Fraunces', serif;
  --body: 'Archivo', sans-serif;
  --label: 'Archivo Expanded', sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important;}
}

body{
  background:var(--carbone);
  color:var(--sable-pale);
  font-family:var(--body);
  line-height:1.6;
  overflow-x:hidden;
}

::selection{background:var(--terracotta); color:var(--sable-pale);}

a{color:inherit; text-decoration:none;}

img, video{display:block; max-width:100%;}

.wrap{max-width:1280px; margin:0 auto; padding:0 6vw;}
@media (max-width:600px){
  .wrap{padding:0 5vw;}
}

/* ---------- Focus visibility ---------- */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--terracotta);
  outline-offset:4px;
}

/* ---------- Nav ---------- */
header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:28px 6vw;
  display:flex; justify-content:space-between; align-items:center;
  transition:padding 0.4s ease, background 0.4s ease, border-color 0.4s ease;
  background:transparent;
  border-bottom:1px solid transparent;
}
header.scrolled{
  padding:18px 6vw;
  background:rgba(26,23,20,0.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}

.logo{
  display:inline-flex;
  align-items:center;
  font-family:var(--display);
  font-weight:500;
  letter-spacing:0.02em;
  z-index: 4;
}
.logo img{
  display:block;
  width:auto;
  height:55px;
}
@media (max-width:480px){
  .logo img{height:40px;}
  header{padding:20px 5vw;}
  header.scrolled{padding:14px 5vw;}
}

nav ul{
  display:flex; gap:38px;
  list-style:none;
}
nav, nav ul, header {
  isolation: isolate;
}
nav a{
  font-family:var(--body);
  font-size:13px;
  font-weight:500;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--sable-pale);
  position:relative;
  padding-bottom:4px;
  transition:color 0.22s ease;
}
nav a::after{
  content:'';
  position:absolute; left:0; bottom:0;
  width:0; height:1px;
  background:var(--terracotta);
  transition:width 0.3s ease;
}
nav a:hover::after{width:100%;}
nav a:active,
nav a:focus,
nav a:focus-visible{
  color:var(--terracotta);
}
/* mark current link if present */
nav a[aria-current="page"]{color:var(--terracotta);} 

.nav-toggle{display:none;}

@media (max-width:780px){
@media (max-width: 780px){


  nav ul{
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;

    background: rgba(26,23,20,0.98); /* IMPORTANT: uniforme partout */
    backdrop-filter: blur(12px);

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;

    gap: 34px;

    transform: translateX(100%);
    transition: transform 0.45s cubic-bezier(.65,0,.35,1);

    z-index: 1500; /* CRUCIAL: au-dessus de tout */
  }

  nav ul.open{
    transform: translateX(0);
  }
}
  nav a{font-size:20px;}
  .nav-toggle{
    display:flex; flex-direction:column; gap:5px;
    background:none; border:none; cursor:pointer;
    z-index:200; position:relative;
    padding:8px;
  }
  .nav-toggle span{
    width:24px; height:2px; background:var(--sable-pale);
    transition:all 0.3s ease;
  }
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle.open span:nth-child(2){opacity:0;}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  height:100svh;
  min-height:560px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  overflow:hidden;
}

.hero-media{
  position:absolute; inset:0;
  /* No background here — gradient is only on pseudo-element, above video, below content */
}
.hero-media::before{
  content:'';
  position:absolute; inset:0;
  pointer-events:none;
  z-index:2;
  /* Main gradient: darkens top & bottom, not the middle — keeps text readable without covering the image unnaturally */
  background:
    linear-gradient(180deg,
      rgba(26, 23, 20, 0.096) 0%,
      rgba(26,23,20,0.10) 38%,
      rgba(26,23,20,0.10) 58%,
      rgba(26, 23, 20, 0.207) 100%
    );
}

.hero-media::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(135deg, rgba(143,67,34,0.10) 0%, rgba(26,23,20,0.06) 100%),
    radial-gradient(circle at 50% 30%, rgba(181,86,45,0.05) 0%, rgba(181,86,45,0.01) 42%, rgba(26,23,20,0.08) 72%);
  z-index:2;
  pointer-events:none;
}

.hero-media video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:1;
  filter:brightness(0.82) contrast(1.04) saturate(0.92);
}

.hero-content{
  position:relative; z-index:10;
  padding:0 6vw 7vw;
  text-shadow:0 2px 18px rgba(26,23,20,0.55);
}

.eyebrow{
  font-family:var(--label);
  font-size:11px;
  letter-spacing:0.26em;
  text-transform:uppercase;
  color:var(--sable-pale);
  margin-bottom:22px;
  display:inline-flex;
  align-items:center;
  gap:12px;
  width:fit-content;
  padding:0;
  border:none;
  border-radius:0;
  background:none;
  backdrop-filter:none;
  box-shadow:none;
  text-shadow:none;
  font-weight:600;
  animation:fadeUp 0.9s ease 0.2s forwards;
}
.eyebrow-word{color:var(--sable-pale);}
.eyebrow-sep{
  color:var(--terracotta);
  font-size:1.55em;
  line-height:1;
}
.eyebrow-line{
  width:28px;
  height:2px;
  background:var(--terracotta);
  opacity:0.8;
  flex-shrink:0;
}
.eyebrow::before{
  content:'';
  width:28px; height:2px;
  background:var(--terracotta);
  opacity:0.8;
}

.hero h1{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(2.1rem, 5vw, 4.2rem);
  line-height:1.08;
  letter-spacing:-0.01em;
  max-width:18ch;
  opacity:0;
  animation:fadeUp 1s ease 0.4s forwards;
}
.hero h1 em{
  font-style:italic;
  font-weight:300;
  color:var(--sable-pale);
}

.hero-sub{
  margin-top:28px;
  margin-bottom:64px;
  max-width:46ch;
  font-size:clamp(1rem, 1.6vw, 1.18rem);
  color:rgba(245,240,230,0.94);
  font-weight:400;
  opacity:0;
  animation:fadeUp 1s ease 0.6s forwards;
}

.hero-bottom-row{
  margin-top:48px;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
  flex-wrap:wrap;
  opacity:0;
  animation:fadeUp 1s ease 0.8s forwards;
}

.scroll-cue{
  display:flex; align-items:center; gap:12px;
  font-size:12px; letter-spacing:0.1em; text-transform:uppercase;
  color:rgba(245,240,230,0.55);
}
.scroll-cue .line{
  width:1px; height:42px;
  background:linear-gradient(180deg, var(--terracotta), transparent);
  position:relative;
  overflow:hidden;
}
.scroll-cue .line::after{
  content:'';
  position:absolute; top:-100%; left:0; width:100%; height:100%;
  background:var(--sable-pale);
  animation:scrollDrip 2.2s ease-in-out infinite;
}
@keyframes scrollDrip{
  0%{top:-100%;} 60%{top:100%;} 100%{top:100%;}
}

@keyframes fadeUp{
  from{opacity:0; transform:translateY(24px);}
  to{opacity:1; transform:translateY(0);}
}

/* ---------- Section shared ---------- */
section{
  padding:140px 0;
  position:relative;
}
@media (max-width:780px){
  section{padding:72px 0;}
}

/* Hero mobile */
@media (max-width:600px){
  .hero-content{padding:0 5vw 11vw;}
  .hero h1{font-size:clamp(1.8rem, 8vw, 2.8rem); max-width:100%;}
  .hero-sub{margin-bottom:32px; font-size:0.97rem;}
  .hero-bottom-row{margin-top:24px; gap:16px;}
  .eyebrow{font-size:10px; gap:8px;}
}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:40px;
  margin-bottom:72px;
  flex-wrap:wrap;
}
@media (max-width:600px){
  .section-head{margin-bottom:40px; gap:24px;}
}

.section-eyebrow{
  font-family:var(--label);
  font-size:12px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--terracotta);
  margin-bottom:18px;
}

.section-title{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(2rem, 4vw, 3.4rem);
  line-height:1.05;
  max-width:16ch;
}
.section-title em{font-style:italic; color:var(--sable);}

.section-note{
  max-width:34ch;
  font-size:0.98rem;
  color:rgba(245,240,230,0.62);
}

.reveal{
  opacity:0;
  transform:translateY(36px);
  transition:opacity 0.9s cubic-bezier(.22,1,.36,1), transform 0.9s cubic-bezier(.22,1,.36,1);
}
.reveal.in{opacity:1; transform:translateY(0);}

/* ---------- Bandeau clients ---------- */
.clients-strip{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:28px 0;
}
.clients-strip .wrap{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:16px 32px;
}
.client-tag{
  font-family:var(--label);
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(245,240,230,0.45);
  white-space:nowrap;
}
@media (max-width:600px){
  .client-tag{font-size:10.5px; letter-spacing:0.08em;}
  .clients-strip .wrap{gap:12px 22px;}
}

/* ---------- Showreel ---------- */
.reel-frame{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  border-radius:3px;
  overflow:hidden;
  background:linear-gradient(135deg, #2c2620, #1f1b16);
}
.reel-frame video{
  width:100%; height:100%;
  object-fit:cover;
}
.reel-placeholder{
  position:absolute; inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:22px;
}
.reel-placeholder-text{
  font-family:var(--body);
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(232,220,200,0.3);
}
.reel-play{
  width:76px; height:76px;
  border-radius:50%;
  border:1px solid var(--line-strong);
  background:rgba(232,220,200,0.06);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition:transform 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}
.reel-play:hover{
  transform:scale(1.08);
  background:rgba(181,86,45,0.16);
  border-color:var(--terracotta);
}
.reel-play svg{width:22px; height:22px; fill:var(--sable-pale); margin-left:4px;}

/* ---------- Galerie photo ---------- */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.g-item{
  position:relative;
  overflow:hidden;
  border-radius:2px;
  aspect-ratio:4/5;
  background:linear-gradient(135deg, #2c2620, #1f1b16);
  cursor:pointer;
}
.g-item::before{
  content:attr(data-label);
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  text-align:center; padding:1.4rem;
  font-family:var(--body); font-size:11.5px; letter-spacing:0.07em; text-transform:uppercase;
  color:rgba(232,220,200,0.3);
  z-index:1;
}
.g-item img, .g-item video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  transition:transform 0.7s cubic-bezier(.22,1,.36,1), opacity 0.3s ease;
  opacity:0;
}
.g-item img[src], .g-item video[src]{opacity:1;}
.g-item:hover img, .g-item:hover video{transform:scale(1.06);}

.g-tag{
  position:absolute; bottom:16px; left:18px; z-index:2;
  font-family:var(--label);
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--sable-pale);
  background:rgba(26,23,20,0.55);
  backdrop-filter:blur(6px);
  padding:6px 12px;
  border-radius:100px;
  opacity:0;
  transform:translateY(8px);
  transition:all 0.35s ease;
}
.g-item:hover .g-tag{opacity:1; transform:translateY(0);}

@media (max-width:780px){
  .gallery-grid{grid-template-columns:repeat(2, 1fr); gap:10px;}
}
@media (max-width:480px){
  .gallery-grid{grid-template-columns:1fr; gap:10px;}
  .g-item{aspect-ratio:16/9;}
}

/* ---------- Services ---------- */
.services{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
@media (max-width:900px){
  .services{grid-template-columns:1fr;}
}
@media (max-width:600px){
  .service{padding:36px 24px;}
}

.service{
  background:var(--carbone);
  padding:52px 40px;
  transition:background 0.4s ease;
}
.service:hover{background:var(--carbone-soft);}

.service-icon{
  width:46px; height:46px;
  margin-bottom:32px;
}
.service-icon svg{width:100%; height:100%; stroke:var(--terracotta); fill:none; stroke-width:1.2;}

.service h3{
  font-family:var(--display);
  font-weight:400;
  font-size:1.6rem;
  margin-bottom:16px;
}

.service p{
  color:rgba(245,240,230,0.62);
  font-size:0.96rem;
  margin-bottom:24px;
}

.service ul{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:9px;
}
.service li{
  font-size:0.88rem;
  color:rgba(245,240,230,0.78);
  display:flex;
  align-items:baseline;
  gap:10px;
}
.service li::before{
  content:'';
  width:5px; height:5px;
  border-radius:50%;
  background:var(--terracotta);
  flex-shrink:0;
  transform:translateY(-2px);
}

/* ---------- Approche ---------- */
.approche{
  background:var(--sable);
  color:var(--carbone);
}
.approche .section-eyebrow{color:var(--terracotta-deep);}
.approche .section-note{color:rgba(26,23,20,0.62);}
.approche .section-title em{color:var(--terracotta-deep);}

.approche-grid{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:80px;
  align-items:start;
}
@media (max-width:900px){
  .approche-grid{
    grid-template-columns:1fr;
    grid-template-areas:
      "text"
      "list"
      "photo";
    gap:36px;
  }
  .approche-photo{margin-top:0;}
  .approche-photo img{max-width:100%; height:auto;}
}

.approche-text p{
  font-size:1.08rem;
  line-height:1.75;
  color:rgba(26,23,20,0.78);
  margin-bottom:22px;
}
.approche-text p:last-child{margin-bottom:0;}
.approche-text strong{color:var(--carbone); font-weight:600;}

.approche-list{
  display:flex;
  flex-direction:column;
}
.approche-row{
  padding:26px 0;
  border-top:1px solid rgba(26,23,20,0.14);
  display:flex;
  justify-content:space-between;
  gap:24px;
}
.approche-list .approche-row:last-child{border-bottom:1px solid rgba(26,23,20,0.14);}
/* Photo approche */
.approche-photo{
  margin-top:40px;
}

.approche-grid{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,0.9fr);
  grid-template-areas:
    "text list"
    "photo list";
  column-gap:80px;
  row-gap:40px;
  align-items:start;
}

.approche-text{
  grid-area:text;
}

.approche-list{
  grid-area:list;
  align-self:start;
}

.approche-photo{
  grid-area:photo;
  margin-top: -45px;
}

.approche-photo img{
  max-width:520px;
  width:100%;
}


/* approche-photo mobile handled above */
.approche-row .num{
  font-family:var(--display);
  font-style:italic;
  font-size:1.1rem;
  color:var(--terracotta-deep);
  flex-shrink:0;
}
.approche-row .label{
  font-family:var(--label);
  font-size:0.9rem;
  font-weight:600;
  letter-spacing:0.04em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.approche-row .desc{
  font-size:0.88rem;
  color:rgba(26,23,20,0.6);
}
.approche-row .text-block{flex:1;}

/* ---------- Formules ---------- */
.formules{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
@media (max-width:900px){
  .formules{grid-template-columns:1fr; gap:18px;}
}
@media (max-width:600px){
  .formule{padding:28px 20px;}
  .formule-badge{right:20px;}
}

.formule{
  border:1px solid var(--line);
  padding:40px 32px;
  position:relative;
  transition:border-color 0.4s ease, transform 0.4s ease;
}
.formule:hover{border-color:var(--line-strong); transform:translateY(-4px);}
.formule.feat{
  border-color:var(--terracotta);
  background:linear-gradient(165deg, rgba(181,86,45,0.08), transparent 60%);
}

.formule-badge{
  position:absolute; top:-1px; right:32px;
  background:var(--terracotta);
  color:var(--sable-pale);
  font-family:var(--label);
  font-size:10.5px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  padding:6px 14px;
  border-radius:0 0 6px 6px;
}

.formule h3{
  font-family:var(--display);
  font-size:1.5rem;
  font-weight:400;
  margin-bottom:8px;
}
.formule .tagline{
  font-size:0.86rem;
  color:rgba(245,240,230,0.5);
  margin-bottom:28px;
}
.formule ul{
  list-style:none;
  display:flex; flex-direction:column; gap:13px;
  margin-bottom:32px;
}
.formule li{
  font-size:0.9rem;
  color:rgba(245,240,230,0.78);
  display:flex; align-items:baseline; gap:10px;
}
.formule li::before{
  content:'—';
  color:var(--terracotta);
  flex-shrink:0;
}
.formule-cta{
  display:inline-block;
  font-family:var(--label);
  font-size:12px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  padding:13px 0;
  border-top:1px solid var(--line-strong);
  width:100%;
  text-align:center;
  transition:color 0.3s ease;
}
.formule-cta:hover{color:var(--terracotta);}

/* ---------- Photo profil ---------- */
.photo-profil{
  padding:120px 0 100px;
  background:
    radial-gradient(circle at top left, rgba(181,86,45,0.12), transparent 38%),
    linear-gradient(180deg, rgba(26,23,20,0.94), rgba(18,16,14,1));
}
.photo-profil-grid{
  display:grid;
  grid-template-columns:0.95fr 1.05fr;
  gap:40px;
  align-items:center;
}
@media (max-width:900px){
  .photo-profil-grid{grid-template-columns:1fr; gap:28px;}
}
@media (max-width:600px){
  .photo-profil{padding:72px 0 60px;}
  .photo-profil-frame{min-height:260px;}
}
.photo-profil-text .section-title{
  max-width:12ch;
  margin-bottom:18px;
}
.photo-profil-text .section-note{
  max-width:36ch;
}
.photo-profil-frame{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:6px;
  background:linear-gradient(135deg, #2c2620, #1f1b16);
  aspect-ratio:4 / 3;
  min-height:360px;
}
.photo-profil-frame::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(26,23,20,0.06), rgba(26,23,20,0.28));
  z-index:1;
  pointer-events:none;
}
.photo-profil-frame img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  object-position:center center;
}

/* ---------- Témoignage / chiffre ---------- */
.statline{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.statline .wrap{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
}
@media (max-width:780px){
  .statline .wrap{grid-template-columns:repeat(2, 1fr);}
}
.stat{
  padding:48px 24px;
  text-align:center;
  border-left:1px solid var(--line);
}
.stat:first-child{border-left:none;}
@media (max-width:780px){
  .stat:nth-child(2n+1){border-left:none;}
  .stat:nth-child(n+3){border-top:1px solid var(--line);}
}
@media (max-width:480px){
  .statline .wrap{grid-template-columns:1fr;}
  .stat{border-left:none !important; border-top:1px solid var(--line);}
  .stat:first-child{border-top:none;}
}
.stat .num{
  font-family:var(--display);
  font-style:italic;
  font-size:2.4rem;
  color:var(--terracotta);
  margin-bottom:8px;
}
.stat .lbl{
  font-size:0.82rem;
  letter-spacing:0.04em;
  color:rgba(245,240,230,0.55);
}

/* ---------- Contact ---------- */
.contact{
  position:relative;
  overflow:hidden;
}
.contact-bg{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(26,23,20,0.55), rgba(26,23,20,0.96)),
    linear-gradient(120deg, #3a3128, #1A1714);
  z-index:0;
}
.contact-bg::before{
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(180deg, rgba(26,23,20,0.55), rgba(26,23,20,0.96)),
    url('IMG_1197.jpg');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  pointer-events:none;
}

.contact-inner{position:relative; z-index:1;}

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
}
@media (max-width:900px){
  .contact-grid{grid-template-columns:1fr; gap:40px;}
}
@media (max-width:600px){
  .contact-inner{padding-left:5vw; padding-right:5vw;}
}

.contact-direct{
  display:flex;
  flex-direction:column;
  gap:28px;
  margin-top:40px;
}
.contact-direct a{
  font-family:var(--display);
  font-size:clamp(1.1rem, 3.5vw, 1.9rem);
  display:flex;
  align-items:center;
  gap:14px;
  width:fit-content;
  border-bottom:1px solid transparent;
  transition:border-color 0.3s ease, color 0.3s ease;
}
.contact-direct a:hover{border-color:var(--terracotta); color:var(--terracotta);}
.contact-direct svg{width:20px; height:20px; stroke:var(--terracotta); fill:none; stroke-width:1.4; flex-shrink:0;}

.contact-zone{
  margin-top:36px;
  font-size:0.92rem;
  color:rgba(245,240,230,0.55);
  display:flex;
  align-items:center;
  gap:10px;
}

.social-row{
  display:flex; gap:18px; margin-top:36px;
}
.social-row a{
  width:42px; height:42px;
  border:1px solid var(--line-strong);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:border-color 0.3s ease, background 0.3s ease;
}
.social-row a:hover{border-color:var(--terracotta); background:rgba(181,86,45,0.1);}
.social-row svg{width:17px; height:17px; stroke:var(--sable-pale); fill:none; stroke-width:1.4;}

/* Form */
.form-group{margin-bottom:22px;}
.form-group label{
  display:block;
  font-family:var(--label);
  font-size:11.5px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:rgba(245,240,230,0.55);
  margin-bottom:10px;
}
.form-group input, .form-group textarea, .form-group select{
  width:100%;
  background:transparent;
  border:none;
  border-bottom:1px solid var(--line-strong);
  padding:12px 2px;
  font-family:var(--body);
  font-size:1rem;
  color:var(--sable-pale);
  transition:border-color 0.3s ease;
}
.form-group select{appearance:none; cursor:pointer;}
.form-group select option{background:var(--carbone-soft); color:var(--sable-pale);}
.form-group input::placeholder, .form-group textarea::placeholder{color:rgba(245,240,230,0.32);}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus{
  border-color:var(--terracotta);
  outline:none;
}
.form-group textarea{resize:vertical; min-height:90px;}

.submit-btn{
  margin-top:12px;
  background:var(--terracotta);
  color:var(--sable-pale);
  border:none;
  padding:17px 38px;
  font-family:var(--label);
  font-size:12.5px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  cursor:pointer;
  border-radius:2px;
  transition:background 0.3s ease, transform 0.2s ease;
  display:inline-flex;
  align-items:center;
  gap:12px;
}
.submit-btn:hover{background:var(--terracotta-deep); transform:translateY(-2px);}
.submit-btn svg{width:14px; height:14px; stroke:var(--sable-pale); fill:none; stroke-width:1.6;}
@media (max-width:600px){
  .submit-btn{width:100%; justify-content:center;}
}

.form-success{
  display:none;
  padding:18px 20px;
  border:1px solid var(--terracotta);
  border-radius:2px;
  font-size:0.92rem;
  color:var(--sable-pale);
}
.form-success.show{display:block;}

/* ---------- Footer ---------- */
footer{
  padding:64px 0 36px;
  border-top:1px solid var(--line);
  background:var(--carbone);
}
.footer-main{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:48px;
  margin-bottom:48px;
  padding-bottom:48px;
  border-bottom:1px solid var(--line);
}
@media (max-width:780px){
  .footer-main{grid-template-columns:1fr; gap:36px; margin-bottom:36px; padding-bottom:36px;}
}

.footer-brand img{
  height:44px;
  width:auto;
  margin-bottom:16px;
  opacity:0.9;
}
.footer-slogan{
  font-family:var(--display);
  font-style:italic;
  font-size:1.02rem;
  color:rgba(245,240,230,0.55);
  margin-bottom:6px;
}
.footer-tagline-sub{
  font-size:0.78rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(245,240,230,0.28);
  font-family:var(--label);
}

.footer-col-title{
  font-family:var(--label);
  font-size:10.5px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--terracotta);
  margin-bottom:20px;
}
.footer-links{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.footer-links a{
  font-size:0.88rem;
  color:rgba(245,240,230,0.52);
  transition:color 0.25s ease;
}
.footer-links a:hover{color:var(--sable-pale);}

.footer-contact-info{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.footer-contact-info a{
  font-size:0.88rem;
  color:rgba(245,240,230,0.52);
  display:flex;
  align-items:center;
  gap:10px;
  transition:color 0.25s ease;
}
.footer-contact-info a:hover{color:var(--sable-pale);}
.footer-contact-info svg{width:14px; height:14px; stroke:var(--terracotta); fill:none; stroke-width:1.4; flex-shrink:0;}

.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}
.footer-note{
  font-size:0.78rem;
  color:rgba(245,240,230,0.3);
}
.footer-back{
  font-family:var(--label);
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:rgba(245,240,230,0.4);
  transition:color 0.3s ease;
}
.footer-back:hover{color:var(--terracotta);}

/* Lightbox */
.lightbox{
  position:fixed; inset:0; z-index:1000;
  background:rgba(26,23,20,0.96);
  display:none;
  align-items:center; justify-content:center;
  padding:6vw;
}
.lightbox.open{display:flex;}
.lightbox img, .lightbox video{
  max-width:100%; max-height:88vh;
  border-radius:2px;
}
.lightbox-close{
  position:absolute; top:28px; right:6vw;
  width:42px; height:42px;
  border:1px solid var(--line-strong);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  background:none;
}
.lightbox-close svg{width:16px; height:16px; stroke:var(--sable-pale); fill:none; stroke-width:1.5;}

/* =========================
   FIX GLOBAL IMAGE QUI DÉBORDE (PROFIL + SECTIONS)
========================= */

img {
  max-width: 100%;
  height: auto;
}

/* sécurité stricte anti overflow horizontal */
html, body {
  overflow-x: hidden !important;
}

/* =========================
   FIX SPÉCIFIQUE PHOTO PROFIL (profil.png)
========================= */

.photo-profil-frame {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.photo-profil-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* =========================
   MOBILE SAFETY (renforce les layouts cassés)
========================= */

@media (max-width: 600px) {

  .photo-profil-grid {
    grid-template-columns: 1fr !important;
  }

  .photo-profil-frame {
    aspect-ratio: 4 / 3;
    width: 100%;
    overflow: hidden;
  }
}

/* =========================
   APPROCHE MOBILE ORDRE EXACT
========================= */

@media (max-width: 900px) {

  .approche-grid {
    display: flex !important;
    flex-direction: column !important;
  }

  .approche-text {
    order: 1;
  }

  .approche-photo {
    order: 2;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    margin: 16px 0;
  }

  .approche-photo img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
  }

  .approche-list {
    order: 3;
  }
}

@media (max-width: 600px) {

  .hero {
    justify-content: flex-start;
  }

  .hero-content {
    padding: 110px 5vw 0;
  }

  .hero h1 {
    font-size: 2rem;
    line-height: 1.1;
  }

  .hero-sub {
    margin-bottom: 24px;
  }

  /* =========================
     BOTTOM HERO PLUS BAS
  ========================= */

  .hero-bottom-row {
    margin-top: 150px; /* 👈 ICI tu descends le bloc */
  }

  /* scroll cue + contact */
  .scroll-cue,
  .hero-bottom-row a,
  .hero-bottom-row .contact-link {
    color: rgba(245, 240, 230, 0.879);
  }
}

/* =========================
   BURGER MOBILE ALIGN RIGHT
========================= */

@media (max-width: 780px) {

  header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 2000;
  }

  nav {
    flex: 0;
  }

  .nav-toggle {
    margin-left: auto;
    position: relative;
    z-index: 200;
  }
}
/* ---------- Impact / Pourquoi investir ---------- */
.impact{
  padding:120px 0;
  background:linear-gradient(160deg, var(--terracotta) 0%, var(--terracotta-deep) 35%, var(--carbone) 85%);
}
.impact .section-eyebrow{color:var(--sable-pale);}
.impact .section-title{color:var(--sable-pale);}
.impact .section-note{color:rgba(245,240,230,0.82);}

.impact-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:rgba(245,240,230,0.18);
  border:1px solid rgba(245,240,230,0.18);
  margin-top:56px;
}
@media (max-width:900px){
  .impact-grid{grid-template-columns:1fr;}
}

.impact-stat{
  background:rgba(26,23,20,0.22);
  backdrop-filter:blur(6px);
  padding:48px 36px;
  transition:background 0.4s ease;
}
.impact-stat:hover{background:rgba(26,23,20,0.4);}
@media (max-width:600px){
  .impact-stat{padding:36px 24px;}
}

.impact-number{
  font-family:var(--display);
  font-size:clamp(2.6rem, 5vw, 3.8rem);
  font-weight:400;
  color:var(--sable-pale);
  line-height:1;
  margin-bottom:20px;
}

.impact-label{
  font-size:0.98rem;
  color:rgba(245,240,230,0.88);
  line-height:1.5;
  max-width:30ch;
  margin-bottom:14px;
}

.impact-source{
  font-family:var(--label);
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:rgba(245,240,230,0.6);
}

.impact-conclusion{
  margin-top:48px;
  max-width:62ch;
  font-family:var(--display);
  font-style:italic;
  font-size:1.15rem;
  color:var(--sable-pale);
  line-height:1.5;
}
@media (max-width:600px){
  .impact{padding:80px 0;}
  .impact-conclusion{font-size:1.02rem;}
}