:root{
  --bg:#05070b;
  --bg-2:#0b0f17;
  --card:#0d1320;
  --line:rgba(255,255,255,.08);

  --text:#f5f7fb;
  --muted:#9aa4b5;

  --red:#ff1f45;
  --red-dark:#a30022;

  --gold:#f0bb4b;
  --green:#27d366;

  --radius:28px;
  --shadow:0 20px 80px rgba(0,0,0,.45);
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  background:#04060a;
  color:var(--text);
  font-family:'Manrope',sans-serif;
  overflow-x:hidden;
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  background:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:60px 60px;
  pointer-events:none;
  opacity:.25;
}

.site-bg{
  position:fixed;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(circle at top left, rgba(255,31,69,.16), transparent 35%),
    radial-gradient(circle at right, rgba(240,187,75,.10), transparent 30%),
    linear-gradient(180deg,#06080d,#04060a);
}

img{
  max-width:100%;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
}

main{
  width:min(1500px,92%);
  margin:auto;
}

/* TOPBAR */

.topbar{
  position:sticky;
  top:18px;
  z-index:1000;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;

  margin:24px auto 40px;

  padding:14px 22px;

  background:rgba(5,8,14,.72);
  border:1px solid rgba(255,255,255,.08);

  backdrop-filter:blur(18px);
  border-radius:999px;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.brand-logo{
  width:62px;
  height:62px;

  border-radius:20px;
  overflow:hidden;

  background:#000;
  border:1px solid rgba(255,255,255,.08);
}

.brand-logo img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.brand strong{
  display:block;
  font-size:1.25rem;
  font-family:'Oxanium',sans-serif;
}

.brand em{
  color:var(--muted);
  font-style:normal;
  font-size:.92rem;
}

.site-nav{
  display:flex;
  align-items:center;
  gap:32px;
}

.site-nav a{
  font-weight:700;
  color:#d9dfeb;
}

.site-nav a:hover{
  color:#fff;
}

.call-pill{
  background:linear-gradient(135deg,var(--red),#ff365a);
  color:#fff;
  padding:16px 26px;
  border-radius:999px;
  font-weight:800;
  box-shadow:0 10px 30px rgba(255,31,69,.35);
}

/* HERO */

.hero{
  display:grid;
  grid-template-columns:1.2fr 1fr .55fr;
  gap:28px;

  align-items:stretch;
  margin-bottom:40px;
}

.hero-copy,
.hero-price-card,
.hero-visual{
  background:rgba(10,14,22,.78);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
}

.hero-copy{
  padding:56px;
}

.eyebrow{
  color:#ff7f97;
  font-size:.85rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:800;
  margin-bottom:18px;
}

.hero h1{
  font-family:'Oxanium',sans-serif;
  font-size:clamp(3.4rem,6vw,6rem);
  line-height:.95;
  margin-bottom:24px;
}

.hero h1 span{
  color:var(--gold);
}

.hero-text{
  font-size:1.18rem;
  line-height:1.7;
  color:#d2d8e2;
  max-width:760px;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:34px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  min-height:58px;
  padding:0 28px;

  border-radius:999px;
  font-weight:800;

  transition:.25s ease;
}

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

.btn-red{
  background:linear-gradient(135deg,var(--red),#ff3558);
  box-shadow:0 14px 40px rgba(255,31,69,.35);
}

.btn-green{
  background:var(--green);
  color:#041107;
}

.btn-dark{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
}

.proof-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:26px;
}

.proof-row span{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  border-radius:999px;
  padding:12px 18px;
  color:#d6dcea;
  font-weight:700;
}

.hero-visual{
  position:relative;
  min-height:680px;
}

.hero-visual img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.hero-visual::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg,transparent,rgba(0,0,0,.35)),
    linear-gradient(90deg,rgba(0,0,0,.45),transparent);
}

.hero-badge{
  position:absolute;
  left:26px;
  bottom:26px;
  z-index:2;

  background:rgba(0,0,0,.65);
  backdrop-filter:blur(10px);

  padding:18px 22px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.08);
}

.hero-badge strong{
  display:block;
  margin-bottom:6px;
}

.hero-badge span{
  color:#d0d6e0;
}

