
:root{--bg:#040406;--card:#101018;--muted:#b8b8c8;--blue:#2367ff;--purple:#b326ff;--stroke:rgba(255,255,255,.13)}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:radial-gradient(circle at 50% -10%,#18002b,#040406 44%);color:white;font-family:Inter,Arial,sans-serif;overflow-x:hidden}
a{color:inherit;text-decoration:none}
.site-header{position:sticky;top:0;z-index:100;min-height:82px;padding:10px clamp(18px,4vw,56px);display:flex;align-items:center;justify-content:space-between;background:rgba(0,0,0,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--stroke)}
.brand{display:flex;align-items:center;gap:16px;min-width:0}
.brand img{width:92px;height:auto;max-height:62px;object-fit:contain;border-radius:0;background:transparent;filter:drop-shadow(0 0 14px rgba(179,38,255,.42))}
.brand span{font-family:Oswald,Inter,sans-serif;font-size:28px;font-weight:700;letter-spacing:.08em;white-space:nowrap}
.burger{display:none;background:none;border:0;color:#fff;font-size:32px}
.main-nav{display:flex;align-items:center;gap:20px;text-transform:uppercase;font-size:13px;font-weight:900}
.main-nav a:hover{color:#ba62ff}
.nav-cta{padding:12px 16px;border:1px solid rgba(179,38,255,.65);border-radius:8px;background:rgba(179,38,255,.1)}
.home-hero{position:relative;min-height:calc(100svh - 82px);display:flex;align-items:center;padding:80px clamp(20px,6vw,90px);overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.92),rgba(0,0,0,.65),rgba(0,0,0,.45))}
.hero-content{position:relative;z-index:1;max-width:720px}
.badge{display:inline-flex;padding:9px 15px;border:1px solid rgba(179,38,255,.55);border-radius:999px;background:rgba(0,0,0,.35);color:#ead9ff;text-transform:uppercase;font-size:12px;font-weight:900;letter-spacing:.03em}
h1,h2{font-family:Oswald,Inter,sans-serif;text-transform:uppercase;line-height:.98;margin:14px 0}
h1{font-size:clamp(44px,7vw,94px)}
h2{font-size:clamp(28px,4vw,48px)}
em{font-style:normal;color:#a946ff}
p{color:#ddd;line-height:1.55;font-size:18px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:15px 22px;border-radius:10px;font-weight:900;text-transform:uppercase;border:0}
.primary{background:linear-gradient(90deg,var(--blue),var(--purple));color:white}
.secondary{border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.04)}
.home-cards{padding:38px clamp(18px,4vw,56px);display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.service-card,.panel{background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.02));border:1px solid var(--stroke);border-radius:20px;padding:22px;overflow:hidden}
.service-card{display:flex;flex-direction:column;transition:.25s ease}
.service-card:hover{transform:translateY(-5px);border-color:rgba(179,38,255,.65)}
.service-card span{color:#b16aff;font-weight:900;text-transform:uppercase}
.service-card img,.engine-visual{width:100%;height:250px;object-fit:cover;border-radius:15px;margin:14px 0;background:#09090d}
.engine-visual{display:grid;place-items:center;font-size:84px}
.service-card h2{font-size:30px}
.service-card p{color:var(--muted);font-size:15px}
.service-card strong,.panel strong{font-size:28px;color:#bb55ff;margin-top:auto}
.trust-bar{margin:0 clamp(18px,4vw,56px) 36px;padding:20px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;border:1px solid var(--stroke);border-radius:18px;background:rgba(255,255,255,.035)}
.trust-bar div{text-align:center;border-right:1px solid rgba(255,255,255,.12);padding:10px}
.trust-bar div:last-child{border-right:0}
.trust-bar b{display:block;text-transform:uppercase;font-size:20px}
.trust-bar span{color:#bbb;text-transform:uppercase;font-size:12px;font-weight:800}
.page{padding:44px clamp(18px,4vw,56px)}
.page-hero{padding:62px 0 36px;max-width:920px}
.two-col,.form-layout,.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
.image-panel{background:#08080c;border:1px solid var(--stroke);border-radius:22px;padding:18px}
.image-panel img{width:100%;border-radius:16px;display:block;object-fit:cover}
.price-list{list-style:none;padding:0;margin:20px 0;display:grid;gap:12px}
.price-list li{display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid rgba(255,255,255,.1);padding:12px 0;color:#ddd}
.price-list b{color:white}
.gallery-two,.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:20px 0 36px}
.gallery-two img,.gallery-grid img{width:100%;height:420px;object-fit:cover;border-radius:22px;border:1px solid var(--stroke)}
.gallery-grid{grid-template-columns:repeat(4,1fr)}
.gallery-grid img{height:280px}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pricing-grid.wide{grid-template-columns:repeat(4,1fr)}
.featured{border-color:rgba(179,38,255,.62)}
.options-panel{margin-top:20px}
.form{display:grid;gap:18px}
.form-block{border:1px solid var(--stroke);background:rgba(255,255,255,.035);border-radius:18px;padding:18px;display:grid;gap:12px}
.form-block h2{font-size:26px;margin:0 0 8px}
input,select,textarea{width:100%;padding:16px;border:1px solid rgba(255,255,255,.15);border-radius:12px;background:#090910;color:white;font:inherit}
.dynamic{display:none;border:1px solid rgba(179,38,255,.38);background:rgba(179,38,255,.055);border-radius:14px;padding:14px;gap:10px}
.dynamic.active{display:grid}
.dynamic label{display:flex;gap:10px;align-items:flex-start;color:#ddd;font-weight:700;line-height:1.4}
.dynamic input{width:auto;margin-top:3px}
.total-box{border:1px solid rgba(179,38,255,.65);background:linear-gradient(90deg,rgba(35,103,255,.16),rgba(179,38,255,.16));border-radius:16px;padding:18px;font-size:20px;font-weight:900}
.total-box strong{font-size:34px;margin-left:8px}
.contact-panel ul{list-style:none;padding:0;margin:22px 0;display:grid;gap:14px;color:#ddd}
.map-panel{min-height:360px;border:1px solid var(--stroke);border-radius:22px;padding:30px;display:grid;place-items:center;text-align:center;background:radial-gradient(circle,rgba(179,38,255,.35),rgba(255,255,255,.03) 45%,rgba(255,255,255,.02))}
.pin{width:90px;height:90px;border-radius:50%;background:linear-gradient(90deg,var(--blue),var(--purple));display:grid;place-items:center;font-size:44px;box-shadow:0 0 40px rgba(179,38,255,.45)}
.whatsapp-float{position:fixed;right:18px;bottom:18px;z-index:200;background:#20c85a;color:white;border-radius:999px;padding:14px 20px;font-weight:900;box-shadow:0 12px 30px rgba(0,0,0,.38)}
.footer{display:flex;justify-content:space-between;gap:20px;padding:28px clamp(18px,4vw,56px);border-top:1px solid var(--stroke);background:#050507;color:#aaa}
.footer div{display:grid;gap:6px}
@media(max-width:1050px){
  .burger{display:block}
  .main-nav{display:none;position:absolute;top:82px;left:0;right:0;padding:18px;background:#050507;grid-template-columns:1fr;gap:10px}
  .main-nav.open{display:grid}
  .brand img{width:76px}
  .brand span{font-size:22px}
  .home-cards,.two-col,.form-layout,.contact-layout,.pricing-grid,.pricing-grid.wide,.gallery-two{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:650px){
  .site-header{min-height:74px;padding:8px 18px}
  .brand img{width:58px;max-height:48px}
  .brand span{font-size:18px;letter-spacing:.06em}
  .main-nav{top:74px}
  .home-hero{min-height:calc(100svh - 74px);padding:54px 20px 86px;align-items:center}
  .hero-video{object-position:center}
  .hero-overlay{background:linear-gradient(180deg,rgba(0,0,0,.67),rgba(0,0,0,.82))}
  h1{font-size:40px}
  .hero-content p{font-size:16px}
  .hero-actions{flex-direction:column}
  .btn{width:100%;font-size:13px}
  .home-cards{padding:28px 18px;grid-template-columns:1fr}
  .service-card img,.engine-visual{height:230px}
  .trust-bar{grid-template-columns:1fr;margin:0 18px 28px}
  .trust-bar div{border-right:0;border-bottom:1px solid rgba(255,255,255,.1)}
  .trust-bar div:last-child{border-bottom:0}
  .page{padding:32px 18px}
  .page-hero{padding:38px 0 22px}
  .gallery-two img,.gallery-grid img{height:280px}
  .gallery-grid{grid-template-columns:1fr}
  .price-list li{flex-direction:column}
  .whatsapp-float{right:14px;bottom:14px;padding:12px 16px;font-size:14px}
  .footer{flex-direction:column}
}

.prestations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.prestation-tile{min-height:250px;display:flex;flex-direction:column}
.prestation-tile strong{margin-top:auto}
.legal-panel{max-width:980px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border:1px solid var(--stroke);border-radius:22px;padding:28px}
.legal-panel h2{font-size:28px;margin-top:28px}
.legal-panel p{color:#ddd}
.legal-note{font-size:14px;color:#aaa!important;border-top:1px solid var(--stroke);padding-top:18px;margin-top:28px}
.footer a{color:#aaa;text-decoration:underline}
@media(max-width:900px){.prestations-grid{grid-template-columns:1fr}.legal-panel{padding:20px}}


.about-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:20px;
margin-top:40px
}

.brand-text{
font-size:22px;
font-weight:800;
letter-spacing:2px;
color:#fff
}

@media(max-width:900px){
.about-grid{
grid-template-columns:1fr
}

.brand-text{
font-size:18px
}
}

/* V4 - Animations + devis gratuit + configurateur */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease, transform .75s ease}
.reveal.visible{opacity:1;transform:none}
.service-card,.panel,.btn{transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease}
.service-card:hover,.panel:hover{transform:translateY(-4px);box-shadow:0 18px 45px rgba(0,0,0,.25);border-color:rgba(179,38,255,.45)}
.btn:hover{transform:translateY(-2px);box-shadow:0 0 28px rgba(179,38,255,.28)}
.free-quote{margin:34px clamp(18px,4vw,56px);padding:28px;border:1px solid rgba(179,38,255,.45);border-radius:22px;background:linear-gradient(90deg,rgba(35,103,255,.16),rgba(179,38,255,.12));display:flex;align-items:center;justify-content:space-between;gap:24px}
.free-quote h2{margin:8px 0;font-size:clamp(28px,4vw,48px)}
.free-quote p{max-width:760px}
.faq-preview{padding:54px clamp(18px,4vw,56px)}
.section-title{text-align:center;margin-bottom:26px}
.faq-mini,.faq-list{display:grid;gap:14px;max-width:980px;margin:0 auto 24px}
.faq-mini details,.faq-list details{border:1px solid var(--stroke);background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border-radius:18px;padding:18px}
.faq-mini summary,.faq-list summary{cursor:pointer;font-weight:900;text-transform:uppercase}
.faq-mini p,.faq-list p{margin-bottom:0;color:#ddd}
.configurator-page{padding-bottom:70px}
.config-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:start}
.wheel-stage{min-height:620px;border:1px solid var(--stroke);border-radius:28px;background:radial-gradient(circle at center,rgba(179,38,255,.22),#07070b 58%);display:grid;place-items:center;padding:28px;overflow:hidden}
.scene{width:min(100%,560px);height:470px;display:grid;place-items:center;perspective:1100px}
.wheel-3d{position:relative;width:min(92vw,460px);height:360px;display:grid;place-items:center;transform-style:preserve-3d;animation:wheelFloat 4.5s ease-in-out infinite}
.wheel-3d img{width:100%;max-height:330px;object-fit:contain;border-radius:28px;transform:rotateY(-14deg) rotateX(5deg);filter:drop-shadow(0 40px 35px rgba(0,0,0,.55))}
.glow-ring{position:absolute;inset:25px;border:2px solid var(--accent,#b326ff);border-radius:50%;opacity:.3;filter:blur(4px);transform:translateZ(-35px)}
.led-badge,.material-badge{position:absolute;padding:9px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.55);backdrop-filter:blur(10px);font-weight:900;text-transform:uppercase}
.led-badge{right:10px;top:26px;color:var(--accent,#b326ff);display:none}
.material-badge{left:10px;bottom:34px;color:white}
.rotate-hint{text-align:center;color:var(--muted);font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.08em}
@keyframes wheelFloat{0%,100%{transform:translateY(0) rotateY(-7deg)}50%{transform:translateY(-14px) rotateY(8deg)}}
.config-panel{border:1px solid var(--stroke);border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));padding:26px}
.option-row, .config-options{display:grid;gap:12px;margin:18px 0}
.config-options label{display:flex;gap:10px;align-items:flex-start;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:14px;background:rgba(0,0,0,.18);font-weight:800;color:#ddd}
.config-options input{width:auto;margin-top:3px}
.color-choice{margin:22px 0}
.color-choice h3{margin-bottom:12px}
.color-dot{width:38px;height:38px;border-radius:50%;border:2px solid rgba(255,255,255,.22);background:var(--c);margin-right:9px;cursor:pointer}
.color-dot.active{outline:3px solid rgba(255,255,255,.35)}
.config-total{display:flex;justify-content:space-between;align-items:center;padding:18px;border-radius:18px;background:linear-gradient(90deg,rgba(35,103,255,.18),rgba(179,38,255,.18));border:1px solid rgba(179,38,255,.45);margin:20px 0}
.config-total span{text-transform:uppercase;font-weight:900;color:#ddd}
.config-total strong{font-size:42px;color:#fff}
.config-note{font-size:13px;color:#aaa}
@media(max-width:900px){.free-quote{flex-direction:column;align-items:flex-start}.free-quote .btn{width:100%}.config-layout{grid-template-columns:1fr}.wheel-stage{min-height:470px}.scene{height:350px}.wheel-3d{height:300px}.config-total{align-items:flex-start;flex-direction:column;gap:8px}}


.footer-links{
display:flex;
gap:14px;
align-items:center;
font-size:12px;
opacity:.7
}

.footer-links a{
text-decoration:none;
color:#aaa
}

.footer-links a:hover{
color:#fff
}


/* CONFIGURATEUR 2D TEXTURÉ STABLE */
.config2d-layout{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr);
  gap:28px;
  align-items:start;
}

.viewer2d-card,.config2d-panel{
  border:1px solid var(--stroke,rgba(255,255,255,.13));
  border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.018));
  overflow:hidden;
  box-shadow:0 22px 70px rgba(0,0,0,.35);
}

.wheel2d-scene{
  min-height:620px;
  height:68vh;
  max-height:760px;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at 50% 40%, rgba(255,255,255,.10), transparent 20%),
    radial-gradient(circle at 50% 45%, rgba(139,53,255,.28), transparent 42%),
    radial-gradient(circle at 50% 100%, rgba(0,102,255,.18), transparent 45%),
    #060608;
  perspective:1000px;
  overflow:hidden;
}

.wheel2d{
  position:relative;
  width:min(74vw,500px);
  aspect-ratio:1/1;
  transform-style:preserve-3d;
  animation:wheel2dFloat 4.8s ease-in-out infinite;
  filter:drop-shadow(0 34px 35px rgba(0,0,0,.65));
}

@keyframes wheel2dFloat{
  0%,100%{transform:rotateY(-10deg) rotateX(7deg) translateY(0)}
  50%{transform:rotateY(10deg) rotateX(5deg) translateY(-12px)}
}

.ring-base{
  position:absolute;
  inset:4%;
  border:42px solid #111116;
  border-radius:50%;
  background:transparent;
  box-shadow:
    inset 0 0 25px rgba(255,255,255,.08),
    0 0 45px rgba(139,53,255,.16);
}

.ring-base::after{
  content:"";
  position:absolute;
  inset:-22px;
  border-radius:50%;
  background:linear-gradient(135deg,rgba(255,255,255,.10),transparent 34%,rgba(255,255,255,.06));
  pointer-events:none;
}

.top-carbon{
  position:absolute;
  left:50%;
  top:3%;
  width:48%;
  height:20%;
  transform:translateX(-50%);
  border-radius:170px 170px 36px 36px;
  background-image:url("assets/carbone-tresse.webp");
  background-size:190px;
  box-shadow:inset 0 0 20px rgba(255,255,255,.12), 0 0 18px rgba(255,255,255,.05);
}

.flat-bottom{
  position:absolute;
  left:50%;
  bottom:2%;
  width:48%;
  height:13%;
  transform:translateX(-50%);
  border-radius:18px;
  background:#111116;
  box-shadow:inset 0 0 16px rgba(255,255,255,.08);
}

.grip2d{
  position:absolute;
  top:34%;
  width:18%;
  height:34%;
  border-radius:60px;
  background-image:url("assets/daim-grip.webp");
  background-size:220px;
  box-shadow:inset 0 0 25px rgba(0,0,0,.65), inset 0 0 12px rgba(255,255,255,.06);
  z-index:3;
}

.grip-left{left:4%;transform:rotate(5deg)}
.grip-right{right:4%;transform:rotate(-5deg)}

.center-carbon{
  position:absolute;
  left:50%;
  top:50%;
  width:35%;
  height:28%;
  transform:translate(-50%,-50%);
  border-radius:38% 38% 48% 48%;
  background-image:url("assets/carbone-tresse.webp");
  background-size:200px;
  box-shadow:inset 0 0 22px rgba(255,255,255,.10), 0 16px 28px rgba(0,0,0,.35);
  z-index:5;
}

.hub2d{
  position:absolute;
  left:50%;
  top:49%;
  width:17%;
  aspect-ratio:1/1;
  transform:translate(-50%,-50%);
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#050507;
  border:3px solid var(--accent,#0066ff);
  color:#fff;
  font-family:Oswald,Inter,sans-serif;
  font-size:22px;
  font-weight:900;
  box-shadow:0 0 28px color-mix(in srgb, var(--accent,#0066ff) 65%, transparent);
  z-index:8;
}

.spoke2d{
  position:absolute;
  background-image:url("assets/carbone-tresse.webp");
  background-size:170px;
  border-radius:14px;
  z-index:4;
  box-shadow:inset 0 0 14px rgba(255,255,255,.10);
}

.spoke-left{left:28%;top:55%;width:26%;height:8%;transform:rotate(-28deg)}
.spoke-right{right:28%;top:55%;width:26%;height:8%;transform:rotate(28deg)}
.spoke-bottom{left:50%;top:61%;width:9%;height:26%;transform:translateX(-50%)}

.stitch-loop{
  position:absolute;
  inset:11%;
  border:4px dashed var(--accent,#0066ff);
  border-radius:50%;
  opacity:.72;
  filter:drop-shadow(0 0 8px var(--accent,#0066ff));
  pointer-events:none;
  z-index:7;
}

.led2d{
  position:absolute;
  left:50%;
  top:10%;
  width:34%;
  height:5%;
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(90deg,transparent,var(--accent,#0066ff),transparent);
  box-shadow:0 0 24px var(--accent,#0066ff);
  opacity:0;
  z-index:8;
}

.paddle2d{
  position:absolute;
  top:33%;
  width:7%;
  height:32%;
  border-radius:14px;
  background:linear-gradient(180deg,#dedeee,#7a7a88);
  opacity:0;
  z-index:1;
  box-shadow:0 16px 22px rgba(0,0,0,.45);
}

.paddle-left{left:31%;transform:rotate(-18deg)}
.paddle-right{right:31%;transform:rotate(18deg)}

.wheel2d.grip-cuir .grip2d{background-image:url("assets/cuir-perfore.jpg");background-size:170px}
.wheel2d.carbon-forge .top-carbon,
.wheel2d.carbon-forge .center-carbon,
.wheel2d.carbon-forge .spoke2d{background-image:url("assets/carbone-forge.webp");background-size:210px}
.wheel2d.led-on .led2d{opacity:1}
.wheel2d.palettes-on .paddle2d{opacity:1}

.config2d-panel{padding:26px}
.config2d-panel h2{margin-top:0}
.segmented{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.seg{
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:14px 12px;
  background:rgba(0,0,0,.22);
  color:#ddd;
  font-weight:900;
  text-transform:uppercase;
  cursor:pointer;
}
.seg.active{
  background:linear-gradient(90deg,rgba(35,103,255,.25),rgba(179,38,255,.25));
  border-color:rgba(179,38,255,.65);
  color:#fff;
}
.texture-preview{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:12px;
}
.texture-preview div{
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  overflow:hidden;
  background:rgba(255,255,255,.04);
}
.texture-preview img{width:100%;height:82px;object-fit:cover;display:block}
.texture-preview span{
  display:block;
  padding:8px;
  font-size:12px;
  color:#ddd;
  text-transform:uppercase;
  font-weight:900;
}
.stitch-colors{display:flex;gap:14px}
.stitch-dot{
  width:46px;height:46px;border-radius:50%;
  border:2px solid rgba(255,255,255,.25);
  background:var(--c);
  cursor:pointer;
}
.stitch-dot.active{outline:3px solid rgba(255,255,255,.38)}
.config2d-total{
  display:flex;justify-content:space-between;align-items:center;
  margin:20px 0;padding:18px;border-radius:18px;
  background:linear-gradient(90deg,rgba(35,103,255,.18),rgba(179,38,255,.18));
  border:1px solid rgba(179,38,255,.5);
}
.config2d-total span{text-transform:uppercase;font-weight:900;color:#d8d8e4}
.config2d-total strong{font-size:42px}
.footer-links{display:flex;gap:14px;align-items:center;font-size:12px;opacity:.7}
.footer-links a{text-decoration:none;color:#aaa}
.footer-links a:hover{color:#fff}

@media(max-width:1000px){
  .config2d-layout{grid-template-columns:1fr}
  .wheel2d-scene{height:58vh;min-height:460px}
}
@media(max-width:650px){
  .wheel2d-scene{height:52vh;min-height:390px}
  .config2d-panel{padding:18px}
  .segmented{grid-template-columns:1fr}
  .config2d-total{flex-direction:column;align-items:flex-start;gap:8px}
}


/* V18 multi-marques + plastique OEM + nettoyage textes */
.viewer-tools{display:none!important}
.hub2d span{display:none!important}

.segmented.three,
.texture-preview.three{
  grid-template-columns:repeat(3,1fr);
}

.oem-swatch{
  display:block;
  width:100%;
  height:82px;
  background:
    radial-gradient(circle at 25% 25%, rgba(255,255,255,.08), transparent 18%),
    repeating-linear-gradient(45deg,#17171c 0 4px,#111116 4px 8px);
}

.wheel2d.carbon-oem .top-carbon,
.wheel2d.carbon-oem .center-carbon,
.wheel2d.carbon-oem .spoke2d,
.wheel2d.carbon-oem .flat-bottom{
  background:
    radial-gradient(circle at 25% 25%, rgba(255,255,255,.08), transparent 20%),
    repeating-linear-gradient(45deg,#17171c 0 5px,#101015 5px 10px)!important;
  box-shadow:inset 0 0 18px rgba(255,255,255,.05);
}

.wheel2d.carbon-tresse .flat-bottom,
.wheel2d.carbon-tresse .top-carbon,
.wheel2d.carbon-tresse .center-carbon,
.wheel2d.carbon-tresse .spoke2d{
  background-image:url("assets/carbone-tresse.webp");
  background-size:190px;
}

.wheel2d.carbon-forge .flat-bottom,
.wheel2d.carbon-forge .top-carbon,
.wheel2d.carbon-forge .center-carbon,
.wheel2d.carbon-forge .spoke2d{
  background-image:url("assets/carbone-forge.webp")!important;
  background-size:210px;
}

#vehiclePlate{
  text-transform:uppercase;
}

.config-note{
  color:#cfcfe0!important;
  line-height:1.5;
}

@media(max-width:650px){
  .segmented.three,
  .texture-preview.three{
    grid-template-columns:1fr;
  }
}


/* V19 nettoyage configurateur + formulaire direct site */
.hub2d img{
  width:72%;
  height:72%;
  object-fit:contain;
  filter:drop-shadow(0 0 10px rgba(139,53,255,.45));
}

.configurator-form{
  display:block;
}

.configurator-form button.btn{
  width:100%;
  cursor:pointer;
  border:0;
}

.contact-form-panel{
  margin-top:28px;
}

.form button{
  cursor:pointer;
}


.form-success{
  margin-top:16px;
  padding:14px 16px;
  border-radius:14px;
  background:rgba(32, 201, 94, .14);
  border:1px solid rgba(32, 201, 94, .45);
  color:#d9ffe7;
  font-weight:800;
  line-height:1.4;
}

button[disabled]{
  opacity:.75;
  cursor:not-allowed;
}


/* V30 - Cuir lisse + nouvelle vidéo accueil */
.wheel2d.grip-lisse .grip2d{
  background-image:url("assets/cuir-lisse.jpg")!important;
  background-size:210px;
}

.option-group .segmented[data-group="grips"],
.option-group .texture-preview{
  grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
}

.hero video,
.hero-video,
.video-bg{
  object-fit:cover;
}


/* V32 - Formulaire RDV complet */
.rdv-form-panel{
  max-width:980px;
  margin-inline:auto;
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.rdv-form textarea{
  width:100%;
  margin-top:14px;
}
.rdv-form button.btn{
  margin-top:18px;
  width:100%;
}
.form-success{
  margin-top:16px;
  padding:14px 16px;
  border-radius:14px;
  background:rgba(32,201,94,.14);
  border:1px solid rgba(32,201,94,.45);
  color:#d9ffe7;
  font-weight:800;
  line-height:1.4;
}
@media(max-width:700px){
  .form-grid{grid-template-columns:1fr}
}


/* V33 - Cuir lisse sur centre/haut/bas + vidéo accueil plus lumineuse */
.wheel2d.carbon-cuircentral .top-carbon,
.wheel2d.carbon-cuircentral .center-carbon,
.wheel2d.carbon-cuircentral .spoke2d,
.wheel2d.carbon-cuircentral .flat-bottom{
  background-image:url("assets/cuir-lisse.jpg")!important;
  background-size:210px;
  box-shadow:
    inset 0 0 20px rgba(255,255,255,.10),
    inset 0 0 45px rgba(0,0,0,.35),
    0 0 18px rgba(255,255,255,.04);
}

/* Plastique OEM noir piano plus propre */
.wheel2d.carbon-oem .top-carbon,
.wheel2d.carbon-oem .center-carbon,
.wheel2d.carbon-oem .spoke2d,
.wheel2d.carbon-oem .flat-bottom{
  background:
    linear-gradient(145deg, #050507 0%, #19191f 32%, #070709 58%, #24242b 100%)!important;
  box-shadow:
    inset 0 0 22px rgba(255,255,255,.14),
    inset 0 -18px 28px rgba(0,0,0,.55),
    0 0 16px rgba(255,255,255,.05)!important;
}

/* Augmente la luminosité de la vidéo en fond d'accueil */
.hero video,
.hero-video,
.video-bg,
.hero-bg video,
.background-video{
  filter: brightness(1.28) contrast(1.08) saturate(1.08)!important;
}

/* Overlay un peu moins sombre sur l'accueil */
.hero::before,
.hero-bg::before,
.video-overlay{
  opacity:.55!important;
}


/* V34 - Correction définitive mapping textures configurateur */

/* Plastique OEM noir piano : haut + centre + bas */
.wheel2d.carbon-oem .top-carbon,
.wheel2d.carbon-oem .center-carbon,
.wheel2d.carbon-oem .spoke2d,
.wheel2d.carbon-oem .flat-bottom{
  background:
    linear-gradient(135deg, #020203 0%, #111116 18%, #2a2a31 35%, #050506 55%, #181820 78%, #030304 100%)!important;
  background-size:100% 100%!important;
  box-shadow:
    inset 0 0 22px rgba(255,255,255,.16),
    inset 0 -20px 30px rgba(0,0,0,.60),
    0 0 18px rgba(255,255,255,.05)!important;
}

/* Carbone tressé : haut + centre + bas */
.wheel2d.carbon-tresse .top-carbon,
.wheel2d.carbon-tresse .center-carbon,
.wheel2d.carbon-tresse .spoke2d,
.wheel2d.carbon-tresse .flat-bottom{
  background-image:url("assets/carbone-tresse.webp")!important;
  background-size:190px!important;
  background-position:center!important;
  box-shadow:
    inset 0 0 20px rgba(255,255,255,.12),
    inset 0 -18px 28px rgba(0,0,0,.40),
    0 0 18px rgba(255,255,255,.04)!important;
}

/* Carbone forgé : haut + centre + bas */
.wheel2d.carbon-forge .top-carbon,
.wheel2d.carbon-forge .center-carbon,
.wheel2d.carbon-forge .spoke2d,
.wheel2d.carbon-forge .flat-bottom{
  background-image:url("assets/carbone-forge.webp")!important;
  background-size:210px!important;
  background-position:center!important;
  box-shadow:
    inset 0 0 20px rgba(255,255,255,.12),
    inset 0 -18px 28px rgba(0,0,0,.42),
    0 0 18px rgba(255,255,255,.04)!important;
}

/* Cuir lisse haut/bas uniquement : haut + bas + branches, PAS le centre */
.wheel2d.carbon-cuirhb .top-carbon,
.wheel2d.carbon-cuirhb .spoke2d,
.wheel2d.carbon-cuirhb .flat-bottom{
  background-image:url("assets/cuir-lisse.jpg")!important;
  background-size:210px!important;
  background-position:center!important;
  box-shadow:
    inset 0 0 20px rgba(255,255,255,.10),
    inset 0 0 45px rgba(0,0,0,.35),
    0 0 18px rgba(255,255,255,.04)!important;
}

/* Quand cuir lisse haut/bas est choisi, le centre reste plastique noir piano */
.wheel2d.carbon-cuirhb .center-carbon{
  background:
    linear-gradient(135deg, #020203 0%, #111116 18%, #2a2a31 35%, #050506 55%, #181820 78%, #030304 100%)!important;
  background-size:100% 100%!important;
  box-shadow:
    inset 0 0 22px rgba(255,255,255,.16),
    inset 0 -20px 30px rgba(0,0,0,.60),
    0 0 18px rgba(255,255,255,.05)!important;
}

/* Grips */
.wheel2d:not(.grip-cuir):not(.grip-lisse) .grip2d{
  background-image:url("assets/daim-grip.webp")!important;
  background-size:220px!important;
}

.wheel2d.grip-cuir .grip2d{
  background-image:url("assets/cuir-perfore.jpg")!important;
  background-size:170px!important;
}

.wheel2d.grip-lisse .grip2d{
  background-image:url("assets/cuir-lisse.jpg")!important;
  background-size:210px!important;
}

/* Boutons premium */
.seg, .stitch-dot, .btn, button{
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease!important;
}

.seg{
  position:relative;
  overflow:hidden;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04), 0 10px 25px rgba(0,0,0,.22);
}

.seg::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent, rgba(255,255,255,.16), transparent);
  transform:translateX(-120%);
  transition:transform .45s ease;
}

.seg:hover::before{transform:translateX(120%)}
.seg:hover{transform:translateY(-2px);border-color:rgba(179,38,255,.75)!important}
.seg.active{
  box-shadow:0 0 28px rgba(139,53,255,.25), inset 0 0 18px rgba(255,255,255,.08)!important;
}

.btn:hover, button:hover{
  transform:translateY(-2px);
}

/* Logo plus gros au centre */
.hub2d{
  width:23%!important;
}

.hub2d img{
  width:112%!important;
  height:112%!important;
  object-fit:cover!important;
}

/* Animations premium sur tout le site */
.panel, .service-card, .card, .big-card, .contact-card, .tarif-card{
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease!important;
}

.panel:hover, .service-card:hover, .card:hover, .big-card:hover, .contact-card:hover, .tarif-card:hover{
  transform:translateY(-5px);
  box-shadow:0 22px 55px rgba(0,0,0,.35), 0 0 28px rgba(139,53,255,.12);
  border-color:rgba(139,53,255,.45)!important;
}

@media (prefers-reduced-motion: reduce){
  .wheel2d, .seg, .btn, button, .panel, .service-card, .card, .big-card{animation:none!important;transition:none!important}
}


/* V35 - Palettes boîte auto plus détaillées */
.paddle2d{
  position:absolute;
  top:30%!important;
  width:9%!important;
  height:38%!important;
  border-radius:22px 22px 18px 18px!important;
  opacity:0;
  z-index:1;
  background:
    linear-gradient(105deg, rgba(255,255,255,.55) 0%, rgba(180,180,195,.95) 16%, rgba(72,72,84,.95) 48%, rgba(210,210,225,.95) 80%, rgba(255,255,255,.38) 100%)!important;
  box-shadow:
    inset 0 0 10px rgba(255,255,255,.35),
    inset 0 -18px 22px rgba(0,0,0,.35),
    0 18px 28px rgba(0,0,0,.55),
    0 0 22px rgba(255,255,255,.08)!important;
  border:1px solid rgba(255,255,255,.28);
  overflow:hidden;
}

.paddle2d::before{
  content:"";
  position:absolute;
  inset:9px 7px;
  border-radius:16px;
  background:
    repeating-linear-gradient(180deg, rgba(255,255,255,.18) 0 2px, transparent 2px 8px),
    linear-gradient(180deg, rgba(255,255,255,.20), rgba(0,0,0,.20));
  opacity:.55;
}

.paddle2d::after{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  font-family:Inter,Arial,sans-serif;
  font-size:28px;
  font-weight:900;
  color:rgba(255,255,255,.88);
  text-shadow:0 2px 8px rgba(0,0,0,.65);
}

.paddle-left{
  left:27%!important;
  transform:rotate(-12deg) skewY(-4deg)!important;
}

.paddle-right{
  right:27%!important;
  transform:rotate(12deg) skewY(4deg)!important;
}

.paddle-left::after{
  content:"−";
}

.paddle-right::after{
  content:"+";
}

.wheel2d.palettes-on .paddle2d{
  opacity:1!important;
  animation:paddlePop .35s ease both;
}

@keyframes paddlePop{
  from{opacity:0;transform:translateY(8px) scale(.92)}
  to{opacity:1}
}

/* Petit reflet premium sur les palettes */
.wheel2d.palettes-on .paddle2d{
  filter:drop-shadow(0 0 12px rgba(180,180,255,.12));
}


/* V36 - Configurateur partageable + rendu plus premium */
.share-config-box{
  margin:18px 0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.share-config-box .whatsapp-share{
  grid-column:1 / -1;
  background:linear-gradient(90deg,#18b756,#22e071);
  color:#fff;
}

.share-btn,
.whatsapp-share,
.btn.ghost{
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
  padding:14px 16px;
  text-align:center;
  font-weight:900;
  text-transform:uppercase;
  cursor:pointer;
}

.btn.ghost{
  background:rgba(255,255,255,.04);
  color:#fff;
}

.share-message{
  grid-column:1/-1;
  margin:0;
  padding:12px;
  border-radius:12px;
  background:rgba(32,201,94,.14);
  border:1px solid rgba(32,201,94,.42);
  color:#dcffe8;
  font-weight:800;
}

/* effet "showroom" plus propre */
.wheel2d-scene{
  background:
    radial-gradient(circle at 50% 38%, rgba(255,255,255,.16), transparent 19%),
    radial-gradient(circle at 50% 45%, rgba(139,53,255,.34), transparent 42%),
    radial-gradient(circle at 50% 100%, rgba(0,102,255,.24), transparent 46%),
    linear-gradient(180deg,#0b0b10,#030305)!important;
}

.wheel2d{
  filter:
    drop-shadow(0 34px 36px rgba(0,0,0,.70))
    drop-shadow(0 0 22px rgba(139,53,255,.10))!important;
}

/* matières plus contrastées */
.wheel2d.carbon-tresse .top-carbon,
.wheel2d.carbon-tresse .center-carbon,
.wheel2d.carbon-tresse .spoke2d,
.wheel2d.carbon-tresse .flat-bottom{
  filter:contrast(1.15) brightness(1.08);
}

.wheel2d.carbon-forge .top-carbon,
.wheel2d.carbon-forge .center-carbon,
.wheel2d.carbon-forge .spoke2d,
.wheel2d.carbon-forge .flat-bottom{
  filter:contrast(1.18) brightness(1.06);
}

.wheel2d.grip-lisse .grip2d,
.wheel2d.grip-cuir .grip2d{
  filter:contrast(1.08) brightness(1.05);
}

/* option sélectionnée très visible */
.seg.active{
  background:
    linear-gradient(90deg,rgba(35,103,255,.35),rgba(179,38,255,.34))!important;
  border-color:rgba(200,120,255,.85)!important;
  color:#fff!important;
  transform:translateY(-1px);
}

.stitch-dot.active{
  box-shadow:0 0 0 4px rgba(255,255,255,.22), 0 0 22px var(--c)!important;
}

@media(max-width:650px){
  .share-config-box{
    grid-template-columns:1fr;
  }
}


/* V37 - Section jeu concours accueil */
.contest-home{
  position:relative;
  margin:0 auto;
  padding:70px 6vw;
  overflow:hidden;
  background:
    radial-gradient(circle at 72% 45%, rgba(139,53,255,.24), transparent 30%),
    radial-gradient(circle at 30% 75%, rgba(0,102,255,.14), transparent 34%),
    linear-gradient(180deg,#050507,#09090d);
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(139,53,255,.18);
}
.contest-glow{
  position:absolute;
  inset:auto -10% -30% -10%;
  height:300px;
  background:radial-gradient(circle, rgba(139,53,255,.28), transparent 62%);
  pointer-events:none;
  filter:blur(10px);
}
.contest-content{
  position:relative;
  max-width:1280px;
  margin:auto;
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);
  gap:34px;
  align-items:center;
}
.contest-text h2{
  margin:18px 0 14px;
  font-family:Oswald,Inter,sans-serif;
  font-size:clamp(42px,6vw,82px);
  line-height:.92;
  text-transform:uppercase;
  color:#fff;
}
.contest-text h2::after{
  content:"";
  display:block;
  width:120px;
  height:4px;
  margin-top:18px;
  border-radius:999px;
  background:linear-gradient(90deg,#2367ff,#b326ff);
  box-shadow:0 0 20px rgba(179,38,255,.5);
}
.contest-lead{
  max-width:620px;
  color:#dedee8;
  font-size:18px;
  line-height:1.55;
}
.contest-lead strong{color:#b980ff}
.contest-value{
  display:inline-flex;
  align-items:center;
  gap:18px;
  margin:20px 0;
  padding:16px 22px;
  border:1px solid rgba(179,38,255,.55);
  border-radius:18px;
  background:linear-gradient(90deg,rgba(35,103,255,.16),rgba(179,38,255,.18));
  box-shadow:0 0 26px rgba(139,53,255,.18);
}
.contest-value span{
  text-transform:uppercase;
  color:#cfcfe0;
  font-weight:900;
}
.contest-value strong{
  font-size:42px;
  color:#fff;
}
.contest-steps{
  list-style:none;
  padding:0;
  margin:10px 0 26px;
  display:grid;
  gap:11px;
}
.contest-steps li{
  color:#fff;
  padding:13px 14px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  background:rgba(255,255,255,.035);
  backdrop-filter:blur(8px);
}
.contest-steps strong,.contest-steps span{color:#b980ff}
.contest-poster-wrap{
  position:relative;
  border-radius:28px;
  padding:10px;
  background:linear-gradient(135deg,rgba(35,103,255,.38),rgba(179,38,255,.42),rgba(255,255,255,.08));
  box-shadow:0 34px 90px rgba(0,0,0,.55), 0 0 42px rgba(139,53,255,.18);
  transform:perspective(1000px) rotateY(-4deg);
  transition:transform .35s ease, box-shadow .35s ease;
}
.contest-poster-wrap:hover{
  transform:perspective(1000px) rotateY(0deg) translateY(-6px);
  box-shadow:0 42px 100px rgba(0,0,0,.62), 0 0 52px rgba(179,38,255,.28);
}
.contest-poster-wrap img{
  display:block;
  width:100%;
  border-radius:22px;
  object-fit:cover;
}
@media(max-width:900px){
  .contest-content{grid-template-columns:1fr}
  .contest-poster-wrap{transform:none}
}


/* V39 - Présentation premium concours sur page Volants */
.contest-volants-premium{
  padding:70px 6vw;
  background:
    radial-gradient(circle at 20% 20%, rgba(139,53,255,.20), transparent 32%),
    radial-gradient(circle at 88% 52%, rgba(35,103,255,.12), transparent 28%),
    linear-gradient(180deg,#050507,#09090d);
}

.contest-volants-card{
  max-width:1180px;
  margin:auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,420px);
  gap:34px;
  align-items:center;
  padding:28px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:30px;
  background:
    linear-gradient(135deg,rgba(255,255,255,.075),rgba(255,255,255,.025)),
    radial-gradient(circle at 82% 24%,rgba(179,38,255,.18),transparent 35%);
  box-shadow:0 30px 90px rgba(0,0,0,.48), 0 0 38px rgba(139,53,255,.12);
  overflow:hidden;
}

.contest-volants-info h2{
  margin:16px 0 14px;
  font-family:Oswald,Inter,sans-serif;
  font-size:clamp(36px,5vw,68px);
  line-height:.95;
  text-transform:uppercase;
  color:#fff;
}

.contest-volants-info p{
  max-width:680px;
  color:#d9d9e6;
  font-size:18px;
  line-height:1.55;
}

.contest-volants-info p strong{
  color:#b980ff;
}

.contest-volants-highlight{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin:24px 0;
}

.contest-volants-highlight > div{
  padding:18px;
  border:1px solid rgba(179,38,255,.38);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(35,103,255,.14),rgba(179,38,255,.16));
}

.contest-volants-highlight small{
  display:block;
  margin-bottom:8px;
  color:#aaaabe;
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:.05em;
}

.contest-volants-highlight strong{
  display:block;
  color:#fff;
  font-size:clamp(26px,4vw,42px);
  font-weight:900;
}

.contest-volants-steps{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:0 0 24px;
}

.contest-volants-steps div{
  display:flex;
  gap:10px;
  align-items:center;
  padding:13px 14px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:15px;
  background:rgba(255,255,255,.035);
  color:#fff;
}

.contest-volants-steps span{
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  border-radius:50%;
  background:linear-gradient(135deg,#2367ff,#b326ff);
  font-weight:900;
  box-shadow:0 0 18px rgba(139,53,255,.35);
}

.contest-volants-image{
  position:relative;
  padding:8px;
  border-radius:24px;
  background:linear-gradient(135deg,rgba(35,103,255,.42),rgba(179,38,255,.52));
  box-shadow:0 24px 70px rgba(0,0,0,.45), 0 0 34px rgba(139,53,255,.22);
  transform:rotate(1.5deg);
}

.contest-volants-image img{
  display:block;
  width:100%;
  border-radius:18px;
}

@media(max-width:900px){
  .contest-volants-card{
    grid-template-columns:1fr;
    padding:22px;
  }
  .contest-volants-steps,
  .contest-volants-highlight{
    grid-template-columns:1fr;
  }
  .contest-volants-image{
    transform:none;
  }
}


/* V41 - Banderole concours page volants */

.contest-banner-top{
  position:relative;
  overflow:hidden;
  padding:38px 6vw 48px;
  background:
    radial-gradient(circle at 20% 20%, rgba(139,53,255,.24), transparent 30%),
    radial-gradient(circle at 80% 60%, rgba(35,103,255,.14), transparent 30%),
    linear-gradient(180deg,#08080b,#050507);
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(179,38,255,.18);
}

.contest-banner-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(179,38,255,.06), transparent 50%, rgba(35,103,255,.08));
  pointer-events:none;
}

.contest-banner-content{
  position:relative;
  max-width:1380px;
  margin:auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) 460px;
  gap:36px;
  align-items:center;
}

.contest-banner-text h1{
  margin:12px 0 14px;
  font-size:clamp(42px,6vw,88px);
  line-height:.9;
  font-family:Oswald,Inter,sans-serif;
  text-transform:uppercase;
  color:#fff;
}

.contest-mini{
  display:inline-flex;
  padding:10px 16px;
  border-radius:999px;
  background:linear-gradient(90deg,#2367ff,#b326ff);
  color:#fff;
  font-size:13px;
  font-weight:900;
  letter-spacing:.12em;
  box-shadow:0 0 22px rgba(139,53,255,.35);
}

.contest-banner-text p{
  font-size:18px;
  color:#dadbea;
  margin-bottom:24px;
}

.contest-banner-info{
  display:flex;
  gap:16px;
  margin-bottom:24px;
  flex-wrap:wrap;
}

.contest-banner-info div{
  min-width:160px;
  padding:16px 18px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(10px);
}

.contest-banner-info small{
  display:block;
  margin-bottom:6px;
  color:#9da0bb;
  text-transform:uppercase;
  font-weight:800;
}

.contest-banner-info strong{
  color:#fff;
  font-size:32px;
}

.contest-banner-image{
  position:relative;
  border-radius:28px;
  padding:10px;
  background:linear-gradient(135deg,rgba(35,103,255,.35),rgba(179,38,255,.45));
  box-shadow:0 34px 90px rgba(0,0,0,.55), 0 0 44px rgba(139,53,255,.18);
  transform:rotate(-2deg);
}

.contest-banner-image img{
  width:100%;
  display:block;
  border-radius:20px;
}

@media(max-width:980px){
  .contest-banner-content{
    grid-template-columns:1fr;
  }

  .contest-banner-image{
    max-width:520px;
    margin:auto;
    transform:none;
  }
}


/* V43 - Clean final */
.form-success,.cv-clean-success{
  margin-top:16px;
  padding:14px 16px;
  border-radius:16px;
  background:linear-gradient(135deg,rgba(35,103,255,.16),rgba(179,38,255,.18));
  border:1px solid rgba(179,38,255,.45);
  color:#fff;
  font-weight:900;
  line-height:1.4;
  box-shadow:0 0 28px rgba(139,53,255,.18);
}
.cv-clean-success.is-visible{animation:cvSuccessPop .45s ease both}
@keyframes cvSuccessPop{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

.old-price{text-decoration:line-through;opacity:.55;margin-right:10px;color:#aaa}
.promo-price{color:#fff;font-weight:900}
.promo-tag{
  display:inline-flex;
  padding:5px 10px;
  margin-left:8px;
  border-radius:999px;
  background:linear-gradient(90deg,#2367ff,#b326ff);
  color:#fff;
  font-size:.78rem;
  font-weight:900;
  box-shadow:0 0 18px rgba(139,53,255,.35);
}
.debug,.netlify-debug,.form-debug{display:none!important}

.btn,button,.seg{transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease!important}
.btn:hover,button:hover,.seg:hover{transform:translateY(-2px)}
.btn.primary{box-shadow:0 0 28px rgba(139,53,255,.22)}
.btn.primary:hover{box-shadow:0 0 36px rgba(179,38,255,.38),0 14px 32px rgba(0,0,0,.32)}

.home-trust,.mini-faq{padding:70px 6vw;max-width:1240px;margin:auto}
.trust-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.trust-grid article,.mini-faq details{
  padding:22px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:22px;
  background:rgba(255,255,255,.035);
  box-shadow:0 18px 44px rgba(0,0,0,.24);
}
.trust-grid strong{display:block;color:#fff;font-size:20px;margin-bottom:8px}
.trust-grid span,.mini-faq p{color:#d6d6e2}
.mini-faq details{margin:12px 0}
.mini-faq summary{color:#fff;font-weight:900;cursor:pointer}
@media(max-width:760px){.trust-grid{grid-template-columns:1fr}.form-success{font-size:14px}}

/* V44 - Configurateur complet style Custom Valley */
.config-page-v44{background:radial-gradient(circle at 78% 18%,rgba(139,53,255,.16),transparent 30%),radial-gradient(circle at 10% 35%,rgba(35,103,255,.10),transparent 32%),#050507}
.config-hero-v44{max-width:1180px;margin:auto}
.configurator-full-v44{width:min(1380px,94vw);margin:30px auto 90px;display:grid;grid-template-columns:minmax(320px,430px) minmax(0,1fr);gap:28px;align-items:start}
.config-preview-v44{position:sticky;top:96px}
.preview-card-v44,.config-form-v44{border:1px solid rgba(255,255,255,.10);border-radius:28px;background:linear-gradient(135deg,rgba(255,255,255,.07),rgba(255,255,255,.025)),radial-gradient(circle at 50% 0%,rgba(179,38,255,.13),transparent 34%);box-shadow:0 30px 90px rgba(0,0,0,.42),0 0 35px rgba(139,53,255,.12)}
.preview-card-v44{padding:18px}
.preview-label{display:inline-flex;margin:0 0 14px;padding:8px 12px;border-radius:999px;color:#fff;font-weight:900;background:linear-gradient(90deg,#2367ff,#b326ff);box-shadow:0 0 20px rgba(139,53,255,.35)}
.compact-preview{min-height:390px;border-radius:22px;overflow:hidden}
.estimate-box-v44{margin-top:16px;padding:18px;border-radius:20px;border:1px solid rgba(179,38,255,.42);background:linear-gradient(90deg,rgba(35,103,255,.16),rgba(179,38,255,.18));display:flex;align-items:center;justify-content:space-between}
.estimate-box-v44 span{color:#cfcfe0;font-weight:900;text-transform:uppercase}.estimate-box-v44 strong{color:#fff;font-size:42px}
.config-form-v44{padding:26px}.form-section-v44{padding:24px 0;border-bottom:1px solid rgba(255,255,255,.08)}.form-section-v44:first-child{padding-top:0}
.form-section-v44 h2{margin:0 0 18px;font-family:Oswald,Inter,sans-serif;font-size:clamp(26px,3vw,40px);text-transform:uppercase;color:#fff}
.form-section-v44 h3{margin:20px 0 12px;color:#fff;font-size:18px;text-transform:uppercase}
.form-grid-v44,.stitch-slots-v44{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-grid-v44 label,.stitch-slots-v44 label,.full-label-v44{color:#dcdcec;font-weight:800;display:grid;gap:8px}
.config-form-v44 input,.config-form-v44 select,.config-form-v44 textarea{width:100%;border:1px solid rgba(255,255,255,.14);border-radius:14px;background:rgba(0,0,0,.34);color:#fff;padding:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}
.config-form-v44 input:focus,.config-form-v44 select:focus,.config-form-v44 textarea:focus{border-color:rgba(179,38,255,.75);box-shadow:0 0 0 4px rgba(179,38,255,.12);background:rgba(0,0,0,.48)}
.choice-grid-v44{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.choice-grid-v44 label,.option-list-v44 label{display:flex;gap:10px;align-items:center;padding:14px;border:1px solid rgba(255,255,255,.10);border-radius:16px;background:rgba(255,255,255,.035);color:#fff;font-weight:800;cursor:pointer}
.choice-grid-v44.segmented{grid-template-columns:repeat(3,minmax(0,1fr))}
.choice-grid-v44 .seg{min-height:56px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.035);color:#fff;font-weight:900;text-transform:uppercase;cursor:pointer}
.choice-grid-v44 .seg.active{background:linear-gradient(90deg,rgba(35,103,255,.34),rgba(179,38,255,.35));border-color:rgba(190,120,255,.85);box-shadow:0 0 28px rgba(139,53,255,.24)}
.option-list-v44{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stitch-dots-v44{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.form-submit-v44{padding-top:24px}.form-submit-v44 .btn{width:100%;min-height:60px}.form-submit-v44 p,.config-note,.mini-note{color:#cfcfe0;line-height:1.5}
@media(max-width:1020px){.configurator-full-v44{grid-template-columns:1fr}.config-preview-v44{position:relative;top:auto}}
@media(max-width:720px){.form-grid-v44,.stitch-slots-v44,.choice-grid-v44,.choice-grid-v44.segmented,.option-list-v44{grid-template-columns:1fr}}


/* V45 - Configurateur clean sans rendu 2D */
.config-page-v45{
  background:radial-gradient(circle at 78% 18%,rgba(139,53,255,.16),transparent 30%),radial-gradient(circle at 10% 35%,rgba(35,103,255,.10),transparent 32%),#050507;
}
.config-hero-v45{max-width:1180px;margin:auto}
.config-form-v45{
  width:min(1180px,94vw);
  margin:30px auto 90px;
  padding:28px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:30px;
  background:linear-gradient(135deg,rgba(255,255,255,.07),rgba(255,255,255,.025)),radial-gradient(circle at 50% 0%,rgba(179,38,255,.13),transparent 34%);
  box-shadow:0 30px 90px rgba(0,0,0,.42),0 0 35px rgba(139,53,255,.12);
}
.sticky-estimate-v45{
  position:sticky;
  top:86px;
  z-index:20;
  margin:-6px 0 24px;
  padding:16px 18px;
  border:1px solid rgba(179,38,255,.48);
  border-radius:22px;
  background:linear-gradient(90deg,rgba(35,103,255,.22),rgba(179,38,255,.25)),rgba(0,0,0,.72);
  backdrop-filter:blur(14px);
  display:flex;
  justify-content:space-between;
  align-items:center;
  box-shadow:0 16px 42px rgba(0,0,0,.38),0 0 26px rgba(139,53,255,.2);
}
.sticky-estimate-v45 span,.sticky-estimate-v45 small{color:#d8d8e8;font-weight:900;text-transform:uppercase}
.sticky-estimate-v45 strong{color:#fff;font-size:38px}
.form-section-v45{padding:26px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.form-section-v45:first-of-type{padding-top:0}
.form-section-v45 h2{
  margin:0 0 18px;
  font-family:Oswald,Inter,sans-serif;
  font-size:clamp(28px,3.5vw,44px);
  text-transform:uppercase;
  color:#fff;
}
.form-section-v45 h3{margin:22px 0 12px;color:#fff;text-transform:uppercase;font-size:18px}
.form-grid-v45{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-grid-v45 label,.full-label-v45{display:grid;gap:8px;color:#dcdcec;font-weight:800}
.config-form-v45 input,.config-form-v45 select,.config-form-v45 textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  background:rgba(0,0,0,.34);
  color:#fff;
  padding:14px;
  outline:none;
}
.config-form-v45 input:focus,.config-form-v45 select:focus,.config-form-v45 textarea:focus{
  border-color:rgba(179,38,255,.75);
  box-shadow:0 0 0 4px rgba(179,38,255,.12);
}
.choice-grid-v45,.button-grid-v45,.option-list-v45{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.button-grid-v45{grid-template-columns:repeat(3,minmax(0,1fr))}
.choice-grid-v45 label,.option-list-v45 label,.premium-choice{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-start;
  min-height:58px;
  padding:15px 16px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:rgba(255,255,255,.035);
  color:#fff;
  font-weight:900;
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.premium-choice{
  appearance:none;
  width:100%;
  text-transform:uppercase;
}
.premium-choice small{color:#caa8ff;margin-left:auto}
.premium-choice::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.14),transparent);
  transform:translateX(-120%);
  transition:.45s ease;
}
.premium-choice:hover::before{transform:translateX(120%)}
.premium-choice:hover,.choice-grid-v45 label:hover,.option-list-v45 label:hover{
  border-color:rgba(179,38,255,.65);
  transform:translateY(-2px);
}
.premium-choice.active{
  background:linear-gradient(90deg,rgba(35,103,255,.36),rgba(179,38,255,.38));
  border-color:rgba(202,140,255,.9);
  box-shadow:0 0 28px rgba(139,53,255,.26),inset 0 0 18px rgba(255,255,255,.08);
}
.palette-block-v45{
  margin-top:14px;
  padding:16px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(255,255,255,.035);
}
.palette-block-v45 p{margin:0 0 12px;color:#fff;font-weight:900}
.stitch-picker-v45{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.palette-row-v45{display:flex;gap:10px;flex-wrap:wrap}
.palette-row-v45 button{
  width:42px;height:42px;border-radius:50%;
  border:2px solid rgba(255,255,255,.22);
  background:var(--c);
  cursor:pointer;
}
.palette-row-v45 button.active{
  box-shadow:0 0 0 4px rgba(255,255,255,.18),0 0 22px var(--c);
  transform:scale(1.08);
}
.form-submit-v45{padding-top:24px}
.form-submit-v45 .btn{width:100%;min-height:62px}
.form-submit-v45 p,.mini-note{color:#cfcfe0}
.bmw-only-options[hidden]{display:none!important}
@media(max-width:900px){
  .button-grid-v45,.stitch-picker-v45{grid-template-columns:1fr}
}
@media(max-width:720px){
  .form-grid-v45,.choice-grid-v45,.option-list-v45{grid-template-columns:1fr}
  .sticky-estimate-v45{position:relative;top:auto}
}

/* V46 - Bloc SEO discret */
.seo-home-block-v46{
  max-width:1100px;
  margin:40px auto 80px;
  padding:42px 6vw;
  border:1px solid rgba(255,255,255,.10);
  border-radius:28px;
  background:
    radial-gradient(circle at 20% 0%,rgba(139,53,255,.16),transparent 34%),
    linear-gradient(135deg,rgba(255,255,255,.055),rgba(255,255,255,.025));
  box-shadow:0 28px 80px rgba(0,0,0,.38);
}
.seo-home-block-v46 p{
  color:#d8d8e8;
  line-height:1.7;
  font-size:17px;
  max-width:900px;
}


/* V47 - Nettoyage FAQ bas + titre SEO mieux calé */
.seo-home-block-v46{
  max-width: 1280px !important;
  width: min(92vw, 1280px);
}
.seo-home-block-v46 .section-head{
  max-width: 100%;
}
.seo-home-block-v46 h2{
  max-width: 100%;
  line-height: .98;
  font-size: clamp(38px, 4.3vw, 62px);
  text-wrap: balance;
}
@media (min-width: 1200px){
  .seo-home-block-v46 h2{
    white-space: nowrap;
    font-size: 58px;
  }
}
@media (max-width: 760px){
  .seo-home-block-v46 h2{
    white-space: normal;
    font-size: clamp(34px, 10vw, 48px);
  }
}


/* V48 - Correction titre SEO qui déborde */
.seo-home-block-v46{
  overflow:hidden !important;
  max-width:1100px !important;
  width:min(88vw, 1100px) !important;
}
.seo-home-block-v46 h2{
  white-space:normal !important;
  max-width:900px !important;
  font-size:clamp(36px, 4vw, 54px) !important;
  line-height:1.05 !important;
  overflow-wrap:normal;
  word-break:normal;
}
.seo-home-block-v46 .section-head{
  overflow:hidden;
}
@media (min-width:1200px){
  .seo-home-block-v46 h2{
    font-size:50px !important;
  }
}
@media (max-width:760px){
  .seo-home-block-v46{
    width:min(94vw, 1100px) !important;
    padding:30px 22px !important;
  }
  .seo-home-block-v46 h2{
    font-size:34px !important;
  }
}


/* =========================
   V49 - FIX CONFIG MOBILE
========================= */

@media (max-width: 768px){

  /* Corrige cartes options qui coupent le texte */
  .config-option,
  .option-card,
  .choice-card,
  .extra-option,
  .radio-card,
  .checkbox-card{
      display:flex !important;
      align-items:center !important;
      gap:14px !important;
      padding:18px !important;
      min-height:90px !important;
      width:100% !important;
      overflow:hidden !important;
  }

  /* Force le texte à rester visible */
  .config-option label,
  .option-card label,
  .choice-card label,
  .extra-option label,
  .radio-card label,
  .checkbox-card label,
  .config-option span,
  .option-card span,
  .choice-card span,
  .extra-option span{
      display:block !important;
      width:100% !important;
      font-size:16px !important;
      line-height:1.3 !important;
      white-space:normal !important;
      overflow:visible !important;
      text-overflow:unset !important;
      word-break:break-word !important;
      padding-right:8px !important;
  }

  /* Inputs */
  .config-option input,
  .option-card input,
  .choice-card input,
  .extra-option input{
      flex-shrink:0 !important;
      width:22px !important;
      height:22px !important;
  }

  /* Upload fichiers */
  input[type="file"]{
      width:100% !important;
      font-size:14px !important;
      overflow:hidden !important;
  }

  /* Titre sections configurateur */
  .config-section-title,
  .configurator h2,
  .configurator h3{
      font-size:42px !important;
      line-height:0.95 !important;
      word-break:break-word !important;
  }

  /* Supprime le débordement horizontal */
  body,
  html{
      overflow-x:hidden !important;
  }

  .configurator,
  .config-wrapper,
  .config-container{
      overflow:hidden !important;
      width:100% !important;
  }

  /* WhatsApp */
  .whatsapp-button{
      bottom:18px !important;
      right:18px !important;
      transform:scale(.92);
  }
}


/* =========================
   V50 - VRAI FIX CONFIGURATEUR MOBILE
   Corrige les textes coupés à droite dans les labels/options
========================= */

@media (max-width: 820px){

  html, body{
    width:100% !important;
    max-width:100% !important;
    overflow-x:hidden !important;
  }

  main,
  .config-page-v45,
  .config-page-v44,
  .configurator,
  .configurator-full-v44,
  .config-form-v45,
  .config-form-v44,
  form{
    width:100% !important;
    max-width:100% !important;
    overflow-x:hidden !important;
    box-sizing:border-box !important;
  }

  .config-form-v45,
  .config-form-v44{
    width:calc(100% - 22px) !important;
    margin-left:auto !important;
    margin-right:auto !important;
    padding:18px 14px !important;
    border-radius:22px !important;
  }

  .form-section-v45,
  .form-section-v44{
    width:100% !important;
    max-width:100% !important;
    overflow:hidden !important;
    box-sizing:border-box !important;
  }

  .form-section-v45 h2,
  .form-section-v44 h2{
    font-size:clamp(34px, 11vw, 48px) !important;
    line-height:.95 !important;
    max-width:100% !important;
    white-space:normal !important;
    overflow-wrap:break-word !important;
  }

  .form-section-v45 h3,
  .form-section-v44 h3{
    font-size:clamp(22px, 7vw, 34px) !important;
    line-height:1 !important;
    white-space:normal !important;
  }

  .form-grid-v45,
  .form-grid-v44,
  .choice-grid-v45,
  .choice-grid-v44,
  .button-grid-v45,
  .button-grid-v44,
  .option-list-v45,
  .option-list-v44,
  .stitch-picker-v45{
    display:grid !important;
    grid-template-columns:1fr !important;
    width:100% !important;
    max-width:100% !important;
    gap:14px !important;
    overflow:hidden !important;
  }

  .choice-grid-v45 label,
  .choice-grid-v44 label,
  .option-list-v45 label,
  .option-list-v44 label,
  .premium-choice,
  .seg{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    box-sizing:border-box !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    gap:14px !important;
    padding:18px 16px !important;
    min-height:74px !important;
    overflow:hidden !important;
    text-align:left !important;
  }

  .choice-grid-v45 label *,
  .choice-grid-v44 label *,
  .option-list-v45 label *,
  .option-list-v44 label *,
  .premium-choice *,
  .seg *{
    min-width:0 !important;
    max-width:100% !important;
  }

  .choice-grid-v45 label span,
  .choice-grid-v44 label span,
  .option-list-v45 label span,
  .option-list-v44 label span,
  .premium-choice,
  .premium-choice small,
  .seg{
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
    word-break:normal !important;
    overflow-wrap:anywhere !important;
    line-height:1.25 !important;
    font-size:15px !important;
  }

  .choice-grid-v45 input[type="radio"],
  .choice-grid-v44 input[type="radio"],
  .option-list-v45 input[type="checkbox"],
  .option-list-v44 input[type="checkbox"]{
    flex:0 0 22px !important;
    width:22px !important;
    height:22px !important;
    min-width:22px !important;
    margin:0 !important;
  }

  .premium-choice small,
  .seg small{
    margin-left:6px !important;
    display:inline !important;
    font-size:13px !important;
  }

  .config-form-v45 input,
  .config-form-v45 select,
  .config-form-v45 textarea,
  .config-form-v44 input,
  .config-form-v44 select,
  .config-form-v44 textarea{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    box-sizing:border-box !important;
    font-size:16px !important;
  }

  input[type="file"]{
    font-size:13px !important;
    white-space:normal !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }

  .sticky-estimate-v45{
    position:relative !important;
    top:auto !important;
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
  }

  .palette-row-v45{
    width:100% !important;
    max-width:100% !important;
    overflow:hidden !important;
  }

  .whatsapp,
  .whatsapp-button,
  a[href*="wa.me"],
  a[href*="whatsapp"]{
    max-width:170px !important;
    right:14px !important;
    bottom:14px !important;
  }
}

/* sécurité globale contre le débordement des options */
.config-form-v45 *,
.config-form-v44 *{
  box-sizing:border-box;
}


/* =========================================================
   V51_PREMIUM_POLISH — finition visuelle + animations naturelles
   Objectif : rendu plus haut de gamme, moins générique, sans casser la V50.
   ========================================================= */
:root{
  --cv-violet:#9d35ff;
  --cv-violet-soft:rgba(157,53,255,.34);
  --cv-blue:#2267ff;
  --cv-glass:rgba(255,255,255,.055);
  --cv-line:rgba(255,255,255,.12);
  --cv-text:#f6f2ff;
  --cv-muted:#bdb6ca;
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,12%), rgba(157,53,255,.20), transparent 22rem),
    radial-gradient(circle at 12% 18%, rgba(34,103,255,.14), transparent 24rem),
    linear-gradient(180deg,rgba(255,255,255,.018),transparent 28%);
  transition:background-position .4s ease;
}

.site-header{
  background:linear-gradient(180deg,rgba(8,8,12,.88),rgba(5,5,8,.72));
  box-shadow:0 10px 35px rgba(0,0,0,.28);
}

.site-header::after{
  content:"";
  position:absolute;
  left:clamp(18px,4vw,56px);
  right:clamp(18px,4vw,56px);
  bottom:-1px;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(157,53,255,.75),transparent);
  opacity:.65;
}

.brand img{transition:transform .35s ease, filter .35s ease}
.brand:hover img{transform:rotate(-2deg) scale(1.035);filter:drop-shadow(0 0 20px rgba(157,53,255,.55))}
.main-nav a{position:relative;transition:color .24s ease, transform .24s ease}
.main-nav a:not(.nav-cta)::after{
  content:"";position:absolute;left:0;right:0;bottom:-9px;height:2px;
  background:linear-gradient(90deg,var(--cv-blue),var(--cv-violet));
  transform:scaleX(0);transform-origin:center;transition:transform .26s ease;border-radius:99px;
}
.main-nav a:hover{transform:translateY(-1px)}
.main-nav a:hover::after{transform:scaleX(1)}
.nav-cta{border-radius:999px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04),0 0 24px rgba(157,53,255,.16)}

.home-hero::after,.page-hero::after{
  content:"";position:absolute;inset:auto 0 0 0;height:44%;pointer-events:none;
  background:linear-gradient(180deg,transparent,rgba(4,4,6,.96));
}
.home-hero{isolation:isolate}
.hero-video{transform:scale(1.035);filter:saturate(1.06) contrast(1.06)}
.hero-overlay{background:linear-gradient(90deg,rgba(0,0,0,.94),rgba(0,0,0,.68) 48%,rgba(0,0,0,.35)),radial-gradient(circle at 22% 42%,rgba(157,53,255,.22),transparent 38%)}
.hero-content{animation:cvHeroIn .9s cubic-bezier(.2,.75,.2,1) both}
.hero-content h1{letter-spacing:-.025em;text-shadow:0 18px 50px rgba(0,0,0,.55)}
.hero-content p{max-width:620px;color:#ece7f2}
.badge{box-shadow:0 0 26px rgba(157,53,255,.14);backdrop-filter:blur(14px)}

.btn,.primary,.secondary,button[type="submit"]{
  position:relative;overflow:hidden;border-radius:999px;letter-spacing:.02em;
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .24s ease;
}
.btn::before,button[type="submit"]::before{
  content:"";position:absolute;inset:-2px;transform:translateX(-115%) skewX(-18deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);
  transition:transform .7s cubic-bezier(.2,.7,.2,1);pointer-events:none;
}
.btn:hover::before,button[type="submit"]:hover::before{transform:translateX(115%) skewX(-18deg)}
.primary{background:linear-gradient(100deg,#235fff 0%,#8e32ff 52%,#c23cff 100%);box-shadow:0 12px 36px rgba(157,53,255,.22)}
.secondary{background:rgba(255,255,255,.045);backdrop-filter:blur(12px)}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(157,53,255,.28)}
.btn:active{transform:translateY(-1px) scale(.985)}

.service-card,.panel,.prestation-tile,.contact-card,.tarif-card,.legal-panel,.form-block,.contest-content,.free-quote,.faq-preview,.home-trust,.seo-home-block-v46{
  position:relative;
  background:linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.025) 45%,rgba(157,53,255,.035));
  border-color:rgba(255,255,255,.105);
  box-shadow:0 18px 55px rgba(0,0,0,.26);
}
.service-card::before,.panel::before,.prestation-tile::before,.contest-content::before,.free-quote::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(157,53,255,.42),rgba(255,255,255,.03));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.45;pointer-events:none;
}
.service-card:hover,.panel:hover,.prestation-tile:hover,.tarif-card:hover{
  transform:translateY(-7px);
  border-color:rgba(157,53,255,.48)!important;
  box-shadow:0 26px 75px rgba(0,0,0,.40),0 0 34px rgba(157,53,255,.15)!important;
}
.service-card img,.gallery-two img,.gallery-grid img,.image-panel img,.contest-poster-wrap img{
  transition:transform .7s cubic-bezier(.2,.7,.2,1),filter .7s ease;
}
.service-card:hover img,.gallery-two img:hover,.gallery-grid img:hover,.image-panel:hover img,.contest-poster-wrap:hover img{
  transform:scale(1.035);filter:saturate(1.08) contrast(1.05);
}

.trust-bar{background:linear-gradient(90deg,rgba(255,255,255,.045),rgba(157,53,255,.045),rgba(255,255,255,.028));box-shadow:0 18px 55px rgba(0,0,0,.22)}
.trust-bar b{color:#fff;text-shadow:0 0 18px rgba(157,53,255,.22)}

input,select,textarea,.config-form-v45 input,.config-form-v45 select,.config-form-v45 textarea{
  background:rgba(7,7,11,.72)!important;
  border-color:rgba(255,255,255,.13)!important;
  transition:border-color .22s ease,box-shadow .22s ease,background .22s ease!important;
}
input:focus,select:focus,textarea:focus,.config-form-v45 input:focus,.config-form-v45 select:focus,.config-form-v45 textarea:focus{
  border-color:rgba(157,53,255,.72)!important;
  box-shadow:0 0 0 4px rgba(157,53,255,.12),0 0 26px rgba(157,53,255,.12)!important;
}

.premium-choice,.seg,.config-options label,.option-list-v45 label,.choice-grid-v45 label{
  transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease!important;
}
.premium-choice:hover,.seg:hover,.config-options label:hover,.option-list-v45 label:hover,.choice-grid-v45 label:hover{
  transform:translateY(-2px);
  border-color:rgba(157,53,255,.45)!important;
  box-shadow:0 12px 32px rgba(0,0,0,.25),0 0 22px rgba(157,53,255,.10)!important;
}
.premium-choice.active,.seg.active,.color-dot.active,.palette-row-v45 button.active{
  box-shadow:0 0 0 1px rgba(255,255,255,.14),0 0 28px rgba(157,53,255,.26)!important;
}

.reveal{transform:translateY(34px) scale(.985);filter:blur(3px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.75,.2,1),filter .8s ease!important}
.reveal.visible{filter:blur(0)}
.reveal.visible:nth-child(2n){transition-delay:.04s}
.reveal.visible:nth-child(3n){transition-delay:.08s}

.whatsapp-float{
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 18px 48px rgba(0,0,0,.34),0 0 28px rgba(32,200,90,.22);
  transition:transform .25s ease, box-shadow .25s ease;
}
.whatsapp-float:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 24px 62px rgba(0,0,0,.40),0 0 40px rgba(32,200,90,.30)}

@keyframes cvHeroIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes cvSoftPulse{0%,100%{box-shadow:0 0 0 rgba(157,53,255,0)}50%{box-shadow:0 0 34px rgba(157,53,255,.16)}}

@media (max-width:650px){
  .hero-overlay{background:linear-gradient(180deg,rgba(0,0,0,.58),rgba(0,0,0,.86)),radial-gradient(circle at 50% 22%,rgba(157,53,255,.23),transparent 42%)}
  .hero-content h1{font-size:clamp(42px,12vw,58px);line-height:.94}
  .service-card,.panel,.form-block{border-radius:22px}
  .btn{min-height:50px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* V52_CIEL_PHOTOS_FIX — correction galerie ciel étoilé
   Corrige l'effet visuel "moitié noir" causé par le recadrage/effet hover sur les photos. */
.gallery-two img[src*="ciel"]{
  opacity:1!important;
  filter:none!important;
  mix-blend-mode:normal!important;
  background:#07070b!important;
  transform-origin:center center;
  will-change:transform;
}

.gallery-two img[src$="ciel1.jpeg"]{
  object-fit:cover!important;
  object-position:center center!important;
  padding:0!important;
  background:#07070b!important;
}

.gallery-two img[src$="ciel2.jpeg"]{
  object-position:center 48%!important;
}

.gallery-two img[src*="ciel"]:hover{
  filter:none!important;
  transform:scale(1.015)!important;
}

@media(max-width:650px){
  .gallery-two img[src*="ciel"]{
    height:auto!important;
    max-height:none!important;
    aspect-ratio:auto!important;
    object-fit:cover!important;
  }
}


/* =========================================================
   V55 PERFORMANCE MOTION — animations premium optimisées
   Objectif : rendu plus cinématique SANS latence.
   - suppression des effets lourds permanents
   - animations GPU uniquement: transform / opacity
   - pas de blur massif, pas de balayage plein écran infini
   ========================================================= */
:root{
  --cv-neon:#b037ff;
  --cv-blue:#2f66ff;
  --cv-card-x:50%;
  --cv-card-y:20%;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{overflow-x:hidden;background:#020206}
body::before,
body::after{display:none!important;animation:none!important}
main,section{content-visibility:auto;contain-intrinsic-size:1px 900px}
.site-header{
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  transition:background .28s ease,border-color .28s ease,box-shadow .28s ease,transform .28s ease!important;
  will-change:auto!important;
}
.site-header.is-scrolled{background:rgba(3,3,7,.88)!important;border-color:rgba(176,55,255,.24)!important;box-shadow:0 16px 40px rgba(0,0,0,.34)!important}
.brand img{animation:none!important;filter:drop-shadow(0 0 14px rgba(176,55,255,.35))}
.brand span{letter-spacing:.08em}
.home-hero{isolation:isolate;overflow:hidden;contain:layout paint style}
.home-hero::before{
  content:""!important;display:block!important;position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(circle at 18% 38%,rgba(176,55,255,.28),transparent 28%),
    radial-gradient(circle at 78% 24%,rgba(47,102,255,.16),transparent 30%),
    linear-gradient(90deg,rgba(0,0,0,.82),rgba(0,0,0,.42) 48%,rgba(0,0,0,.84));
  opacity:.95;animation:cvV55HeroLight 8s ease-in-out infinite alternate!important;transform:translateZ(0)
}
.home-hero::after{
  content:""!important;display:block!important;position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(115deg,transparent 0 42%,rgba(255,255,255,.09) 49%,transparent 56% 100%);
  transform:translate3d(-120%,0,0) skewX(-10deg);
  animation:cvV55HeroScan 5.8s cubic-bezier(.16,1,.3,1) 1 .45s both!important;
  opacity:.5
}
.hero-video{transform:scale(1.045) translateZ(0)!important;animation:cvV55VideoMove 18s ease-in-out infinite alternate!important;filter:contrast(1.06) saturate(1.08)!important;will-change:transform}
.hero-content{position:relative;z-index:3;animation:cvV55HeroEnter .9s cubic-bezier(.16,1,.3,1) both!important;will-change:auto!important}
.hero-content .badge{animation:cvV55BadgeIn .75s cubic-bezier(.16,1,.3,1) .15s both!important;box-shadow:0 0 0 1px rgba(176,55,255,.55),0 0 34px rgba(176,55,255,.16)!important}
.hero-content h1{animation:cvV55TitleIn .95s cubic-bezier(.16,1,.3,1) .12s both!important;text-wrap:balance}
.hero-content h1 em,h2 em{
  color:transparent!important;
  background:linear-gradient(100deg,#8d35ff 0%,#c456ff 45%,#ffffff 52%,#9b37ff 68%,#2f66ff 100%);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;
  animation:cvV55Chrome 4.2s ease-in-out infinite!important;
  text-shadow:none!important;filter:drop-shadow(0 0 18px rgba(176,55,255,.35))
}
.hero-content p{animation:cvV55FadeUp .75s cubic-bezier(.16,1,.3,1) .26s both!important;text-wrap:pretty}
.hero-actions .btn{animation:cvV55FadeUp .75s cubic-bezier(.16,1,.3,1) .38s both!important}
.hero-actions .btn:nth-child(2){animation-delay:.48s!important}
.btn,.nav-cta,.whatsapp-float,.main-nav a{position:relative;overflow:hidden;transform:translateZ(0);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease!important}
.btn::after,.nav-cta::after,.main-nav a::after{
  content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(110deg,transparent 0 35%,rgba(255,255,255,.28),transparent 65% 100%);transform:translate3d(-125%,0,0);transition:transform .62s cubic-bezier(.16,1,.3,1)!important
}
.btn:hover::after,.nav-cta:hover::after,.main-nav a:hover::after{transform:translate3d(125%,0,0)}
.btn:hover,.nav-cta:hover{transform:translate3d(0,-3px,0) scale(1.012)!important;box-shadow:0 16px 38px rgba(176,55,255,.22)!important}
.service-card,.prestation-tile,.panel,.form-block,.image-panel,.map-panel,.contact-panel,.legal-panel,.big-card,.trust-bar{
  position:relative;isolation:isolate;transform:translateZ(0);backface-visibility:hidden;
  transition:transform .32s cubic-bezier(.16,1,.3,1),box-shadow .32s ease,border-color .32s ease,background .32s ease!important;
  will-change:auto!important
}
.service-card::before,.prestation-tile::before,.panel::before,.form-block::before,.image-panel::before,.map-panel::before,.contact-panel::before,.legal-panel::before,.big-card::before{
  content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;pointer-events:none;opacity:.22;transition:opacity .3s ease!important;
  background:linear-gradient(135deg,rgba(255,255,255,.22),rgba(176,55,255,.58),rgba(47,102,255,.28),rgba(255,255,255,.06));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude
}
.service-card::after,.prestation-tile::after,.panel::after,.form-block::after,.image-panel::after,.big-card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;z-index:-1;pointer-events:none;opacity:0;transition:opacity .28s ease!important;
  background:radial-gradient(circle at var(--cv-card-x,50%) var(--cv-card-y,20%),rgba(176,55,255,.22),transparent 38%)
}
.service-card:hover,.prestation-tile:hover,.panel:hover,.form-block:hover,.image-panel:hover,.big-card:hover{transform:translate3d(0,-7px,0)!important;border-color:rgba(176,55,255,.48)!important;box-shadow:0 22px 58px rgba(0,0,0,.34),0 0 34px rgba(176,55,255,.10)!important}
.service-card:hover::before,.prestation-tile:hover::before,.panel:hover::before,.form-block:hover::before,.image-panel:hover::before,.big-card:hover::before{opacity:.75}
.service-card:hover::after,.prestation-tile:hover::after,.panel:hover::after,.form-block:hover::after,.image-panel:hover::after,.big-card:hover::after{opacity:1}
.service-card img,.gallery-two img,.gallery-grid img,.image-panel img{transition:transform .55s cubic-bezier(.16,1,.3,1),filter .28s ease!important;animation:none!important;will-change:auto!important;transform:translateZ(0)}
.service-card:hover img,.gallery-two img:hover,.gallery-grid img:hover,.image-panel:hover img{transform:scale(1.035) translateZ(0)!important;filter:saturate(1.08) contrast(1.05)!important}
.cv-reveal{opacity:0!important;transform:translate3d(0,36px,0) scale(.985)!important;filter:none!important;transition:opacity .72s cubic-bezier(.16,1,.3,1),transform .72s cubic-bezier(.16,1,.3,1)!important;transition-delay:var(--cv-delay,0ms)!important}
.cv-reveal.cv-visible{opacity:1!important;transform:translate3d(0,0,0) scale(1)!important;filter:none!important}
input,select,textarea{transition:border-color .2s ease,box-shadow .2s ease!important}
input:focus,select:focus,textarea:focus{transform:none!important;box-shadow:0 0 0 4px rgba(176,55,255,.12)!important;border-color:rgba(176,55,255,.72)!important}
.whatsapp-float{animation:cvV55WhatsApp 3.2s ease-in-out infinite!important;will-change:transform}
.whatsapp-float:hover{transform:translate3d(0,-4px,0) scale(1.035)!important}
.cv-ripple{position:absolute;border-radius:999px;transform:scale(0);background:rgba(255,255,255,.32);pointer-events:none;animation:cvV55Ripple .58s ease-out forwards}
@keyframes cvV55HeroLight{0%{opacity:.78;transform:translate3d(-1%,0,0)}100%{opacity:.98;transform:translate3d(1%,0,0)}}
@keyframes cvV55HeroScan{0%{transform:translate3d(-125%,0,0) skewX(-10deg)}100%{transform:translate3d(125%,0,0) skewX(-10deg)}}
@keyframes cvV55VideoMove{0%{transform:scale(1.045) translate3d(-.4%,0,0)}100%{transform:scale(1.075) translate3d(.5%,.4%,0)}}
@keyframes cvV55HeroEnter{from{opacity:0;transform:translate3d(0,34px,0)}to{opacity:1;transform:translate3d(0,0,0)}}
@keyframes cvV55BadgeIn{from{opacity:0;transform:translate3d(0,16px,0) scale(.96)}to{opacity:1;transform:translate3d(0,0,0) scale(1)}}
@keyframes cvV55TitleIn{from{opacity:0;transform:translate3d(0,24px,0) scale(.975)}to{opacity:1;transform:translate3d(0,0,0) scale(1)}}
@keyframes cvV55FadeUp{from{opacity:0;transform:translate3d(0,18px,0)}to{opacity:1;transform:translate3d(0,0,0)}}
@keyframes cvV55Chrome{0%,100%{background-position:0% 50%;filter:drop-shadow(0 0 14px rgba(176,55,255,.28))}50%{background-position:100% 50%;filter:drop-shadow(0 0 24px rgba(176,55,255,.58))}}
@keyframes cvV55WhatsApp{0%,100%{transform:translate3d(0,0,0);box-shadow:0 14px 32px rgba(0,0,0,.34),0 0 0 0 rgba(32,200,90,.28)}50%{transform:translate3d(0,-2px,0);box-shadow:0 18px 40px rgba(0,0,0,.38),0 0 0 10px rgba(32,200,90,0)}}
@keyframes cvV55Ripple{to{transform:scale(3.4);opacity:0}}
@media(max-width:768px){
  html{scroll-behavior:auto}
  main,section{content-visibility:visible;contain-intrinsic-size:auto}
  .home-hero::after{display:none!important}
  .hero-video{animation:none!important;transform:scale(1.03) translateZ(0)!important}
  .hero-content h1 em,h2 em{animation:none!important;filter:drop-shadow(0 0 14px rgba(176,55,255,.35))}
  .service-card:hover,.prestation-tile:hover,.panel:hover,.form-block:hover,.image-panel:hover,.big-card:hover{transform:translate3d(0,-3px,0)!important}
  .whatsapp-float{animation:none!important}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto!important}
  *,*::before,*::after{animation:none!important;transition:none!important}
  .cv-reveal{opacity:1!important;transform:none!important;filter:none!important}
}

/* =========================================================
   V56 SERVICES ULTRA PREMIUM + MOBILE FLUID FIX
   ========================================================= */
.services-showcase-v56{
  position:relative;
  padding:70px clamp(18px,4vw,56px) 52px;
  overflow:hidden;
  isolation:isolate;
}
.services-showcase-v56::before{
  content:"";
  position:absolute;
  inset:28px clamp(10px,3vw,42px);
  border-radius:34px;
  background:
    radial-gradient(circle at 18% 12%,rgba(179,38,255,.22),transparent 28%),
    radial-gradient(circle at 86% 18%,rgba(35,103,255,.16),transparent 24%),
    linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.012));
  border:1px solid rgba(255,255,255,.08);
  z-index:-2;
}
.services-showcase-v56::after{
  content:"";
  position:absolute;
  left:-15%;right:-15%;top:35%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(179,38,255,.55),rgba(35,103,255,.45),transparent);
  opacity:.55;
  animation:cvV56Line 5.5s ease-in-out infinite;
  z-index:-1;
}
.services-head-v56{max-width:820px;margin:0 0 28px}
.services-head-v56 p{max-width:720px;color:#cfcfe2}
.services-orbit-v56{position:absolute;inset:0;pointer-events:none;z-index:-1;overflow:hidden}
.services-orbit-v56 span{position:absolute;border-radius:999px;filter:blur(.2px);opacity:.45;border:1px solid rgba(179,38,255,.35)}
.services-orbit-v56 span:nth-child(1){width:380px;height:380px;right:4%;top:5%;animation:cvV56Float 9s ease-in-out infinite}
.services-orbit-v56 span:nth-child(2){width:220px;height:220px;left:6%;bottom:8%;animation:cvV56Float 7s ease-in-out infinite reverse}
.services-orbit-v56 span:nth-child(3){width:120px;height:120px;right:34%;bottom:16%;animation:cvV56Float 6s ease-in-out infinite}
.services-grid-v56{display:grid;grid-template-columns:1.12fr .88fr;gap:20px;align-items:stretch}
.service-card-v56{
  min-height:455px;
  border-radius:28px!important;
  padding:0!important;
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.022))!important;
  display:grid!important;
  grid-template-rows:auto 1fr;
  box-shadow:0 24px 70px rgba(0,0,0,.22);
}
.service-featured-v56{grid-row:span 2;min-height:100%;}
.service-card-v56 img,
.engine-visual-v56,
.scan-visual-v56{
  width:100%;height:260px;margin:0!important;border-radius:28px 28px 0 0!important;
  object-fit:cover;position:relative;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.1)
}
.service-featured-v56 img{height:410px}
.service-kicker-v56{position:absolute!important;top:18px;left:18px;z-index:3;background:rgba(0,0,0,.62);border:1px solid rgba(179,38,255,.48);padding:9px 13px;border-radius:999px;color:#fff!important;backdrop-filter:blur(12px)}
.service-content-v56{padding:22px;display:flex;flex-direction:column;gap:10px;min-width:0}
.service-content-v56 h2{font-size:clamp(27px,3vw,42px);margin:0;text-wrap:balance}
.service-content-v56 p{font-size:15.5px;color:#c9c9d8;margin:0;text-wrap:pretty}
.service-content-v56 ul{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;list-style:none;padding:0;margin:8px 0 12px}
.service-content-v56 li{font-size:12px;font-weight:900;text-transform:uppercase;color:#f3eaff;border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:8px 9px;background:rgba(255,255,255,.045);text-align:center;white-space:normal}
.service-content-v56 strong{font-size:14px!important;letter-spacing:.05em;text-transform:uppercase;color:#fff!important;margin-top:auto!important;display:inline-flex;align-items:center;gap:10px}
.service-content-v56 strong::after{content:"→";display:inline-grid;place-items:center;width:30px;height:30px;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--purple));box-shadow:0 0 18px rgba(179,38,255,.28)}
.engine-visual-v56{display:grid;place-items:center;background:radial-gradient(circle at 50% 45%,rgba(179,38,255,.34),#07070b 54%,#050507)!important}
.engine-visual-v56 span{font-size:92px;filter:drop-shadow(0 0 24px rgba(179,38,255,.45));animation:cvV56Gear 8s linear infinite;display:block}
.scan-visual-v56{display:grid;place-items:center;background:linear-gradient(135deg,#07070b,#101024)!important;color:#fff}
.scan-visual-v56::before{content:"";position:absolute;inset:24px;border:1px solid rgba(179,38,255,.32);border-radius:24px;background:repeating-linear-gradient(0deg,rgba(255,255,255,.05) 0 1px,transparent 1px 18px)}
.scan-visual-v56 i{position:absolute;left:28px;right:28px;height:3px;background:linear-gradient(90deg,transparent,#b326ff,#2367ff,transparent);box-shadow:0 0 24px rgba(179,38,255,.7);animation:cvV56Scan 2.6s ease-in-out infinite}
.scan-visual-v56 b{font-family:Oswald,Inter,sans-serif;font-size:72px;letter-spacing:.08em;z-index:1;text-shadow:0 0 28px rgba(179,38,255,.45)}
.scan-visual-v56 small{z-index:1;color:#bcbcdf;font-weight:900;letter-spacing:.35em}
.prestations-cinema-v56{position:relative;margin-top:20px}
.prestations-intro-v56{max-width:850px;margin-bottom:24px}
.prestations-grid-v56{grid-template-columns:repeat(4,1fr)!important;gap:18px!important}
.prestation-tile-v56{min-height:315px!important;border-radius:28px!important;padding:24px!important;position:relative;overflow:hidden;background:linear-gradient(160deg,rgba(255,255,255,.078),rgba(255,255,255,.018))!important}
.prestation-tile-v56 span{font-family:Oswald,Inter,sans-serif;font-size:54px;line-height:1;color:rgba(255,255,255,.085);font-weight:900;position:absolute;right:18px;top:14px}
.tile-icon-v56{width:54px;height:54px;border-radius:17px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(35,103,255,.28),rgba(179,38,255,.28));border:1px solid rgba(255,255,255,.12);font-size:24px;box-shadow:0 0 28px rgba(179,38,255,.16);margin-bottom:34px}
.prestation-tile-v56 h2{font-size:30px!important;margin:0 0 10px!important;text-wrap:balance}
.prestation-tile-v56 p{font-size:15px;color:#c9c9d8;margin:0 0 16px;text-wrap:pretty}
.prestation-tile-v56 strong{font-size:13px!important;text-transform:uppercase;letter-spacing:.05em;color:#fff!important;display:flex;align-items:center;gap:10px}
.prestation-tile-v56 strong::after{content:"";width:42px;height:2px;background:linear-gradient(90deg,var(--blue),var(--purple));box-shadow:0 0 18px rgba(179,38,255,.35)}
.prestation-wide-v56{grid-column:span 2}
.prestation-tile-v56:hover .tile-icon-v56{animation:cvV56Icon .7s cubic-bezier(.16,1,.3,1)}
/* fluid mobile polish */
@media(max-width:1020px){
  .services-grid-v56{grid-template-columns:1fr}
  .service-featured-v56{grid-row:auto}
  .service-featured-v56 img{height:300px}
  .prestations-grid-v56{grid-template-columns:repeat(2,1fr)!important}
  .prestation-wide-v56{grid-column:span 2}
}
@media(max-width:760px){
  body{background:radial-gradient(circle at 50% 0%,#130024,#040406 42%)}
  .site-header{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
  .main-nav.open{max-height:calc(100svh - 74px);overflow:auto;padding:18px;border-bottom:1px solid rgba(255,255,255,.1)}
  .main-nav.open a{min-height:46px;display:flex;align-items:center;border-radius:14px;padding:0 14px;background:rgba(255,255,255,.035)}
  .home-hero{min-height:auto;padding:48px 18px 72px}
  .hero-content{max-width:100%}
  .hero-content h1{font-size:clamp(39px,14vw,58px);line-height:.94;letter-spacing:-.025em;max-width:100%;overflow-wrap:break-word}
  .hero-content p{font-size:15.5px;max-width:95%}
  .badge{font-size:10.5px;padding:8px 12px;max-width:100%;white-space:normal;text-align:center}
  .services-showcase-v56{padding:46px 14px 34px}
  .services-showcase-v56::before{inset:14px 8px;border-radius:26px}
  .services-head-v56{padding:0 4px;margin-bottom:18px}
  .services-head-v56 h2{font-size:34px;line-height:1.02}
  .services-head-v56 p{font-size:15px}
  .services-grid-v56{gap:14px}
  .service-card-v56{min-height:auto;border-radius:24px!important;box-shadow:0 16px 48px rgba(0,0,0,.28)}
  .service-card-v56 img,.engine-visual-v56,.scan-visual-v56{height:220px;border-radius:24px 24px 0 0!important}
  .service-featured-v56 img{height:230px}
  .service-content-v56{padding:18px;gap:8px}
  .service-content-v56 h2{font-size:29px;line-height:1.02}
  .service-content-v56 p{font-size:14.5px}
  .service-content-v56 ul{grid-template-columns:1fr;gap:7px;margin:8px 0}
  .service-content-v56 li{text-align:left;padding:9px 11px;font-size:11.5px}
  .service-kicker-v56{top:14px;left:14px;font-size:10.5px;padding:8px 11px}
  .engine-visual-v56 span{font-size:74px;animation:none}
  .scan-visual-v56 b{font-size:58px}
  .prestations-grid-v56{grid-template-columns:1fr!important;gap:14px!important}
  .prestation-wide-v56{grid-column:auto}
  .prestation-tile-v56{min-height:250px!important;border-radius:24px!important;padding:20px!important}
  .prestation-tile-v56 span{font-size:42px;right:16px;top:12px}
  .tile-icon-v56{width:48px;height:48px;border-radius:15px;margin-bottom:26px}
  .prestation-tile-v56 h2{font-size:27px!important}
  .prestation-tile-v56 p{font-size:14.5px}
  .home-cards,.services-grid-v56,.prestations-grid-v56,.trust-grid,.pricing-grid,.gallery-grid{width:100%;max-width:100%;overflow:hidden}
  .panel,.service-card,.prestation-tile,.form-block,.image-panel,.big-card{transform:none!important;will-change:auto!important}
  .panel:hover,.service-card:hover,.prestation-tile:hover,.form-block:hover,.image-panel:hover,.big-card:hover{transform:none!important}
}
@media(max-width:420px){
  .brand span{font-size:16px}.brand img{width:52px}.burger{font-size:28px}
  .hero-actions{gap:10px}.btn{padding:14px 16px;border-radius:12px}
  .service-card-v56 img,.engine-visual-v56,.scan-visual-v56{height:205px}
}
@keyframes cvV56Line{0%,100%{transform:translateX(-2%);opacity:.35}50%{transform:translateX(2%);opacity:.75}}
@keyframes cvV56Float{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(12px,-14px,0) scale(1.04)}}
@keyframes cvV56Gear{to{transform:rotate(360deg)}}
@keyframes cvV56Scan{0%,100%{top:34px;opacity:.55}50%{top:calc(100% - 38px);opacity:1}}
@keyframes cvV56Icon{0%{transform:translateY(0) rotate(0)}45%{transform:translateY(-8px) rotate(-6deg)}100%{transform:translateY(0) rotate(0)}}
@media(prefers-reduced-motion:reduce){
  .services-showcase-v56::after,.services-orbit-v56 span,.engine-visual-v56 span,.scan-visual-v56 i{animation:none!important}
}

/* ==============================
   V57 - SERVICES GRID CLEANUP
   Fix espace sous volant + fusion mécanique/diagnostic
   ============================== */
.services-grid-v56{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  align-items:stretch!important;
}
.service-card-v56{
  min-height:0!important;
  height:auto!important;
  grid-template-rows:auto 1fr!important;
}
.service-featured-v56{
  grid-row:auto!important;
  min-height:0!important;
}
.service-featured-v56 img,
.service-card-v56 img,
.engine-visual-v56,
.scan-visual-v56{
  height:285px!important;
}
.service-content-v56{
  min-height:0!important;
  padding:24px!important;
}
.service-mechdiag-v57{
  grid-column:1 / -1!important;
  display:grid!important;
  grid-template-columns:.95fr 1.05fr!important;
  grid-template-rows:1fr!important;
  min-height:360px!important;
}
.service-mechdiag-v57 .service-kicker-v56{top:20px;left:20px}
.service-mechdiag-v57 .scan-visual-v56{
  height:100%!important;
  min-height:360px!important;
  border-radius:28px 0 0 28px!important;
  border-bottom:0!important;
  border-right:1px solid rgba(255,255,255,.1)!important;
}
.scan-visual-v57{
  background:
    radial-gradient(circle at 50% 45%,rgba(179,38,255,.34),transparent 32%),
    linear-gradient(135deg,#060608,#111126 60%,#060608)!important;
}
.scan-visual-v57::after{
  content:"";
  position:absolute;
  width:190px;height:190px;border-radius:50%;
  border:1px solid rgba(179,38,255,.35);
  box-shadow:0 0 45px rgba(179,38,255,.18), inset 0 0 32px rgba(35,103,255,.10);
  animation:cvV57Pulse 2.8s ease-in-out infinite;
}
.scan-visual-v57 b{font-size:86px!important;position:relative;z-index:2}
.scan-visual-v57 small{position:relative;z-index:2;text-align:center;letter-spacing:.18em!important}
.service-mechdiag-v57 .service-content-v56{justify-content:center!important}
.service-mechdiag-v57 .service-content-v56 h2{font-size:clamp(34px,4vw,58px)!important}
@keyframes cvV57Pulse{0%,100%{transform:scale(.92);opacity:.35}50%{transform:scale(1.08);opacity:.85}}

@media(max-width:1020px){
  .services-grid-v56{grid-template-columns:1fr!important}
  .service-mechdiag-v57{grid-column:auto!important;grid-template-columns:1fr!important;min-height:0!important}
  .service-mechdiag-v57 .scan-visual-v56{height:270px!important;min-height:270px!important;border-radius:28px 28px 0 0!important;border-right:0!important;border-bottom:1px solid rgba(255,255,255,.1)!important}
}
@media(max-width:760px){
  .service-featured-v56 img,
  .service-card-v56 img,
  .engine-visual-v56,
  .scan-visual-v56{height:215px!important}
  .service-mechdiag-v57 .scan-visual-v56{height:225px!important;min-height:225px!important}
  .service-content-v56{padding:20px!important}
  .service-content-v56 ul{grid-template-columns:1fr!important}
  .scan-visual-v57 b{font-size:62px!important}
}

/* =========================================================
   V58 - CIEL ÉTOILÉ LUXURY TWINKLE
   Scintillement premium + constellation + parallax léger
   ========================================================= */
.page-ciel-etoile{--star-x:50%;--star-y:35%;}
.page-ciel-etoile .page{position:relative;overflow:hidden}
.ciel-hero-v58{
  position:relative!important;
  overflow:hidden!important;
  isolation:isolate;
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at var(--star-x) var(--star-y),rgba(163,68,255,.24),transparent 34%),
    radial-gradient(circle at 76% 20%,rgba(45,110,255,.12),transparent 31%),
    linear-gradient(135deg,#050508,#090912 54%,#020204)!important;
}
.ciel-stars-v58,
.ciel-aurora-v58{
  position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden;border-radius:inherit;
}
.ciel-hero-v58 > .badge,
.ciel-hero-v58 > h1,
.ciel-hero-v58 > p{position:relative;z-index:2}
.ciel-aurora-v58::before,
.ciel-aurora-v58::after{
  content:"";position:absolute;border-radius:999px;filter:blur(28px);opacity:.55;transform:translateZ(0);
}
.ciel-aurora-v58::before{width:48%;height:54%;left:2%;top:8%;background:radial-gradient(circle,rgba(179,38,255,.42),transparent 62%);animation:cvV58Aurora 9s ease-in-out infinite alternate}
.ciel-aurora-v58::after{width:42%;height:46%;right:6%;bottom:8%;background:radial-gradient(circle,rgba(45,105,255,.26),transparent 64%);animation:cvV58Aurora 10s ease-in-out infinite alternate-reverse}
.ciel-star-v58{
  position:absolute;width:var(--s,2px);height:var(--s,2px);left:var(--x);top:var(--y);border-radius:50%;
  background:rgba(255,255,255,.96);box-shadow:0 0 calc(var(--s,2px)*5) rgba(190,130,255,.95),0 0 calc(var(--s,2px)*10) rgba(88,140,255,.35);
  opacity:.35;transform:translate3d(0,0,0) scale(.65);
  animation:cvV58Twinkle var(--d,2.8s) ease-in-out infinite;animation-delay:var(--delay,0s);
}
.ciel-star-v58:nth-child(4n){background:#e9dcff;box-shadow:0 0 10px rgba(179,38,255,.9)}
.ciel-star-v58:nth-child(7n){background:#d8e8ff;box-shadow:0 0 12px rgba(45,105,255,.9)}
.ciel-shooting-v58{
  position:absolute;width:140px;height:1px;left:-160px;top:var(--top,35%);pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.95),rgba(179,38,255,.75),transparent);
  box-shadow:0 0 18px rgba(179,38,255,.72);opacity:0;transform:rotate(-17deg) translate3d(0,0,0);
  animation:cvV58Shooting 6.5s cubic-bezier(.16,1,.3,1) infinite;animation-delay:var(--delay,1s);
}
.ciel-gallery-v58{
  position:relative!important;isolation:isolate;overflow:visible!important;
}
.ciel-gallery-v58::before{
  content:"";position:absolute;inset:-18px;border-radius:32px;z-index:-1;pointer-events:none;
  background:radial-gradient(circle at var(--star-x) var(--star-y),rgba(179,38,255,.24),transparent 34%),linear-gradient(180deg,rgba(255,255,255,.035),transparent);
  border:1px solid rgba(255,255,255,.06);opacity:.85;
}
.ciel-gallery-v58 img{
  border:1px solid rgba(255,255,255,.11)!important;
  box-shadow:0 24px 65px rgba(0,0,0,.34),0 0 36px rgba(179,38,255,.08)!important;
}
.ciel-gallery-v58 img:hover{
  box-shadow:0 28px 80px rgba(0,0,0,.42),0 0 52px rgba(179,38,255,.18)!important;
}
.ciel-gallery-v58 img::selection{background:transparent}
.ciel-constellation-v58{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden;border-radius:28px}
.ciel-constellation-v58 span{
  position:absolute;width:6px;height:6px;border-radius:50%;background:#fff;opacity:.75;
  box-shadow:0 0 14px rgba(179,38,255,.95),0 0 26px rgba(45,105,255,.42);
  animation:cvV58Constellation 2.8s ease-in-out infinite;
}
.ciel-constellation-v58 span:nth-child(1){left:14%;top:18%}
.ciel-constellation-v58 span:nth-child(2){left:48%;top:12%;animation-delay:.5s}
.ciel-constellation-v58 span:nth-child(3){right:16%;top:28%;animation-delay:1s}
.ciel-constellation-v58::before,
.ciel-constellation-v58::after{
  content:"";position:absolute;left:14%;right:16%;top:22%;height:1px;opacity:.35;
  background:linear-gradient(90deg,rgba(255,255,255,.65),rgba(179,38,255,.55),rgba(45,105,255,.40),rgba(255,255,255,.55));
  transform-origin:left center;animation:cvV58LineGlow 3.6s ease-in-out infinite;
}
.ciel-constellation-v58::after{top:30%;left:48%;opacity:.24;animation-delay:.8s}
.options-panel{position:relative;overflow:hidden}
.page-ciel-etoile .options-panel::after{
  content:"";position:absolute;width:180px;height:180px;right:-70px;top:-80px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(179,38,255,.22),transparent 68%);animation:cvV58OptionGlow 5s ease-in-out infinite alternate;
}
@keyframes cvV58Twinkle{0%,100%{opacity:.22;transform:translate3d(0,0,0) scale(.55)}38%{opacity:1;transform:translate3d(0,-1px,0) scale(1.2)}62%{opacity:.48;transform:translate3d(0,1px,0) scale(.82)}}
@keyframes cvV58Shooting{0%,72%{opacity:0;transform:rotate(-17deg) translate3d(0,0,0)}76%{opacity:1}100%{opacity:0;transform:rotate(-17deg) translate3d(125vw,0,0)}}
@keyframes cvV58Aurora{0%{transform:translate3d(-2%,1%,0) scale(.96);opacity:.38}100%{transform:translate3d(3%,-2%,0) scale(1.08);opacity:.68}}
@keyframes cvV58Constellation{0%,100%{opacity:.45;transform:scale(.85)}50%{opacity:1;transform:scale(1.25)}}
@keyframes cvV58LineGlow{0%,100%{opacity:.18;filter:drop-shadow(0 0 4px rgba(179,38,255,.2))}50%{opacity:.55;filter:drop-shadow(0 0 14px rgba(179,38,255,.55))}}
@keyframes cvV58OptionGlow{from{transform:scale(.9);opacity:.35}to{transform:scale(1.08);opacity:.75}}

@media(max-width:760px){
  .ciel-hero-v58{border-radius:24px!important;margin-inline:12px!important;padding:42px 18px!important}
  .ciel-aurora-v58::before,.ciel-aurora-v58::after{filter:blur(22px);opacity:.42}
  .ciel-star-v58:nth-child(n+38){display:none}
  .ciel-shooting-v58{display:none}
  .ciel-gallery-v58::before{inset:-8px;border-radius:24px}
  .ciel-constellation-v58::before,.ciel-constellation-v58::after{opacity:.2}
}
@media(prefers-reduced-motion:reduce){
  .ciel-star-v58,.ciel-shooting-v58,.ciel-aurora-v58::before,.ciel-aurora-v58::after,.ciel-constellation-v58 span,.ciel-constellation-v58::before,.ciel-constellation-v58::after,.page-ciel-etoile .options-panel::after{animation:none!important}
}


/* =========================================================
   V59 - CIEL ÉTOILÉ CLEAN STARLIGHT FIX
   Objectif : garder l'effet premium sans traits sur les photos
   et réduire le bloc trop massif.
   ========================================================= */
.ciel-hero-v58{
  max-width:min(760px,92vw)!important;
  min-height:0!important;
  padding:46px 34px 40px!important;
  margin:34px 0 22px!important;
  border-radius:24px!important;
}
.ciel-hero-v58 h1{
  font-size:clamp(48px,7.4vw,104px)!important;
  line-height:.88!important;
  max-width:760px!important;
}
.ciel-hero-v58 p{
  font-size:clamp(17px,1.8vw,22px)!important;
  max-width:680px!important;
}
.ciel-gallery-v58{
  overflow:hidden!important;
  border-radius:24px!important;
}
.ciel-gallery-v58::before,
.ciel-constellation-v58,
.ciel-constellation-v58::before,
.ciel-constellation-v58::after,
.ciel-constellation-v58 span{
  display:none!important;
  content:none!important;
}
.ciel-gallery-v58 img{
  position:relative!important;
  z-index:1!important;
  height:390px!important;
  transform:none!important;
  filter:none!important;
  opacity:1!important;
  box-shadow:0 18px 42px rgba(0,0,0,.28)!important;
}
.ciel-gallery-v58 img:hover{
  transform:translateY(-4px) scale(1.012)!important;
  box-shadow:0 24px 58px rgba(0,0,0,.36),0 0 28px rgba(179,38,255,.12)!important;
}
.ciel-shooting-v58{
  width:86px!important;
  opacity:0;
  filter:blur(.1px);
}
.ciel-star-v58{
  max-width:3px!important;
  max-height:3px!important;
}
@media(max-width:760px){
  .ciel-hero-v58{
    max-width:calc(100% - 24px)!important;
    padding:34px 18px 30px!important;
    margin:22px 12px 18px!important;
  }
  .ciel-hero-v58 h1{font-size:clamp(42px,14vw,68px)!important;}
  .ciel-gallery-v58{border-radius:20px!important;margin-inline:12px!important;}
  .ciel-gallery-v58 img{height:280px!important;border-radius:20px!important;}
}

/* ==============================
   V60 — PREMIUM EXPERIENCE + MOBILE PERFORMANCE
   ============================== */
:root{--cv-v60-glow:rgba(179,38,255,.34);--cv-v60-blue:rgba(35,103,255,.28)}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;background:radial-gradient(circle at var(--mx,50%) var(--my,8%),rgba(179,38,255,.16),transparent 32%),linear-gradient(180deg,rgba(255,255,255,.018),transparent 40%);transition:background .25s ease}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.045;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E")}
.cv-loader-v60{position:fixed;inset:0;z-index:99999;display:grid;place-items:center;background:#030306;transition:opacity .55s ease,visibility .55s ease}.cv-loader-v60.is-hidden{opacity:0;visibility:hidden}.cv-loader-v60 div{position:relative;display:grid;place-items:center;text-align:center;gap:12px}.cv-loader-v60 img{width:118px;filter:drop-shadow(0 0 32px rgba(179,38,255,.55));animation:loaderPulseV60 1.5s ease-in-out infinite}.cv-loader-v60 span{font-family:Oswald,Inter,sans-serif;letter-spacing:.18em;font-weight:900;color:#fff;text-transform:uppercase}.cv-loader-v60 i{display:block;width:210px;height:1px;background:linear-gradient(90deg,transparent,#7d37ff,#fff,#7d37ff,transparent);animation:loaderLineV60 1.4s ease-in-out infinite}@keyframes loaderPulseV60{50%{transform:scale(1.045);filter:drop-shadow(0 0 44px rgba(179,38,255,.75))}}@keyframes loaderLineV60{0%,100%{transform:scaleX(.35);opacity:.35}50%{transform:scaleX(1);opacity:1}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .78s cubic-bezier(.2,.8,.2,1),transform .78s cubic-bezier(.2,.8,.2,1)}.reveal.in-view{opacity:1;transform:none}
.btn,.panel,.service-card,.prestation-tile,.premium-choice,.nav-cta{will-change:transform;transition:transform .28s cubic-bezier(.2,.8,.2,1),border-color .28s ease,box-shadow .28s ease,background .28s ease}.btn:hover,.panel:hover,.service-card:hover,.prestation-tile:hover,.premium-choice:hover{transform:translateY(-5px);box-shadow:0 24px 70px rgba(0,0,0,.28),0 0 35px rgba(179,38,255,.16)}
.service-card,.panel,.prestation-tile{position:relative}.service-card::before,.panel::before,.prestation-tile::before{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,transparent,rgba(255,255,255,.18),rgba(179,38,255,.44),transparent);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .35s ease}.service-card:hover::before,.panel:hover::before,.prestation-tile:hover::before{opacity:1}.service-card::after,.panel::after,.prestation-tile::after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at var(--card-x,50%) var(--card-y,0%),rgba(179,38,255,.12),transparent 34%);opacity:0;transition:opacity .25s ease;pointer-events:none}.service-card:hover::after,.panel:hover::after,.prestation-tile:hover::after{opacity:1}
.cinematic-strip-v60{margin:28px clamp(18px,4vw,56px);padding:32px;min-height:260px;border:1px solid rgba(255,255,255,.12);border-radius:28px;background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.018)),radial-gradient(circle at 80% 30%,rgba(179,38,255,.22),transparent 36%);display:grid;grid-template-columns:1.25fr .75fr;gap:28px;align-items:center;overflow:hidden}.cinematic-copy-v60 p{max-width:720px}.motion-orbit-v60{position:relative;min-height:230px;display:grid;place-items:center}.motion-orbit-v60 span,.motion-orbit-v60 i{position:absolute;border-radius:50%;border:1px solid rgba(179,38,255,.35);box-shadow:0 0 32px rgba(179,38,255,.18)}.motion-orbit-v60 span{width:190px;height:190px;animation:orbitV60 8s linear infinite}.motion-orbit-v60 i{width:132px;height:132px;animation:orbitV60 5.8s linear infinite reverse}.motion-orbit-v60 span::before,.motion-orbit-v60 i::before{content:"";position:absolute;width:10px;height:10px;border-radius:50%;background:#fff;box-shadow:0 0 18px #b326ff;top:14px;left:50%}.motion-orbit-v60 b{width:86px;height:86px;border-radius:26px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(35,103,255,.34),rgba(179,38,255,.32));border:1px solid rgba(255,255,255,.16);font-family:Oswald;font-size:30px;box-shadow:0 0 55px rgba(179,38,255,.28)}@keyframes orbitV60{to{transform:rotate(360deg)}}
.projects-preview-v60,.testimonials-v60{margin:52px clamp(18px,4vw,56px)}.project-grid-v60{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:20px 0}.project-grid-v60 a{min-height:390px;border-radius:26px;border:1px solid rgba(255,255,255,.13);background:#09090d;overflow:hidden;position:relative;padding:18px;display:flex;flex-direction:column;justify-content:flex-end;isolation:isolate}.project-grid-v60 img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.72;transition:transform .75s cubic-bezier(.2,.8,.2,1),opacity .35s ease;z-index:-2}.project-grid-v60 a::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(0,0,0,.86));z-index:-1}.project-grid-v60 a:hover img{transform:scale(1.06);opacity:.95}.project-grid-v60 strong{font-family:Oswald;text-transform:uppercase;font-size:30px}.project-grid-v60 span{color:#d8d4df}.obd-card-v60{min-height:220px;border-radius:22px;background:radial-gradient(circle,rgba(179,38,255,.26),rgba(10,10,16,.95) 55%);display:grid;place-items:center;border:1px solid rgba(255,255,255,.13);position:relative;overflow:hidden}.obd-card-v60 i{position:absolute;width:72%;height:2px;background:linear-gradient(90deg,transparent,#49f,#fff,#b326ff,transparent);animation:scanV60 2.4s ease-in-out infinite}.obd-card-v60 b{font-family:Oswald;font-size:74px;letter-spacing:.08em;text-shadow:0 0 30px rgba(179,38,255,.55)}.obd-card-v60 small{position:absolute;bottom:24px;color:#c8b7ff;font-weight:900;letter-spacing:.22em}@keyframes scanV60{0%,100%{transform:translateY(-85px);opacity:.2}50%{transform:translateY(85px);opacity:1}}
.testimonial-grid-v60{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.testimonial-grid-v60 article{border:1px solid rgba(255,255,255,.13);border-radius:22px;padding:22px;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));box-shadow:0 18px 60px rgba(0,0,0,.22)}.testimonial-grid-v60 b{color:#d98cff;letter-spacing:.08em}.testimonial-grid-v60 span{color:#8d8aa0;text-transform:uppercase;font-weight:900;font-size:12px}
.pricing-grid-v60{grid-template-columns:repeat(3,1fr)!important}.tariff-card-v60{min-height:245px;display:flex!important;flex-direction:column;gap:10px}.tariff-card-v60 span{color:#b16aff;font-weight:900}.tariff-card-v60 strong{font-size:30px!important}.tariff-card-v60 em{margin-top:auto;color:#fff;font-weight:900;text-transform:uppercase;font-style:normal}.tariff-wide-v60{background:radial-gradient(circle at 70% 10%,rgba(179,38,255,.18),rgba(255,255,255,.035))!important}
.configurator-premium-note-v60{display:grid;grid-template-columns:.9fr 1.1fr;gap:20px;align-items:center;margin:0 0 24px;padding:22px;border:1px solid rgba(179,38,255,.22);border-radius:22px;background:linear-gradient(135deg,rgba(179,38,255,.09),rgba(35,103,255,.045))}.configurator-premium-note-v60 span{color:#b16aff;text-transform:uppercase;font-weight:900;font-size:12px;letter-spacing:.08em}.configurator-premium-note-v60 h2{font-size:clamp(24px,3vw,38px);margin:6px 0}.configurator-premium-note-v60 p{font-size:16px;margin:0}.configurator-v45 small,.total-box,.config-total,.price-summary,.mobile-summary,.configurator-total,[id*="total"],[class*="total2d"]{display:none!important}.configurator-v45 .premium-choice{min-height:62px}.configurator-v45 .option-list-v45 label span{word-break:normal;overflow-wrap:anywhere}
.prestation-mechdiag-v60{grid-column:span 2;background:radial-gradient(circle at 85% 20%,rgba(179,38,255,.18),rgba(255,255,255,.035))!important}.tile-obd-v60{width:86px;height:52px;border-radius:16px;display:grid;place-items:center;background:rgba(179,38,255,.12);border:1px solid rgba(179,38,255,.28);position:relative;overflow:hidden;margin-bottom:8px}.tile-obd-v60 i{position:absolute;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,#fff,#b326ff,transparent);animation:scanMiniV60 1.9s ease-in-out infinite}.tile-obd-v60 b{font-family:Oswald;letter-spacing:.12em}@keyframes scanMiniV60{0%,100%{transform:translateY(-18px);opacity:.25}50%{transform:translateY(18px);opacity:1}}
.projets-page-v60 .page-hero{text-align:left}.project-showcase-v60{display:grid;gap:24px}.project-card-v60{display:grid;grid-template-columns:.9fr 1.1fr;gap:26px;align-items:center;border:1px solid rgba(255,255,255,.13);border-radius:28px;padding:20px;background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.018));overflow:hidden}.project-card-v60:nth-child(even){grid-template-columns:1.1fr .9fr}.project-card-v60 img{width:100%;height:370px;object-fit:cover;border-radius:22px}.project-card-v60 span{color:#b16aff;text-transform:uppercase;font-weight:900}.obd-card-v60.large{height:340px}.footer-links{display:flex!important;gap:14px;align-items:start}
@media(max-width:1050px){.cinematic-strip-v60,.project-card-v60,.project-card-v60:nth-child(even){grid-template-columns:1fr}.project-grid-v60,.testimonial-grid-v60,.pricing-grid-v60{grid-template-columns:1fr!important}.prestation-mechdiag-v60{grid-column:auto}.project-grid-v60 a{min-height:310px}.cinematic-strip-v60{padding:24px}.motion-orbit-v60{min-height:180px}.project-card-v60 img,.obd-card-v60.large{height:280px}}
@media(max-width:760px){body{background:radial-gradient(circle at 50% -4%,#170027,#040406 36%)}.cv-loader-v60 img{width:90px}.cv-loader-v60 span{font-size:12px}.site-header{min-height:72px;padding:8px 14px}.main-nav{top:72px;max-height:calc(100svh - 72px);overflow:auto}.brand span{font-size:19px}.brand img{width:64px}.home-hero{min-height:72svh;padding:54px 16px}.hero-content{max-width:100%}h1{font-size:clamp(42px,13vw,62px)}h2{font-size:clamp(28px,9vw,42px)}p{font-size:16px}.home-cards,.page,.projects-preview-v60,.testimonials-v60{padding-left:14px!important;padding-right:14px!important;margin-left:0!important;margin-right:0!important}.service-card,.panel,.prestation-tile{border-radius:18px}.service-card img,.engine-visual{height:210px}.trust-bar{grid-template-columns:1fr 1fr;margin:18px 14px}.trust-bar div{border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}.cinematic-strip-v60{margin:20px 14px;padding:20px;border-radius:22px}.motion-orbit-v60 span{width:150px;height:150px}.motion-orbit-v60 i{width:104px;height:104px}.project-grid-v60{gap:14px}.project-grid-v60 a{min-height:270px;border-radius:20px}.testimonial-grid-v60 article{padding:18px}.configurator-premium-note-v60{grid-template-columns:1fr;margin:0 0 18px;padding:18px}.choice-grid-v45,.button-grid-v45,.option-list-v45{grid-template-columns:1fr!important}.premium-choice,.option-list-v45 label{width:100%!important;max-width:100%!important;min-width:0!important}.project-card-v60{border-radius:20px;padding:14px}.project-card-v60 img,.obd-card-v60.large{height:230px;border-radius:16px}.whatsapp-float{right:12px;bottom:12px;padding:12px 15px;font-size:13px}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1!important;transform:none!important}.cv-loader-v60{display:none!important}}


/* ==============================
   V61 — CLEAN CONTENT FIX
   ============================== */
.about-page-v61{max-width:1180px;margin:0 auto;padding-bottom:72px}
.about-hero-v61{max-width:960px}
.about-hero-v61 h1{max-width:920px;letter-spacing:-.02em}
.about-intro-v61{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:end;margin:22px 0 28px;padding:26px;border:1px solid rgba(255,255,255,.12);border-radius:28px;background:linear-gradient(135deg,rgba(255,255,255,.055),rgba(179,38,255,.055));box-shadow:0 24px 80px rgba(0,0,0,.24)}
.about-intro-v61 h2{font-size:clamp(28px,4vw,48px);line-height:.98;margin:10px 0 0}.about-intro-v61 p{margin:0;color:#ddd;font-size:17px;line-height:1.7}
.about-grid-v61{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:22px}.about-grid-v61 article{position:relative;min-height:245px;padding:22px;border:1px solid rgba(255,255,255,.12);border-radius:24px;background:radial-gradient(circle at 20% 0%,rgba(179,38,255,.12),transparent 36%),linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));overflow:hidden}.about-grid-v61 article:before{content:"";position:absolute;inset:auto 18px 0 18px;height:1px;background:linear-gradient(90deg,transparent,rgba(179,38,255,.75),transparent)}.about-grid-v61 span{display:inline-flex;width:42px;height:42px;border-radius:14px;align-items:center;justify-content:center;border:1px solid rgba(179,38,255,.45);color:#c27bff;font-weight:900;background:rgba(179,38,255,.08)}.about-grid-v61 h2{font-size:26px;margin:18px 0 10px}.about-grid-v61 p{font-size:15px;color:#d7d7df;line-height:1.6;margin:0}.about-values-v61{margin-top:26px;padding:26px;border-radius:26px;border:1px solid rgba(179,38,255,.18);background:linear-gradient(90deg,rgba(179,38,255,.07),rgba(35,103,255,.035))}.about-values-v61 h2{margin:0 0 18px;font-size:clamp(24px,3vw,38px)}.about-values-v61 div{display:flex;flex-wrap:wrap;gap:12px}.about-values-v61 strong{padding:12px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.22);font-size:13px;text-transform:uppercase;letter-spacing:.05em}
.testimonials-clean-v61 .section-title h2{max-width:820px;margin-inline:auto}.testimonials-clean-v61 article{border-color:rgba(255,255,255,.11);background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018))}.testimonials-clean-v61 article b{color:#f4f4f7;letter-spacing:.12em}.testimonials-clean-v61 article p{font-size:16px;line-height:1.65;color:#e4e4e8}.testimonials-clean-v61 article span{color:#b16aff}
.projects-preview-v60,.cinematic-strip-v60{display:none!important}
@media(max-width:980px){.about-intro-v61{grid-template-columns:1fr}.about-grid-v61{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.about-page-v61{padding-left:14px!important;padding-right:14px!important}.about-intro-v61{padding:18px;border-radius:20px}.about-grid-v61{grid-template-columns:1fr}.about-grid-v61 article{min-height:auto;padding:18px;border-radius:20px}.about-values-v61{padding:18px;border-radius:20px}.about-values-v61 strong{width:100%;text-align:center}.testimonials-clean-v61 article p{font-size:15px}}
