/* =========================================================================
   MOTION TOON STUDIO — style.css
   Dark cinematic · inspired by Fabrica (minimal, numbered sections, XL type)
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap');

/* ---------- RESET / BASE --------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--bg);
  color:var(--fg);
  line-height:1.6;
  overflow-x:hidden;
  font-weight:400;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ---------- TOKENS / PALETTE ----------------------------------------- */
:root{
  --bg:#0a0a0a;
  --bg-2:#121212;
  --bg-3:#1a1a1a;
  --fg:#f1ede4;
  --fg-muted:#8a8680;
  --fg-dim:#54514c;
  --accent:#D4A34F;        /* Or chaud / anime */
  --accent-2:#FF6B35;      /* Orange brûlé */
  --accent-soft:rgba(212,163,79,.12);
  --line:rgba(241,237,228,.08);
  --line-strong:rgba(241,237,228,.18);
  --radius:4px;
  --max-w:1400px;
  --ease:cubic-bezier(.22,1,.36,1);
  --dur:.6s;
}

/* ---------- TYPOGRAPHIE ---------------------------------------------- */
.display{
  font-family:'Bebas Neue',Impact,sans-serif;
  font-weight:400;
  letter-spacing:.02em;
  line-height:.92;
  text-transform:uppercase;
}
.serif{font-family:'Playfair Display',serif;font-style:italic;font-weight:400}

h1,h2,h3{font-weight:600;letter-spacing:-.01em;line-height:1.1}

.hero-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(64px,13vw,220px);
  line-height:.88;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.section-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(40px,7vw,100px);
  line-height:.95;
  text-transform:uppercase;
  letter-spacing:.015em;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:.25em;text-transform:uppercase;
  color:var(--fg-muted);font-weight:500;
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--accent)}
.lead{font-size:clamp(16px,1.4vw,19px);color:var(--fg-muted);max-width:60ch}

/* ---------- LAYOUT --------------------------------------------------- */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 32px}
@media (max-width:640px){.container{padding:0 20px}}
section{position:relative;padding:clamp(80px,12vw,160px) 0}

/* ---------- NAV ------------------------------------------------------ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:20px 32px;
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(180deg,rgba(10,10,10,.7),rgba(10,10,10,0));
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  transition:background var(--dur) var(--ease),padding var(--dur) var(--ease);
}
.nav.scrolled{background:rgba(10,10,10,.88);padding:14px 32px;border-bottom:1px solid var(--line)}
.nav-logo{display:flex;align-items:center;gap:12px;font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.1em}
.nav-logo img{height:40px;width:auto}
.nav-logo span{opacity:0;transform:translateX(-6px);transition:all var(--dur) var(--ease)}
.nav.scrolled .nav-logo span{opacity:1;transform:translateX(0)}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:13px;letter-spacing:.05em;color:var(--fg-muted);position:relative;padding:6px 0;transition:color .3s var(--ease)}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--fg)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{
  padding:14px 30px;
  background:var(--accent);color:var(--bg)!important;
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;
  border-radius:100px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease);
  box-shadow:0 6px 28px rgba(212,163,79,.55),0 0 0 0 rgba(212,163,79,.4);
  position:relative;
  display:inline-flex;align-items:center;gap:10px;
  animation:ctaGlow 2.5s ease-in-out infinite;
}
@keyframes ctaGlow{
  0%,100%{box-shadow:0 6px 28px rgba(212,163,79,.55),0 0 0 0 rgba(212,163,79,.5)}
  50%{box-shadow:0 6px 28px rgba(212,163,79,.65),0 0 0 10px rgba(212,163,79,0)}
}
.nav-cta::after{content:"→";font-weight:400;transition:transform .3s var(--ease)}
.nav-cta:hover{
  background:var(--fg);color:var(--bg)!important;
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(241,237,228,.25);
}
.nav-cta:hover::after{transform:translateX(3px)}
.nav-toggle{display:none;width:32px;height:32px;position:relative}
.nav-toggle span{position:absolute;left:4px;right:4px;height:1.5px;background:var(--fg);transition:.3s var(--ease)}
.nav-toggle span:nth-child(1){top:11px}
.nav-toggle span:nth-child(2){top:19px}
.nav-toggle.open span:nth-child(1){top:15px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){top:15px;transform:rotate(-45deg)}

@media (max-width:960px){
  .nav{padding:14px 20px}
  .nav.scrolled{padding:10px 20px}
  .nav-logo img{height:34px}
  .nav-logo span{display:none}
  .nav-toggle{display:block;position:relative;z-index:1001}
  .nav-toggle span{background:var(--fg)}
  .nav.has-open .nav-toggle span{background:var(--fg)}

  .nav-links{
    position:fixed !important;
    top:0;left:0;right:0;bottom:0;
    width:100vw;
    height:100vh;
    height:100dvh;
    flex-direction:column;
    justify-content:flex-start;
    align-items:center;
    background:#050505;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:opacity .35s var(--ease), visibility 0s linear .35s;
    gap:18px;
    padding:96px 24px 40px;
    overflow-y:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
    z-index:1000;
  }
  .nav-links.open{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transition:opacity .35s var(--ease), visibility 0s;
  }
  .nav-links a{
    font-size:22px;
    letter-spacing:.03em;
    padding:10px 0;
    color:var(--fg);
    width:100%;
    text-align:center;
  }
  .nav-links a::after{display:none}
  .nav-links a.active{color:var(--accent)}
  .nav-links .lang-switcher{margin:16px 0 8px}
  .nav-links .nav-cta{
    display:inline-block !important;
    margin-top:12px;
    padding:16px 40px;
    font-size:13px;
    background:var(--accent);
    color:var(--bg) !important;
    border:none;
    width:auto;
  }

  /* Lock body scroll when menu open */
  body.menu-open{overflow:hidden;height:100vh}
}

