/* ════════════════════════════════════════════════════════
   KINWORK — Composants : Hero, Ticker, Intro, Chiffres,
             Programmes, Pourquoi, Process, Galerie, Vidéo,
             Stats, Tarifs, Témoignages, FAQ, CTA, Contact
   Fichier : css/components.css
════════════════════════════════════════════════════════ */


/* ── HERO ───────────────────────────────────────────────── */
.hero {
  position: relative;
  height: 100vh;
  min-height: 680px;
  overflow: hidden;
  background: var(--blk);
}

.hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .9s ease;
}

.hero-slide.active {
  opacity: 1;
}

.hero-slide img {
  display: block;
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  object-fit: cover;
  object-position: center 30%;
  filter: grayscale(1) contrast(1.15) brightness(.42);
  animation: kenBurns 22s ease-in-out infinite alternate;
}

@keyframes kenBurns {
  from { transform: scale(1); }
  to   { transform: scale(1.06); }
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top,  rgba(6,6,6,.98) 0%, rgba(6,6,6,.68) 32%, rgba(6,6,6,.18) 68%, transparent 88%),
    linear-gradient(to right, rgba(6,6,6,.82) 0%, rgba(6,6,6,.38) 46%, transparent 70%),
    linear-gradient(to bottom, rgba(6,6,6,.5) 0%, transparent 22%);
}

/* Contenu hero */
.hero-content {
  position: absolute;
  z-index: 2;
  bottom: 108px; left: 64px;
  max-width: 620px;
}

.hero-eyebrow {
  font-size: 9px; font-weight: 600;
  letter-spacing: 5px; text-transform: uppercase;
  color: var(--g);
  margin-bottom: 20px;
  display: flex; align-items: center; gap: 14px;
  opacity: 0; transform: translateY(16px);
  animation: fadeUp .8s var(--ease2) .2s forwards;
}
.hero-eyebrow::before { content:''; width:32px; height:1px; background:var(--g); }

.hero-h1 {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(68px, 10vw, 130px);
  line-height: .82; letter-spacing: 2px;
  color: var(--w);
  margin-bottom: 24px;
  opacity: 0; transform: translateY(24px);
  animation: fadeUp .9s var(--ease2) .4s forwards;
  text-shadow: 0 4px 60px rgba(0,0,0,.8);
}
.hero-h1 em {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-weight: 300;
  color: var(--g);
  display: block;
  font-size: .68em; letter-spacing: 3px; margin-top: 4px;
}

.hero-body {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px; font-weight: 300;
  color: rgba(242,238,231,.72);
  line-height: 1.75; margin-bottom: 28px; max-width: 480px;
  opacity: 0; transform: translateY(20px);
  animation: fadeUp .9s var(--ease2) .6s forwards;
}

.hero-pillars {
  display: flex; gap: 24px; margin-bottom: 32px; flex-wrap: wrap;
  opacity: 0; transform: translateY(16px);
  animation: fadeUp .8s var(--ease2) .72s forwards;
}
.hero-pillar { display: flex; align-items: center; gap: 9px; }
.hero-pillar svg { color: var(--g); flex-shrink: 0; }
.hero-pillar-lbl {
  font-size: 9px; font-weight: 600; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--w4); line-height: 1.35;
}

.hero-btns {
  display: flex; gap: 14px; flex-wrap: wrap;
  opacity: 0; transform: translateY(16px);
  animation: fadeUp .8s var(--ease2) .86s forwards;
}

/* Stats hero (panneau droit) */
.hero-stats {
  position: absolute;
  top: 50%; right: 72px; z-index: 2;
  transform: translateY(-50%);
  text-align: right;
  display: flex; flex-direction: column; gap: 36px;
  opacity: 0; animation: fadeIn 1s ease 1.1s forwards;
  background: rgba(6,6,6,.22);
  backdrop-filter: blur(8px);
  padding: 28px 24px;
}
.hs-n { font-family:'Bebas Neue',sans-serif; font-size:58px; line-height:1; color:var(--w); }
.hs-n em { color:var(--g); font-style:normal; }
.hs-l { font-size:9px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--w2); margin-top:4px; }

