:root{
  --bg:#0b0b0c;
  --panel: rgba(255,255,255,.05);
  --panel2: rgba(255,255,255,.035);
  --text: rgba(255,255,255,.88);
  --muted: rgba(255,255,255,.62);
  --gold:#caa35a;
  --gold2:#e2c27a;
  --line: rgba(202,163,90,.35);
  --danger:#ff6b6b;
  --radius:18px;
  --max:1100px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 500px at 20% 0%, rgba(202,163,90,.14), transparent 60%),
    radial-gradient(900px 500px at 80% 10%, rgba(226,194,122,.10), transparent 55%),
    var(--bg);
  color:var(--text);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  line-height:1.5;
}

a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max); margin:0 auto; padding:28px 18px 60px}

.topbar{
  position:sticky; top:0; z-index:20;
  backdrop-filter: blur(10px);
  background: rgba(11,11,12,.65);
  border-bottom: 1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 18px;
}

.brand{display:flex; gap:12px; align-items:center}
.brand__logo{width:46px;height:46px;object-fit:contain; filter: drop-shadow(0 8px 18px rgba(0,0,0,.6))}
.brand__name{font-family:"Cormorant Garamond", serif; font-weight:700; font-size:18px; color:var(--gold2); letter-spacing:.3px}
.brand__tag{font-size:12px; color:var(--muted)}

.nav{display:flex; gap:12px; flex-wrap:wrap; justify-content:flex-end}
.nav a{
  font-size:13px; color:var(--muted);
  padding:9px 12px; border-radius:999px;
  border:1px solid transparent;
}
.nav a:hover{color:var(--text); border-color:var(--line); background: rgba(255,255,255,.03)}

.hero{
  display:grid; grid-template-columns: 1.1fr .9fr;
  gap:22px; align-items:start;
  padding-top:28px;
}
.hero h1{
  font-family:"Cormorant Garamond", serif;
  font-size:44px; line-height:1.05;
  margin:0 0 10px;
  color: rgba(255,255,255,.92);
}
.muted{color:var(--muted)}
.badges{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}
.badges span{
  font-size:12px; color: rgba(255,255,255,.72);
  padding:8px 10px; border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.02);
}

.card{
  border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius: var(--radius);
  padding:18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.45);
}

.card__head{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px}
.card__title{font-size:13px; color: rgba(255,255,255,.78)}

.steps{display:flex; gap:8px}
.step{
  width:28px;height:28px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);
  color: rgba(255,255,255,.75);
  font-size:13px;
  background: rgba(255,255,255,.02);
}
.step--active{
  border-color: rgba(226,194,122,.7);
  box-shadow: 0 0 0 4px rgba(226,194,122,.12);
  color: var(--gold2);
}

.field{display:block; margin-top:12px}
.field span{display:block; font-size:12px; color: rgba(255,255,255,.72); margin-bottom:6px}
.field input, .field select{
  width:100%;
  padding:12px 12px;
  border-radius: 12px;
  border:1px solid rgba(202,163,90,.35);
  background: rgba(10,10,10,.55);
  color: rgba(255,255,255,.9);
  outline:none;
}
.field input::placeholder{color: rgba(255,255,255,.35)}
.field input:focus, .field select:focus{
  border-color: rgba(226,194,122,.75);
  box-shadow: 0 0 0 4px rgba(226,194,122,.12);
}

.row{display:flex; gap:10px; margin-top:14px}
.row--space{justify-content:space-between}
.btn{
  padding:12px 14px;
  border-radius: 12px;
  border:1px solid rgba(202,163,90,.35);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.85);
  cursor:pointer;
  font-weight:600;
}
.btn:hover{border-color: rgba(226,194,122,.75)}
.btn--primary{
  background: linear-gradient(180deg, rgba(226,194,122,.22), rgba(202,163,90,.12));
  border-color: rgba(226,194,122,.85);
  color: rgba(255,255,255,.92);
  flex:1;
}
.hint{font-size:12px; color: rgba(255,255,255,.5); margin-top:10px}
.error{margin-top:10px; font-size:12px; color: var(--danger); min-height: 16px}
.hidden{display:none !important}

.grid2{display:grid; grid-template-columns: 1fr 1fr; gap:12px; margin-top:8px}
.panelMini{
  border:1px solid rgba(202,163,90,.25);
  background: rgba(255,255,255,.02);
  border-radius: 14px;
  padding:12px;
}
.panelMini__title{
  font-size:12px; color: var(--gold2);
  margin-bottom:4px; letter-spacing:.2px
}

.result{
  margin-top:14px;
  border:1px solid rgba(226,194,122,.5);
  background: rgba(226,194,122,.06);
  border-radius: 14px;
  padding:12px;
}
.result__title{font-size:12px; color: rgba(255,255,255,.8)}
.result__price{
  font-family:"Cormorant Garamond", serif;
  font-size:34px;
  margin:6px 0;
  color: var(--gold2);
}

.section{margin-top:46px}
.section h2{
  font-family:"Cormorant Garamond", serif;
  font-size:30px; margin:0 0 10px; color: rgba(255,255,255,.92)
}
.cards3{display:grid; grid-template-columns: repeat(3, 1fr); gap:12px}
.miniCard{
  border:1px solid rgba(202,163,90,.25);
  background: rgba(255,255,255,.02);
  border-radius: 14px;
  padding:14px;
}

.footer{
  border-top: 1px solid var(--line);
  padding:18px;
  color: rgba(255,255,255,.55);
  text-align:center;
}

@media (max-width: 980px){
  .hero{grid-template-columns: 1fr}
  .hero h1{font-size:36px}
}
@media (max-width: 720px){
  .cards3{grid-template-columns: 1fr}
  .grid2{grid-template-columns: 1fr}
  .nav{display:none}
}
/* Autocomplete */
.autocomplete {
  position: relative;
}

.suggest {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: rgba(10,10,10,.92);
  border: 1px solid rgba(226,194,122,.35);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,.55);
  z-index: 50;
}

.suggest button {
  width: 100%;
  text-align: left;
  padding: 10px 12px;
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.88);
  cursor: pointer;
  font-size: 13px;
}

.suggest button:hover {
  background: rgba(226,194,122,.10);
}
/* =========================
   PAGE ZONES (layout + map)
========================= */
.pageHero{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  align-items:start;
  padding-top:28px;
}