@media (max-width:480px){
  .nav{padding:12px 16px}
  .nav-logo img{height:28px}
  .nav-links{padding:84px 20px 32px;gap:14px}
  .nav-links a{font-size:19px;padding:8px 0}
  .nav-links .nav-cta{padding:14px 32px;font-size:12px}
}

/* Very short screens — reduce gap more */
@media (max-width:960px) and (max-height:700px){
  .nav-links{padding:80px 24px 24px;gap:10px}
  .nav-links a{font-size:18px;padding:6px 0}
}

/* ---------- LANG SWITCHER MOBILE CLONE ------------------------------ */
/* Clone visible sur mobile uniquement, placé directement dans la nav */
.lang-switcher.mobile-clone{display:none}
@media (max-width:960px){
  .lang-switcher.mobile-clone{
    display:inline-flex !important;
    padding:3px;
    margin-right:8px;
    z-index:1002;
    flex-shrink:0;
  }
  .lang-switcher.mobile-clone button{
    padding:5px 8px;
    font-size:10px;
    min-width:28px;
    letter-spacing:.08em;
  }
}
@media (max-width:480px){
  .lang-switcher.mobile-clone{margin-right:6px}
  /* Hide disabled langs on very small screens to save room */
  .lang-switcher.mobile-clone button:disabled{display:none}
}

