.elementor-39 .elementor-element.elementor-element-8a2bc3b{--display:flex;}.elementor-39 .elementor-element.elementor-element-8a2bc3b:not(.elementor-motion-effects-element-type-background), .elementor-39 .elementor-element.elementor-element-8a2bc3b > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#050505;}.elementor-39 .elementor-element.elementor-element-223770a{width:100%;max-width:100%;}.elementor-39 .elementor-element.elementor-element-223770a.elementor-element{--order:-99999 /* order start hack */;}.elementor-39 .elementor-element.elementor-element-d595e0d{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-39 .elementor-element.elementor-element-d595e0d:not(.elementor-motion-effects-element-type-background), .elementor-39 .elementor-element.elementor-element-d595e0d > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#050505;}.elementor-39 .elementor-element.elementor-element-fb4616a{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-39 .elementor-element.elementor-element-fb4616a:not(.elementor-motion-effects-element-type-background), .elementor-39 .elementor-element.elementor-element-fb4616a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#050505;}.elementor-39 .elementor-element.elementor-element-40719f7{width:100%;max-width:100%;}.elementor-39 .elementor-element.elementor-element-f08ebec{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;}.elementor-39 .elementor-element.elementor-element-f08ebec:not(.elementor-motion-effects-element-type-background), .elementor-39 .elementor-element.elementor-element-f08ebec > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#050505;}.elementor-39 .elementor-element.elementor-element-f08ebec.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-39 .elementor-element.elementor-element-b22d5ef.elementor-element{--align-self:center;}.elementor-39 .elementor-element.elementor-element-2ef5f6a{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-39 .elementor-element.elementor-element-2ef5f6a:not(.elementor-motion-effects-element-type-background), .elementor-39 .elementor-element.elementor-element-2ef5f6a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#050505;}.elementor-39 .elementor-element.elementor-element-f6941c1{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-39 .elementor-element.elementor-element-f6941c1:not(.elementor-motion-effects-element-type-background), .elementor-39 .elementor-element.elementor-element-f6941c1 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#050505;}.elementor-39 .elementor-element.elementor-element-b8fd7ed{width:100%;max-width:100%;}.elementor-39 .elementor-element.elementor-element-5db7404{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-39 .elementor-element.elementor-element-5db7404:not(.elementor-motion-effects-element-type-background), .elementor-39 .elementor-element.elementor-element-5db7404 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#050505;}.elementor-39 .elementor-element.elementor-element-4094222{width:100%;max-width:100%;}@media(max-width:767px){.elementor-39 .elementor-element.elementor-element-f08ebec{--width:394.556px;}}/* Start custom CSS for html, class: .elementor-element-223770a *//* ===== NAVBAR THEME (scoped) ===== */
.navbar-theme{
  /* variables locales à la navbar */
  --black:#050505; --ink:#efe7d2;
  --gold:#D6AF62; --gold-b:#F4D991; --gold-d:#A17E3A;
  --grey:#cfc7b3; --accent:#25D366;
  --radius:16px; --shadow:0 18px 60px rgba(0,0,0,.55);

  position:sticky; top:0; z-index:50;
  color:var(--ink);
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(10px) saturate(130%);
  border-bottom:1px solid rgba(214,175,98,.25);
}

/* limite le style à l’intérieur de la navbar */
.navbar-theme .container{
  max-width:1200px; margin:0 auto; padding:12px 22px;
  display:flex; align-items:center; justify-content:space-between; gap:18px;
}

