/*
Theme Name: By Kamal Films Cinema
Theme URI: https://bykamalfilms.com
Author: By Kamal Films
Author URI: https://bykamalfilms.com
Description: Theme cinematographique premium pour videaste de mariage a Lyon. Films pour les couples qui veulent revivre leur journee dans dix ou vingt ans. Lyon, Rhone-Alpes, Provence, Cote d'Azur, Paris, France entiere.
Version: 1.1.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bykamalfilms-cinema
Tags: dark, cinematic, premium, wedding, responsive
*/

:root{
  /* Palette: noir profond, ivoire, champagne, doré subtil */
  --bg: #0A0908;
  --bg-alt: #14130F;
  --bg-warm: #1A1815;
  --ink: #F5F0E5;
  --ink-soft: #C5BEB0;
  --ink-mute: #807A6F;
  --line: #1F1D19;
  --champagne: #C9A66B;
  --gold: #A88752;
  --gold-soft: #8B7045;
  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --serif: "Fraunces", "Times New Roman", serif;
  --sans: "Inter", system-ui, -apple-system, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  --wrap: 1440px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,video,iframe{display:block;max-width:100%;}

/* === CINEMATIC GRAIN — réutilisable sur toute image/visuel === */
.cinematic-grain{position:relative;isolation:isolate;overflow:hidden;}
.cinematic-grain::after{
  content:"";
  position:absolute;inset:0;
  pointer-events:none;
  z-index:5;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.4 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size:240px 240px;
  opacity:0.18;
  mix-blend-mode:overlay;
  animation:grainShift 6s steps(8) infinite;
}
@media (max-width:768px){
  .cinematic-grain::after{opacity:0.1;animation:none;}
}
@keyframes grainShift{
  0%,100%{transform:translate(0,0);}
  20%{transform:translate(-3%,2%);}
  40%{transform:translate(2%,-3%);}
  60%{transform:translate(-1%,1%);}
  80%{transform:translate(3%,-2%);}
}

/* === CURSOR === */
.cursor{
  position:fixed;width:18px;height:18px;
  border:1px solid var(--ink);border-radius:50%;
  pointer-events:none;z-index:10000;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease);
  mix-blend-mode:difference;
  top:0;left:0;
}
.cursor.hover{width:56px;height:56px;background:var(--ink);}
@media (hover:none){.cursor{display:none;}}

/* === NAV === */
.nav{
  position:fixed;top:24px;left:50%;transform:translateX(-50%);
  z-index:100;
  display:flex;align-items:center;gap:48px;
  padding:14px 24px 14px 28px;
  background:rgba(10,9,8,0.7);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--line);border-radius:999px;
  font-size:13px;
  transition:transform .4s var(--ease),background .4s var(--ease);
}
.nav.hidden{transform:translateX(-50%) translateY(-150%);}
.nav-logo{
  font-family:var(--serif);
  font-style:italic;font-weight:500;font-size:18px;
  letter-spacing:-0.02em;color:var(--ink);text-decoration:none;
}
.nav-logo sup{
  font-family:var(--mono);font-style:normal;font-size:9px;
  letter-spacing:.1em;color:var(--ink-mute);margin-left:4px;vertical-align:super;
}
.nav-links{display:flex;gap:28px;}
.nav-links a{color:var(--ink-soft);text-decoration:none;font-size:13px;transition:color .3s var(--ease);}
.nav-links a:hover{color:var(--champagne);}
.nav-cta{
  padding:9px 18px;background:var(--ink);color:var(--bg);
  border-radius:999px;font-weight:500;font-size:13px;
  text-decoration:none;transition:background .3s var(--ease),color .3s var(--ease);
}
.nav-cta:hover{background:var(--champagne);color:var(--bg);}
@media (max-width:900px){
  .nav{gap:0;padding:10px 14px 10px 18px;}
  .nav-links{display:none;}
}

/* === LAYOUT === */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 48px;}
section{position:relative;}
@media (max-width:768px){.wrap{padding:0 22px;}}

