:root{
  --bg:#050b18;
  --bg2:#081426;
  --card:#0d1b31cc;
  --text:#f7fbff;
  --muted:#a9b6c8;
  --line:#ffffff1f;
  --blue:#18b7ff;
  --cyan:#55f0ff;
  --lime:#c7ff4b;
  --white:#fff;
  --shadow:0 24px 80px #0008;
  --radius:28px;
  --max:1180px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.55;overflow-x:hidden}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}.container{width:min(var(--max),calc(100% - 40px));margin-inline:auto}.skip{position:absolute;left:-999px;top:12px;background:#fff;color:#000;padding:10px 14px;border-radius:999px;z-index:20}.skip:focus{left:12px}.site-header{position:fixed;inset:0 0 auto 0;z-index:10;transition:.25s;background:linear-gradient(#050b18d9,#050b1800);backdrop-filter:blur(0)}.site-header.scrolled{background:#050b18d9;backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.header-inner{height:82px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand img{width:190px;height:auto;filter:drop-shadow(0 0 18px #26c8ff55)}.nav{display:flex;align-items:center;gap:22px;color:var(--muted);font-size:15px}.nav a:hover{color:#fff}.nav-cta{color:#06111f!important;background:linear-gradient(135deg,var(--cyan),var(--blue));padding:11px 18px;border-radius:999px;font-weight:800}.menu-btn{display:none;background:#ffffff12;color:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 14px}.hero{position:relative;min-height:100vh;padding:150px 0 90px;display:grid;align-items:center;overflow:hidden}.hero-bg{position:absolute;inset:0;background:linear-gradient(90deg,#050b18 0%,#050b18e8 42%,#050b1865 100%),url("img/bg.jpg") center/cover;transform:scale(1.03)}.hero:after{content:"";position:absolute;width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,var(--blue),transparent 65%);filter:blur(80px);opacity:.28;right:-180px;top:12%}.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.08fr .72fr;align-items:center;gap:48px}.eyebrow{margin:0 0 14px;color:var(--cyan);text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:900}h1,h2,h3,p{margin-top:0}h1{font-size:clamp(44px,7vw,82px);line-height:.94;letter-spacing:-.06em;margin-bottom:24px;max-width:850px}h2{font-size:clamp(32px,5vw,58px);line-height:1;letter-spacing:-.045em;margin-bottom:18px}h3{font-size:24px;line-height:1.1;margin-bottom:10px}.lead{font-size:clamp(18px,2vw,23px);color:#d9e7f6;max-width:710px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:14px 22px;border-radius:999px;font-weight:850;border:1px solid transparent;transition:.2s}.btn:hover{transform:translateY(-2px)}.primary{background:linear-gradient(135deg,var(--cyan),var(--blue));color:#03101e;box-shadow:0 12px 40px #18b7ff44}.secondary{background:#ffffff12;border-color:var(--line);color:#fff;backdrop-filter:blur(16px)}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:32px 0}.proof-row{display:flex;gap:12px;flex-wrap:wrap}.proof-row span{border:1px solid var(--line);background:#ffffff0e;padding:10px 13px;border-radius:999px;color:#d7e5f5;font-size:14px}.hero-card{position:relative;border:1px solid var(--line);background:linear-gradient(180deg,#ffffff18,#ffffff08);border-radius:var(--radius);padding:10px;box-shadow:var(--shadow);backdrop-filter:blur(20px)}.hero-card img{height:min(620px,72vh);width:100%;object-fit:cover;border-radius:22px}.floating-card{position:absolute;left:-22px;bottom:34px;background:#f7fbff;color:#06111f;border-radius:22px;padding:16px 18px;width:230px;box-shadow:0 18px 60px #0007}.floating-card strong,.floating-card span{display:block}.floating-card span{color:#47576b;font-size:14px}.section{padding:96px 0}.section-head{max-width:790px;margin-bottom:36px}.section-head p{color:var(--muted);font-size:18px}.trustbar{padding:34px 0;background:#071426;border-block:1px solid var(--line)}.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.trust-grid div{padding:22px;border:1px solid var(--line);border-radius:22px;background:#ffffff08}.metric{font-size:32px;font-weight:950;color:#fff;letter-spacing:-.04em}.trust-grid p{margin:4px 0 0;color:var(--muted)}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.service-card{background:linear-gradient(180deg,#ffffff12,#ffffff07);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 18px 60px #0004}.service-card img{height:280px;width:100%;object-fit:cover}.service-card div{padding:24px}.service-card p,.split p,.review-card p,.about p{color:var(--muted)}.dark-band{background:radial-gradient(circle at 20% 20%,#18b7ff30,transparent 35%),linear-gradient(135deg,#071426,#050b18);border-block:1px solid var(--line)}.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.benefits{display:grid;gap:14px}.benefits p{margin:0;padding:18px 20px;border:1px solid var(--line);border-radius:20px;background:#ffffff0b;color:#eaf5ff}.gallery{display:grid;grid-template-columns:1.25fr .75fr;grid-auto-rows:310px;gap:18px}.gallery img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line)}.gallery .wide{grid-row:span 2}.reviews{background:#071426;overflow:hidden}.reviews-layout{display:grid;grid-template-columns:.78fr 1.22fr;gap:34px;align-items:center}.reviews-intro p:not(.eyebrow){color:var(--muted);font-size:18px}.reviews-carousel{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(285px,1fr);gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 22px;overscroll-behavior-x:contain;scrollbar-width:thin}.reviews-carousel::-webkit-scrollbar{height:8px}.reviews-carousel::-webkit-scrollbar-thumb{background:#ffffff25;border-radius:999px}.review-card{scroll-snap-align:start;min-height:255px;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,#ffffff12,#ffffff08);padding:30px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 18px 60px #0004}.stars{color:var(--lime);font-size:28px;letter-spacing:.08em}.review-author{display:inline-flex;width:max-content;margin-top:18px;padding:8px 12px;border-radius:999px;border:1px solid var(--line);color:#dcecff;background:#ffffff0c;font-size:13px;font-weight:800}.score{display:block;font-size:clamp(42px,6vw,70px);line-height:.9;font-weight:950;letter-spacing:-.06em;color:#fff}.reviews-title-row{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:start}.rating-badge{min-width:138px;border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,#ffffff18,#ffffff09);padding:16px 18px;box-shadow:0 18px 60px #0003}.rating-score{display:block;font-size:42px;line-height:.9;font-weight:950;letter-spacing:-.06em;color:#fff}.rating-stars{display:block;color:var(--lime);font-size:16px;letter-spacing:.08em;margin-top:9px}.rating-label{display:block;color:var(--muted);font-size:13px;font-weight:800;margin-top:4px}.text-link{color:var(--cyan);font-weight:800}.about-grid{align-items:center}.portrait{border-radius:var(--radius);height:560px;width:100%;object-fit:cover;border:1px solid var(--line);box-shadow:var(--shadow)}.contact-section{background:radial-gradient(circle at 85% 0,#55f0ff22,transparent 34%)}.contact-grid{display:grid;grid-template-columns:.85fr 1fr;gap:34px}
.contact-photo{margin-top:26px;max-width:420px;height:260px;}
.contact-photo img{width:100%;height:100%;object-fit:cover;border-radius:inherit;}
.contact-lines{display:grid;gap:10px;margin-top:24px}.contact-lines a,.contact-lines span{padding:15px 18px;border-radius:18px;background:#ffffff0c;border:1px solid var(--line);color:#eaf5ff}.contact-form{display:grid;gap:14px;padding:24px;border:1px solid var(--line);border-radius:var(--radius);background:#ffffff0d;box-shadow:var(--shadow)}label{display:grid;gap:8px;color:#d7e5f5;font-size:14px}input,textarea{width:100%;border:1px solid #ffffff2e;background:#06111f;color:#fff;border-radius:16px;padding:14px 15px;font:inherit;outline:none}input:focus,textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 4px #55f0ff1f}.form-note{font-size:13px;color:var(--muted);margin:0}.footer{padding:54px 0 26px;border-top:1px solid var(--line);background:#030713}.footer-grid{display:grid;grid-template-columns:1.3fr .7fr .7fr;gap:26px}.footer-logo{width:190px;margin-bottom:14px}.footer p{color:#fff;margin:0 0 8px}.footer span,.footer a,.legal{display:block;color:var(--muted);margin:4px 0}.legal{margin-top:26px;font-size:13px}.sticky-call{position:fixed;right:18px;bottom:18px;z-index:9;background:linear-gradient(135deg,var(--cyan),var(--blue));color:#03101e;font-weight:950;padding:14px 18px;border-radius:999px;box-shadow:0 12px 36px #18b7ff55}.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:none}@media(max-width:920px){.reviews-title-row{grid-template-columns:1fr}.rating-badge{width:max-content}}@media(max-width:920px){.menu-btn{display:inline-flex}.nav{position:absolute;top:72px;left:20px;right:20px;display:none;flex-direction:column;align-items:stretch;background:#050b18f2;border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:var(--shadow)}.nav.open{display:flex}.nav a{padding:12px}.hero{padding-top:120px}.hero-grid,.split,.reviews-layout,.contact-grid{grid-template-columns:1fr}.hero-card{max-width:520px}.floating-card{left:16px}.trust-grid,.cards{grid-template-columns:1fr 1fr}.gallery{grid-template-columns:1fr;grid-auto-rows:260px}.gallery .wide{grid-row:auto}.footer-grid{grid-template-columns:1fr}.reviews-carousel{grid-auto-columns:minmax(270px,82vw)}}@media(max-width:620px){body{padding-bottom:82px}.container{width:min(100% - 26px,var(--max))}.header-inner{height:70px}.brand img{width:154px}.hero{min-height:auto;padding-bottom:60px}.hero-bg{background:linear-gradient(#050b18d7,#050b18f2),url("img/bg.jpg") center/cover}h1{font-size:42px}.section{padding:68px 0}.trust-grid,.cards{grid-template-columns:1fr}.service-card img{height:230px}.portrait{height:430px}.btn{width:100%}.sticky-call{left:16px;right:16px;bottom:calc(14px + env(safe-area-inset-bottom));text-align:center;padding:16px 18px;box-shadow:0 10px 30px #18b7ff50}.hero-card img{height:460px}.review-card{min-height:235px;padding:24px}.reviews-carousel{margin-inline:-13px;padding-inline:13px}}

/* Effet vitré actif sur certaines cartes et images secondaires. */
body.glass-on .hero-card,
body.glass-on .service-card,
body.glass-on .review-card,
body.glass-on .contact-form,
body.glass-on .trust-grid div,
body.glass-on .benefits p,
body.glass-on .gallery img,
body.glass-on .portrait{
  background:linear-gradient(135deg,#ffffff22,#ffffff0a 52%,#ffffff16);
  border-color:#ffffff36;
  backdrop-filter:blur(24px) saturate(1.35);
  -webkit-backdrop-filter:blur(24px) saturate(1.35);
  box-shadow:inset 0 1px 0 #ffffff40, 0 24px 90px #0007;
}
body.glass-on .gallery img,
body.glass-on .portrait,
body.glass-on .hero-card img{
  outline:1px solid #ffffff28;
  outline-offset:-10px;
}
.slot-metric{
  display:inline-flex;
  align-items:baseline;
  min-height:1.15em;
  overflow:hidden;
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
.slot-char{
  display:inline-block;
  transform:translateY(0);
  will-change:transform, filter;
}
.slot-metric.slot-running .slot-char{
  animation:slotRoll .9s cubic-bezier(.18,.86,.28,1.02) both;
}
.slot-metric .slot-char:nth-child(2){animation-delay:.05s}
.slot-metric .slot-char:nth-child(3){animation-delay:.1s}
.slot-metric .slot-char:nth-child(4){animation-delay:.15s}
.slot-metric .slot-char:nth-child(5){animation-delay:.2s}
.slot-metric .slot-char:nth-child(6){animation-delay:.25s}
@keyframes slotRoll{
  0%{transform:translateY(-280%) scaleY(1.15);filter:blur(2px);opacity:.2}
  35%{transform:translateY(90%) scaleY(.88);filter:blur(1px);opacity:1}
  62%{transform:translateY(-45%) scaleY(1.06);filter:blur(.6px)}
  82%{transform:translateY(16%) scaleY(.98);filter:blur(0)}
  100%{transform:translateY(0) scaleY(1);filter:blur(0);opacity:1}
}
/* Glassmorphisme corrigé : vrai cadre autour des images + effet visible sur les cartes. */
.glass-frame{
  position:relative;
  overflow:hidden;
  border-radius:calc(var(--radius) + 2px);
  transition:background .25s ease,border-color .25s ease,box-shadow .25s ease,padding .25s ease;
}
.glass-frame > img{
  position:relative;
  z-index:1;
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:inherit;
}
.service-card .card-media{
  padding:0;
  height:280px;
  border-radius:0;
}
.service-card .card-media img{
  height:100%;
  border-radius:0;
}
.gallery .glass-frame{
  width:100%;
  height:100%;
}
.portrait-frame{
  width:100%;
  height:560px;
}
.portrait-frame .portrait{
  height:100%;
  border:0;
  box-shadow:none;
}
body.glass-on .glass-frame{
  padding:10px;
  border:1px solid rgba(255,255,255,.36);
  background:
    linear-gradient(135deg,rgba(255,255,255,.30),rgba(255,255,255,.08) 46%,rgba(85,240,255,.16)),
    radial-gradient(circle at 10% 0,rgba(255,255,255,.34),transparent 36%);
  backdrop-filter:blur(26px) saturate(1.45);
  -webkit-backdrop-filter:blur(26px) saturate(1.45);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55), inset 0 -1px 0 rgba(255,255,255,.12), 0 26px 90px rgba(0,0,0,.52);
}
body.glass-on .glass-frame::after{
  content:"";
  position:absolute;
  inset:10px;
  z-index:2;
  border-radius:calc(var(--radius) - 6px);
  pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.24),transparent 28%,transparent 72%,rgba(85,240,255,.16));
  border:1px solid rgba(255,255,255,.16);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}
body.glass-on .hero-card,
body.glass-on .service-card,
body.glass-on .review-card,
body.glass-on .contact-form,
body.glass-on .trust-grid div,
body.glass-on .benefits p{
  background:linear-gradient(145deg,rgba(255,255,255,.18),rgba(255,255,255,.06));
  border-color:rgba(255,255,255,.32);
  backdrop-filter:blur(22px) saturate(1.35);
  -webkit-backdrop-filter:blur(22px) saturate(1.35);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.34),0 24px 80px rgba(0,0,0,.42);
}
body:not(.glass-on) .glass-frame{
  border:0;
  background:transparent;
  box-shadow:none;
  padding:0;
}
body:not(.glass-on) .glass-frame::after{display:none;}
@media(max-width:620px){
  .service-card .card-media{height:230px;}
  .portrait-frame{height:430px;}
  body.glass-on .glass-frame{padding:7px;}
  body.glass-on .glass-frame::after{inset:7px;}
}