.pageHero h1{
  font-family:"Cormorant Garamond", serif;
  font-size:44px;
  line-height:1.05;
  margin:0 0 10px;
  color: rgba(255,255,255,.92);
}

.zonesSeo{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  margin-top:12px;
}

.zoneCard{ position:relative; overflow:hidden; }
.zoneCard::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(900px 240px at 10% 0%, rgba(226,194,122,.14), transparent 60%),
    radial-gradient(900px 240px at 90% 10%, rgba(202,163,90,.12), transparent 55%);
  opacity:.9;
  pointer-events:none;
}
.zoneCard > *{ position:relative; }

.zoneCard__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:8px;
}
.zoneCard__title{
  font-family:"Cormorant Garamond", serif;
  font-size:22px;
  color: rgba(255,255,255,.92);
  letter-spacing:.2px;
}
.zoneCard__pill{
  font-size:12px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(226,194,122,.45);
  background: rgba(226,194,122,.08);
  color: rgba(255,255,255,.82);
  white-space:nowrap;
}
.zoneCard__pill--soft{
  border-color: rgba(202,163,90,.35);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.72);
}

.zoneChips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 6px;
}
.chip{
  font-size:12px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(202,163,90,.28);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.78);
}

.zoneNote{
  display:flex;
  gap:10px;
  align-items:flex-start;
  margin-top:10px;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.68);
  font-size:12px;
}
.zoneNote .dot{
  width:8px; height:8px; margin-top:4px;
  border-radius:999px;
  background: rgba(226,194,122,.9);
  box-shadow: 0 0 0 4px rgba(226,194,122,.12);
}

.zoneStats{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
  margin:12px 0 0;
}
.stat{
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  border-radius:14px;
  padding:10px;
}
.stat__k{
  font-family:"Cormorant Garamond", serif;
  font-size:20px;
  color: var(--gold2);
  line-height:1.1;
}
.stat__v{ font-size:12px; color: rgba(255,255,255,.62); }

/* Carte design */
.mapMock{
  position:relative;
  height:180px;
  border-radius:14px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  overflow:hidden;
}
.mapMock__glow{
  position:absolute; inset:-40px;
  background:
    radial-gradient(420px 220px at 30% 20%, rgba(226,194,122,.16), transparent 60%),
    radial-gradient(380px 220px at 80% 60%, rgba(202,163,90,.14), transparent 62%);
  opacity:.9;
}
.mapMock__grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 34px 34px;
  opacity:.45;
}
.pin{
  position:absolute;
  width:12px; height:12px;
  border-radius:999px;
  background: rgba(226,194,122,.95);
  box-shadow: 0 0 0 6px rgba(226,194,122,.10), 0 10px 18px rgba(0,0,0,.45);
}
.pin--a{ left:58%; top:38%; }
.pin--b{ left:36%; top:54%; }
.pin--c{ left:52%; top:52%; }
.pin--d{ left:60%; top:60%; }

.mapMock__labels{
  position:absolute;
  left:10px; right:10px; bottom:10px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.mapMock__labels span{
  font-size:12px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.72);
}

/* Liste SEO */
.seoList{
  margin:10px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.seoList li{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.76);
  font-size:13px;
}
.seoDot{
  width:8px; height:8px;
  border-radius:999px;
  background: rgba(226,194,122,.9);
  box-shadow: 0 0 0 4px rgba(226,194,122,.10);
}

@media (max-width: 980px){
  .pageHero{ grid-template-columns: 1fr; }
  .pageHero h1{ font-size:36px; }
  .zonesSeo{ grid-template-columns: 1fr; }
}
/* =========================
   PAGE AVIS (premium + dynamique)
========================= */
.reviewsHero{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  align-items:start;
  padding-top:28px;
}

.reviewsHero h1{
  font-family:"Cormorant Garamond", serif;
  font-size:44px;
  line-height:1.05;
  margin:0 0 10px;
  color: rgba(255,255,255,.92);
}

.reviewsToolbar{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  margin-top:12px;
  flex-wrap:wrap;
}

.filters{display:flex; gap:8px; flex-wrap:wrap}
.filterBtn{
  border:1px solid rgba(202,163,90,.25);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.75);
  padding:9px 12px;
  border-radius:999px;
  cursor:pointer;
  font-weight:700;
  font-size:13px;
}
.filterBtn:hover{border-color: rgba(226,194,122,.75)}
.filterBtn--active{
  border-color: rgba(226,194,122,.85);
  background: rgba(226,194,122,.10);
  color: rgba(255,255,255,.9);
}

.searchBox input{
  width:min(420px, 80vw);
  padding:12px 12px;
  border-radius: 12px;
  border:1px solid rgba(202,163,90,.35);
  background: rgba(10,10,10,.55);
  color: rgba(255,255,255,.9);
  outline:none;
}
.searchBox input:focus{
  border-color: rgba(226,194,122,.75);
  box-shadow: 0 0 0 4px rgba(226,194,122,.12);
}

.reviewsGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:12px;
  margin-top:12px;
}

.reviewCard{
  border:1px solid rgba(202,163,90,.25);
  background: rgba(255,255,255,.02);
  border-radius: 16px;
  padding:14px;
  box-shadow: 0 10px 26px rgba(0,0,0,.35);
  transform: translateY(0);
  transition: transform .18s ease, border-color .18s ease;
}
.reviewCard:hover{
  transform: translateY(-3px);
  border-color: rgba(226,194,122,.55);
}

.reviewCard__top{
  display:flex;
  align-items:center;
  gap:10px;
  justify-content:space-between;
}

.avatar{
  width:38px; height:38px;
  border-radius: 12px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(226,194,122,.10);
  border:1px solid rgba(226,194,122,.25);
  color: var(--gold2);
  font-weight:800;
  flex: 0 0 auto;
}

.who{flex:1; min-width:0}
.who__name{font-weight:800; color: rgba(255,255,255,.9); font-size:13px}
.who__meta{font-size:12px}

.reviewCard__text{
  margin-top:10px;
  color: rgba(255,255,255,.78);
  font-size:13px;
  line-height:1.5;
}

.stars{display:flex; gap:2px; justify-content:flex-end}
.star{opacity:.25}
.star--on{opacity:1; color: var(--gold2)}

.reviewsKpi__top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}

.kpi__label{font-size:12px; color: rgba(255,255,255,.68)}
.kpi__value{
  font-family:"Cormorant Garamond", serif;
  font-size:34px;
  margin:4px 0 2px;
  color: var(--gold2);
  line-height:1;
}