.hero-price-card{
  padding:36px 28px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.price-card-head h2{
  font-size:4rem;
  font-family:'Oxanium',sans-serif;
  color:var(--gold);
}

.price-card-head span{
  color:var(--muted);
}

.price-mini-grid{
  display:grid;
  gap:14px;
  margin:36px 0;
}

.price-mini-grid div{
  display:flex;
  justify-content:space-between;
  align-items:center;

  padding:16px 18px;

  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
}

.price-mini-grid strong{
  font-size:1.2rem;
  color:var(--gold);
}

.price-link{
  color:#fff;
  font-weight:800;
}

/* STRIP */

.quick-strip{
  display:flex;
  flex-wrap:wrap;
  gap:18px;

  margin-bottom:70px;

  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);

  padding:18px 0;
}

.quick-strip span{
  color:#d9dfea;
  font-weight:800;
  font-family:'Oxanium',sans-serif;
}

/* SECTION */

.section{
  margin-bottom:110px;
}

.section-title{
  max-width:850px;
  margin-bottom:44px;
}

.section-title h2{
  font-family:'Oxanium',sans-serif;
  font-size:clamp(2.4rem,4vw,4.5rem);
  line-height:1.05;
  margin-bottom:18px;
}

.section-title p:last-child{
  color:#b7c0cd;
  line-height:1.8;
  font-size:1.08rem;
}

.compact{
  max-width:980px;
}

/* SERVICES */

.service-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:22px;
}

.service-card{
  background:rgba(12,18,29,.85);
  border:1px solid rgba(255,255,255,.08);

  border-radius:32px;
  padding:34px;

  min-height:280px;
}

.service-card.highlight{
  border-color:rgba(255,31,69,.35);
  box-shadow:0 10px 40px rgba(255,31,69,.12);
}

.service-card span{
  display:inline-block;
  margin-bottom:24px;
  color:#ff6d89;
  font-weight:900;
  font-size:1.15rem;
}

.service-card h3{
  font-size:2rem;
  font-family:'Oxanium',sans-serif;
  margin-bottom:18px;
}

.service-card p{
  color:#bcc5d3;
  line-height:1.8;
}

/* PRICES */

.price-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:22px;
}