/* ---------- LANG SWITCHER ------------------------------------------- */
.lang-switcher{
  display:inline-flex;align-items:center;gap:2px;
  padding:4px;border:1px solid var(--line-strong);border-radius:100px;
  position:relative;isolation:isolate;
  background:var(--bg-2);
}
.lang-indicator{
  position:absolute;top:4px;left:4px;height:calc(100% - 8px);
  background:var(--accent);border-radius:100px;z-index:0;
  transition:transform .45s cubic-bezier(.22,1,.36,1),width .45s cubic-bezier(.22,1,.36,1);
  pointer-events:none;
  box-shadow:0 2px 12px rgba(212,163,79,.35);
}
.lang-switcher button{
  position:relative;z-index:1;
  padding:7px 12px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--fg-muted);font-weight:600;
  transition:color .3s var(--ease);min-width:38px;
  border-radius:100px;
}
.lang-switcher button.active{color:var(--bg)}
.lang-switcher button:hover:not(.active):not(:disabled){color:var(--fg)}
.lang-switcher button:disabled{opacity:.35;cursor:not-allowed;position:relative}
.lang-switcher button:disabled::after{
  content:"bientôt";position:absolute;top:-32px;left:50%;transform:translateX(-50%) translateY(4px);
  font-size:9px;letter-spacing:.12em;background:var(--bg-3);color:var(--fg);
  padding:5px 9px;border-radius:3px;white-space:nowrap;text-transform:lowercase;
  opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;
  border:1px solid var(--line-strong);
}
.lang-switcher button:disabled:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- HERO ----------------------------------------------------- */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding-bottom:80px;padding-top:140px;
  overflow:hidden;position:relative;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 50% 30%,transparent 0%,var(--bg) 85%),
    linear-gradient(180deg,rgba(10,10,10,.2),rgba(10,10,10,.9));
  z-index:1;
}
.hero-bg video,.hero-bg iframe,.hero-bg img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:.55;
}
.hero-bg iframe{border:none;pointer-events:none;transform:scale(1.2)}
.hero-content{position:relative;z-index:2;max-width:1200px}
.hero-meta{display:flex;gap:40px;margin-top:40px;padding-top:24px;border-top:1px solid var(--line);align-items:center;flex-wrap:wrap}
.hero-meta-item{display:flex;flex-direction:column;gap:4px}
.hero-meta-item .k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-dim)}
.hero-meta-item .v{font-size:14px;color:var(--fg)}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:.3em;color:var(--fg-muted);display:flex;flex-direction:column;align-items:center;gap:12px;z-index:3}
.hero-scroll::after{content:"";width:1px;height:32px;background:var(--accent);animation:scrollDown 2s var(--ease) infinite}
@keyframes scrollDown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.01%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- BUTTONS -------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:17px 32px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  font-weight:600;border-radius:2px;
  transition:transform .35s var(--ease),background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
  position:relative;overflow:hidden;
  cursor:pointer;isolation:isolate;
  white-space:nowrap;
}
.btn::after{
  content:"→";display:inline-block;font-size:16px;line-height:1;
  transition:transform .35s var(--ease);
  font-weight:400;
}
.btn[data-noarrow]::after{content:""}
.btn:hover::after{transform:translateX(5px)}
.btn-primary{
  background:var(--accent);color:var(--bg);
  box-shadow:0 4px 24px rgba(212,163,79,0);
}
.btn-primary:hover{
  background:var(--fg);color:var(--bg);transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(241,237,228,.18);
}
.btn-ghost{
  border:1px solid var(--line-strong);color:var(--fg);
  background:transparent;
}
.btn-ghost:hover{
  border-color:var(--accent);color:var(--bg);background:var(--accent);
  transform:translateY(-2px);
}
.btn-ghost::before{
  content:"";position:absolute;inset:0;background:var(--accent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease);z-index:-1;
}
.btn-ghost:hover::before{transform:scaleX(1)}
.btn-icon{padding:17px;min-width:54px;justify-content:center}
.btn-icon::after{content:""}

/* Size variants */
.btn-lg{padding:22px 40px;font-size:13px;letter-spacing:.22em}
.btn-sm{padding:11px 20px;font-size:11px;letter-spacing:.15em}

/* ---------- SECTION NUMBERING --------------------------------------- */
.section-num{
  display:block;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(14px,1vw,16px);
  letter-spacing:.3em;color:var(--accent);
  margin-bottom:clamp(32px,4vw,60px);
}
.section-head{margin-bottom:clamp(48px,6vw,96px);max-width:900px}
.section-head .lead{margin-top:24px}

/* ---------- CARDS / SERVICES GRID ----------------------------------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
@media (max-width:960px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.services-grid{grid-template-columns:1fr}}
.service-card{
  background:var(--bg);padding:40px 32px;min-height:320px;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;transition:background .4s var(--ease);
}
.service-card::before{
  content:"";position:absolute;inset:0;background:var(--accent);
  transform:translateY(101%);transition:transform .55s var(--ease);z-index:0;
}
.service-card > *{position:relative;z-index:1}
.service-card:hover{color:var(--bg)}
.service-card:hover::before{transform:translateY(0)}
.service-card:hover .service-num{color:var(--bg)}
.service-num{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:.25em;color:var(--accent);margin-bottom:32px;transition:color .4s var(--ease)}
.service-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(28px,3vw,42px);line-height:1;letter-spacing:.015em;text-transform:uppercase;margin-bottom:16px}
.service-desc{font-size:15px;color:var(--fg-muted);line-height:1.6;transition:color .4s var(--ease)}
.service-card:hover .service-desc{color:rgba(10,10,10,.8)}
.service-arrow{align-self:flex-end;margin-top:32px;transition:transform .4s var(--ease)}
.service-card:hover .service-arrow{transform:translate(6px,-6px)}

/* ---------- SHOWREEL CARD ------------------------------------------- */
.showreel-card{
  position:relative;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;
  background:var(--bg-2);
  box-shadow:0 40px 120px rgba(0,0,0,.4);
}
.showreel-card iframe,.showreel-card video{position:absolute;inset:0;width:100%;height:100%;border:0;object-fit:cover}

