.elementor-1212 .elementor-element.elementor-element-295f8e3d{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1212 .elementor-element.elementor-element-3ccc74d1{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}@media(min-width:768px){.elementor-1212 .elementor-element.elementor-element-3ccc74d1{--width:100%;}}/* Start custom CSS for text-editor, class: .elementor-element-3d6cac03 */@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700&display=swap');

:root{
  --fv-red:#9B2526;
  --fv-blue:#006A8D;
  --fv-ink:#0b1220;
  --fv-muted:#5b6472;
  --fv-border:rgba(11,18,32,.10);
  --fv-radius:24px;
  --fv-shadow:0 18px 60px rgba(11,18,32,.14);
  --fv-shadow-soft:0 10px 30px rgba(11,18,32,.10);
}

/* =========================
   HERO COMMUN (UNIFORMISÉ)
   -> mets class="fv-hero-paint fv-hero-main" sur tes sections hero
   ========================= */
.fv-hero-paint.fv-hero-main{
  position:relative;
  font-family:Poppins, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--fv-ink);
  background:#fff;
  overflow:hidden;
}

.fv-hero-paint.fv-hero-main .fv-hero-bg{
  position:absolute;
  inset:-200px -200px auto -200px;
  height:520px;
  background:
    radial-gradient(900px 420px at 15% 35%, rgba(0,106,141,.22), transparent 60%),
    radial-gradient(900px 420px at 80% 25%, rgba(155,37,38,.20), transparent 55%),
    radial-gradient(700px 380px at 45% 0%, rgba(0,106,141,.12), transparent 55%);
  pointer-events:none;
  z-index:0;
}

.fv-hero-paint.fv-hero-main .fv-hero-container{
  position:relative;
  z-index:1;
  max-width:1200px;
  margin:0 auto;
  padding:90px 20px 70px;

  display:grid !important;
  grid-template-columns: 1.05fr .95fr !important;
  gap:44px !important;
  align-items:center !important;
}

.fv-hero-paint.fv-hero-main .fv-hero-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:18px;
}

.fv-hero-paint.fv-hero-main .fv-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border:1px solid var(--fv-border);
  border-radius:999px;
  background:rgba(255,255,255,.78);
  backdrop-filter: blur(8px);
  box-shadow: 0 8px 20px rgba(11,18,32,.06);
  font-size:.86rem;
  color:rgba(11,18,32,.85);
}
.fv-hero-paint.fv-hero-main .fv-badge i{ color:var(--fv-blue); }

.fv-hero-paint.fv-hero-main .fv-hero-title{
  margin:0 0 14px 0 !important;
  font-size: clamp(2.1rem, 3.1vw, 3.25rem) !important;
  line-height:1.12 !important;
  letter-spacing:-.02em !important;
  text-transform:none !important;
  color:var(--fv-ink) !important;
}

.fv-hero-paint.fv-hero-main .fv-hero-sub{
  margin:0 0 22px 0 !important;
  font-size:1.05rem !important;
  color:var(--fv-muted) !important;
  max-width:52ch !important;
}

.fv-hero-paint.fv-hero-main .fv-hero-cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin: 18px 0 24px;
}

.fv-hero-paint.fv-hero-main .fv-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 18px;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  border:1px solid transparent;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  will-change: transform;
}

.fv-hero-paint.fv-hero-main .fv-btn-primary{
  background: linear-gradient(135deg, var(--fv-red), var(--fv-blue));
  color:#ffffff !important;
  box-shadow: 0 16px 40px rgba(155,37,38,.20), 0 12px 34px rgba(0,106,141,.18);
}
.fv-hero-paint.fv-hero-main .fv-btn-primary:hover{
  transform: translateY(-2px);
  box-shadow: 0 22px 60px rgba(155,37,38,.22), 0 18px 46px rgba(0,106,141,.20);
}

.fv-hero-paint.fv-hero-main .fv-btn-ghost{
  background:rgba(255,255,255,.78);
  color:var(--fv-ink) !important;
  border-color: var(--fv-border);
  box-shadow: 0 10px 26px rgba(11,18,32,.08);
}
.fv-hero-paint.fv-hero-main .fv-btn-ghost:hover{
  transform: translateY(-2px);
  border-color: rgba(0,106,141,.35);
}