.kpi__bubble{
  border:1px solid rgba(202,163,90,.25);
  background: rgba(255,255,255,.02);
  border-radius: 14px;
  padding:10px 12px;
  text-align:center;
  min-width:88px;
}
.kpi__count{
  font-family:"Cormorant Garamond", serif;
  font-size:30px;
  color: rgba(255,255,255,.92);
  line-height:1;
}
.kpi__small{font-size:12px; color: rgba(255,255,255,.6)}

.bars{margin-top:12px; display:grid; gap:8px}
.barRow{
  display:grid;
  grid-template-columns: 34px 1fr 46px;
  gap:10px;
  align-items:center;
  font-size:13px;
  color: rgba(255,255,255,.78);
}
.bar{
  height:10px;
  border-radius:999px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  overflow:hidden;
}
.bar i{
  display:block;
  height:100%;
  background: linear-gradient(90deg, rgba(226,194,122,.35), rgba(202,163,90,.20));
}

.reviewsKpi__note{margin-top:12px; font-size:12px}

/* rating picker */
.ratingPick{display:flex; gap:6px; margin-top:8px}
.rStar{
  width:36px; height:36px;
  border-radius:12px;
  border:1px solid rgba(202,163,90,.25);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.25);
  cursor:pointer;
  font-size:18px;
  line-height:1;
}
.rStar:hover{border-color: rgba(226,194,122,.65)}
.rStar--on{color: var(--gold2); border-color: rgba(226,194,122,.75); background: rgba(226,194,122,.06)}

@media (max-width: 980px){
  .reviewsHero{grid-template-columns: 1fr}
  .reviewsHero h1{font-size:36px}
  .reviewsGrid{grid-template-columns: 1fr}
}
/* =========================
   CONTACT (page dynamique)
========================= */
.contactHero{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  align-items:start;
  padding-top:28px;
}

.contactHero h1{
  font-family:"Cormorant Garamond", serif;
  font-size:44px;
  line-height:1.05;
  margin:0 0 10px;
  color: rgba(255,255,255,.92);
}

.contactQuick .quickGrid{
  display:grid;
  gap:10px;
  margin-top:10px;
}

.quickCard{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  transition: transform .18s ease, border-color .18s ease;
}
.quickCard:hover{
  transform: translateY(-2px);
  border-color: rgba(226,194,122,.55);
}

.quickCard__icon{
  width:42px; height:42px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(226,194,122,.10);
  border:1px solid rgba(226,194,122,.25);
  color: var(--gold2);
  font-size:18px;
  flex:0 0 auto;
}

.quickCard__body{flex:1; min-width:0}
.quickCard__title{font-weight:800; color: rgba(255,255,255,.9); font-size:13px}
.quickCard__text{font-size:12px}

.quickCard__cta{
  color: rgba(255,255,255,.65);
  font-size:18px;
  flex:0 0 auto;
}

.contactGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:12px;
  margin-top:12px;
}

.contactSide{
  position:relative;
  overflow:hidden;
}

.contactSide::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(900px 240px at 10% 0%, rgba(226,194,122,.12), transparent 60%),
    radial-gradient(900px 240px at 90% 10%, rgba(202,163,90,.10), transparent 55%);
  opacity:.9;
  pointer-events:none;
}

.contactSide > *{ position:relative; }

.sep{
  height:1px;
  background: rgba(202,163,90,.18);
  margin:12px 0;
}

.infoList{display:grid; gap:10px; margin-top:10px}
.infoRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
}
.infoKey{font-size:13px; color: rgba(255,255,255,.78); font-weight:800}
.infoVal{font-size:13px; color: rgba(255,255,255,.65)}

.faq{margin-top:10px}
.faqQ{
  width:100%;
  text-align:left;
  padding:12px 10px;
  border-radius:12px;
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.82);
  font-weight:800;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-top:8px;
}
.faqA{
  max-height:0px;
  overflow:hidden;
  transition: max-height .22s ease;
  padding:0 10px;
}
.faqA.muted{margin-top:8px}

@media (max-width: 980px){
  .contactHero{grid-template-columns: 1fr}
  .contactHero h1{font-size:36px}
  .contactGrid{grid-template-columns: 1fr}
}
/* =========================
   SERVICES (page stylée + dynamique)
========================= */
.servicesHero{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  align-items:start;
  padding-top:28px;
}
.servicesHero h1{
  font-family:"Cormorant Garamond", serif;
  font-size:44px;
  line-height:1.05;
  margin:0 0 10px;
  color: rgba(255,255,255,.92);
}

/* quick contact cards (re-use du style contact) */
.servicesQuick .quickGrid{ display:grid; gap:10px; margin-top:10px; }
.quickCard{
  display:flex; align-items:center; gap:12px;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  transition: transform .18s ease, border-color .18s ease;
}
.quickCard:hover{ transform: translateY(-2px); border-color: rgba(226,194,122,.55); }
.quickCard__icon{
  width:42px; height:42px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(226,194,122,.10);
  border:1px solid rgba(226,194,122,.25);
  color: var(--gold2);
  font-size:18px;
  flex:0 0 auto;
}
.quickCard__body{ flex:1; min-width:0; }
.quickCard__title{ font-weight:800; color: rgba(255,255,255,.9); font-size:13px; }
.quickCard__text{ font-size:12px; }
.quickCard__cta{ color: rgba(255,255,255,.65); font-size:18px; flex:0 0 auto; }

/* toolbar */
.servicesToolbar{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  margin-top:12px;
  flex-wrap:wrap;
}
.tabs{ display:flex; gap:8px; flex-wrap:wrap; }
.tabBtn{
  border:1px solid rgba(202,163,90,.25);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.75);
  padding:9px 12px;
  border-radius:999px;
  cursor:pointer;
  font-weight:800;
  font-size:13px;
}
.tabBtn:hover{ border-color: rgba(226,194,122,.75); }
.tabBtn--active{
  border-color: rgba(226,194,122,.85);
  background: rgba(226,194,122,.10);
  color: rgba(255,255,255,.92);
}
.searchBox input{
  width:min(420px, 80vw);
  padding:12px 12px;
  border-radius: 12px;
  border:1px solid rgba(202,163,90,.35);
  background: rgba(10,10,10,.55);
  color: rgba(255,255,255,.9);
  outline:none;
}
.searchBox input:focus{
  border-color: rgba(226,194,122,.75);
  box-shadow: 0 0 0 4px rgba(226,194,122,.12);
}