/* Scroll indicator */
.hero-scroll {
  position: absolute; bottom: 36px; left: 50%;
  transform: translateX(-50%); z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  animation: fadeIn 1s ease 1.5s both;
}
.hero-scroll span { font-size:8px; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--w2); }
.scroll-line {
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, var(--g), transparent);
  animation: scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine {
  0%,100% { opacity:.3; }
  50%     { opacity:1; transform:scaleY(.7); }
}

/* Dots carrousel */
.hero-dots { position:absolute; bottom:36px; left:64px; z-index:3; display:flex; gap:8px; }
.hero-dot {
  width:28px; height:2px;
  background:rgba(184,150,78,.25);
  cursor:pointer;
  transition:background .3s, width .3s;
  border:none; padding:0;
}
.hero-dot.active { background:var(--g); width:48px; }

/* Flèches carrousel */
.hero-arr {
  position:absolute; top:50%; z-index:3;
  background:rgba(6,6,6,.3); backdrop-filter:blur(10px);
  border:1px solid rgba(184,150,78,.2);
  color:var(--g); width:52px; height:52px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; transform:translateY(-50%);
  transition:all .25s;
}
.hero-arr:hover { background:var(--g); color:var(--blk); border-color:var(--g); }
.arr-l { left:24px; }
.arr-r { right:24px; }


/* ── TICKER ─────────────────────────────────────────────── */
.ticker {
  background: var(--blk3);
  padding: 14px 0;
  overflow: hidden;
  white-space: nowrap;
  border-top: 1px solid var(--bdr);
  border-bottom: 1px solid var(--bdr);
}
.ticker-inner {
  display: inline-flex;
  animation: tick 50s linear infinite;
}
.ticker-inner span {
  font-size: 9px; font-weight: 700;
  letter-spacing: 6px; text-transform: uppercase;
  padding: 0 32px; color: var(--g); opacity: .45;
}
.ticker-inner span::after {
  content: '◆'; margin-left: 32px;
  font-size: 4px; opacity: .3; vertical-align: middle;
}
@keyframes tick {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}


/* ── INTRO 3 COLS ───────────────────────────────────────── */
.intro { background: var(--blk2); border-bottom: 1px solid var(--bdr); }
.intro-grid { display: grid; grid-template-columns: repeat(3,1fr); }
.intro-col {
  padding: 52px 48px;
  border-right: 1px solid var(--bdr);
  position: relative; overflow: hidden;
}
.intro-col::before {
  content: '';
  position: absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(to right, transparent, var(--g), transparent);
  opacity: 0; transition: opacity .4s;
}
.intro-col:hover::before { opacity: .5; }
.intro-col:last-child { border-right: none; }
.intro-col-label { font-size:9px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--g); opacity:.7; margin-bottom:12px; }
.intro-col-title { font-family:'Bebas Neue',sans-serif; font-size:28px; letter-spacing:2px; color:var(--w); line-height:1.05; margin-bottom:12px; }
.intro-col-title em { color:var(--g); font-style:normal; }
.intro-col-body { font-family:'Cormorant Garamond',serif; font-size:15px; color:var(--w6); line-height:1.72; }


/* ── CHIFFRES ────────────────────────────────────────────── */
.chiffres-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 1px; background: var(--bdr);
  max-width: var(--max); margin: 0 auto;
}
.chiffre-item {
  background: var(--blk);
  padding: 56px 44px;
  display: flex; align-items: flex-start; gap: 20px;
  transition: background .3s;
}
.chiffre-item:hover { background: var(--blk3); }
.chiffre-ico { color:var(--g); flex-shrink:0; margin-top:4px; }
.chiffre-n { font-family:'Bebas Neue',sans-serif; font-size:52px; line-height:1; color:var(--w); margin-bottom:6px; }
.chiffre-n em { color:var(--g); font-style:normal; }
.chiffre-l { font-size:11px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--w4); }
.chiffre-sub { font-family:'Cormorant Garamond',serif; font-size:13px; color:var(--w2); margin-top:4px; line-height:1.5; }


/* ── PROGRAMMES ─────────────────────────────────────────── */
.programmes { background: var(--blk2); }
.prog-header { text-align:center; margin-bottom:72px; }