/* ---------- STORYBOARD GRID (tall format) --------------------------- */
.grid-sb{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media (max-width:960px){.grid-sb{grid-template-columns:repeat(2,1fr)}}
.grid-sb img{width:100%;height:auto;border-radius:var(--radius);transition:transform .6s var(--ease),box-shadow .6s var(--ease);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.grid-sb img:hover{transform:translateY(-6px);box-shadow:0 40px 120px rgba(0,0,0,.5)}

/* ---------- WEBTOON GRID (portrait-ish) ----------------------------- */
.grid-wt{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media (max-width:960px){.grid-wt{grid-template-columns:repeat(2,1fr)}}
.grid-wt img{width:100%;height:auto;border-radius:var(--radius);transition:transform .6s var(--ease);box-shadow:0 16px 48px rgba(0,0,0,.3)}
.grid-wt img:hover{transform:translateY(-4px) scale(1.02)}

/* ---------- GALLERY STRIP (infinite scroll) ------------------------- */
.gallery-strip{overflow:hidden;padding:16px 0;mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.gallery-strip-inner{display:flex;gap:16px;width:max-content;animation:strip 60s linear infinite}
.gallery-strip-inner img{height:280px;width:auto;border-radius:var(--radius);flex-shrink:0;object-fit:cover;filter:grayscale(.2);transition:filter .4s var(--ease)}
.gallery-strip-inner img:hover{filter:grayscale(0)}
@keyframes strip{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (max-width:760px){.gallery-strip-inner img{height:180px}}

/* ---------- BANNER NOTE --------------------------------------------- */
.banner-note{
  display:inline-flex;align-items:flex-start;gap:12px;
  background:var(--accent-soft);
  border-left:3px solid var(--accent);
  color:var(--fg);padding:18px 22px;
  font-size:14px;line-height:1.6;
  border-radius:2px;
  max-width:820px;
  white-space:normal;
  font-weight:400;
}
.banner-note::before{
  content:"⚠";color:var(--accent);font-size:16px;line-height:1.6;flex-shrink:0;
}

/* ---------- PROJECT CARDS (griot, etc) ------------------------------ */
.projects-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
@media (max-width:960px){.projects-grid{grid-template-columns:repeat(6,1fr)}}
.project{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--bg-2);grid-column:span 6;aspect-ratio:4/3}
.project.wide{grid-column:span 8;aspect-ratio:16/9}
.project.narrow{grid-column:span 4;aspect-ratio:3/4}
@media (max-width:960px){.project,.project.wide,.project.narrow{grid-column:span 6;aspect-ratio:4/3}}
.project img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.project:hover img{transform:scale(1.06)}
.project-info{position:absolute;inset:auto 0 0 0;padding:32px;background:linear-gradient(transparent,rgba(10,10,10,.92));z-index:2}
.project-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(24px,2.2vw,34px);text-transform:uppercase;letter-spacing:.01em;margin-bottom:6px}
.project-sub{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}

/* ---------- TEAM ----------------------------------------------------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
@media (max-width:760px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.team-grid{grid-template-columns:1fr}}
.team-member{padding:32px;background:var(--bg);transition:background .4s var(--ease);cursor:default}
.team-member:hover{background:var(--bg-2)}
.team-member .tm-role{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);margin-bottom:16px;min-height:30px;display:flex;align-items:flex-end}
.team-member .tm-name{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:.02em;text-transform:uppercase;line-height:1;margin-bottom:8px}
.team-member .tm-id{font-size:11px;color:var(--fg-dim);letter-spacing:.15em;font-family:'Bebas Neue',sans-serif}

/* ---------- TARIFS TABLE -------------------------------------------- */
.pricing-controls{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px;align-items:center}
.tab{padding:10px 22px;border:1px solid var(--line-strong);border-radius:100px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;transition:all .3s var(--ease)}
.tab:hover{border-color:var(--fg-muted)}
.tab.active{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.currency-select{margin-left:auto;display:flex;gap:2px;background:var(--bg-2);padding:4px;border-radius:100px}
.currency-select button{padding:6px 14px;font-size:11px;letter-spacing:.1em;font-weight:600;border-radius:100px;color:var(--fg-muted);transition:all .25s var(--ease)}
.currency-select button.active{background:var(--accent);color:var(--bg)}
.currency-select button:hover:not(.active){color:var(--fg)}

.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media (max-width:960px){.pricing-grid{grid-template-columns:1fr}}
.pricing-col{background:var(--bg);padding:40px 32px}
.pricing-col h3{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:.02em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.pricing-row{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--line);font-size:14px}
.pricing-row:last-child{border-bottom:none}
.pricing-row .label{color:var(--fg-muted)}
.pricing-row .price{color:var(--fg);font-weight:500;white-space:nowrap;font-variant-numeric:tabular-nums}
.pricing-note{font-size:12px;color:var(--fg-dim);margin-top:32px;letter-spacing:.03em;font-style:italic}

/* ---------- SIMULATEUR ---------------------------------------------- */
.sim-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
@media (max-width:960px){.sim-grid{grid-template-columns:1fr;gap:40px}}
.sim-form{display:flex;flex-direction:column;gap:32px}
.sim-group{display:flex;flex-direction:column;gap:24px;padding:28px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);position:relative}
.sim-group-label{
  position:absolute;top:-10px;left:20px;
  background:var(--bg);padding:2px 12px;
  font-size:10px;letter-spacing:.25em;text-transform:uppercase;
  color:var(--accent);font-weight:600;
  border:1px solid var(--line-strong);border-radius:2px;
}
.sim-field label{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-muted);margin-bottom:10px;font-weight:500}
.sim-field input[type=number],.sim-field input[type=text],.sim-field input[type=email],.sim-field select,.sim-field textarea{
  width:100%;padding:14px 44px 14px 16px;background:var(--bg);border:1px solid var(--line-strong);
  color:var(--fg);font-family:inherit;font-size:15px;border-radius:2px;
  transition:border-color .3s var(--ease),background .3s var(--ease);
}
.sim-field input:focus,.sim-field select:focus,.sim-field textarea:focus{outline:none;border-color:var(--accent);background:var(--bg-2)}
.sim-field textarea{resize:vertical;min-height:120px}
.sim-radio-group{display:flex;gap:10px;flex-wrap:wrap}
.sim-radio{position:relative;cursor:pointer}
.sim-radio input{position:absolute;opacity:0;pointer-events:none}
.sim-radio span{display:block;padding:10px 18px;border:1px solid var(--line-strong);border-radius:100px;font-size:13px;letter-spacing:.05em;transition:all .25s var(--ease);color:var(--fg-muted)}
.sim-radio:hover span{color:var(--fg)}
.sim-radio input:checked + span{background:var(--accent);border-color:var(--accent);color:var(--bg)}
.sim-slider-row{display:flex;align-items:center;gap:16px}
.sim-slider-row input[type=range]{flex:1;accent-color:var(--accent);height:4px}
.sim-slider-row .val{font-variant-numeric:tabular-nums;font-size:15px;min-width:50px;text-align:right;color:var(--accent);font-weight:600}

.sim-result{position:sticky;top:100px;background:var(--bg-2);border:1px solid var(--line);padding:40px;border-radius:var(--radius)}
.sim-result h3{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.sim-compare{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:24px 0}
.sim-price{padding:20px;background:var(--bg);border-radius:var(--radius);border:1px solid var(--line)}
.sim-price.ours{border-color:var(--accent);background:linear-gradient(180deg,var(--accent-soft),var(--bg))}
.sim-price .label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-muted);margin-bottom:10px}
.sim-price .amount{font-family:'Bebas Neue',sans-serif;font-size:clamp(28px,3.2vw,42px);line-height:1;color:var(--fg);font-variant-numeric:tabular-nums}
.sim-price.ours .amount{color:var(--accent)}
.sim-price .range{font-size:12px;color:var(--fg-muted);margin-top:8px}
.sim-savings{text-align:center;padding:18px;background:var(--bg);border-radius:var(--radius);margin-top:16px;border:1px dashed var(--accent)}
.sim-savings .pct{font-family:'Bebas Neue',sans-serif;font-size:42px;color:var(--accent);line-height:1;letter-spacing:.01em}
.sim-savings .lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-muted);margin-top:8px}
.sim-breakdown{margin-top:24px;font-size:13px}
.sim-breakdown .br-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--line);color:var(--fg-muted)}
.sim-breakdown .br-row .v{color:var(--fg);font-variant-numeric:tabular-nums}
.sim-disclaimer{font-size:11px;color:var(--fg-dim);margin-top:20px;line-height:1.5;font-style:italic}