.navbar-theme .logoRow{ display:flex; align-items:center; gap:14px; min-width:0; }
.navbar-theme .logoRow img{ height:46px; width:auto; display:block; }
.navbar-theme .brand{
  font-family:"Playfair Display",serif; font-weight:900; letter-spacing:.8px; white-space:nowrap;
  background:linear-gradient(180deg,var(--gold-b),var(--gold),var(--gold-d));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* Nav links */
.navbar-theme #navbar ul{ display:flex; gap:24px; list-style:none; margin:0; padding:0; }
.navbar-theme #navbar a{ font-weight:800; opacity:.92; color:var(--ink); text-decoration:none; }
.navbar-theme #navbar a:hover{ opacity:1; }

/* Langue (si utilisée) */
.navbar-theme .lang{ display:flex; align-items:center; gap:10px; }
.navbar-theme .lang select{
  appearance:none; background:transparent; border:1px solid rgba(214,175,98,.4);
  color:var(--ink); padding:6px 28px 6px 10px; border-radius:10px; font-weight:800;
}

/* Bouton “Call” (optionnel) */
.navbar-theme .call-cta{
  padding:10px 16px; border-radius:12px; font-weight:900;
  background:linear-gradient(180deg,var(--gold-b),var(--gold));
  color:#000; border:1px solid rgba(214,175,98,.65);
  box-shadow: var(--shadow);
}
.navbar-theme .call-cta:hover{
  filter:brightness(1.06);
}

/* Petits écrans */
@media (max-width:900px){
  .navbar-theme .container{ flex-wrap:wrap; }
  .navbar-theme #navbar ul{ gap:16px; flex-wrap:wrap; }
  .navbar-theme .brand{ font-size:15px; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-4c4f003 *//* ========= HERO / TOP — Black & Gold (SCOPÉ UNIQUEMENT À CETTE SECTION) ========= */
/* Ajoute la classe .top-theme sur ton bloc hero : <div class="top top-theme" id="home"> */

.top-theme{
  /* Variables locales à la section */
  --black:#050505; --ink:#efe7d2;
  --gold:#D6AF62; --gold-b:#F4D991; --gold-d:#A17E3A;
  --grey:#cfc7b3; --accent:#25D366;
  --radius:16px; --shadow:0 18px 60px rgba(0,0,0,.55);
  --container:1200px;

  position:relative;
  color:var(--ink);
  background:var(--black);
  border-bottom:1px solid rgba(214,175,98,.2);
  background-image: linear-gradient(180deg, rgba(255,255,255,.04), transparent);
}

/* Vignette subtile — uniquement derrière le hero */
.top-theme::before{
  content:""; position:absolute; inset:-20%;
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(214,175,98,.08), transparent 60%),
    radial-gradient(1200px 700px at 50% 120%, rgba(214,175,98,.05), transparent 60%);
  pointer-events:none; z-index:-1;
}

/* Resets et container locaux (ne sortent pas de la section) */
.top-theme, .top-theme *{ box-sizing:border-box; }
.top-theme img{ max-width:100%; height:auto; display:block; }
.top-theme a{ color:inherit; text-decoration:none; }
.top-theme .container{ max-width:var(--container); margin:0 auto; padding:42px 22px 26px; }

/* Grid principal */
.top-theme .heroGrid{
  display:grid; grid-template-columns:1.2fr .9fr; gap:24px; align-items:center;
}
@media (max-width:980px){
  .top-theme .heroGrid{ grid-template-columns:1fr; }
}

/* Titre & sous-titre */
.top-theme .h1{
  font-family:"Playfair Display",serif;
  font-size: clamp(42px, 6vw, 86px); line-height:1.05; margin:0 0 10px;
  background:linear-gradient(180deg,var(--gold-b),var(--gold) 60%, var(--gold-d));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow:0 1px 0 rgba(255,255,255,.2);
}
.top-theme .tag{ font-style:italic; color:var(--gold-b); margin-bottom:16px; }

/* CTA */
.top-theme .hero-cta{ display:flex; gap:12px; flex-wrap:wrap; }
.top-theme .btn{
  display:inline-block; padding:12px 18px; border-radius:14px;
  font-weight:900; letter-spacing:.2px;
}
.top-theme .btn-gold{
  color:#000;
  background:linear-gradient(180deg,var(--gold-b),var(--gold) 60%, var(--gold-d));
  border:1px solid rgba(214,175,98,.65);
  box-shadow:0 20px 50px rgba(214,175,98,.22), inset 0 1px 0 rgba(255,255,255,.35);
}
.top-theme .btn-ghost{
  border:1px solid rgba(214,175,98,.5);
  color:var(--ink);
  background:rgba(255,255,255,.02);
}
.top-theme .btn-dark{
  background:#000; color:#fff; border:1px solid rgba(255,255,255,.06);
}

/* “Proof” icons */
.top-theme .topIcons{
  display:flex; gap:18px; justify-content:center; margin:18px 0 0; flex-wrap:wrap;
}
.top-theme .topIcons .iconCard{
  display:flex; align-items:center; gap:10px; padding:8px 12px;
  border:1px solid rgba(214,175,98,.3); border-radius:999px;
  background:rgba(255,255,255,.03); font-weight:800; color:#e8dec7;
}

/* Image */
.top-theme .hero-image{
  border-radius:16px; overflow:hidden;
  border:1px solid rgba(214,175,98,.28);
  box-shadow:var(--shadow);
}
.top-theme .hero-image img{ width:100%; height:auto; }

/* Petites optimisations responsive */
@media (max-width:600px){
  .top-theme .btn{ width:100%; text-align:center; }
  .top-theme .h1{ font-size: clamp(36px, 9vw, 56px); }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-40719f7 *//* ===== INSTANT QUOTE — Black & Gold (SCOPÉ UNIQUEMENT ICI) ===== */
.estimate-scope{
  /* Variables locales à la section */
  --black:#050505; --ink:#efe7d2;
  --gold:#D6AF62; --gold-b:#F4D991; --gold-d:#A17E3A;
  --grey:#cfc7b3; --accent:#25D366;
  --radius:16px; --shadow:0 18px 60px rgba(0,0,0,.55);
  --container:1200px;

  position:relative;
  color:var(--ink);
}

/* Base section (uniquement ici) */
.estimate-scope.middle{ padding:64px 0; border-bottom:1px solid rgba(214,175,98,.12); }
.estimate-scope .sectionTitle{
  font-family:"Playfair Display",serif; text-align:center; margin:0 0 26px;
  letter-spacing:.6px; font-size:34px;
  background:linear-gradient(180deg,var(--gold-b),var(--gold),var(--gold-d));
  -webkit-background-clip:text; background-clip:text; color:transparent; position:relative; padding-top:6px;
}
.estimate-scope .sectionTitle:after{
  content:""; position:absolute; left:50%; transform:translateX(-50%); bottom:-12px;
  width:90px; height:2px; background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.estimate-scope .copy{ color:#d6ceb8; max-width:980px; margin:18px auto 0; text-align:center; }

/* Container local (si tu utilises .container autour) */
.estimate-scope .container{ max-width:var(--container); margin:0 auto; padding:0 22px; }

/* Vignette subtile locale (optionnel) */
.estimate-scope::before{
  content:""; position:absolute; inset:-20%;
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(214,175,98,.08), transparent 60%),
    radial-gradient(1200px 700px at 50% 120%, rgba(214,175,98,.05), transparent 60%);
  pointer-events:none; z-index:-1;
}

/* ===== Formulaire (scopé) ===== */
.estimate-scope .quote-card{
  display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:18px auto 0;
  max-width:720px;
  padding:12px; border-radius:14px; backdrop-filter:blur(10px);
  background:rgba(0,0,0,.35);
  border:1px solid rgba(214,175,98,.35);
  box-shadow:var(--shadow);
}
@media (max-width:640px){
  .estimate-scope .quote-card{ grid-template-columns:1fr; }
}

/* Inputs */
.estimate-scope .quote-card input,
.estimate-scope .quote-card select,
.estimate-scope .quote-card textarea{
  padding:12px; border-radius:10px;
  border:1px solid rgba(214,175,98,.28);
  background:#0F0F0F; color:var(--ink);
  font:inherit;
}

/* Boutons (scopés) */
.estimate-scope .btn{
  display:inline-block; padding:12px 18px; border-radius:14px;
  font-weight:900; letter-spacing:.2px; text-align:center;
}
.estimate-scope .btn-gold{
  color:#000;
  background:linear-gradient(180deg,var(--gold-b),var(--gold) 60%, var(--gold-d));
  border:1px solid rgba(214,175,98,.65);
  box-shadow:0 20px 50px rgba(214,175,98,.22), inset 0 1px 0 rgba(255,255,255,.35);
}
.estimate-scope .btn-gold:hover{ filter:brightness(1.06); }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-b22d5ef *//* ===== SERVICES — Black & Gold (SCOPÉ UNIQUEMENT À CETTE SECTION) ===== */
.services-scope{
  /* Variables locales à la section */
  --black:#050505; --ink:#efe7d2;
  --gold:#D6AF62; --gold-b:#F4D991; --gold-d:#A17E3A;
  --grey:#cfc7b3; --accent:#25D366;
  --radius:16px; --shadow:0 18px 60px rgba(0,0,0,.55);
  --container:1200px;

  position:relative;
  color:var(--ink);
}

/* Base section locale */
.services-scope.middle{
  padding: 0;
  border-bottom:1px solid rgba(214,175,98,.12);
}
.services-scope .container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 22px;
}

/* Titre */
.services-scope .sectionTitle{
  font-family:"Playfair Display",serif;
  text-align:center;
  margin:0 0 26px;
  letter-spacing:.6px;
  font-size:34px;
  background:linear-gradient(180deg,var(--gold-b),var(--gold),var(--gold-d));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  position:relative; padding-top:6px;
}
.services-scope .sectionTitle:after{
  content:""; position:absolute; left:50%; transform:translateX(-50%);
  bottom:-12px; width:90px; height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

/* Texte secondaire (si besoin) */
.services-scope .copy{ color:#d6ceb8; max-width:980px; margin:0 auto; }

/* Grille services */
.services-scope .services{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:18px;
}
@media (max-width:980px){
  .services-scope .services{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .services-scope .services{ grid-template-columns:1fr; }
}

/* Cartes */
.services-scope .card{
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
  border:1px solid rgba(214,175,98,.35);
  border-radius:16px; overflow:hidden;
  box-shadow:var(--shadow);
  display:flex; flex-direction:column;
}
.services-scope .card .media{ aspect-ratio:4/3; overflow:hidden; }
.services-scope .card .media img{
  width:100%; height:100%; object-fit:cover; display:block;
  filter:contrast(1.02) saturate(.92);
}
.services-scope .card .body{ padding:16px 16px 18px; }
.services-scope .card h3{
  font-family:"Playfair Display",serif;
  font-size:22px; margin:0 0 6px; color:var(--gold-b);
}
.services-scope .card .sub{ font-style:italic; color:#e8dec7; margin-bottom:8px; }
.services-scope .card p{ margin:0; color:#d6ceb8; }
.services-scope .card a{
  display:inline-block; margin-top:12px;
  font-weight:900; border-bottom:2px solid var(--gold);
  color:var(--ink); text-decoration:none;
}

/* Vignette subtile locale (optionnel) */
.services-scope::before{
  content:""; position:absolute; inset:-20%;
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(214,175,98,.08), transparent 60%),
    radial-gradient(1200px 700px at 50% 120%, rgba(214,175,98,.05), transparent 60%);
  pointer-events:none; z-index:-1;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-d7a2252 *//* ===== OUR WORK — Black & Gold (scope: .work-scope) ===== */
.work-scope{
  /* Variables */
  --container: 1200px;
  --black: #050505;
  --ink: #efe7d2;
  --gold: #D6AF62;
  --gold-b: #F4D991;
  --gold-d: #A17E3A;
  --grey: #cfc7b3;
  --shadow: 0 18px 60px rgba(0,0,0,.55);

  color: var(--ink);
  position: relative;
  background: transparent;
}

/* Section base */
.work-scope.middle{
  padding: 0;
  border-bottom: 1px solid rgba(214,175,98,.12);
}
.work-scope .container{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 22px;
}

/* Title */
.work-scope .sectionTitle{
  font-family: "Playfair Display", serif;
  text-align: center;
  margin: 0;
  letter-spacing: .6px;
  font-size: 34px;
  padding-top: 6px;
  background: linear-gradient(180deg, var(--gold-b), var(--gold), var(--gold-d));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  position: relative;
}
.work-scope .sectionTitle:after{
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -12px;
  width: 90px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}

/* ===== UNIVERSAL CAROUSEL (ALL DEVICES, NO JS) ===== */
.work-scope .carousel-wrap{
  margin-top: 56px;
  position: relative;
}
.work-scope .carousel{
  display: flex;
  gap: 0;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border: 1px solid rgba(214,175,98,.22);
  box-shadow: 0 30px 70px rgba(0,0,0,.55);
}
.work-scope .carousel::-webkit-scrollbar{ display: none; }

/* Slide — MODIFIÉ pour voir l'image en ENTIER (object-fit: contain) */
.work-scope .slide{
  position: relative;
  flex: 0 0 100%;
  max-width: 100%;
  scroll-snap-align: center;
  overflow: hidden;
  /* On remplace l'aspect-ratio par une hauteur responsive pour préserver l'intégralité de l'image */
  height: clamp(240px, 52vw, 560px);       /* ajuste si besoin */
  background: #0B0B0B;                      /* letterboxing noir si nécessaire */
  border-right: 1px solid rgba(214,175,98,.12);
}
.work-scope .slide:last-child{ border-right: 0; }

/* Image — affichage intégral */
.work-scope .slide img{
  width: 100%;
  height: 100%;
  object-fit: contain;                       /* clé : image entière visible */
  object-position: center center;
  display: block;
  background: #0B0B0B;                       /* zones vides en noir */
  filter: contrast(1.02) saturate(.92);
  transition: transform .45s ease;
}
/* Désactive l’effet zoom pour éviter toute coupe visuelle */
.work-scope .slide:hover img{ transform: none; }

/* Arrows (anchors) */
.work-scope .nav-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 46px;
  height: 46px;
  line-height: 46px;
  text-align: center;
  font-size: 26px;
  color: #F4D991;
  text-decoration: none;
  background: rgba(5,5,5,.65);
  border: 1px solid rgba(214,175,98,.55);
  border-radius: 999px;
  box-shadow: 0 12px 28px rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
  transition: filter .2s ease, transform .2s ease;
}
.work-scope .nav-btn.prev{ left: 12px; }
.work-scope .nav-btn.next{ right: 12px; }
.work-scope .nav-btn:hover{ filter: brightness(1.08); }

/* Dots */
.work-scope .dots{
  display: flex;
  gap: 8px;
  justify-content: center;
  align-items: center;
  margin-top: 14px;
}
.work-scope .dots a{
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: rgba(214,175,98,.35);
  border: 1px solid rgba(214,175,98,.55);
  display: inline-block;
  transition: background .2s ease, transform .2s ease;
}
.work-scope .dots a:hover,
.work-scope .dots a:focus-visible{
  background: var(--gold);
  transform: scale(1.12);
}

/* ===== BRAND ROW / LOGOS — cartes uniformes + logos plus grands ===== */
.work-scope .brand-row{
  /* Taille des cartes (peut rester comme avant) */
  --card-w: clamp(120px, 18vw, 180px);
  --card-h: clamp(64px, 8.5vw, 92px);

  /* <<< AJUSTE ICI POUR GROSSIR/RÉDUIRE LES LOGOS >>> */
  --logo-fill: 92%;   /* % de remplissage du cadre par le logo */
  --pad: 6px;         /* padding interne : plus petit => logo plus grand */

  display:flex; gap:18px; flex-wrap:wrap;
  justify-content:center; align-items:center;
  list-style:none; margin:28px auto 0; padding:0;
  text-align:center;
}

.work-scope .brand-row li{
  box-sizing:border-box;
  width: var(--card-w);
  height: var(--card-h);
  display:flex; align-items:center; justify-content:center;

  padding: var(--pad);
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(214,175,98,.32);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  overflow:hidden;                         /* rien ne dépasse */
}

/* Logos plus grands, centrés, et tous à la même échelle visuelle */
.work-scope .brand-row img{
  width: auto; height: auto; display:block; margin:0 auto;
  max-width: calc(var(--logo-fill));       /* ~ largeur/hauteur max du logo */
  max-height: calc(var(--logo-fill));
  object-fit: contain; object-position:center;
  filter:none;
}

/* Mobile : un peu plus compact mais toujours bien rempli */
@media (max-width: 980px){
  .work-scope .brand-row{
    --card-w: clamp(110px, 40vw, 150px);
    --card-h: clamp(58px, 16vw, 82px);
    --logo-fill: 90%;
  }
}


/* ===== SUBTITLE & COPY ===== */
.work-scope .work-sub{
  text-align: center;
  margin: 40px 0 6px;
  font-size: 22px;
  font-weight: 900;
  color: #e8dec7;
  padding-top: 40px;
}
.work-scope .work-sub span{
  background: linear-gradient(180deg, var(--gold-b), var(--gold));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.work-scope .copy{
  color: #d6ceb8;
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}

/* ===== RESPONSIVE FINESSE ===== */
@media (min-width: 1100px){
  .work-scope .carousel-wrap{ padding: 0 12px; }
  /* Hauteur plus généreuse sur desktop pour mieux contenir les visuels verticaux */
  .work-scope .slide{ height: clamp(380px, 46vw, 680px); }
}

/* ===== ACCESSIBILITY HELPERS ===== */
.work-scope .nav-btn:focus-visible,
.work-scope .dots a:focus-visible{
  outline: 2px solid var(--gold-b);
  outline-offset: 2px;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-b8fd7ed *//* ===== LOCATIONS — Black & Gold (SCOPÉ UNIQUEMENT À CETTE SECTION) ===== */
.locations-scope{
  /* Variables locales */
  --black:#050505; --ink:#efe7d2;
  --gold:#D6AF62; --gold-b:#F4D991; --gold-d:#A17E3A;
  --grey:#cfc7b3; --shadow:0 18px 60px rgba(0,0,0,.55);
  --container:1200px;
  

  color:var(--ink);
  position:relative;
}

/* Base section locale */
.locations-scope.middle{
  padding:64px 0;
  border-bottom:1px solid rgba(214,175,98,.12);
}
.locations-scope .container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 22px;
}
/* Titres */
.locations-scope .sectionTitle{
  font-family:"Playfair Display",serif;
  text-align:center;
  margin:0 0 18px;
  letter-spacing:.6px;
  font-size:34px;
  padding-top:6px;
  background:linear-gradient(180deg,var(--gold-b),var(--gold),var(--gold-d));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  position:relative;
}
.locations-scope .sectionTitle:after{
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-12px;
  width:90px;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

/* Sous-titre (H2) centré */
.locations-scope h2{
  margin:24px 0 6px;
  font-size:26px;
  font-weight:900;
  color:#e8dec7;
  text-align:center;          /* <-- centre le H2 */
}

/* Paragraphe centré */
.locations-scope .copy{
  color:#d6ceb8;
  max-width:880px;
  margin:0 auto 18px;
  text-align:center;          /* <-- centre le texte */
}


/* Carte / Map */
.locations-scope .mapDiv{
  margin:18px auto 0;
  border:1px solid rgba(214,175,98,.28);
  border-radius:14px; overflow:hidden;
  box-shadow:var(--shadow);
  max-width:100%;
}
.locations-scope .mapDiv img{
  width:100%; height:auto; display:block;
  filter:grayscale(100%) invert(6%) brightness(1.1) contrast(95%);
  /* au besoin, ajuste le rendu pour matcher ton thème */
}

/* Si tu utilises un <embed> (Google Maps ou autre) */
.locations-scope .mapDiv embed{
  width:100%; height:360px;
  filter:grayscale(100%) invert(90%) contrast(90%);
  display:block;
}

/* Responsive */
@media (max-width:600px){
  .locations-scope h2{ font-size:22px; }
}
/* LOCATIONS — garder les couleurs originales de la carte */
.locations-scope .mapDiv img{
  filter: none !important;
}

.locations-scope .mapDiv embed{
  filter: none !important;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-4094222 *//* ===== CONTACT & FOOTER — Black & Gold (SCOPÉ À CETTE SECTION) ===== */
.footer-scope{
  /* Variables locales */
  --black:#050505; --ink:#efe7d2;
  --gold:#D6AF62; --gold-b:#F4D991; --gold-d:#A17E3A;
  --grey:#cfc7b3; --shadow:0 18px 60px rgba(0,0,0,.55);
  --container:1200px;
  color:var(--ink);
}
.footer-scope .container{ max-width:var(--container); margin:0 auto; padding:0 22px; }
.footer-scope.bottom{ padding:40px 0; text-align:center; border-top:1px solid rgba(214,175,98,.12); }

/* Menu du footer */
.footer-scope .footermenu a{ color:#d6ceb8; }
.footer-scope .footermenu a:hover{ color:var(--gold-b); }

/* Logo + titre */
.footer-scope .footerLogo{ filter:sepia(.35) saturate(.6) brightness(.92); margin:0 auto 6px; }
.footer-scope .likeH1{
  font-family:"Playfair Display",serif; font-weight:900; letter-spacing:.6px;
  background:linear-gradient(180deg,var(--gold-b),var(--gold),var(--gold-d));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* Texte */
.footer-scope .footerCopy{ max-width:760px; margin:8px auto; color:#d6ceb8; }
.footer-scope .telNum{ margin-top:8px; }
.footer-scope .telNum a{ font-weight:900; color:var(--gold-b); text-decoration:none; }

/* Boutons */
.footer-scope .ctaRow{ margin-top:12px; display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }
.footer-scope .btn{ display:inline-block; padding:12px 18px; border-radius:14px; font-weight:900; letter-spacing:.2px; }
.footer-scope .btn-gold{
  color:#000; background:linear-gradient(180deg,var(--gold-b),var(--gold) 60%, var(--gold-d));
  border:1px solid rgba(214,175,98,.65); box-shadow:0 20px 50px rgba(214,175,98,.22), inset 0 1px 0 rgba(255,255,255,.35);
}
.footer-scope .btn-ghost{ border:1px solid rgba(214,175,98,.5); color:var(--ink); background:rgba(255,255,255,.02); }
.footer-scope .btn-dark{ background:#000; color:#fff; border:1px solid rgba(255,255,255,.06); }

/* Mentions légales & attribution */
.footer-scope .legal{ margin-top:14px; color:#cfc7b3; }
.footer-scope .attribution{
  margin-top:6px; color:#bfb6a0; font-size:12px; opacity:.85;
}
.footer-scope .attribution a{
  color:#d6af62; text-decoration:none; border-bottom:1px dotted rgba(214,175,98,.5);
}

/* Petite amélioration responsive */
@media (max-width:520px){
  .footer-scope .ctaRow .btn{ width:100%; text-align:center; }
}/* End custom CSS */