/* services cards */
.servicesGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:12px;
  margin-top:12px;
}
.svcCard{
  border:1px solid rgba(202,163,90,.25);
  background: rgba(255,255,255,.02);
  border-radius: 16px;
  padding:14px;
  box-shadow: 0 10px 26px rgba(0,0,0,.35);
  transform: translateY(0);
  transition: transform .18s ease, border-color .18s ease;
  position:relative;
  overflow:hidden;
}
.svcCard::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(700px 220px at 20% 0%, rgba(226,194,122,.10), transparent 60%),
    radial-gradient(700px 220px at 90% 10%, rgba(202,163,90,.09), transparent 55%);
  opacity:.9;
  pointer-events:none;
}
.svcCard > *{ position:relative; }

.svcCard:hover{ transform: translateY(-3px); border-color: rgba(226,194,122,.55); }
.svcCard__top{ display:flex; gap:10px; align-items:center; }
.svcIcon{
  width:42px; height:42px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(226,194,122,.10);
  border:1px solid rgba(226,194,122,.25);
  color: var(--gold2);
  font-size:18px;
  flex:0 0 auto;
}
.svcTitle{ font-weight:900; color: rgba(255,255,255,.92); font-size:13px; }
.svcDesc{ margin-top:10px; font-size:13px; line-height:1.5; }
.svcTags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.svcTag{
  font-size:12px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.72);
}

/* packs */
.packsGrid{ align-items:stretch; }
.pack{ position:relative; overflow:hidden; }
.pack__top{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.pack__name{
  font-family:"Cormorant Garamond", serif;
  font-size:26px;
  color: rgba(255,255,255,.92);
}
.pack__pill{
  font-size:12px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(202,163,90,.35);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.72);
}
.pack__pill--gold{
  border-color: rgba(226,194,122,.7);
  background: rgba(226,194,122,.10);
  color: rgba(255,255,255,.86);
}
.pack__list{
  margin:10px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.pack__list li{
  display:flex; gap:10px; align-items:flex-start;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.76);
  font-size:13px;
}
.tick{
  width:18px; height:18px;
  border-radius:6px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(226,194,122,.10);
  border:1px solid rgba(226,194,122,.25);
  color: var(--gold2);
  flex:0 0 auto;
}
.pack--focus{
  border:1px solid rgba(226,194,122,.55);
  background: rgba(226,194,122,.04);
}

/* timeline */
.timeline{ margin-top:12px; display:grid; gap:12px; }
.tItem{ display:grid; grid-template-columns: 18px 1fr; gap:12px; align-items:stretch; }
.tDot{
  width:12px; height:12px; margin-top:14px;
  border-radius:999px;
  background: rgba(226,194,122,.9);
  box-shadow: 0 0 0 4px rgba(226,194,122,.12);
}
.tCard{
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  border-radius:14px;
  padding:12px;
}
.tTitle{
  font-weight:900;
  color: rgba(255,255,255,.90);
  margin-bottom:6px;
}

/* FAQ accordion (même style que contact) */
.faq{ margin-top:10px; }
.faqQ{
  width:100%;
  text-align:left;
  padding:12px 10px;
  border-radius:12px;
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.82);
  font-weight:900;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-top:8px;
}
.faqA{
  max-height:0px;
  overflow:hidden;
  transition: max-height .22s ease;
  padding:0 10px;
}

@media (max-width: 980px){
  .servicesHero{ grid-template-columns: 1fr; }
  .servicesHero h1{ font-size:36px; }
  .servicesGrid{ grid-template-columns: 1fr; }
}
.brand{
display:flex;
align-items:center;
gap:12px;
text-decoration:none;
}

.brand:hover{
opacity:0.9;
transform:scale(1.02);
transition:0.2s;
}
.brand__text{
  text-decoration: none;
  color: inherit;
  display: block;
}

.brand__text:hover .brand__name{
  opacity: .95;
}

.brand__text:hover .brand__tag{
  color: rgba(255,255,255,.75);
}
/* FIX: clic menu (évite les superpositions) */
.topbar { z-index: 9999; }
.brand { position: relative; z-index: 10000; }
.nav { position: relative; z-index: 10001; }
.nav a { position: relative; z-index: 10002; }
/* FIX: overlays décoratifs ne doivent jamais capter les clics */
.card::before,
.zoneCard::before,
.contactSide::before,
.heroCard::before,
.svcCard::before{
  pointer-events: none;
}
/* =========================
   ACCUEIL LÉGER (vitrine)
========================= */
.homeLite{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:16px;
  align-items:stretch;
  padding-top: 22px;
}

.homeLite__media{
  display:grid;
  grid-template-columns: 1.3fr .7fr;
  gap:12px;
}

.homeLite__stack{
  display:grid;
  grid-template-rows: 1fr 1fr;
  gap:12px;
}

.homeLite__img{
  border-radius: 18px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  overflow:hidden;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  min-height: 150px;
}
.homeLite__img--big{ min-height: 340px; }

.homeLite__img img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.homeLite__content{
  border:1px solid rgba(202,163,90,.22);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.homeLite__title{
  font-family:"Cormorant Garamond", serif;
  font-size:44px;
  line-height:1.05;
  margin:0 0 8px;
  color: rgba(255,255,255,.92);
}

.homeLite__subtitle{
  margin:0;
  font-size:14px;
}

.homeLite__chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top: 14px;
}

.chip{
  font-size:12px;
  color: rgba(255,255,255,.72);
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.02);
}

.homeLiteBand{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:12px;
}

.homeLiteBand__item{
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  border-radius: 16px;
  padding:12px;
  display:flex;
  gap:10px;
  align-items:center;
}

.homeLiteBand__k{
  width:22px; height:22px;
  border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(226,194,122,.10);
  border:1px solid rgba(226,194,122,.25);
  color: var(--gold2);
  flex:0 0 auto;
}

.homeLiteBand__v{
  font-weight:800;
  color: rgba(255,255,255,.85);
  font-size:13px;
}

@media (max-width: 980px){
  .homeLite{ grid-template-columns: 1fr; }
  .homeLite__media{ grid-template-columns: 1fr; }
  .homeLite__img--big{ min-height: 220px; }
  .homeLiteBand{ grid-template-columns: 1fr; }
}
/* ===== MENU MOBILE ===== */
.menuToggle{
  display:none;
  background: transparent;
  border: 1px solid rgba(202,163,90,.35);
  color: rgba(255,255,255,.9);
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 20px;
  cursor: pointer;
}