/* === HERO === */
.hero{
  min-height:100vh;
  min-height:100svh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:140px 48px 80px;
  position:relative;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;background:#000;z-index:0;overflow:hidden;}
.hero-bg video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:brightness(0.6) contrast(1.02);
  pointer-events:none;
}
/* Hide native iOS/Android video controls (play button overlay) */
.hero-bg video::-webkit-media-controls,
.hero-bg video::-webkit-media-controls-enclosure,
.hero-bg video::-webkit-media-controls-panel,
.hero-bg video::-webkit-media-controls-play-button,
.hero-bg video::-webkit-media-controls-start-playback-button,
.hero-bg video::-webkit-media-controls-overlay-play-button{
  display:none !important;
  -webkit-appearance:none !important;
  appearance:none !important;
  opacity:0 !important;
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(10,9,8,.45) 0%,rgba(10,9,8,.7) 55%,rgba(10,9,8,.98) 100%),
    rgba(10,9,8,.15);
  z-index:2;
}
.hero-content{position:relative;z-index:3;max-width:var(--wrap);margin:0 auto;width:100%;}
.hero-top{
  position:absolute;top:-100px;left:0;right:0;
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  color:var(--ink-soft);text-transform:uppercase;
}
.hero-top .left{display:flex;gap:32px;flex-wrap:wrap;}
.hero-top .right{text-align:right;}
.hero-top .clock{color:var(--champagne);}
.hero h1{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(44px,8vw,128px);
  line-height:0.98;
  letter-spacing:-0.035em;
  margin-bottom:32px;
  max-width:1100px;
}
.hero h1 em{
  font-style:italic;font-weight:300;color:var(--champagne);
}
.hero h1 .reveal-word{display:inline-block;opacity:0;transform:translateY(40px);animation:revealUp 1.2s var(--ease-out) forwards;}
@keyframes revealUp{to{opacity:1;transform:translateY(0);}}
.hero-meta{
  display:flex;justify-content:space-between;align-items:flex-end;
  flex-wrap:wrap;gap:32px;margin-top:24px;
}
.hero-sub{
  max-width:520px;
  font-size:clamp(15px,1.3vw,18px);line-height:1.55;
  color:var(--ink-soft);font-weight:300;
}
.hero-ctas{display:flex;gap:14px;align-items:center;flex-wrap:wrap;}
@media (max-width:768px){
  .hero{padding:120px 22px 60px;}
  .hero-top{position:relative;top:auto;margin-bottom:48px;flex-direction:column;gap:8px;}
  .hero-top .right{text-align:left;}
}

/* === BUTTONS === */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 28px;font-family:var(--sans);
  font-size:13px;font-weight:500;letter-spacing:.02em;
  border-radius:999px;text-decoration:none;
  transition:all .4s var(--ease);
  border:1px solid transparent;cursor:pointer;
}
.btn-primary{background:var(--ink);color:var(--bg);}
.btn-primary:hover{background:var(--champagne);}
.btn-ghost{background:transparent;color:var(--ink);border-color:rgba(245,240,229,.25);}
.btn-ghost:hover{border-color:var(--ink);background:rgba(245,240,229,.04);}
.btn .arrow{display:inline-block;width:14px;height:14px;position:relative;}
.btn .arrow::after{
  content:"→";position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  transition:transform .4s var(--ease);
}
.btn:hover .arrow::after{transform:translateX(4px);}

.scroll-indicator{
  position:absolute;bottom:36px;right:48px;z-index:4;
  font-family:var(--mono);font-size:10px;letter-spacing:.25em;
  color:var(--ink-mute);text-transform:uppercase;
  display:flex;align-items:center;gap:12px;
}
.scroll-indicator .line{
  display:inline-block;width:1px;height:36px;background:var(--ink-mute);
  animation:scrollLine 2.4s var(--ease) infinite;transform-origin:top;
}
@keyframes scrollLine{
  0%{transform:scaleY(0);transform-origin:top;}
  50%{transform:scaleY(1);transform-origin:top;}
  51%{transform-origin:bottom;}
  100%{transform:scaleY(0);transform-origin:bottom;}
}
@media (max-width:768px){.scroll-indicator{display:none;}}

/* === EYEBROW === */
.eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--champagne);
  margin-bottom:32px;display:flex;align-items:center;gap:14px;
}
.eyebrow::after{content:"";flex:1;height:1px;background:var(--line);max-width:240px;}