.price-grid article{
  background:linear-gradient(180deg,#0f1521,#0a0f18);
  border:1px solid rgba(255,255,255,.08);

  border-radius:28px;
  padding:32px;

  display:flex;
  flex-direction:column;
  gap:10px;
}

.price-grid strong{
  font-size:2.3rem;
  color:var(--gold);
  font-family:'Oxanium',sans-serif;
}

.price-grid span{
  font-size:2rem;
  font-weight:900;
}

.price-grid em{
  font-style:normal;
  color:var(--muted);
}

/* EMERGENCY */

.emergency{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:30px;

  background:linear-gradient(135deg,#0b1321,#070a11);
  border:1px solid rgba(255,255,255,.08);

  border-radius:40px;
  padding:56px;
}

.emergency h2{
  font-family:'Oxanium',sans-serif;
  font-size:clamp(2.6rem,4vw,4.5rem);
  line-height:1;
  margin-bottom:22px;
}

.emergency p{
  color:#c7d0dd;
  line-height:1.8;
  margin-bottom:28px;
}

.emergency img{
  border-radius:28px;
  object-fit:cover;
  height:100%;
  min-height:420px;
}

/* ATELIER */

.atelier-grid{
  display:grid;
  grid-template-columns:1.15fr .8fr 1fr;
  gap:24px;
}

.atelier-grid img{
  border-radius:28px;
  object-fit:cover;
  height:100%;
}

.atelier-grid .large{
  min-height:700px;
}

.atelier-points{
  display:flex;
  flex-direction:column;
  gap:22px;
}

.atelier-points article{
  flex:1;

  padding:34px;

  background:rgba(12,18,29,.85);
  border:1px solid rgba(255,255,255,.08);

  border-radius:28px;
}

.atelier-points strong{
  display:block;
  margin-bottom:14px;
  font-size:2rem;
  font-family:'Oxanium',sans-serif;
}

.atelier-points span{
  color:#bcc5d3;
  line-height:1.7;
}

/* CONTACT */

.contact-layout{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:28px;
}

.lead-form,
.contact-card,
.zone-card,
.map-card{
  background:rgba(10,14,22,.82);
  border:1px solid rgba(255,255,255,.08);
  border-radius:34px;
}

.lead-form{
  padding:38px;
}

.lead-form label{
  display:block;
  margin-bottom:22px;
  font-weight:700;
}

.lead-form input,
.lead-form textarea,
.lead-form select{
  width:100%;
  margin-top:10px;

  border:none;
  outline:none;

  background:#141b28;
  border:1px solid rgba(255,255,255,.08);

  color:#fff;

  padding:18px 20px;
  border-radius:18px;

  font-size:1rem;
}

.lead-form textarea{
  resize:vertical;
}

.contact-card{
  overflow:hidden;
}

.contact-card img{
  width:100%;
  height:280px;
  object-fit:cover;
}

.contact-lines{
  padding:34px;
}

.contact-lines p{
  display:flex;
  flex-direction:column;
  gap:8px;

  padding:18px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.contact-lines strong{
  font-size:1.2rem;
}

.contact-lines a,
.contact-lines span{
  color:#c5cfdb;
}

.card-actions{
  display:flex;
  gap:16px;
  padding:0 34px 34px;
}

/* MAP */

.map-layout{
  display:grid;
  grid-template-columns:1.3fr .7fr;
  gap:28px;
}

.map-card{
  overflow:hidden;
  min-height:520px;
}

.map-card iframe{
  width:100%;
  height:100%;
  border:none;
}

.zone-card{
  padding:42px;
}

.zone-card h3{
  font-family:'Oxanium',sans-serif;
  font-size:3rem;
  line-height:1.1;
  margin-bottom:18px;
}

.zone-card p{
  color:#c1cad7;
  line-height:1.8;
}

.zones{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:30px;
}

.zones span{
  padding:14px 18px;
  border-radius:999px;

  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);

  font-weight:700;
}

/* STICKY */

.sticky-call{
  position:fixed;
  left:50%;
  bottom:20px;
  transform:translateX(-50%);

  z-index:1000;

  background:linear-gradient(135deg,var(--red),#ff3558);
  color:#fff;

  padding:18px 34px;
  border-radius:999px;

  font-weight:900;

  box-shadow:0 14px 40px rgba(255,31,69,.35);
}

/* MOBILE */

.nav-toggle{
  display:none;
}

@media (max-width:1200px){

  .hero{
    grid-template-columns:1fr;
  }

  .service-grid,
  .price-grid,
  .atelier-grid,
  .contact-layout,
  .map-layout,
  .emergency{
    grid-template-columns:1fr;
  }

  .hero-visual{
    min-height:500px;
  }
}

@media (max-width:860px){

  .topbar{
    border-radius:28px;
    padding:16px 18px;
  }

  .site-nav{
    position:absolute;
    top:100%;
    left:0;
    right:0;

    display:none;
    flex-direction:column;

    margin-top:14px;
    padding:24px;

    background:#0a0f18;
    border-radius:28px;
    border:1px solid rgba(255,255,255,.08);
  }

  .site-nav.open{
    display:flex;
  }

  .nav-toggle{
    display:flex;
    flex-direction:column;
    gap:5px;

    background:none;
    border:none;
    cursor:pointer;
  }

  .nav-toggle span{
    width:28px;
    height:3px;
    border-radius:999px;
    background:#fff;
  }

  .call-pill{
    display:none;
  }

  .hero-copy{
    padding:38px 28px;
  }

  .hero h1{
    font-size:3rem;
  }

  .section-title h2{
    font-size:2.6rem;
  }

  .emergency,
  .lead-form,
  .zone-card{
    padding:30px;
  }

  .sticky-call{
    left:16px;
    right:16px;
    bottom:16px;
    transform:none;
    text-align:center;
  }
}
@media (max-width: 860px) {
  .hero-price-card {
    padding: 26px 20px;
  }

  .price-card-head h2 {
    font-size: 3rem;
  }

  .price-mini-grid {
    grid-template-columns: 1fr;
    gap: 10px;
    margin: 24px 0;
  }

  .price-mini-grid div {
    width: 100%;
    display: grid;
    grid-template-columns: 64px 1fr;
    justify-content: initial;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
  }

  .price-mini-grid strong {
    font-size: 1.15rem;
  }

  .price-mini-grid span {
    text-align: right;
/* FIX MOBILE PRIX V3 */
@media (max-width: 900px) {
  .price-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .price-grid article {
    width: 100% !important;
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: 70px 1fr 1fr 1fr !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 18px !important;
  }

  .price-grid article strong {
    font-size: 1.6rem !important;
  }

  .price-grid article span {
    font-size: 1.2rem !important;
  }

  .price-grid article em {
    font-size: 0.78rem !important;
  }

  .hero-price-card {
    width: 100% !important;
    min-width: 0 !important;
  }

  .price-mini-grid div {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 70px 1fr !important;
    gap: 12px !important;
  }

  .price-mini-grid span {
    text-align: right !important;
  }
}    font-size: 0.98rem;
  }
}
@media (max-width: 860px) {
  .hero,
  .hero-copy,
  .hero-price-card,
  .hero-visual {
    width: 100%;
    min-width: 0;
  }
}