.prog-photos {
  display: grid; grid-template-columns: repeat(5,1fr);
  gap: 2px; margin-bottom: 2px;
}
.prog-photo { position:relative; overflow:hidden; aspect-ratio:3/4; cursor:pointer; }
.prog-photo img {
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(1) contrast(1.1) brightness(.65);
  transition:filter .5s var(--ease), transform .6s var(--ease);
}
.prog-photo:hover img { filter:grayscale(.5) contrast(1.05) brightness(.75); transform:scale(1.04); }
.prog-photo-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(6,6,6,.9) 0%,transparent 55%); }
.prog-photo-lbl { position:absolute; bottom:16px; left:16px; right:16px; font-family:'Bebas Neue',sans-serif; font-size:14px; letter-spacing:2.5px; color:var(--w); }
.prog-photo-num { position:absolute; top:14px; left:14px; font-size:8px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--g); opacity:.8; }

.prog-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:2px; background:var(--bdr2); }
.prog-card {
  background: var(--blk3);
  padding: 28px 20px 24px;
  display: flex; flex-direction: column; align-items: center; text-align: center;
  border: 1px solid transparent;
  transition: all .35s var(--ease);
}
.prog-card:hover { background:var(--blk4); border-color:var(--bdr); transform:translateY(-2px); }
.prog-card svg { color:var(--g); margin-bottom:14px; transition:transform .3s; }
.prog-card:hover svg { transform:scale(1.1); }
.prog-num  { font-size:8px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--g); opacity:.5; margin-bottom:5px; }
.prog-name { font-family:'Bebas Neue',sans-serif; font-size:14px; letter-spacing:2px; color:var(--w); line-height:1.2; margin-bottom:8px; }
.prog-desc { font-size:10.5px; color:var(--w4); line-height:1.58; }
.prog-row2 .prog-card { background:var(--blk2); }


/* ── POURQUOI KINWORK ───────────────────────────────────── */
.why { background: var(--blk); }
.why-grid { display:grid; grid-template-columns:1fr 1fr; max-width:var(--max); margin:0 auto; }
.why-img { position:relative; overflow:hidden; min-height:600px; }
.why-img img { width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.08) brightness(.65); transition:transform .8s; }
.why-img:hover img { transform:scale(1.02); }
.why-img-overlay { position:absolute; inset:0; background:linear-gradient(to right, transparent 50%, var(--blk)); }
.why-content { background:var(--blk); padding:80px 72px; display:flex; flex-direction:column; justify-content:center; border-left:1px solid var(--bdr); }
.why-list { list-style:none; margin-top:28px; display:flex; flex-direction:column; }
.why-list li { display:flex; align-items:flex-start; gap:16px; padding:18px 0; border-bottom:1px solid var(--bdr2); transition:background .2s; }
.why-list li:first-child { padding-top:0; }
.why-list li:last-child  { border-bottom:none; }
.why-list-ico { width:36px; height:36px; border:1px solid var(--bdr); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--g); transition:all .25s; }
.why-list li:hover .why-list-ico { background:var(--gdim); border-color:var(--g); }
.why-list-title { font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--w); margin-bottom:3px; }
.why-list-sub   { font-size:12px; color:var(--w4); line-height:1.6; }


/* ── PROCESS ─────────────────────────────────────────────── */
.process { background: var(--blk3); }
.process-steps {
  display: grid; grid-template-columns: repeat(5,1fr);
  gap: 0; margin-top: 72px; position: relative;
}
.process-steps::before {
  content: '';
  position: absolute; top:28px; left:10%; right:10%; height:1px;
  background: var(--bdr); z-index: 0;
}
.process-step {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 0 20px;
  position: relative; z-index: 1;
}
.step-circle {
  width:56px; height:56px;
  border:1px solid var(--bdr); border-radius:50%;
  background:var(--blk3);
  display:flex; align-items:center; justify-content:center;
  color:var(--g); margin-bottom:20px; transition:all .3s;
}
.process-step:hover .step-circle { background:var(--gdim); border-color:var(--g); }
.step-n     { font-size:9px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--g); opacity:.6; margin-bottom:8px; }
.step-title { font-family:'Bebas Neue',sans-serif; font-size:18px; letter-spacing:2px; color:var(--w); margin-bottom:6px; }
.step-desc  { font-size:11px; color:var(--w4); line-height:1.6; }