/* === SECTION TITLES === */
.section{padding:140px 48px;}
.section-title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,3.6vw,56px);line-height:1.08;
  letter-spacing:-0.025em;
  max-width:900px;
}
.section-title em{font-style:italic;color:var(--champagne);}
.section-lead{
  font-size:clamp(16px,1.5vw,19px);line-height:1.6;
  color:var(--ink-soft);font-weight:300;max-width:680px;margin-top:32px;
}
@media (max-width:768px){.section{padding:80px 22px;}}

/* === MANIFESTE === */
.manifeste{padding:140px 48px;text-align:center;}
.manifeste-inner{max-width:780px;margin:0 auto;}
.manifeste .eyebrow{justify-content:center;}
.manifeste .eyebrow::after{content:none;}
.manifeste-intro{
  font-family:var(--sans);font-weight:300;
  font-size:15px;line-height:1.85;
  color:var(--ink-mute);max-width:600px;
  margin:0 auto 56px;letter-spacing:.005em;
}
.manifeste-intro .nowrap-line{white-space:nowrap;}
@media (max-width:640px){
  .manifeste-intro .nowrap-line{white-space:normal;}
}
.manifeste-quote{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(28px,4vw,56px);line-height:1.1;
  letter-spacing:-0.025em;color:var(--ink);
}
.manifeste-quote em{color:var(--champagne);font-style:italic;}
.manifeste-close{
  margin-top:56px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  color:var(--champagne);text-transform:uppercase;
}
@media (max-width:768px){.manifeste{padding:80px 22px;}}

/* === APPROCHE === */
.approche{
  padding:120px 48px;
  background:var(--bg-alt);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.approche-inner{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;}
.approche-text h2,
.approche-text .section-title{
  font-size:clamp(24px,2.8vw,42px);line-height:1.15;letter-spacing:-0.02em;
  margin-bottom:28px;
}
.approche-text p{font-size:15px;line-height:1.7;color:var(--ink-soft);font-weight:300;}
.approche-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0;}
.approche-item{
  padding:28px 0;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:8px;
}
.approche-item .num{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--champagne);text-transform:uppercase;
}
.approche-item h3{
  font-family:var(--serif);font-weight:300;font-size:22px;line-height:1.2;letter-spacing:-0.01em;
}
.approche-item p{font-size:14px;color:var(--ink-mute);line-height:1.5;font-weight:300;margin-top:4px;}
@media (max-width:900px){
  .approche-inner{grid-template-columns:1fr;gap:48px;}
  .approche-list{grid-template-columns:1fr;}
}

/* === KAMAL / RÉALISATEUR — photo à gauche, texte à droite === */
.kamal{padding:80px 48px;border-bottom:1px solid var(--line);}
.kamal-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:240px 1fr;gap:64px;align-items:start;
}
.kamal-portrait{
  position:relative;
  width:240px;height:240px;
  border-radius:50%;
  overflow:hidden;
  background:var(--bg-warm);
  justify-self:start;
  position:sticky;top:120px;
}
.kamal-portrait img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.15) contrast(1.02);
  transition:filter 1.2s var(--ease-out),transform 1.2s var(--ease-out);
}
.kamal-portrait:hover img{filter:grayscale(0);transform:scale(1.05);}
.kamal-portrait-label{display:none;}
.kamal-text .eyebrow{margin-bottom:18px;}
.kamal-text h2,
.kamal-text .section-title{
  font-size:clamp(22px,2.2vw,32px);line-height:1.2;letter-spacing:-0.02em;
  margin-bottom:24px;
}
.kamal-text p{
  font-size:14px;line-height:1.7;color:var(--ink-soft);
  font-weight:300;max-width:580px;margin-bottom:12px;
}
.kamal-text p strong{color:var(--ink);font-weight:400;}
.kamal-punch{
  margin-top:24px;padding-top:20px;
  border-top:1px solid var(--line);
  font-family:var(--serif);font-weight:300;
  font-size:clamp(15px,1.4vw,20px);line-height:1.4;
  color:var(--ink);letter-spacing:-0.01em;
  max-width:560px;
}
.kamal-punch em{color:var(--champagne);font-style:italic;}
.kamal-signature{
  margin-top:18px;font-family:var(--serif);font-style:italic;
  font-size:20px;color:var(--champagne);letter-spacing:-0.015em;
}
@media (max-width:900px){
  .kamal{padding:60px 22px;}
  .kamal-inner{grid-template-columns:1fr;gap:32px;text-align:center;}
  .kamal-portrait{width:160px;height:160px;justify-self:center;position:static;}
  .kamal-text p,.kamal-punch{margin-left:auto;margin-right:auto;}
}