/* Effets premium allégés : 3D conservée, halos/curseur supprimés */
main{position:relative;z-index:1;}
.site-header{z-index:50;}
.sticky-call{position:fixed;right:22px;bottom:22px;z-index:70;}

[data-tilt],[data-tilt-soft]{
  transform-style:preserve-3d;
  will-change:transform;
}
body.premium-on [data-tilt],body.premium-on [data-tilt-soft]{
  transition:transform .18s ease, box-shadow .25s ease, border-color .25s ease;
}
body:not(.premium-on) [data-tilt],body:not(.premium-on) [data-tilt-soft]{
  transform:none!important;
}

body.premium-on .slot-metric{
  perspective:900px;
  transform:translateZ(18px);
}
body.premium-on .slot-metric.slot-running .slot-char{
  animation:slotRoll3D 1.05s cubic-bezier(.16,.94,.22,1.02) both;
}
@keyframes slotRoll3D{
  0%{transform:translateY(-360%) rotateX(76deg) scaleY(1.1);filter:blur(3px);opacity:.08}
  38%{transform:translateY(88%) rotateX(-28deg) scaleY(.9);filter:blur(1.4px);opacity:1}
  63%{transform:translateY(-34%) rotateX(18deg) scaleY(1.04);filter:blur(.4px)}
  82%{transform:translateY(10%) rotateX(-7deg) scaleY(.99);filter:blur(0)}
  100%{transform:translateY(0) rotateX(0) scaleY(1);filter:blur(0);opacity:1}
}