/* ── GALERIE ─────────────────────────────────────────────── */
.gallery { background:var(--blk); overflow:hidden; }
.gallery-strip { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.gallery-img { overflow:hidden; aspect-ratio:1/1; }
.gallery-img img {
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(1) contrast(1.12) brightness(.6);
  transition:transform .7s var(--ease), filter .5s;
}
.gallery-img:hover img { transform:scale(1.05); filter:grayscale(.7) brightness(.7); }


/* ── VIDÉO PLEIN ÉCRAN ──────────────────────────────────── */
.video-sec {
  position:relative; height:70vh; min-height:480px;
  overflow:hidden; display:flex; align-items:center; justify-content:center;
}
.video-bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:grayscale(1) brightness(.38); }
.video-overlay { position:absolute; inset:0; background:radial-gradient(ellipse at center, transparent 30%, rgba(6,6,6,.8) 100%); }
.video-content { position:relative; z-index:1; text-align:center; padding:0 40px; }
.video-content h2 { font-family:'Bebas Neue',sans-serif; font-size:clamp(44px,7vw,88px); letter-spacing:3px; color:var(--w); line-height:.9; margin-bottom:16px; }
.video-content h2 em { font-family:'Cormorant Garamond',serif; font-style:italic; font-weight:300; color:var(--g); }
.video-content p { font-family:'Cormorant Garamond',serif; font-size:20px; font-weight:300; color:var(--w6); margin-bottom:32px; }
.play-btn {
  width:80px; height:80px;
  border:1px solid rgba(184,150,78,.5); border-radius:50%;
  background:rgba(6,6,6,.4); backdrop-filter:blur(10px);
  display:flex; align-items:center; justify-content:center;
  color:var(--g); font-size:24px;
  margin:0 auto; cursor:pointer; transition:all .3s;
}
.play-btn:hover { background:var(--g); color:var(--blk); border-color:var(--g); transform:scale(1.08); }


/* ── STATS BAND ─────────────────────────────────────────── */
.stats-band { background:var(--g); }
.stats-inner { display:grid; grid-template-columns:repeat(4,1fr); max-width:var(--max); margin:0 auto; }
.stat-item { text-align:center; padding:52px 24px; border-right:1px solid rgba(8,8,8,.15); }
.stat-item:last-child { border-right:none; }
.stat-n { font-family:'Bebas Neue',sans-serif; font-size:68px; line-height:1; color:var(--blk); }
.stat-l { font-size:10px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:rgba(8,8,8,.55); margin-top:6px; }


/* ── TARIFS ──────────────────────────────────────────────── */
.tarifs { background:var(--blk2); }
.tarifs-header { text-align:center; margin-bottom:72px; }
.tarifs-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:var(--bdr); max-width:var(--max); margin:0 auto; }
.tarif-card {
  background:var(--blk3); padding:48px 36px 40px;
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  transition:all .4s var(--ease);
  border:1px solid transparent;
}
.tarif-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:transparent; transition:background .3s; }
.tarif-card:hover            { background:var(--blk4); border-color:var(--bdr); transform:translateY(-6px); box-shadow:0 24px 64px rgba(0,0,0,.7); }
.tarif-card:hover::before,
.tarif-card.best::before     { background:var(--g); }
.tarif-card.best             { background:var(--blk); }
.tarif-badge { position:absolute; top:18px; right:18px; background:var(--g); color:var(--blk); font-size:8px; font-weight:700; letter-spacing:2px; text-transform:uppercase; padding:4px 12px; }
.tarif-label   { font-size:9px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--g); margin-bottom:10px; opacity:.8; }
.tarif-name    { font-family:'Bebas Neue',sans-serif; font-size:28px; letter-spacing:2px; color:var(--w); margin-bottom:6px; }
.tarif-persons { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:14px; color:var(--w4); margin-bottom:24px; }
.tarif-price   { font-family:'Bebas Neue',sans-serif; font-size:52px; line-height:1; color:var(--w); margin-bottom:4px; }
.tarif-price span { font-size:22px; }
.tarif-unit    { font-size:10px; color:var(--w4); margin-bottom:8px; }
.tarif-per     { font-size:12px; color:var(--w4); margin-bottom:28px; }
.tarif-sep     { width:28px; height:1px; background:var(--g); opacity:.4; margin-bottom:24px; }
.tarif-features { list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:auto; padding-bottom:32px; }
.tarif-features li  { display:flex; align-items:center; gap:10px; font-size:12px; color:var(--w6); }
.tarif-features svg { color:var(--g); flex-shrink:0; }
.tarif-card .btn { margin-top:auto; justify-content:center; font-size:9px; }