/* === SHOWREEL === */
.showreel{padding:80px 48px;}
.showreel-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  max-width:var(--wrap);margin:0 auto 32px;flex-wrap:wrap;gap:24px;
}
.showreel-head h3{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(28px,3.5vw,48px);line-height:1;letter-spacing:-0.02em;
}
.showreel-head .meta{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-mute);text-align:right;
}
.showreel-frame{
  position:relative;max-width:var(--wrap);margin:0 auto;
  aspect-ratio:16/9;background:#000;border-radius:4px;overflow:hidden;
}
.showreel-iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:2;}
.showreel-corner{position:absolute;width:24px;height:24px;border:1px solid var(--champagne);z-index:3;pointer-events:none;}
.showreel-corner.tl{top:16px;left:16px;border-right:none;border-bottom:none;}
.showreel-corner.tr{top:16px;right:16px;border-left:none;border-bottom:none;}
.showreel-corner.bl{bottom:16px;left:16px;border-right:none;border-top:none;}
.showreel-corner.br{bottom:16px;right:16px;border-left:none;border-top:none;}
@media (max-width:768px){.showreel{padding:40px 22px;}}

/* === POURQUOI NOUS — 3 piliers éditoriaux === */
.why{padding:120px 48px;border-top:1px solid var(--line);}
.why-inner{max-width:var(--wrap);margin:0 auto;}
.why-head{margin-bottom:80px;}
.why-head .section-title{
  font-size:clamp(24px,2.8vw,42px);line-height:1.15;letter-spacing:-0.02em;
}
.why-pillar{
  display:grid;grid-template-columns:1fr 1.4fr;gap:96px;
  padding:56px 0;border-top:1px solid var(--line);
  align-items:start;
}
.why-pillar:last-of-type{border-bottom:1px solid var(--line);}
.why-pillar.reverse{grid-template-columns:1.4fr 1fr;}
.why-pillar.reverse .why-pillar-content{order:2;}
.why-pillar.reverse .why-pillar-label{order:1;}
.why-pillar-label{padding-top:6px;}
.why-pillar-label .marker{
  font-family:var(--mono);font-size:11px;letter-spacing:.25em;
  color:var(--champagne);text-transform:uppercase;display:block;margin-bottom:12px;
}
.why-pillar-label h3{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(24px,2.8vw,38px);line-height:1.1;letter-spacing:-0.025em;color:var(--ink);
}
.why-pillar-content p{
  font-size:15px;line-height:1.65;
  color:var(--ink-soft);font-weight:300;max-width:540px;
}
.why-pillar-content p + p{margin-top:14px;}
@media (max-width:900px){
  .why{padding:80px 22px;}
  .why-pillar,.why-pillar.reverse{grid-template-columns:1fr;gap:24px;padding:48px 0;}
  .why-pillar.reverse .why-pillar-content{order:initial;}
  .why-pillar.reverse .why-pillar-label{order:initial;}
}

/* === GALERIE — wide / full-bleed === */
.galerie{padding:140px 0;border-top:1px solid var(--line);}
.galerie-inner{margin:0;}
.galerie-head{
  margin:0 auto 80px;max-width:var(--wrap);
  padding:0 48px;
}
.galerie-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  grid-auto-flow:dense;
  width:100%;
}
.g-cell{
  position:relative;overflow:hidden;
  background:var(--bg-alt);
  isolation:isolate;
}
.g-cell img{
  width:100%;height:100%;display:block;
  object-fit:cover;
  filter:grayscale(.05) contrast(1.02);
  transition:transform 1.4s var(--ease-out),filter 1.4s var(--ease-out);
}
.g-cell:hover img{transform:scale(1.04);filter:grayscale(0);}
.g-cell.p{aspect-ratio:4/5;}
.g-cell.l{grid-column:span 2;aspect-ratio:8/5;}
.g-cell.tall{aspect-ratio:9/16;}
@media (max-width:1200px){
  .galerie-grid{grid-template-columns:repeat(3,1fr);}
  .g-cell.l{grid-column:span 2;}
}
@media (max-width:768px){
  .galerie-grid{grid-template-columns:repeat(2,1fr);}
  .g-cell.l{grid-column:span 2;}
  .g-cell.tall{aspect-ratio:4/5;}
}