.fv-hero-paint.fv-hero-main .fv-hero-proof{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.fv-hero-paint.fv-hero-main .fv-proof{
  flex: 1 1 140px;
  border:1px solid var(--fv-border);
  border-radius:18px;
  background:rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  padding:14px 14px;
  box-shadow: var(--fv-shadow-soft);
}
.fv-hero-paint.fv-hero-main .fv-proof strong{ display:block; font-size:1.05rem; color:var(--fv-ink); }
.fv-hero-paint.fv-hero-main .fv-proof{ color:var(--fv-muted); }

/* =========================
   PEINTURE : AVANT/APRÈS
   ========================= */
.fv-hero-main .fv-compare{
  position:relative;
  width:100%;
  height:420px;
  border-radius: var(--fv-radius);
  overflow:hidden;
  box-shadow: var(--fv-shadow);
  border:1px solid rgba(11,18,32,.12);
  background:#000;
  user-select:none;
  touch-action:none;
  --pos:50%;
}

.fv-hero-main .fv-compare-img{
  width:100%;
  height:100%;
  display:block;
  object-fit: contain;
  object-position:center center;
  background:#000;
  -webkit-user-drag:none;
  user-drag:none;
}

.fv-hero-main .fv-compare-beforeWrap{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  overflow:hidden;
  -webkit-clip-path: inset(0 calc(100% - var(--pos)) 0 0);
  clip-path: inset(0 calc(100% - var(--pos)) 0 0);
  will-change: clip-path;
}

.fv-hero-main .fv-compare-handle{
  position:absolute;
  inset:0;
  pointer-events:none;
}

.fv-hero-main .fv-compare-line{
  position:absolute;
  top:0;
  bottom:0;
  left: var(--pos);
  width:2px;
  transform: translateX(-1px);
  background: rgba(255,255,255,.98);
  box-shadow: 0 0 0 1px rgba(0,0,0,.35);
}

.fv-hero-main .fv-compare-knob{
  position:absolute;
  top:50%;
  left: var(--pos);
  transform: translate(-50%, -50%);
  width:56px;
  height:56px;
  border-radius:999px;
  background: rgba(255,255,255,.92);
  display:grid;
  place-items:center;
  box-shadow: 0 18px 45px rgba(0,0,0,.25);
  border:1px solid rgba(0,0,0,.15);
}
.fv-hero-main .fv-compare-knob i{
  color: var(--fv-blue);
  font-size: 18px;
}

.fv-hero-main .fv-compare-range{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor: ew-resize;
}

.fv-hero-main .fv-compare-label{
  position:absolute;
  top:14px;
  padding:8px 10px;
  font-weight:800;
  font-size:.82rem;
  letter-spacing:.08em;
  border-radius:999px;
  background: rgba(11,18,32,.55);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(8px);
  z-index:5;
}
.fv-hero-main .fv-compare-label-left{ left:14px; }
.fv-hero-main .fv-compare-label-right{ right:14px; }

/* =========================
   REVÊTEMENTS : CARROUSEL
   ========================= */
.fv-hero-main .fv-wall-carousel{
  position:relative;
  width:100%;
  height:420px;
  border-radius: var(--fv-radius);
  overflow:hidden;
  box-shadow: var(--fv-shadow);
  border:1px solid rgba(11,18,32,.12);
  background:#000;
  user-select:none;
  touch-action: pan-y;
}

.fv-hero-main .fv-wall-track{
  height:100%;
  display:flex;
  transform: translate3d(0,0,0);
  transition: transform .55s cubic-bezier(.2,.8,.2,1);
  will-change: transform;
}

.fv-hero-main .fv-wall-slide{
  min-width:100%;
  height:100%;
  margin:0;
}

.fv-hero-main .fv-wall-img{
  width:100%;
  height:100%;
  display:block;
  object-fit: cover;
  object-position:center;
  background:#000;
}

.fv-hero-main .fv-wall-carousel::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: radial-gradient(120% 90% at 50% 20%, rgba(0,0,0,.00), rgba(0,0,0,.30));
}

.fv-hero-main .fv-wall-nav{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
  z-index:3;
}
.fv-hero-main .fv-wall-nav i{ color: var(--fv-blue); }
.fv-hero-main .fv-wall-nav:hover{
  transform: translateY(-50%) scale(1.04);
  background: rgba(255,255,255,.92);
  box-shadow: 0 22px 58px rgba(0,0,0,.26);
}
.fv-hero-main .fv-wall-prev{ left:14px; }
.fv-hero-main .fv-wall-next{ right:14px; }

.fv-hero-main .fv-wall-dots{
  position:absolute;
  left:50%;
  bottom:14px;
  transform: translateX(-50%);
  display:flex;
  gap:8px;
  z-index:3;
  padding:8px 10px;
  border-radius:999px;
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
  border:1px solid rgba(11,18,32,.10);
  box-shadow: 0 10px 26px rgba(11,18,32,.10);
}