/* Abonnements */
.abos-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:var(--bdr); max-width:var(--max); margin:24px auto 0; }
.abo-card { background:var(--blk3); padding:36px 28px; position:relative; transition:all .35s; border:1px solid transparent; }
.abo-card:hover { border-color:var(--bdr); transform:translateY(-3px); }
.abo-card.best::after { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--g); }
.abo-name  { font-size:9px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--g); margin-bottom:8px; }
.abo-price { font-family:'Bebas Neue',sans-serif; font-size:42px; line-height:1; color:var(--w); }
.abo-price span { font-size:18px; }
.abo-freq  { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:14px; color:var(--g); margin:6px 0 20px; }
.abo-sep   { width:24px; height:1px; background:var(--g); opacity:.4; margin-bottom:18px; }
.abo-features { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.abo-features li  { display:flex; align-items:center; gap:8px; font-size:11px; color:var(--w6); }
.abo-features svg { color:var(--g); flex-shrink:0; }
.abo-card.gold                 { background:var(--g); }
.abo-card.gold .abo-name,
.abo-card.gold .abo-freq       { color:var(--blk); }
.abo-card.gold .abo-price      { color:var(--blk); }
.abo-card.gold .abo-features li { color:rgba(8,8,8,.8); }
.abo-card.gold .abo-features svg { color:var(--blk); }


/* ── TÉMOIGNAGES ─────────────────────────────────────────── */
.temos { background:var(--blk); }
.temo-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--bdr2); margin-top:64px; }
.temo {
  background:var(--blk2); padding:44px 36px;
  position:relative; overflow:hidden;
  transition:all .35s;
  border:1px solid transparent;
}
.temo::before {
  content:'\201C';
  position:absolute; top:-20px; left:24px;
  font-family:'Cormorant Garamond',serif;
  font-size:180px; font-style:italic;
  color:var(--g); opacity:.06; line-height:1;
  pointer-events:none;
}
.temo:hover { border-color:var(--bdr); transform:translateY(-3px); }
.temo-stars { display:flex; gap:4px; margin-bottom:24px; }
.temo-star  { color:var(--g); font-size:13px; }
.temo-text  { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:17px; color:var(--w8); line-height:1.7; margin-bottom:32px; }
.temo-author { display:flex; align-items:center; gap:14px; }
.temo-av { width:44px; height:44px; border-radius:50%; background:var(--bdr); border:1px solid var(--bdr); display:flex; align-items:center; justify-content:center; font-family:'Bebas Neue',sans-serif; font-size:18px; color:var(--g); flex-shrink:0; }
.temo-name { font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--w); margin-bottom:2px; }
.temo-role { font-size:11px; color:var(--w2); }


/* ── FAQ ─────────────────────────────────────────────────── */
.faq-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:0; background:var(--bdr2); margin-top:56px; }
.faq-item { background:var(--blk2); border:1px solid transparent; transition:border-color .2s; }
.faq-item:hover { border-color:var(--bdr); }
.faq-item.open  { border-color:var(--bdr); }
.faq-q {
  display:flex; align-items:center; justify-content:space-between;
  padding:28px 32px; cursor:pointer; gap:20px;
}
.faq-q-text { font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--w); }
.faq-icon   { width:28px; height:28px; border:1px solid var(--bdr); border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:var(--g); transition:all .25s; }
.faq-item.open .faq-icon { background:var(--g); color:var(--blk); border-color:var(--g); transform:rotate(45deg); }
.faq-a { display:none; padding:0 32px 28px; font-family:'Cormorant Garamond',serif; font-size:15px; color:var(--w6); line-height:1.7; }
.faq-item.open .faq-a { display:block; }