/* === FORFAITS === */
.forfaits{padding:160px 48px;background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.forfaits-inner{max-width:var(--wrap);margin:0 auto;}
.forfaits-head{margin-bottom:80px;text-align:center;}
.forfaits-head .eyebrow{justify-content:center;}
.forfaits-head .eyebrow::after,.forfaits-head .eyebrow::before{content:"";flex:1;height:1px;background:var(--line);max-width:120px;}
.forfaits-head h2{margin:0 auto;}
.forfaits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.tarif{
  padding:48px 36px;border:1px solid var(--line);border-radius:6px;
  background:var(--bg);display:flex;flex-direction:column;gap:32px;
  position:relative;transition:border-color .4s var(--ease),transform .4s var(--ease);
}
.tarif:hover{border-color:var(--gold-soft);transform:translateY(-4px);}
.tarif.featured{border-color:var(--champagne);background:var(--bg-warm);}
.tarif.featured::before{
  content:"RECOMMANDÉ";
  position:absolute;top:-11px;left:36px;
  padding:4px 14px;background:var(--champagne);color:var(--bg);
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;border-radius:999px;
}
.tarif-name{
  font-family:var(--mono);font-size:11px;letter-spacing:.25em;
  text-transform:uppercase;color:var(--champagne);
}
.tarif-tagline{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:18px;line-height:1.4;color:var(--ink-soft);
  margin-top:12px;
}
.tarif-price{
  font-family:var(--serif);font-weight:300;font-size:56px;
  line-height:1;letter-spacing:-0.03em;color:var(--ink);
}
.tarif-price .from{
  display:block;font-family:var(--mono);font-size:11px;
  letter-spacing:.15em;color:var(--ink-mute);
  text-transform:uppercase;margin-bottom:8px;
}
.tarif-price .currency{font-size:28px;color:var(--ink-soft);margin-left:4px;}
.tarif-features{list-style:none;padding:0;display:flex;flex-direction:column;gap:12px;flex:1;}
.tarif-features li{
  font-size:14px;line-height:1.55;color:var(--ink-soft);
  padding-left:22px;position:relative;font-weight:300;
}
.tarif-features li::before{
  content:"";position:absolute;left:0;top:10px;
  width:8px;height:1px;background:var(--champagne);
}
.tarif-cta{
  margin-top:auto;padding:16px 0;text-align:center;
  border:1px solid var(--line);border-radius:999px;
  font-size:13px;font-weight:500;color:var(--ink);
  text-decoration:none;transition:all .3s var(--ease);
}
.tarif.featured .tarif-cta{background:var(--champagne);color:var(--bg);border-color:var(--champagne);}
.tarif.featured .tarif-cta:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.tarif-cta:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.forfaits-note{
  margin-top:48px;text-align:center;
  font-family:var(--mono);font-size:11px;letter-spacing:.15em;
  color:var(--ink-mute);text-transform:uppercase;
}
@media (max-width:900px){.forfaits-grid{grid-template-columns:1fr;}}

/* === RARETÉ === */
.rarete{padding:160px 48px;text-align:center;}
.rarete-inner{max-width:780px;margin:0 auto;}
.rarete .eyebrow{justify-content:center;}
.rarete .eyebrow::after{content:none;}
.rarete h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(36px,5vw,72px);line-height:1.1;
  letter-spacing:-0.03em;margin-bottom:32px;
}
.rarete h2 em{font-style:italic;color:var(--champagne);}
.rarete p{font-size:17px;line-height:1.7;color:var(--ink-soft);font-weight:300;}
.rarete-number{
  margin-top:64px;font-family:var(--serif);font-weight:300;
  font-size:clamp(80px,12vw,180px);line-height:1;
  letter-spacing:-0.05em;color:var(--champagne);
}
.rarete-number small{
  display:block;font-family:var(--mono);font-size:11px;
  letter-spacing:.2em;color:var(--ink-mute);text-transform:uppercase;margin-top:16px;
}