.fv-hero-main .fv-wall-dot{
  width:9px;
  height:9px;
  border-radius:999px;
  border:1px solid rgba(11,18,32,.20);
  background: rgba(11,18,32,.18);
  cursor:pointer;
  transition: transform .18s ease, background .18s ease, width .18s ease;
}
.fv-hero-main .fv-wall-dot[aria-current="true"]{
  background: linear-gradient(135deg, var(--fv-red), var(--fv-blue));
  border-color: rgba(0,0,0,.08);
  width:22px;
}

/* Responsive commun */
@media (max-width: 980px){
  .fv-hero-paint.fv-hero-main .fv-hero-container{
    grid-template-columns: 1fr !important;
    padding:70px 18px 56px !important;
  }
  .fv-hero-paint.fv-hero-main .fv-hero-sub{ max-width:none !important; }
  .fv-hero-main .fv-compare{ height:360px; }
  .fv-hero-main .fv-wall-carousel{ height:360px; }
}

@media (max-width: 520px){
  .fv-hero-paint.fv-hero-main .fv-btn{ width:100%; }
  .fv-hero-main .fv-compare{ height:360px; }
  .fv-hero-main .fv-wall-carousel{ height:320px; }
}/* End custom CSS */
/* Start custom CSS for text-editor, class: .elementor-element-b38b90f *//* =========================
   SOL & VITRIFICATION — PAGE (sans HERO)
   Style identique au modèle fourni
   ========================= */