/* ── CTA BAND ────────────────────────────────────────────── */
.cta-band { display:grid; grid-template-columns:1fr 400px; max-width:var(--max); margin:0 auto; }
.cta-content { padding:80px 72px; background:var(--blk3); }
.cta-tag  { font-size:9px; font-weight:700; letter-spacing:5px; text-transform:uppercase; color:var(--g); margin-bottom:20px; }
.cta-h    { font-family:'Bebas Neue',sans-serif; font-size:clamp(40px,4.5vw,62px); letter-spacing:2px; color:var(--w); line-height:.9; margin-bottom:20px; }
.cta-h em { font-family:'Cormorant Garamond',serif; font-style:italic; font-weight:300; color:var(--g); display:block; }
.cta-body { font-family:'Cormorant Garamond',serif; font-size:16px; font-weight:300; color:var(--w6); margin-bottom:36px; line-height:1.7; }
.cta-btns { display:flex; gap:14px; flex-wrap:wrap; }
.cta-img  { overflow:hidden; }
.cta-img img { width:100%; height:100%; object-fit:cover; filter:grayscale(1) brightness(.55); }


/* ── CLIENTS LOGOS ──────────────────────────────────────── */
.clients-section { background:var(--blk2); border-top:1px solid var(--bdr2); border-bottom:1px solid var(--bdr2); padding:52px 0; }
.clients-label { text-align:center; font-size:9px; font-weight:700; letter-spacing:5px; text-transform:uppercase; color:var(--w2); margin-bottom:40px; }
.clients-logos { display:flex; align-items:center; justify-content:center; gap:48px; flex-wrap:wrap; padding:0 64px; }
.client-logo { font-family:'Bebas Neue',sans-serif; font-size:18px; letter-spacing:3px; color:var(--w2); transition:color .2s; }
.client-logo:hover { color:var(--g); }


/* ── CONTACT ─────────────────────────────────────────────── */
.contact-grid { display:grid; grid-template-columns:1.2fr 1fr; gap:72px; max-width:var(--max); margin:0 auto; padding:0 64px; }
.contact-form-label { font-size:9px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--g); margin-bottom:32px; opacity:.8; }
.fi { margin-bottom:24px; }
.fi label { display:block; font-size:9px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--w4); margin-bottom:10px; }
.fi input,
.fi select,
.fi textarea {
  width:100%; background:transparent;
  border:none; border-bottom:1px solid var(--bdr2);
  color:var(--w); font-family:'Inter',sans-serif; font-size:13px;
  padding:10px 0; outline:none;
  transition:border-color .2s;
  -webkit-appearance:none; appearance:none;
}
.fi input:focus,
.fi select:focus,
.fi textarea:focus   { border-bottom-color:var(--g); }
.fi input::placeholder,
.fi textarea::placeholder { color:var(--w2); }
.fi textarea { min-height:100px; resize:vertical; }
.fi select option { background:#141414; }
.fi.error input,
.fi.error select,
.fi.error textarea { border-bottom-color:#c0392b; }
.fi-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }

.contact-info { padding-top:8px; }
.c-info-block { padding:20px 0; border-bottom:1px solid var(--bdr2); display:flex; align-items:flex-start; gap:16px; }
.c-info-ic { width:40px; height:40px; border:1px solid var(--bdr); display:flex; align-items:center; justify-content:center; color:var(--g); flex-shrink:0; }
.c-info-lbl { font-size:9px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--g); opacity:.8; margin-bottom:4px; }
.c-info-val { font-size:13px; color:var(--w6); }
.contact-promise { margin-top:36px; border:1px solid var(--bdr); padding:28px; background:var(--gdim2); }
.contact-promise-title { font-size:9px; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--g); margin-bottom:8px; }
.contact-promise-body { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:15px; color:var(--w6); line-height:1.7; }

#formSuccess { display:none; margin-top:16px; background:var(--gdim); border:1px solid var(--bdr); padding:16px 20px; }
#formSuccess p { font-size:13px; color:var(--g); }


/* ── EN-TÊTES DE PAGE INTÉRIEURE ────────────────────────── */
.page-hero {
  position:relative; height:420px;
  overflow:hidden; display:flex; align-items:flex-end;
  margin-top:var(--nav-h);
}
.page-hero img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.1) brightness(.35); }
.page-hero::after { content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(6,6,6,.98) 0%, rgba(6,6,6,.5) 50%, transparent 100%); }
.page-hero-content { position:relative; z-index:1; padding:0 64px 56px; }