@media (max-width: 720px){
  .menuToggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }

  /* on cache le menu normal */
  .nav{
    display:none !important;
    position:absolute;
    top:64px;
    right:12px;
    width: min(260px, calc(100vw - 24px));
    background: rgba(11,11,12,.96);
    border:1px solid rgba(202,163,90,.35);
    border-radius: 16px;
    padding: 10px;
    flex-direction: column;
    gap: 6px;
    z-index: 10002;
    box-shadow: 0 18px 60px rgba(0,0,0,.55);
  }

  /* menu ouvert */
  .nav.active{
    display:flex !important;
  }

  .nav a{
    padding: 12px 12px;
    border-radius: 12px;
    font-size: 16px;
    color: rgba(255,255,255,.85);
    border: 1px solid transparent;
  }

  .nav a:hover{
    border-color: rgba(202,163,90,.35);
    background: rgba(255,255,255,.03);
  }
}/* ===== MENU MOBILE ===== */
.menuToggle{
  display:none;
  background: transparent;
  border: 1px solid rgba(202,163,90,.35);
  color: rgba(255,255,255,.9);
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 20px;
  cursor: pointer;
}

@media (max-width: 720px){
  .menuToggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }

  .nav{
    display:none !important;
    position:absolute;
    top:64px;
    right:12px;
    width: min(260px, calc(100vw - 24px));
    background: rgba(11,11,12,.96);
    border:1px solid rgba(202,163,90,.35);
    border-radius: 16px;
    padding: 10px;
    flex-direction: column;
    gap: 6px;
    z-index: 10002;
    box-shadow: 0 18px 60px rgba(0,0,0,.55);
  }

  .nav.active{
    display:flex !important;
  }

  .nav a{
    padding: 12px 12px;
    border-radius: 12px;
    font-size: 16px;
    color: rgba(255,255,255,.85);
    border: 1px solid transparent;
  }

  .nav a:hover{
    border-color: rgba(202,163,90,.35);
    background: rgba(255,255,255,.03);
  }
}
/* =========================
   ACCUEIL HERO IMAGE PREMIUM
========================= */

.homeLite{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:28px;
  align-items:center;
  padding-top:28px;
}

.homeHeroMedia{
  position:relative;
}

.homeHeroMedia__frame{
  position:relative;
  margin:0;
  height:430px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(202,163,90,.28);
  background: rgba(255,255,255,.02);
  box-shadow:
    0 24px 70px rgba(0,0,0,.45),
    0 0 0 1px rgba(226,194,122,.06) inset;
}

.homeHeroMedia__frame::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.22)),
    radial-gradient(800px 280px at 20% 0%, rgba(226,194,122,.12), transparent 60%);
  z-index:1;
  pointer-events:none;
}

.homeHeroMedia__frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  transform:scale(1.02);
}

.homeLite__content{
  min-height:430px;
  border:1px solid rgba(202,163,90,.22);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  border-radius:28px;
  padding:26px;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.homeLite__title{
  font-family:"Cormorant Garamond", serif;
  font-size:64px;
  line-height:.95;
  margin:0 0 12px;
  color: rgba(255,255,255,.94);
  letter-spacing:-0.5px;
}

.homeLite__subtitle{
  margin:0;
  font-size:18px;
  color: rgba(255,255,255,.76);
}

.homeLite__chips{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}

.homeLiteBand{
  margin-top:16px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}

.homeLiteBand__item{
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  border-radius:18px;
  padding:14px 16px;
  display:flex;
  gap:12px;
  align-items:center;
}

.homeLiteBand__k{
  width:26px;
  height:26px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(226,194,122,.10);
  border:1px solid rgba(226,194,122,.25);
  color: var(--gold2);
  font-weight:800;
  flex:0 0 auto;
}

.homeLiteBand__v{
  font-weight:800;
  color: rgba(255,255,255,.88);
  font-size:15px;
}

/* tablette */
@media (max-width: 1100px){
  .homeLite{
    grid-template-columns: 1fr;
    gap:18px;
  }

  .homeHeroMedia__frame{
    height:360px;
  }

  .homeLite__content{
    min-height:auto;
  }

  .homeLite__title{
    font-size:52px;
  }
}

/* smartphone */
@media (max-width: 720px){
  .homeLite{
    grid-template-columns: 1fr;
    gap:16px;
    padding-top:18px;
  }

  .homeHeroMedia__frame{
    height:300px;
    border-radius:22px;
  }

  .homeLite__content{
    border-radius:22px;
    padding:20px;
    min-height:auto;
  }

  .homeLite__title{
    font-size:42px;
    line-height:1;
  }

  .homeLite__subtitle{
    font-size:16px;
  }

  .row{
    flex-direction:column;
  }

  .btn,
  .btn--primary{
    width:100%;
    justify-content:center;
  }

  .homeLiteBand{
    grid-template-columns: 1fr;
    gap:10px;
  }

  .homeLiteBand__item{
    padding:13px 14px;
  }

  .homeLiteBand__v{
    font-size:14px;
  }
}
/* =========================
   ACCUEIL COMPLET
========================= */

.homeSection{
  margin-top:60px;
}

.sectionHead{
  margin-bottom:22px;
}

.sectionHead--center{
  text-align:center;
  max-width:860px;
  margin:0 auto 24px;
}

.sectionHead--left{
  max-width:760px;
}

.sectionEyebrow{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:1.6px;
  color: var(--gold2);
  margin-bottom:10px;
  font-weight:800;
}

.sectionLead{
  max-width:760px;
  margin:10px auto 0;
  color: rgba(255,255,255,.68);
  font-size:15px;
  line-height:1.7;
}

.sectionLead--left{
  margin-left:0;
  margin-right:0;
}

/* services complémentaires */
.extrasGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  margin-top:18px;
}

.extraItem{
  display:flex;
  gap:14px;
  align-items:flex-start;
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  border-radius:18px;
  padding:18px;
  transition: transform .18s ease, border-color .18s ease;
}

.extraItem:hover{
  transform: translateY(-3px);
  border-color: rgba(226,194,122,.45);
}

.extraIcon{
  width:42px;
  height:42px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(226,194,122,.10);
  border:1px solid rgba(226,194,122,.25);
  flex:0 0 auto;
  font-size:18px;
}