/* === EXPÉRIENCE === */
.experience{padding:80px 48px;background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
@media (max-width:768px){.experience{padding:60px 22px;}}
.experience-inner{max-width:var(--wrap);margin:0 auto;}
.experience-head{margin-bottom:40px;}
.experience-head .section-title{
  font-size:clamp(22px,2.6vw,40px);line-height:1.15;letter-spacing:-0.02em;
}
.experience-steps{display:grid;}
.step{
  display:grid;grid-template-columns:100px 1fr 1.2fr;gap:24px;
  padding:9px 0;border-top:1px solid var(--line);align-items:start;
  transition:background .4s var(--ease);
}
.step:hover{background:rgba(201,166,107,.04);}
.step:last-child{border-bottom:1px solid var(--line);}
.step-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.15em;
  color:var(--champagne);text-transform:uppercase;
  padding-top:2px;
}
.step h3{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(15px,1.5vw,19px);line-height:1.15;letter-spacing:-0.015em;
}
.step h3 em{font-style:italic;color:var(--champagne);}
.step p{font-size:13px;line-height:1.45;color:var(--ink-soft);font-weight:300;margin:0;}
@media (max-width:900px){.step{grid-template-columns:1fr;gap:16px;padding:32px 0;}}

/* === DESTINATION === */
.destination{padding:160px 48px;position:relative;overflow:hidden;}
.destination::before{
  content:"";position:absolute;
  top:0;right:0;width:50%;height:100%;
  background:radial-gradient(circle at 30% 50%,rgba(201,166,107,.06),transparent 60%);
  pointer-events:none;
}
.destination-inner{max-width:var(--wrap);margin:0 auto;position:relative;z-index:2;}
.destination-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:96px;align-items:center;}
.destination-text h2{margin-bottom:32px;}
.destination-text p{font-size:17px;line-height:1.7;color:var(--ink-soft);font-weight:300;margin-bottom:24px;}
.destination-locations{
  display:flex;flex-wrap:wrap;gap:0;margin-top:40px;
  list-style:none;
}
.destination-locations li{
  padding:14px o;border-bottom:1px solid var(--line);
  display:flex;align-items:baseline;gap:14px;width:100%;
  font-family:var(--mono);font-size:13px;letter-spacing:.05em;
}
.destination-locations li .num{color:var(--champagne);font-size:11px;}
.destination-locations li .name{color:var(--ink);}
.destination-locations li .area{color:var(--ink-mute);margin-left:auto;font-size:11px;letter-spacing:.15em;text-transform:uppercase;}
.destination-visual{
  position:relative;aspect-ratio:4/5;border-radius:4px;overflow:hidden;
  isolation:isolate;background:var(--bg-warm);
}
.destination-visual img{width:100%;height:100%;object-fit:cover;}
.destination-corner{position:absolute;width:24px;height:24px;border:1px solid var(--champagne);z-index:6;}
.destination-corner.tl{top:16px;left:16px;border-right:none;border-bottom:none;}
.destination-corner.br{bottom:16px;right:16px;border-left:none;border-top:none;}
@media (max-width:900px){.destination-grid{grid-template-columns:1fr;gap:64px;}}

/* === EMOTION / TRANSMISSION === */
.emotion{
  padding:200px 48px;text-align:center;
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-warm) 50%,var(--bg) 100%);
}
.emotion-inner{max-width:900px;margin:0 auto;}
.emotion h2{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(40px,7vw,120px);line-height:1;letter-spacing:-0.04em;
}
.emotion h2 em{color:var(--champagne);}
.emotion p{
  margin-top:48px;font-size:18px;line-height:1.7;
  color:var(--ink-soft);font-weight:300;max-width:600px;margin-left:auto;margin-right:auto;
}

/* === AFRO / MULTICULTUREL === */
.multiculturel{padding:140px 48px;border-top:1px solid var(--line);}
.multi-inner{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:96px;align-items:center;}
.multi-visual{
  position:relative;aspect-ratio:1/1;border-radius:4px;overflow:hidden;
  isolation:isolate;background:var(--bg-warm);
}
.multi-visual img{width:100%;height:100%;object-fit:cover;}
.multi-text h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(32px,4.5vw,60px);line-height:1.05;letter-spacing:-0.025em;
  margin-bottom:32px;
}
.multi-text h2 em{font-style:italic;color:var(--champagne);}
.multi-text p{font-size:17px;line-height:1.7;color:var(--ink-soft);font-weight:300;margin-bottom:20px;}
@media (max-width:900px){.multi-inner{grid-template-columns:1fr;gap:48px;}}