.fv-floor-main{
  background:#fff;
  color: var(--fv-ink, #0b1220);
  font-family: Poppins, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.fv-wrap{
  max-width:1200px;
  margin:0 auto;
  padding:72px 20px;
}

.fv-section{ position:relative; }

.fv-alt{
  background: linear-gradient(180deg, rgba(0,106,141,.05), rgba(155,37,38,.04));
}

.fv-center{ text-align:center; }
.fv-max{
  max-width: 78ch;
  margin-left:auto;
  margin-right:auto;
}

.fv-inline-cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;
}
.fv-inline-cta.fv-center{ justify-content:center; }

/* Buttons (si déjà définis ailleurs, aucun conflit) */
.fv-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 18px;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  border:1px solid transparent;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.fv-btn-primary{
  background: linear-gradient(135deg, var(--fv-red,#9B2526), var(--fv-blue,#006A8D));
  color:#fff !important;
  box-shadow: 0 16px 40px rgba(155,37,38,.20), 0 12px 34px rgba(0,106,141,.18);
}
.fv-btn-primary i{ color:#fff !important; }
.fv-btn-primary:hover{
  transform: translateY(-2px);
  box-shadow: 0 22px 60px rgba(155,37,38,.22), 0 18px 46px rgba(0,106,141,.20);
}
.fv-btn-ghost{
  background:rgba(255,255,255,.80);
  color: var(--fv-ink, #0b1220);
  border-color: rgba(11,18,32,.12);
  box-shadow: 0 10px 26px rgba(11,18,32,.08);
}
.fv-btn-ghost:hover{
  transform: translateY(-2px);
  border-color: rgba(0,106,141,.35);
}

/* Split layout */
.fv-split{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 34px;
  align-items:center;
}

/* Checklist */
.fv-checklist{
  list-style:none;
  padding:0;
  margin: 16px 0 0;
}
.fv-checklist li{
  position:relative;
  padding-left: 30px;
  margin: 10px 0;
  color: rgba(11,18,32,.82);
}
.fv-checklist li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color: var(--fv-blue,#006A8D);
  font-weight:900;
}

/* Callout */
.fv-callout{
  margin-top:16px;
  padding:14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.82);
  box-shadow: 0 10px 30px rgba(11,18,32,.08);
}

/* Media card */
.fv-media-card{
  border-radius: 22px;
  overflow:hidden;
  border:1px solid rgba(11,18,32,.12);
  box-shadow: 0 18px 60px rgba(11,18,32,.14);
  background:#fff;
}
.fv-media-card img{
  width:100%;
  height: 360px;
  object-fit: cover;
  display:block;
}
.fv-media-card figcaption{
  padding:14px 16px;
  color: rgba(11,18,32,.78);
  font-size:.95rem;
}

/* Compare 2 cards */
.fv-compare-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

/* KPI blocks */
.fv-kpi{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 14px;
}
.fv-kpi > div{
  border:1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.86);
  border-radius: 16px;
  padding: 14px 14px;
  box-shadow: 0 10px 30px rgba(11,18,32,.08);
  text-align:center;
}
.fv-kpi strong{ display:block; }
.fv-kpi span{
  display:block;
  color: rgba(11,18,32,.65);
  font-size:.92rem;
}

/* Gallery */
.fv-gallery{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.fv-shot{
  grid-column: span 4;
  border-radius: 20px;
  overflow:hidden;
  border:1px solid rgba(11,18,32,.12);
  box-shadow: 0 10px 30px rgba(11,18,32,.10);
  background:#fff;
  transition: transform .18s ease, box-shadow .18s ease;
}
.fv-shot:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 46px rgba(11,18,32,.14);
}
.fv-shot img{
  width:100%;
  height: 260px;
  object-fit: cover;
  display:block;
}
.fv-shot figcaption{
  padding: 12px 14px;
  color: rgba(11,18,32,.78);
  font-size:.95rem;
}
.fv-shot-wide{ grid-column: span 8; }
.fv-shot-wide img{ height: 320px; }

/* Steps */
.fv-steps{
  margin-top: 26px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.fv-step{
  border:1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.86);
  border-radius: 18px;
  padding: 18px 16px;
  box-shadow: 0 10px 30px rgba(11,18,32,.08);
}
.fv-step-ico{
  width:46px;
  height:46px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(0,106,141,.10);
  border: 1px solid rgba(0,106,141,.22);
  margin-bottom: 10px;
}
.fv-step-ico i{ color: var(--fv-blue,#006A8D); }
.fv-step h3{ margin: 0 0 6px; }
.fv-step p{ margin: 0; color: rgba(11,18,32,.78); }

/* CTA band */
.fv-cta-band{
  margin-top: 22px;
  border-radius: 20px;
  padding: 18px 18px;
  border:1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.90);
  box-shadow: 0 18px 60px rgba(11,18,32,.12);
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.fv-cta-band strong{ display:block; font-size:1.05rem; }
.fv-cta-band span{ display:block; color: rgba(11,18,32,.65); }

/* FAQ */
.fv-faq{
  margin-top: 22px;
  max-width: 920px;
  margin-left:auto;
  margin-right:auto;
  display:grid;
  gap: 12px;
}
.fv-faq-item{
  border:1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.90);
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(11,18,32,.08);
  overflow:hidden;
}
.fv-faq-item summary{
  cursor:pointer;
  padding: 16px 16px;
  font-weight:800;
  list-style:none;
  color: rgba(11,18,32,.92);
}
.fv-faq-item summary::-webkit-details-marker{ display:none; }
.fv-faq-content{
  padding: 0 16px 16px;
  color: rgba(11,18,32,.78);
}
.fv-faq-content p{ margin:0; }

/* Final CTA */
.fv-cta-final{
  margin-top: 22px;
  border-radius: 22px;
  padding: 24px 18px;
  border:1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.90);
  box-shadow: 0 18px 60px rgba(11,18,32,.12);
  text-align:center;
}
.fv-cta-final h3{ margin:0 0 8px; }
.fv-cta-final p{
  margin:0 0 12px;
  color: rgba(11,18,32,.65);
}

/* =========================
   PATCH TRAIT TITRES (stable)
   ========================= */
.fv-floor-main h2::before,
.fv-floor-main h2::after,
.fv-floor-main h3::before,
.fv-floor-main h3::after{
  content: none !important;
}

.fv-floor-main h2,
.fv-floor-main h3{
  position: relative;
  display: inline-block;
  padding-bottom: 16px;
}

.fv-floor-main h2::after,
.fv-floor-main h3::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: 4px;
  width: 64px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--fv-blue, #006A8D), var(--fv-red, #9B2526));
  opacity: .95;
}

.fv-floor-main .fv-center h2::after,
.fv-floor-main .fv-center h3::after{
  left: 50%;
  transform: translateX(-50%);
}

@media (max-width: 520px){
  .fv-floor-main h2::after,
  .fv-floor-main h3::after{
    width: 52px;
    height: 3px;
  }
}

/* Responsive */
@media (max-width: 980px){
  .fv-wrap{ padding: 64px 18px; }
  .fv-split{ grid-template-columns: 1fr; }
  .fv-compare-2{ grid-template-columns: 1fr; }
  .fv-steps{ grid-template-columns: 1fr; }
  .fv-shot{ grid-column: span 12; }
  .fv-shot-wide{ grid-column: span 12; }
}

@media (max-width: 520px){
  .fv-wrap{ padding: 56px 16px; }
  .fv-btn{ width:100%; }
  .fv-kpi{ grid-template-columns: 1fr; }
}/* End custom CSS */