.extraItem h3{
  margin:0 0 6px;
  font-size:16px;
  color: rgba(255,255,255,.9);
}

.extraItem p{
  margin:0;
  color: rgba(255,255,255,.62);
  font-size:13px;
  line-height:1.6;
}

/* bloc personnalisé */
.homeSplit{
  margin-top:68px;
}

.homeSplit__content{
  border:1px solid rgba(202,163,90,.18);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border-radius:24px;
  padding:28px;
  box-shadow: 0 18px 60px rgba(0,0,0,.24);
}

.featureCards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  margin-top:20px;
}

.featureCard{
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  border-radius:18px;
  padding:22px 18px;
  text-align:center;
}

.featureCard__icon{
  width:54px;
  height:54px;
  margin:0 auto 14px;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(226,194,122,.10);
  border:1px solid rgba(226,194,122,.25);
  font-size:22px;
}

.featureCard h3{
  margin:0 0 10px;
  font-size:18px;
  color: rgba(255,255,255,.92);
}

.featureCard p{
  margin:0;
  color: rgba(255,255,255,.62);
  font-size:13px;
  line-height:1.7;
}

/* process */
.homeProcess{
  margin-top:68px;
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  gap:28px;
  align-items:center;
}

.homeProcess--reverse{
  grid-template-columns: 1.05fr .95fr;
}

.homeProcess--reverse .homeProcess__media{
  order:2;
}
.homeProcess--reverse .homeProcess__text{
  order:1;
}

.homeProcess__image{
  margin:0;
  height:360px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
}

.homeProcess__image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.homeProcess__text h2{
  margin-top:0;
}

.miniPoints{
  display:grid;
  gap:10px;
  margin-top:18px;
}

.miniPoint{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  color: rgba(255,255,255,.78);
  font-size:14px;
  font-weight:700;
}

/* bannière avis */
.homeReviewBanner{
  position:relative;
  margin-top:72px;
  border:1px solid rgba(202,163,90,.18);
  border-radius:28px;
  overflow:hidden;
  background: rgba(255,255,255,.02);
  min-height:380px;
}

.homeReviewBanner__media{
  position:absolute;
  inset:0;
}

.homeReviewBanner__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  opacity:.58;
}

.homeReviewBanner__card{
  position:relative;
  z-index:2;
  max-width:420px;
  margin-left:auto;
  margin-right:28px;
  margin-top:28px;
  margin-bottom:28px;
  border:1px solid rgba(202,163,90,.18);
  background: rgba(11,11,12,.78);
  backdrop-filter: blur(8px);
  border-radius:24px;
  padding:24px;
  box-shadow: 0 18px 60px rgba(0,0,0,.28);
}

.homeReviewBanner__card h2{
  margin-top:0;
}

.homeReviewBanner__card p{
  color: rgba(255,255,255,.68);
  line-height:1.7;
  font-size:14px;
}

/* témoignages */
.homeTestimonials{
  margin-top:68px;
}

.testimonialGrid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  margin-top:18px;
}

.testimonialCard{
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  border-radius:20px;
  padding:20px;
  box-shadow: 0 10px 26px rgba(0,0,0,.22);
}

.testimonialTop{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}

.testimonialName{
  font-weight:800;
  color: rgba(255,255,255,.9);
  font-size:14px;
}

.testimonialStars{
  color: var(--gold2);
  letter-spacing:2px;
  font-size:14px;
}

.testimonialCard h3{
  margin:0 0 10px;
  font-size:20px;
  line-height:1.25;
  color: rgba(255,255,255,.94);
}

.testimonialCard p{
  margin:0;
  color: rgba(255,255,255,.64);
  line-height:1.7;
  font-size:14px;
}

/* faq intro */
.homeFaqIntro{
  margin-top:68px;
}

.faqInfoGrid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:16px;
  margin-top:20px;
}

.faqInfoCard{
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  border-radius:20px;
  padding:22px;
}

.faqInfoCard h3{
  margin:0 0 10px;
  font-size:22px;
  color: rgba(255,255,255,.92);
}

.faqInfoCard p{
  margin:0;
  color: rgba(255,255,255,.64);
  font-size:14px;
  line-height:1.8;
}

/* questions */
.homeQuestions{
  margin-top:68px;
}

.questionCols{
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap:18px;
  margin-top:20px;
}

.questionList{
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  border-radius:22px;
  padding:20px;
}

.questionGroupTitle{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:1.4px;
  color: var(--gold2);
  font-weight:800;
  margin:6px 0 10px;
}

.questionItem{
  display:block;
  padding:13px 0;
  border-bottom:1px solid rgba(202,163,90,.12);
  color: rgba(255,255,255,.76);
  font-size:14px;
}

.questionItem:last-child{
  border-bottom:none;
}

.questionAnswer{
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  border-radius:22px;
  padding:24px;
}

.questionAnswer h3{
  margin:0 0 12px;
  font-size:32px;
  line-height:1.15;
  color: rgba(255,255,255,.94);
}

.questionAnswer p{
  margin:0 0 12px;
  color: rgba(255,255,255,.64);
  font-size:14px;
  line-height:1.8;
}

/* à propos */
.homeAbout{
  margin-top:72px;
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  gap:28px;
  align-items:center;
}

.homeAbout__image{
  margin:0;
  height:420px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
}

.homeAbout__image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.statsRow{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:12px;
  margin-top:22px;
}

.statBox{
  border:1px solid rgba(202,163,90,.18);
  background: rgba(255,255,255,.02);
  border-radius:18px;
  padding:16px;
}

.statBox__n{
  font-family:"Cormorant Garamond", serif;
  font-size:34px;
  color: var(--gold2);
  line-height:1;
}

.statBox__t{
  margin-top:8px;
  color: rgba(255,255,255,.64);
  font-size:13px;
}

/* cta final */
.homeFinalCta{
  margin-top:74px;
}

.homeFinalCta__inner{
  border:1px solid rgba(202,163,90,.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)),
    radial-gradient(900px 260px at 20% 0%, rgba(226,194,122,.10), transparent 60%);
  border-radius:28px;
  padding:30px;
  box-shadow: 0 18px 60px rgba(0,0,0,.28);
}

.homeFinalCta__inner h2{
  margin-top:0;
}

.homeFinalCta__inner p{
  max-width:720px;
  color: rgba(255,255,255,.68);
  line-height:1.8;
  font-size:15px;
}