/* === FAQ === */
.faq{padding:140px 48px;max-width:960px;margin:0 auto;}
.faq-head{margin-bottom:56px;}
.faq-head .section-title{
  font-size:clamp(24px,2.8vw,42px);line-height:1.15;letter-spacing:-0.02em;
}
.faq-item{border-top:1px solid var(--line);padding:22px 0;cursor:pointer;}
.faq-item:last-child{border-bottom:1px solid var(--line);}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--serif);font-weight:300;
  font-size:clamp(16px,1.5vw,20px);line-height:1.3;letter-spacing:-0.01em;
  transition:color .3s var(--ease);
}
.faq-item:hover .faq-q{color:var(--champagne);}
.faq-q .plus{
  font-family:var(--mono);font-size:18px;color:var(--champagne);
  transition:transform .4s var(--ease);flex-shrink:0;
}
.faq-item.open .faq-q .plus{transform:rotate(45deg);}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .5s var(--ease),padding .5s var(--ease).opacity .5s var(--ease);
  font-size:15px;line-height:1.65;color:var(--ink-soft);font-weight:300;
  max-width:780px;opacity:.7;
}
.faq-item.open .faq-a{max-height:500px;padding-top:14px;opacity:1;}
@media (max-width:768px){.faq{padding:80px 22px;}}

/* === CTA FINAL === */
.cta-final{
  padding:160px 48px;text-align:center;
  background:var(--bg-warm);
  border-top:1px solid var(--line);
  position:relative;overflow:hidden;
}
.cta-final::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 100%,rgba(201,166,107,.1),transparent 60%);
  pointer-events:none;
}
.cta-final-inner{position:relative;z-index:2;max-width:1100px;margin:0 auto;}
.cta-final .eyebrow{justify-content:center;color:var(--champagne);}
.cta-final .eyebrow::after,.cta-final .eyebrow::before{content:"";flex:1;height:1px;background:var(--line);max-width:120px;}
.cta-final h2{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(44px,7vw,118px);line-height:0.98;letter-spacing:-0.04em;
  margin-bottom:32px;
}
.cta-final p{
  font-size:17px;line-height:1.6;color:var(--ink-soft);font-weight:300;
  max-width:580px;margin:0 auto 48px;
}

/* === FORM === */
.contact-form{
  max-width:680px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
  text-align:left;
}
.contact-form .full{grid-column:span 2;}
.field{display:flex;flex-direction:column;gap:8px;}
.field label{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  color:var(--ink-mute);text-transform:uppercase;
}
.field input,.field select,.field textarea{
  background:transparent;border:none;border-bottom:1px solid var(--line);
  padding:12px 0;color:var(--ink);font-family:var(--sans);font-size:15px;
  transition:border-color .3s var(--ease);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-bottom-color:var(--champagne);
}
.field textarea{resize:vertical;min-height:96px;}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%23C9A66B' fill='none'/></svg>");background-repeat:no-repeat;background-position:right 0 center;padding-right:24px;}
.form-submit{
  grid-column:span 2;margin-top:16px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
}
.form-microcopy{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-mute);text-transform:uppercase;}
@media (max-width:640px){.contact-form{grid-template-columns:1fr;}.contact-form .full{grid-column:span 1;}.form-submit{grid-column:span 1;}}

/* === FOOTER === */
.footer{padding:80px 48px 40px;border-top:1px solid var(--line);}
.footer-inner{max-width:var(--wrap);margin:0 auto;}
.footer-mark{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(64px,14vw,220px);line-height:.85;
  letter-spacing:-0.05em;color:var(--ink);margin-bottom:64px;
}
.footer-mark sup{
  font-family:var(--mono);font-style:normal;font-size:14px;
  letter-spacing:.1em;color:var(--champagne);vertical-align:super;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid var(--line);
}
.footer-col h4{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-mute);
  margin-bottom:20px;font-weight:500;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-col a{color:var(--ink-soft);text-decoration:none;font-size:14px;transition:color .3s var(--ease);}
.footer-col a:hover{color:var(--champagne);}
.footer-col p{font-size:14px;line-height:1.65;color:var(--ink-soft);max-width:320px;font-weight:300;}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:32px;flex-wrap:wrap;gap:16px;
  font-family:var(--mono);font-size:11px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--ink-mute);
}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:600px){.footer-grid{grid-template-columns:1fr;}.footer{padding:60px 22px 30px;}}