/* Le visuel principal du hero reste net : aucun glassmorphisme dessus. */
.hero-main-card.no-glass,
body.glass-on .hero-main-card.no-glass{
  background:linear-gradient(180deg,#ffffff12,#ffffff07)!important;
  border:1px solid var(--line)!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  box-shadow:var(--shadow)!important;
}
body.glass-on .hero-main-card.no-glass img,
.hero-main-card.no-glass img{
  outline:0!important;
  outline-offset:0!important;
}
body.glass-on .hero-main-card.no-glass::after{display:none!important;}

body.premium-on .hero-main-card{
  box-shadow:0 30px 90px rgba(0,0,0,.48)!important;
}
body.premium-on .hero-copy{
  filter:drop-shadow(0 20px 55px rgba(0,0,0,.16));
}
body.premium-on .service-card:hover,
body.premium-on .stat-card:hover,
body.premium-on .review-card:hover{
  border-color:rgba(85,240,255,.38);
  box-shadow:0 24px 70px rgba(0,0,0,.36);
}
body.premium-on .premium-media img,
body.premium-on .card-media img,
body.premium-on .portrait-frame img{
  transition:transform .45s ease, filter .45s ease;
}
body.premium-on .premium-media:hover img,
body.premium-on .card-media:hover img,
body.premium-on .portrait-frame:hover img{
  transform:scale(1.035);
  filter:saturate(1.06) contrast(1.03);
}

@media(max-width:620px){
}
@media(prefers-reduced-motion:reduce){
    [data-tilt],[data-tilt-soft]{transform:none!important;transition:none!important;}
  .slot-metric.slot-running .slot-char{animation:none!important;}
}


/* V5 — carte SMS iPhone dans le hero */
.sms-card{
  width:288px;
  padding:13px;
  border-radius:30px;
  background:linear-gradient(180deg,#fbfdff,#edf3fb);
  border:1px solid rgba(255,255,255,.78);
  color:#06111f;
  box-shadow:0 24px 70px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.9);
  overflow:hidden;
}
.sms-notch{
  width:72px;
  height:5px;
  border-radius:999px;
  background:#c8d1dd;
  margin:1px auto 11px;
}
.sms-head{
  display:flex;
  align-items:center;
  gap:9px;
  padding:0 2px 10px;
  font-size:13px;
  color:#435062;
}
.sms-avatar{
  width:26px;
  height:26px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  color:#06111f;
  font-weight:950;
}
.sms-bubbles{
  display:grid;
  gap:7px;
  margin-bottom:11px;
}
.bubble{
  width:max-content;
  max-width:220px;
  margin:0;
  padding:9px 12px;
  border-radius:18px;
  font-size:13px;
  line-height:1.25;
  letter-spacing:-.01em;
}
.bubble.incoming{
  background:#e6e8ed;
  color:#0b1422;
  border-bottom-left-radius:6px;
}
.bubble.outgoing{
  justify-self:end;
  background:#0a84ff;
  color:#fff;
  border-bottom-right-radius:6px;
}
.sms-cta{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  border-radius:999px;
  background:#111827;
  color:#fff;
  font-weight:900;
  box-shadow:0 12px 30px rgba(10,132,255,.22);
}
body.premium-on .sms-card{
  animation:smsFloat 4.8s ease-in-out infinite;
}
body.premium-on .sms-card .bubble{
  animation:smsBubbleIn .55s cubic-bezier(.16,.94,.24,1.02) both;
}
body.premium-on .sms-card .bubble:nth-child(2){animation-delay:.12s;}
body.premium-on .sms-card .bubble:nth-child(3){animation-delay:.24s;}
@keyframes smsFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-7px)}
}
@keyframes smsBubbleIn{
  from{opacity:0;transform:translateY(9px) scale(.96)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@media(max-width:620px){
  .sms-card{width:min(286px,calc(100% - 28px));left:14px;bottom:18px;}
  .bubble{max-width:205px;}
}

/* V9 — bouton d'appel corrigé + carrousel avis */
.sticky-call{
  position:fixed!important;
  right:22px!important;
  left:auto!important;
  bottom:22px!important;
  z-index:80!important;
}
@media(max-width:620px){
  body{padding-bottom:86px;}
  .sticky-call{
    left:16px!important;
    right:16px!important;
    bottom:calc(14px + env(safe-area-inset-bottom))!important;
    width:auto!important;
    text-align:center;
  }
  }

@media(max-width:1100px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.cards{grid-template-columns:1fr}.contact-photo{height:220px;max-width:none}}

/* V12 — section prestations plus organique, sans rendu bloc/glass lourd */
.expertise-panel{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:28px;
  align-items:stretch;
  padding:18px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:32px;
  background:
    radial-gradient(circle at 10% 0, rgba(85,240,255,.13), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
  box-shadow:0 24px 80px rgba(0,0,0,.28);
  overflow:hidden;
}
.expertise-visual{
  position:relative;
  min-height:520px;
  overflow:hidden;
  border-radius:26px;
  background:#081525;
}
.expertise-visual img{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
  filter:saturate(1.04) contrast(1.02);
}
.expertise-caption{
  position:absolute;
  left:16px;
  right:16px;
  bottom:16px;
  padding:13px 16px;
  border-radius:18px;
  background:rgba(5,11,24,.78);
  border:1px solid rgba(255,255,255,.14);
  color:#eaf5ff;
  font-size:14px;
  letter-spacing:.01em;
  backdrop-filter:blur(12px);
}
.expertise-copy{
  padding:30px 26px 26px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.expertise-copy h3{
  font-size:clamp(30px,3.6vw,48px);
  line-height:1;
  letter-spacing:-.045em;
  margin-bottom:16px;
}
.expertise-copy > p:not(.eyebrow){
  color:var(--muted);
  font-size:18px;
  max-width:650px;
  margin-bottom:26px;
}
.hand-checklist{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:12px;
}
.hand-checklist li{
  display:grid;
  grid-template-columns:36px 1fr;
  grid-template-rows:auto auto;
  column-gap:12px;
  padding:16px 0;
  border-top:1px solid rgba(255,255,255,.12);
}
.hand-checklist li:first-child{border-top:0;}
.hand-checklist span{
  grid-row:1 / span 2;
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  color:#03101e;
  font-family:"Segoe Print","Bradley Hand",cursive;
  font-size:20px;
  line-height:1;
  box-shadow:0 10px 24px rgba(24,183,255,.24);
}
.hand-checklist strong{
  color:#fff;
  font-size:20px;
  line-height:1.15;
  letter-spacing:-.02em;
}
.hand-checklist em{
  margin-top:6px;
  color:#b9c8dc;
  font-style:normal;
  font-size:15px;
  line-height:1.45;
}

/* V12 — avis Google premium, défilement automatique léger */
.reviews-layout{
  grid-template-columns:.72fr 1.28fr;
}
.reviews-marquee{
  position:relative;
  overflow:hidden;
  padding:10px 0;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.reviews-track{
  display:flex;
  gap:18px;
  width:max-content;
  animation:reviewsAutoScroll 34s linear infinite;
}
.reviews-marquee:hover .reviews-track{
  animation-play-state:paused;
}
.reviews-marquee .review-card{
  width:315px;
  min-height:255px;
  flex:0 0 auto;
  background:
    radial-gradient(circle at 15% 0, rgba(85,240,255,.18), transparent 38%),
    linear-gradient(145deg, #0d1b31, #071426 58%, #09182c);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 24px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
}
.google-pill{
  width:max-content;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.13);
  color:#eaf5ff;
  font-size:12px;
  font-weight:850;
}
.reviews-marquee .stars{
  margin-top:18px;
  color:#f4b324;
  text-shadow:0 0 24px rgba(244,179,36,.18);
}
.reviews-marquee .review-card p{
  color:#e2edfb;
  font-size:17px;
  line-height:1.48;
  margin:16px 0 22px;
}
.reviews-marquee .review-author{
  margin-top:auto;
  background:rgba(85,240,255,.08);
  border-color:rgba(85,240,255,.18);
  color:#bfeeff;
}
@keyframes reviewsAutoScroll{
  from{transform:translateX(0)}
  to{transform:translateX(calc(-50% - 9px))}
}

/* Neutralise l'ancien rendu glass s'il reste des classes glass-frame dans les sections secondaires */
body .service-card .glass-frame,
body .expertise-panel .glass-frame{
  padding:0!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
}

@media(max-width:980px){
  .expertise-panel{grid-template-columns:1fr;}
  .expertise-visual,.expertise-visual img{min-height:390px;}
  .reviews-layout{grid-template-columns:1fr;}
}
@media(max-width:620px){
  .expertise-panel{padding:10px;border-radius:26px;}
  .expertise-visual{border-radius:20px;}
  .expertise-visual,.expertise-visual img{min-height:310px;}
  .expertise-copy{padding:24px 12px 14px;}
  .hand-checklist li{grid-template-columns:32px 1fr;padding:14px 0;}
  .hand-checklist strong{font-size:18px;}
  .hand-checklist em{font-size:14px;}
  .reviews-marquee{margin-inline:-13px;padding-inline:13px;-webkit-mask-image:none;mask-image:none;overflow-x:auto;scroll-snap-type:x mandatory;}
  .reviews-track{animation:none;}
  .reviews-marquee .review-card{width:min(305px,82vw);scroll-snap-align:start;}
}
@media(prefers-reduced-motion:reduce){
  .reviews-track{animation:none!important;}
}


/* V13 — section vacances + prestations moins bloc + checklist au bon endroit */
.vacation-section{
  padding:42px 0 76px;
  background:linear-gradient(180deg,#050b18,#071426);
}
.vacation-card{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:26px;
  align-items:center;
  border:1px solid rgba(255,255,255,.14);
  border-radius:34px;
  padding:22px;
  background:linear-gradient(135deg,rgba(255,255,255,.09),rgba(255,255,255,.035));
  box-shadow:0 24px 80px rgba(0,0,0,.28);
  overflow:hidden;
}
.vacation-copy{padding:18px 12px 18px 20px;}
.vacation-copy h2{max-width:720px;}
.vacation-copy p:not(.eyebrow){color:#c9d6e8;font-size:18px;max-width:760px;}
.vacation-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px;}
.vacation-visual{position:relative;min-height:330px;border-radius:26px;overflow:hidden;background:#081525;}
.vacation-visual img{width:100%;height:100%;min-height:330px;object-fit:cover;}
.vacation-badge{position:absolute;left:16px;bottom:16px;display:inline-flex;padding:11px 14px;border-radius:999px;background:#06111fe6;border:1px solid rgba(255,255,255,.14);color:#eaf5ff;font-weight:850;box-shadow:0 12px 34px rgba(0,0,0,.32);}
.service-showcase{
  display:grid;
  grid-template-columns:.78fr 1.22fr;
  gap:30px;
  align-items:stretch;
  border:1px solid rgba(255,255,255,.12);
  border-radius:34px;
  padding:18px;
  background:linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.03));
  box-shadow:0 24px 80px rgba(0,0,0,.24);
}
.service-photo{position:relative;min-height:560px;border-radius:26px;overflow:hidden;background:#081525;}
.service-photo img{width:100%;height:100%;min-height:560px;object-fit:cover;filter:saturate(1.04) contrast(1.02);}
.service-photo span{position:absolute;left:16px;right:16px;bottom:16px;padding:13px 15px;border-radius:18px;background:#06111fe6;border:1px solid rgba(255,255,255,.14);color:#fff;font-weight:850;}
.service-content{padding:28px 20px 18px;display:flex;flex-direction:column;justify-content:center;}
.service-content h3{font-size:clamp(30px,3.6vw,48px);line-height:1;letter-spacing:-.045em;margin-bottom:16px;}
.service-content > p:not(.eyebrow){color:var(--muted);font-size:18px;max-width:720px;margin-bottom:28px;}
.service-lines{display:grid;gap:10px;}
.service-lines article{display:grid;grid-template-columns:52px 1fr;column-gap:16px;padding:15px 0;border-top:1px solid rgba(255,255,255,.12);}
.service-lines article:first-child{border-top:0;}
.service-lines span{color:var(--cyan);font-weight:950;letter-spacing:-.04em;font-size:23px;line-height:1.1;}
.service-lines h4{margin:0 0 5px;color:#fff;font-size:20px;line-height:1.1;letter-spacing:-.02em;}
.service-lines p{margin:0;color:#b9c8dc;font-size:15px;line-height:1.45;}
.why-section .split{align-items:start;}
.electric-note{margin-top:22px!important;padding:16px 18px;border-radius:20px;background:rgba(85,240,255,.08);border:1px solid rgba(85,240,255,.18);color:#dff8ff!important;font-weight:750;}
.reassurance-checklist{list-style:none;margin:0;padding:0;display:grid;gap:12px;}
.reassurance-checklist li{display:grid;grid-template-columns:42px 1fr;align-items:start;gap:13px;padding:18px 0;border-top:1px solid rgba(255,255,255,.14);}
.reassurance-checklist li:first-child{border-top:0;}
.reassurance-checklist span{width:34px;height:34px;display:grid;place-items:center;border-radius:999px;background:linear-gradient(135deg,var(--cyan),var(--blue));color:#03101e;font-family:"Segoe Print","Bradley Hand",cursive;font-size:22px;line-height:1;box-shadow:0 10px 24px rgba(24,183,255,.26);transform:rotate(-5deg);}
.reassurance-checklist p{margin:0!important;color:#eaf5ff!important;font-size:19px;line-height:1.35;}
@media(max-width:980px){
  .vacation-card,.service-showcase{grid-template-columns:1fr;}
  .service-photo,.service-photo img{min-height:390px;}
  .vacation-visual,.vacation-visual img{min-height:360px;}
}
@media(max-width:620px){
  .vacation-section{padding:30px 0 58px;}
  .vacation-card,.service-showcase{padding:10px;border-radius:26px;}
  .vacation-copy,.service-content{padding:22px 12px 14px;}
  .vacation-visual,.vacation-visual img,.service-photo,.service-photo img{min-height:310px;}
  .vacation-actions .btn{width:100%;}
  .service-lines article{grid-template-columns:42px 1fr;}
  .service-lines h4{font-size:18px;}
  .reassurance-checklist li{grid-template-columns:36px 1fr;}
  .reassurance-checklist p{font-size:17px;}
}

/* Champ photo + anti-spam invisible */
.file-field input[type="file"]{
  width:100%;
  padding:14px;
  border:1px dashed rgba(255,255,255,.32);
  border-radius:18px;
  background:#06111f;
  color:#fff;
  cursor:pointer;
}
.file-field input[type="file"]::file-selector-button{
  margin-right:14px;
  border:0;
  border-radius:999px;
  padding:10px 14px;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  color:#03101e;
  font-weight:850;
  cursor:pointer;
}
.file-help{
  display:block;
  margin-top:8px;
  font-size:.88rem;
  line-height:1.4;
  color:var(--muted);
}
.hp-field{
  position:absolute!important;
  left:-10000px!important;
  width:1px!important;
  height:1px!important;
  overflow:hidden!important;
}
.status-page{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:40px 0;
  background:radial-gradient(circle at 80% 20%,#18b7ff33,transparent 34%),var(--bg);
}
.status-card{
  width:min(720px,calc(100% - 32px));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:34px;
  background:linear-gradient(180deg,#ffffff12,#ffffff07);
  box-shadow:var(--shadow);
}
.status-card p{color:var(--muted);font-size:18px;}
.status-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;}

/* Champ anti-spam invisible du formulaire PHP */
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}


.realisations-section {
  overflow: hidden;
}

.realisations-head {
  margin-bottom: 32px;
}

.realisations-head p:not(.eyebrow) {
  max-width: 720px;
  margin: 14px auto 0;
  color: rgba(20, 47, 84, 0.72);
  font-size: clamp(1rem, 1.5vw, 1.12rem);
  line-height: 1.6;
}

.realisations-mosaic {
  display: grid;
  grid-template-columns: 1.25fr 0.85fr 0.85fr;
  grid-auto-rows: 220px;
  gap: 18px;
}

.mosaic-item {
  position: relative;
  margin: 0;
  overflow: hidden;
  border-radius: 28px;
  background: #0b1220;
  box-shadow: 0 22px 55px rgba(5, 11, 24, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.72);
  isolation: isolate;
}

.mosaic-large {
  grid-row: span 2;
}

.mosaic-tall {
  grid-row: span 2;
}

.mosaic-item img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transform: scale(1.015);
  transition: transform 0.55s ease, filter 0.55s ease;
}

.mosaic-item::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(5, 11, 24, 0.02) 35%, rgba(5, 11, 24, 0.68) 100%),
    radial-gradient(circle at 20% 0%, rgba(32, 107, 255, 0.22), transparent 42%);
  pointer-events: none;
}

.mosaic-item figcaption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 16px;
  z-index: 2;
  color: #fff;
  font-size: 0.96rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.45);
}

.mosaic-item:hover img {
  transform: scale(1.055);
  filter: saturate(1.08) contrast(1.03);
}

@media (max-width: 980px) {
  .realisations-mosaic {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 210px;
  }

  .mosaic-large {
    grid-column: span 2;
    grid-row: span 1;
  }

  .mosaic-tall {
    grid-row: span 1;
  }
}

@media (max-width: 640px) {
  .realisations-mosaic {
    display: flex;
    gap: 14px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 10px;
    -webkit-overflow-scrolling: touch;
  }

  .realisations-mosaic::-webkit-scrollbar {
    height: 6px;
  }

  .realisations-mosaic::-webkit-scrollbar-thumb {
    background: rgba(20, 47, 84, 0.22);
    border-radius: 999px;
  }

  .mosaic-item,
  .mosaic-large,
  .mosaic-tall {
    flex: 0 0 82%;
    height: 360px;
    grid-column: auto;
    grid-row: auto;
    scroll-snap-align: start;
  }

  .mosaic-item figcaption {
    font-size: 0.92rem;
  }
}