.homeFinalCta__actions{
  display:flex;
  gap:12px;
  margin-top:18px;
}

.homeFinalCta__meta{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:18px;
  margin-top:30px;
  padding-top:22px;
  border-top:1px solid rgba(202,163,90,.14);
}

.metaTitle{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:1.4px;
  color: var(--gold2);
  margin-bottom:10px;
  font-weight:800;
}

.metaText{
  color: rgba(255,255,255,.66);
  font-size:14px;
  line-height:1.8;
}

/* responsive accueil */
@media (max-width: 1100px){
  .extrasGrid,
  .featureCards,
  .testimonialGrid{
    grid-template-columns: repeat(2, 1fr);
  }

  .homeProcess,
  .homeProcess--reverse,
  .homeAbout,
  .questionCols{
    grid-template-columns: 1fr;
  }

  .homeProcess--reverse .homeProcess__media,
  .homeProcess--reverse .homeProcess__text{
    order:initial;
  }

  .statsRow,
  .homeFinalCta__meta{
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 720px){
  .homeSection,
  .homeSplit,
  .homeProcess,
  .homeReviewBanner,
  .homeTestimonials,
  .homeFaqIntro,
  .homeQuestions,
  .homeAbout,
  .homeFinalCta{
    margin-top:46px;
  }

  .sectionLead{
    font-size:14px;
  }

  .extrasGrid,
  .featureCards,
  .testimonialGrid,
  .faqInfoGrid,
  .statsRow,
  .homeFinalCta__meta{
    grid-template-columns: 1fr;
  }

  .extraItem,
  .featureCard,
  .testimonialCard,
  .faqInfoCard,
  .questionList,
  .questionAnswer,
  .homeSplit__content,
  .homeFinalCta__inner{
    border-radius:18px;
  }

  .homeProcess__image,
  .homeAbout__image{
    height:260px;
    border-radius:22px;
  }

  .homeReviewBanner{
    min-height:auto;
    border-radius:22px;
  }

  .homeReviewBanner__media{
    position:relative;
    height:240px;
  }

  .homeReviewBanner__card{
    margin:0;
    max-width:none;
    border-radius:0 0 22px 22px;
    background: rgba(11,11,12,.88);
  }

  .questionAnswer h3{
    font-size:26px;
  }

  .homeFinalCta__actions{
    flex-direction:column;
  }
}
/* =========================
   ZONES - VRAIE CARTE FRANCE
========================= */

.zoneCoverageCard{
  overflow:hidden;
}

.zoneFlag{
  display:flex;
  justify-content:flex-end;
}

.zoneFlag span{
  height:42px;
  padding:0 16px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(226,194,122,.55);
  background: rgba(226,194,122,.08);
  color: var(--gold2);
  font-size:14px;
  font-weight:800;
  box-shadow: 0 0 0 4px rgba(226,194,122,.08);
}



.cityPin::after{
  content:"";
  position:absolute;
  inset:-3px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.20);
}

/* Placement ajusté pour l’image fournie */
.cityPin--montpellier{ left:59.5%; top:72.5%; }
.cityPin--beziers{ left:54.5%; top:73%; }
.cityPin--sete{ left:57.5%; top:72.4%; }
.cityPin--agde{ left:61.8%; top:73.8%; }
.cityPin--nimes{ left:62.5%; top:67.5%; }
.cityPin--carcassonne{ left:47%; top:72.5%; }
.cityPin--rodez{ left:50.8%; top:60%; }

.realMapLegend{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.realMapLegend span{
  font-size:12px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.76);
}

/* mobile */
@media (max-width: 720px){
  .zoneFlag{
    justify-content:flex-start;
    margin-top:8px;
  }

  .zoneFlag span{
    height:38px;
    font-size:13px;
    padding:0 14px;
  }

  .realMapCard{
    padding:12px;
    border-radius:16px;
  }

  .realMapFigure{
    height:220px;
    border-radius:14px;
  }

  .cityPin{
    width:10px;
    height:10px;
  }

  .realMapLegend{
    gap:6px;
  }

  .realMapLegend span{
    font-size:11px;
    padding:6px 8px;
  }
}
/* =========================
   CARTE FRANCE ZONES
========================= */

.mapFranceContainer{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  padding:10px;
  background:
    radial-gradient(circle at 30% 20%, rgba(226,194,122,.08), transparent 60%),
    rgba(255,255,255,.02);
  border:1px solid rgba(202,163,90,.25);
}

.mapFranceImage{
  width:100%;
  height:auto;
  display:block;
  filter: drop-shadow(0 25px 40px rgba(0,0,0,.45));
  transition: transform .4s ease;
}

.mapFranceContainer:hover .mapFranceImage{
  transform: scale(1.03);
}
/* =========================
   CARTE FRANCE ZONES
========================= */

.zoneCoverageCard{
  overflow:hidden;
}

.zoneFlag{
  display:flex;
  justify-content:flex-end;
}

.zoneFlag span{
  height:42px;
  padding:0 16px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(226,194,122,.55);
  background: rgba(226,194,122,.08);
  color: var(--gold2);
  font-size:14px;
  font-weight:800;
  box-shadow: 0 0 0 4px rgba(226,194,122,.08);
}

.mapFranceContainer{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  padding:10px;
  background:
    radial-gradient(circle at 30% 20%, rgba(226,194,122,.08), transparent 60%),
    rgba(255,255,255,.02);
  border:1px solid rgba(202,163,90,.25);
}

.mapFranceImage{
  width:100%;
  height:auto;
  display:block;
  filter: drop-shadow(0 25px 40px rgba(0,0,0,.45));
  transition: transform .4s ease;
}

.mapFranceContainer:hover .mapFranceImage{
  transform: scale(1.03);
}

@media (max-width: 720px){
  .zoneFlag{
    justify-content:flex-start;
    margin-top:8px;
  }

  .zoneFlag span{
    height:38px;
    font-size:13px;
    padding:0 14px;
  }

  .mapFranceContainer{
    border-radius:16px;
    padding:8px;
  }
}
.quoteActions{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:14px;
}

.quoteActions .btn{
  width:100%;
  text-align:center;
}
.quoteActions{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:14px;
}

.quoteActions .btn{
  width:100%;
  text-align:center;
}

.visitPlanner{
  margin-top:14px;
  padding:14px;
  border:1px solid rgba(202,163,90,.22);
  background: rgba(255,255,255,.02);
  border-radius:14px;
}