/* === RESPONSIVE FINAL — mobile audit === */
@media (max-width:768px){
  .hero{padding:100px 22px 60px;min-height:88vh;min-height:88svh;}
  .hero h1{font-size:clamp(34px,10vw,68px);line-height:1.0;margin-bottom:24px;}
  .hero-sub{font-size:15px;}
  .hero-ctas{width:100%;}
  .hero-ctas .btn{flex:1;justify-content:center;text-align:center;padding:16px 18px;font-size:13px;}
  .btn{padding:16px 22px;}
  .nav{top:14px;padding:8px 12px 8px 16px;gap:8px;}
  .nav-logo{font-size:15px;}
  .nav-logo sup{display:none;}
  .nav-cta{padding:8px 14px;font-size:12px;}
  .eyebrow{font-size:10px;letter-spacing:.18em;margin-bottom:22px;}
  .section,.approche,.kamal,.why,.galerie,.forfaits,.rarete,.experience,.destination,.emotion,.multiculturel,.faq,.cta-final{padding-left:22px;padding-right:22px;}
  .manifeste{padding:60px 22px;}
  .manifeste-intro{font-size:14px;line-height:1.7;margin-bottom:40px;}
  .manifeste-quote{font-size:clamp(22px,6vw,34px);}
  .approche,.experience,.forfaits,.cta-final{padding-top:60px;padding-bottom:60px;}
  .kamal{padding-top:50px;padding-bottom:50px;}
  .why{padding-top:60px;padding-bottom:60px;}
  .why-head{margin-bottom:40px;}
  .why-pillar{gap:16px !important;padding:32px 0 !important;}
  .why-pillar-label h3{font-size:clamp(22px,7vw,32px);}
  .galerie{padding-top:60px;padding-bottom:60px;}
  .galerie-head{padding:0 22px;margin-bottom:40px;}
  .rarete{padding-top:80px;padding-bottom:80px;}
  .rarete-number{font-size:clamp(72px,22vw,110px);margin-top:40px;}
  .tarif{padding:32px 24px;gap:24px;}
  .tarif-price{font-size:42px;}
  .destination{padding-top:60px;padding-bottom:60px;}
  .destination-grid{gap:40px;}
  .multiculturel{padding-top:60px;padding-bottom:60px;}
  .multi-inner{gap:32px;}
  .emotion{padding:100px 22px;}
  .emotion p{font-size:15px;margin-top:32px;}
  .cta-final h2{margin-bottom:24px;}
  .cta-final p{font-size:15px;margin-bottom:32px;}
  .cta-final-meta{flex-direction:column;gap:8px;margin-top:32px;font-size:10px;}
  .footer{padding:48px 22px 28px;}
  .footer-mark{font-size:clamp(56px,18vw,120px);margin-bottom:40px;}
  .footer-bottom{font-size:10px;}
  .scroll-indicator{display:none;}
  .hero-top{position:relative;top:auto;left:auto;right:auto;margin-bottom:32px;font-size:10px;letter-spacing:.15em;}
  .hero-top .right{text-align:left;}
  .hero-top .left{gap:14px;flex-wrap:wrap;}
  .form-microcopy{font-size:10px;}
}
@media (max-width:480px){
  .hero h1{font-size:clamp(30px,11vw,54px);}
  .hero-ctas{flex-direction:column;align-items:stretch;}
  .hero-ctas .btn{width:100%;}
  .manifeste-quote{font-size:clamp(20px,6.5vw,30px);}
  .nav{gap:6px;}
  .nav-cta{padding:7px 12px;font-size:11px;}
  .tarif-features li{font-size:13px;}
}
/* iOS safe area */
@supports (padding:env(safe-area-inset-bottom)){
  body{padding-bottom:env(safe-area-inset-bottom);}
}
/* No horizontal overflow guard */
html,body{overflow-x:hidden;max-width:100vw;}

/* === REVEAL === */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out);}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal.delay-1{transition-delay:.1s;}
.reveal.delay-2{transition-delay:.2s;}
.reveal.delay-3{transition-delay:.3s;}
.reveal.delay-4{transition-delay:.4s;}