/* ---------- FORM / CONTACT ------------------------------------------ */
.form{display:flex;flex-direction:column;gap:24px;max-width:720px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:640px){.form-row{grid-template-columns:1fr}}
.form-field label{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-muted);margin-bottom:10px;font-weight:500}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:14px 16px;background:transparent;border:none;border-bottom:1px solid var(--line-strong);
  color:var(--fg);font-family:inherit;font-size:16px;border-radius:0;transition:border-color .3s var(--ease),background .3s var(--ease);
}
.form-field select{padding-right:44px}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-bottom-color:var(--accent)}
.form-field textarea{resize:vertical;min-height:120px}

/* ---------- SELECT (custom chevron + dropdown theming) -------------- */
select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'><path fill='none' stroke='%23D4A34F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M1 1l6 6 6-6'/></svg>");
  background-repeat:no-repeat;
  background-position:right 18px center;
  background-size:13px;
  cursor:pointer;
}
select:hover{border-color:var(--accent)!important}
/* Option items (native dropdown) */
select option,
option{
  background:#151515;
  color:#f1ede4;
  padding:12px 16px;
  font-family:'Inter',sans-serif;
  font-size:14px;
  font-weight:400;
}
select option:checked,
select option:hover,
option:checked{
  background:linear-gradient(#D4A34F,#D4A34F);
  color:#0a0a0a;
  font-weight:600;
}
select option:disabled,
option:disabled{
  color:#54514c;
}
/* Firefox specific — remove dotted outline on focused option */
select:-moz-focusring{color:transparent;text-shadow:0 0 0 var(--fg)}
.form-msg{padding:16px;border-radius:2px;font-size:14px;margin-top:8px}
.form-msg.ok{background:rgba(100,200,120,.1);border:1px solid rgba(100,200,120,.3);color:#9ad3a9}
.form-msg.err{background:rgba(255,90,90,.1);border:1px solid rgba(255,90,90,.3);color:#ff8a8a}

/* ---------- MARQUEE / SCROLLING STRIP -------------------------------- */
.marquee{overflow:hidden;white-space:nowrap;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee-inner{display:inline-block;animation:marquee 40s linear infinite;font-family:'Bebas Neue',sans-serif;font-size:clamp(50px,7vw,90px);letter-spacing:.02em;text-transform:uppercase;color:var(--fg)}
.marquee-inner span{margin:0 40px;color:var(--fg-dim)}
.marquee-inner span.accent{color:var(--accent)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- FEATURE TWO-COLS ----------------------------------------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:center}
@media (max-width:960px){.two-col{grid-template-columns:1fr;gap:48px}}
.two-col .media{aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;background:var(--bg-2)}
.two-col .media img,.two-col .media video{width:100%;height:100%;object-fit:cover}
.two-col .stat{display:flex;gap:32px;margin-top:32px;padding-top:32px;border-top:1px solid var(--line)}
.two-col .stat div{display:flex;flex-direction:column;gap:6px}
.two-col .stat .n{font-family:'Bebas Neue',sans-serif;font-size:44px;color:var(--accent);line-height:1}
.two-col .stat .l{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-muted)}

/* ---------- FOOTER --------------------------------------------------- */
.footer{background:var(--bg-2);padding:80px 0 32px;border-top:1px solid var(--line);margin-top:120px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
.footer-brand img{height:44px;margin-bottom:16px}
.footer-brand p{color:var(--fg-muted);font-size:14px;max-width:28ch}
.footer h4{font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--fg-muted);margin-bottom:20px;font-weight:600}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer ul a{font-size:14px;color:var(--fg);transition:color .3s var(--ease)}
.footer ul a:hover{color:var(--accent)}
.footer-bottom{margin-top:64px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--fg-dim);letter-spacing:.05em}

/* ---------- ANIMATIONS (scroll reveal) ------------------------------- */
.reveal{opacity:0;transform:translateY(32px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}
.reveal.d4{transition-delay:.4s}

.reveal-split span{display:inline-block;opacity:0;transform:translateY(100%);transition:.8s var(--ease)}
.reveal-split.in span{opacity:1;transform:translateY(0)}

/* ---------- CURSOR FOLLOWER ----------------------------------------- */
.cursor{
  position:fixed;top:0;left:0;width:12px;height:12px;
  border-radius:50%;background:var(--accent);pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  mix-blend-mode:difference;
  transition:width .3s var(--ease),height .3s var(--ease),opacity .3s var(--ease);
}
.cursor.hover{width:48px;height:48px;background:var(--fg)}
@media (hover:none){.cursor{display:none}}

/* ---------- PAGE HEADERS -------------------------------------------- */
.page-header{
  padding:clamp(140px,16vw,200px) 0 clamp(60px,8vw,120px);
  border-bottom:1px solid var(--line);
  position:relative;
}
.page-header .eyebrow{margin-bottom:24px}

/* ---------- FLOATING DEVIS BUTTON (always visible) ------------------ */
.fab-devis{
  position:fixed;
  bottom:24px;right:24px;
  z-index:90;
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 28px;
  background:var(--accent);
  color:var(--bg);
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  font-weight:700;
  border-radius:100px;
  box-shadow:0 10px 40px rgba(212,163,79,.45),0 2px 8px rgba(0,0,0,.3);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),opacity .4s var(--ease);
  opacity:0;transform:translateY(20px) scale(.9);
  cursor:pointer;
  animation:fabPulse 2.8s ease-in-out infinite 3s;
}
.fab-devis.show{opacity:1;transform:translateY(0) scale(1)}
.fab-devis:hover{
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 14px 50px rgba(212,163,79,.65),0 4px 12px rgba(0,0,0,.4);
  animation-play-state:paused;
}
.fab-devis::before{
  content:"";position:absolute;inset:-4px;border-radius:100px;
  background:radial-gradient(circle,rgba(212,163,79,.5),transparent 70%);
  opacity:0;transition:opacity .4s var(--ease);z-index:-1;
  pointer-events:none;
}
.fab-devis:hover::before{opacity:1}
.fab-devis svg{width:14px;height:14px}
@keyframes fabPulse{
  0%,100%{box-shadow:0 10px 40px rgba(212,163,79,.45),0 0 0 0 rgba(212,163,79,.55)}
  50%{box-shadow:0 10px 40px rgba(212,163,79,.55),0 0 0 14px rgba(212,163,79,0)}
}
/* Hide on contact page — already there */
body.on-contact .fab-devis{display:none}
/* Mobile : plus large, centré bas */
@media (max-width:600px){
  .fab-devis{
    bottom:18px;right:18px;left:18px;
    justify-content:center;
    padding:16px 24px;
    font-size:12px;
  }
}
/* Hide when menu mobile open (avoid overlap) */
body.menu-open .fab-devis{opacity:0;pointer-events:none;transform:translateY(20px)}

/* ---------- UTILITIES ----------------------------------------------- */
.text-accent{color:var(--accent)}
.text-muted{color:var(--fg-muted)}
.mt-s{margin-top:16px}.mt-m{margin-top:32px}.mt-l{margin-top:64px}
.mb-s{margin-bottom:16px}.mb-m{margin-bottom:32px}.mb-l{margin-bottom:64px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,4vw,60px)}
@media (max-width:760px){.grid-2{grid-template-columns:1fr}}
.pill{display:inline-block;padding:4px 12px;font-size:11px;letter-spacing:.15em;text-transform:uppercase;border:1px solid var(--line-strong);border-radius:100px;color:var(--fg-muted)}
.chip{display:inline-block;padding:6px 14px;font-size:12px;background:var(--bg-2);border:1px solid var(--line);color:var(--fg-muted);margin:0 6px 6px 0;border-radius:2px}

/* ====================================================================
   MOBILE RESPONSIVE FIXES
   ==================================================================== */

@media (max-width:760px){
  /* Container padding more compact */
  .container{padding:0 20px}

  /* Section spacing */
  section{padding:clamp(60px,14vw,100px) 0}

  /* Hero */
  .hero{min-height:92vh;padding-bottom:64px;padding-top:100px}
  .hero-title{font-size:clamp(52px,14vw,96px);line-height:.9}
  .hero-bg iframe,.hero-bg video{opacity:.35}
  .hero-meta{gap:20px;margin-top:28px;padding-top:20px}
  .hero-meta-item .k{font-size:9px}
  .hero-meta-item .v{font-size:13px}
  .hero-scroll{display:none}

  /* Section heads */
  .section-title{font-size:clamp(34px,9vw,60px)}
  .section-head{margin-bottom:40px}

  /* Lead */
  .lead{font-size:15px}

  /* Service cards taller but not crazy */
  .service-card{min-height:240px;padding:28px 22px}
  .service-title{font-size:26px}
  .service-desc{font-size:14px}

  /* Marquee */
  .marquee-inner{font-size:42px}
  .marquee-inner span{margin:0 20px}

  /* Buttons — full width on very small */
  .btn{padding:14px 24px;font-size:11px;letter-spacing:.15em}
  .btn-lg{padding:16px 28px;font-size:12px}
  .btn-sm{padding:10px 16px;font-size:10px}

  /* Two-col stacks */
  .two-col .stat{gap:16px;margin-top:24px;padding-top:24px;flex-wrap:wrap}
  .two-col .stat .n{font-size:32px}
  .two-col .stat .l{font-size:10px}

  /* Pricing */
  .pricing-controls{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:32px}
  .currency-select{margin-left:0;overflow-x:auto;width:100%;justify-content:flex-start;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}
  .currency-select button{flex-shrink:0;padding:8px 12px;font-size:10px}
  .pricing-col{padding:28px 20px}
  .pricing-col h3{font-size:20px}
  .pricing-row{font-size:13px;padding:12px 0}

  /* Simulator */
  .sim-grid{grid-template-columns:1fr;gap:32px}
  .sim-result{position:static;padding:28px 22px}
  .sim-compare{grid-template-columns:1fr;gap:14px}
  .sim-price .amount{font-size:32px}
  .sim-savings .pct{font-size:36px}
  .sim-group{padding:22px 18px}
  .sim-radio-group{gap:8px}
  .sim-radio span{padding:9px 14px;font-size:12px}

  /* Form */
  .form-row{grid-template-columns:1fr;gap:20px}
  .form-field input,.form-field textarea,.form-field select{font-size:15px}

  /* Team grid: 2 columns on tablet, 1 on small phone */
  .team-grid{grid-template-columns:1fr 1fr}
  .team-member{padding:24px 18px}

  /* Projects grid: simpler */
  .projects-grid{grid-template-columns:repeat(4,1fr);gap:12px}
  .project,.project.wide,.project.narrow{grid-column:span 2;aspect-ratio:4/3}
  .project.wide{grid-column:span 4;aspect-ratio:16/9}
  .project-title{font-size:20px}
  .project-info{padding:20px}

  /* Grid-sb & grid-wt */
  .grid-sb,.grid-wt{grid-template-columns:repeat(2,1fr);gap:14px}

  /* Gallery strip */
  .gallery-strip-inner img{height:160px}

  /* Footer */
  .footer{padding:60px 0 24px;margin-top:80px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .footer-brand{grid-column:span 2}
  .footer-bottom{margin-top:40px;flex-direction:column;gap:8px;font-size:11px}

  /* Eyebrow + section-num */
  .eyebrow,.section-num{font-size:10px;letter-spacing:.2em}

  /* Banner note */
  .banner-note{font-size:13px;padding:14px 16px}

  /* Page header */
  .page-header{padding:120px 0 60px}

  /* Nav CTA hide on very small (shown in menu) */
  .nav .nav-cta{display:none}
}

@media (max-width:480px){
  .container{padding:0 16px}

  .hero-title{font-size:clamp(44px,13vw,64px)}
  .section-title{font-size:clamp(28px,8vw,46px)}

  .services-grid{grid-template-columns:1fr}
  .service-card{min-height:200px}

  .team-grid{grid-template-columns:1fr}

  /* Projects grid on phone: 2 cols max */
  .projects-grid{grid-template-columns:repeat(2,1fr)}
  .project,.project.wide,.project.narrow{grid-column:span 1;aspect-ratio:4/3}
  .project.wide{grid-column:span 2;aspect-ratio:16/10}

  /* Footer back to single column */
  .footer-grid{grid-template-columns:1fr}
  .footer-brand{grid-column:span 1}

  /* Buttons full-width */
  .hero .btn,.mt-l .btn{width:100%;justify-content:center}

  /* Stat blocks */
  .two-col .stat{flex-direction:row;flex-wrap:wrap;gap:16px 20px}
  .two-col .stat > div{min-width:calc(50% - 10px)}

  /* Marquee smaller */
  .marquee-inner{font-size:32px}

  /* Lang switcher */
  .lang-switcher button{min-width:32px;padding:6px 9px;font-size:10px}
}

/* Tablets: landscape tweaks */
@media (min-width:761px) and (max-width:960px){
  .hero-title{font-size:clamp(80px,11vw,140px)}
  .pricing-grid{grid-template-columns:1fr}
  .pricing-controls{flex-wrap:wrap}
}

/* Cacher les spinners number inputs */
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield}

/* Selection color */
::selection{background:var(--accent);color:var(--bg)}

/* Scrollbar custom */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}