.visitPlanner__title{
  font-size:14px;
  font-weight:800;
  color: rgba(255,255,255,.88);
  margin-bottom:8px;
}
/* =========================
   POPUP VISITE TECHNIQUE
========================= */

.visitPlanner{
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(.96);
  width: min(560px, calc(100vw - 28px));
  max-height: min(80vh, 760px);
  overflow: auto;
  z-index: 10050;
  margin: 0;
  padding: 18px;
  border: 1px solid rgba(202,163,90,.28);
  background:
    linear-gradient(180deg, rgba(18,18,18,.98), rgba(10,10,10,.97));
  border-radius: 18px;
  box-shadow: 0 30px 80px rgba(0,0,0,.55);
  opacity: 1;
  transition: opacity .18s ease, transform .18s ease;
}

.visitPlanner.hidden{
  display: none !important;
}

.visitPlanner__title{
  font-size: 16px;
  font-weight: 800;
  color: rgba(255,255,255,.92);
  margin-bottom: 10px;
}

.visitPlanner::before{
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(4px);
}

.visitPlanner__close{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(202,163,90,.28);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.86);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
}

.visitPlanner__close:hover{
  border-color: rgba(226,194,122,.75);
}

.visitPlanner .row{
  margin-top: 12px;
}

.visitPlannerAgenda{
  margin-top: 12px;
}

.visitPlannerAgenda .btn{
  width: 100%;
  text-align: center;
}

body.modal-open{
  overflow: hidden;
}

@media (max-width: 720px){
  .visitPlanner{
    width: calc(100vw - 20px);
    padding: 16px;
    border-radius: 16px;
  }

  .visitPlanner__title{
    font-size: 15px;
    padding-right: 34px;
  }
}
/* =========================
   POPUP VISITE TECHNIQUE PREMIUM
========================= */

.visitPlanner{
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(560px, calc(100vw - 28px));
  max-height: min(82vh, 760px);
  overflow: visible;
  z-index: 10050;
  margin: 0;
  padding: 22px;
  border: 1px solid rgba(202,163,90,.30);
  background:
    radial-gradient(700px 220px at 20% 0%, rgba(226,194,122,.09), transparent 60%),
    linear-gradient(180deg, rgba(18,18,18,.99), rgba(8,8,8,.98));
  border-radius: 22px;
  box-shadow:
    0 30px 80px rgba(0,0,0,.58),
    0 0 0 1px rgba(255,255,255,.02) inset;
  animation: visitPopupIn .18s ease forwards;
}

.visitPlanner.hidden{
  display: none !important;
}

@keyframes visitPopupIn{
  from{
    opacity: 0;
    transform: translate(-50%, -50%) scale(.94);
  }
  to{
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
}

.visitPlanner::before{
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at center, rgba(0,0,0,.24), rgba(0,0,0,.78)),
    rgba(0,0,0,.64);
  backdrop-filter: blur(6px);
}

.visitPlanner__close{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid rgba(202,163,90,.28);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.9);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
  z-index: 3;
  transition: .18s ease;
}

.visitPlanner__close:hover{
  border-color: rgba(226,194,122,.75);
  background: rgba(226,194,122,.08);
  transform: scale(1.04);
}

.visitPlanner__title{
  font-size: 18px;
  font-weight: 800;
  color: rgba(255,255,255,.96);
  margin-bottom: 14px;
  padding-right: 46px;
  letter-spacing: .2px;
}

/* grille popup */
.visitPlanner .grid2{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 8px;
}

.visitPlanner .field{
  margin-top: 0;
}

.visitPlanner .field span{
  display: block;
  font-size: 12px;
  color: rgba(255,255,255,.72);
  margin-bottom: 6px;
}

/* champs */
.visitPlanner .field input,
.visitPlanner .field select{
  width: 100%;
  height: 48px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid rgba(202,163,90,.35);
  background: rgba(11,11,11,.92) !important;
  color: rgba(255,255,255,.92) !important;
  outline: none;
  box-shadow: none;
  font-size: 15px;
}

/* focus */
.visitPlanner .field input:focus,
.visitPlanner .field select:focus{
  border-color: rgba(226,194,122,.78);
  box-shadow: 0 0 0 4px rgba(226,194,122,.10);
}

/* select natif */
.visitPlanner .field select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(226,194,122,.85) 50%),
    linear-gradient(135deg, rgba(226,194,122,.85) 50%, transparent 50%);
  background-position:
    calc(100% - 20px) 20px,
    calc(100% - 14px) 20px;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 42px;
}

.visitPlanner .field select option{
  background: #111;
  color: #fff;
}

/* champ date */
.visitPlanner .field input[type="date"]{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: textfield;
  position: relative;
  padding-right: 48px;
}

/* icône calendrier native : on la rend discrète mais visible */
.visitPlanner .field input[type="date"]::-webkit-calendar-picker-indicator{
  opacity: 0.01;
  position: absolute;
  right: 10px;
  width: 28px;
  height: 28px;
  cursor: pointer;
}

/* icône calendrier designée */
.visitPlanner .fieldDate{
  position: relative;
}

.visitPlanner .fieldDate::after{
  content: "📅";
  position: absolute;
  right: 14px;
  top: 37px;
  transform: translateY(-50%);
  font-size: 18px;
  pointer-events: none;
  opacity: .95;
}

/* lignes / boutons */
.visitPlanner .row{
  margin-top: 14px;
}

.visitPlanner .hint{
  margin-top: 12px;
  line-height: 1.5;
  color: rgba(255,255,255,.72);
}

.visitPlannerAgenda{
  margin-top: 12px;
}

.visitAgendaBtn{
  width: 100%;
  text-align: center;
  border-color: rgba(226,194,122,.55);
  background: rgba(226,194,122,.08);
}

.visitAgendaBtn:hover{
  border-color: rgba(226,194,122,.85);
  background: rgba(226,194,122,.14);
}

body.modal-open{
  overflow: hidden;
}

@media (max-width: 720px){
  .visitPlanner{
    width: calc(100vw - 20px);
    padding: 16px;
    border-radius: 18px;
  }

  .visitPlanner .grid2{
    grid-template-columns: 1fr;
  }

  .visitPlanner__title{
    font-size: 16px;
    padding-right: 38px;
  }

  .visitPlanner__close{
    width: 36px;
    height: 36px;
    font-size: 20px;
  }
}