:root{
  --dark:#080f38;
  --red:#fe0545;
  --green:#00ff55;
  --check:#146610;
  --border:#d7dced;
  --muted:rgba(8,15,56,.72);
  --soft:#f5f6fb;
}

*{
  box-sizing:border-box;
}

body{
  margin:0;
  padding-top:0;
  font-family:"Manrope",sans-serif;
  color:var(--dark);
  background:#fff;
  font-size:16px;
  overflow-x:hidden;
}

img{
  max-width:100%;
  height:auto;
}

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

h1,h2,h3,h4,h5,h6{
  font-family:"Outfit",sans-serif;
}

.container-custom{
  width:min(1280px,calc(100% - 40px));
  margin:0 auto;
}

/* HEADER */

.site-header{
  background:#fff;
  border-bottom:1px solid rgba(8,15,56,.08);
  position:sticky;
  top:0;
  left:0;
  width:100%;
  z-index:9999;
}

.navbar{
  padding:18px 0;
}

.logo-img{
  width:240px;
  display:block;
}

.navbar-nav{
  gap:8px;
}

.nav-link{
  font-family:"Outfit",sans-serif;
  font-size:18px;
  font-weight:600;
  color:#0f1868;
  padding:10px 14px!important;
  border-radius:999px;
}

.nav-link:hover,
.nav-link.show{
  color:var(--red);
  background:transparent;
}

.dropdown-toggle::after{
  display:none;
}

.nav-link .fa-angle-down{
  font-size:13px;
  margin-left:7px;
}

.dropdown-menu{
  border:1px solid rgba(8,15,56,.08);
  border-radius:10px;
  box-shadow:0 20px 50px rgba(8,15,56,.10);
  padding:12px;
}

.dropdown-item{
  border-radius:10px;
  padding:10px 14px;
  color:var(--dark);
  font-weight:700;
  font-size:15px;
}

.dropdown-item:hover{
  color:var(--red);
  background:rgba(254,5,69,.06);
}

.navbar-toggler{
  border:none;
  box-shadow:none!important;
  font-size:34px;
  color:#0f1868;
}

/* BUTTONS PHONE */

.btn-phone-menu{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:var(--red);
  color:#fff;
  border-radius:999px;
  padding:8px 18px 8px 8px;
  font-family:"Outfit",sans-serif;
}

.btn-phone-menu:hover{
  color:#fff;
}

.btn-phone-menu .phone-icon{
  width:46px;
  height:46px;
  border-radius:50%;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  flex-shrink:0;
}

.btn-phone-menu .phone-icon img{
  width:23px;
  height:23px;
}

.btn-phone-menu .phone-icon::after{
  content:"";
  position:absolute;
  right:-2px;
  bottom:3px;
  width:14px;
  height:14px;
  background:var(--green);
  border-radius:50%;
  border:3px solid var(--red);
}

.btn-phone-menu .phone-text{
  font-size:18px;
  font-weight:800;
  line-height:1;
}

.btn-phone-menu small{
  display:block;
  font-family:"Manrope",sans-serif;
  font-size:11px;
  font-weight:400;
  margin-top:5px;
}

/* HERO */

.hero{
  min-height:620px;
  color:#fff;
  background:
    linear-gradient(
      90deg,
      rgba(4,8,43,.98) 0%,
      rgba(4,8,43,.84) 40%,
      rgba(4,8,43,.28) 72%,
      rgba(4,8,43,.05) 100%
    ),
    url("../img/hero-serrurier.jpg")
    right center / cover no-repeat;
}

.hero-inner{
  padding:78px 0 130px;
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(255,255,255,.35);
  backdrop-filter:blur(8px);
  color:#fff;
  padding:8px 14px;
  border-radius:999px;
  font-size:14px;
  font-weight:800;
  margin-bottom:34px;
}

.hero-badge::before{
  content:"";
  width:13px;
  height:13px;
  background:var(--green);
  border-radius:50%;
}

.hero h1{
  max-width:640px;
  font-size:clamp(46px,6vw,60px);
  line-height:.93;
  letter-spacing:normal;
  font-weight:700;
  margin:0 0 34px;
}

.hero-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:26px;
  margin-bottom:34px;
}

.hero-actions small{
  display:block;
  color:rgba(255,255,255,.68);
  margin-top:6px;
}

.btn-phone-hero{
  display:inline-flex;
  align-items:center;
  gap:14px;
  background:var(--red);
  color:#fff;
  border-radius:999px;
  padding:9px 24px 9px 9px;
  font-family:"Outfit",sans-serif;
}

.btn-phone-hero:hover{
  color:#fff;
}

.btn-phone-hero .phone-icon{
  width:58px;
  height:58px;
  border-radius:50%;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  flex-shrink:0;
}

.btn-phone-hero .phone-icon img{
  width:29px;
  height:29px;
}

.btn-phone-hero .phone-icon::after{
  content:"";
  position:absolute;
  right:-4px;
  bottom:4px;
  width:18px;
  height:18px;
  background:var(--green);
  border-radius:50%;
  border:4px solid var(--red);
}

.btn-phone-hero .phone-text{
  font-size:25px;
  font-weight:800;
  line-height:1;
}

.btn-phone-hero small{
  display:block;
  font-family:"Manrope",sans-serif;
  font-size:14px;
  font-weight:400;
  margin-top:7px;
}

.online-link{
  font-family:"Outfit",sans-serif;
  font-size:16px;
  font-weight:700;
  color:#fff;
  text-decoration:underline;
  text-underline-offset:4px;
}

/* RATING */

.rating-link{
  display:inline-block;
}

.rating{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:14px;
  font-size:26px;
  font-weight:800;
}

.stars{
  color:#ffc83d;
  letter-spacing:2px;
}

.avis-logo img{
  height:44px;
  display:block;
}

/* TRUST */

.trust-section{
  padding:0 0 70px;
  background:#fff;
  position:relative;
  z-index:5;
}

.trust-grid{
  width:min(760px,100%);
  margin-top:-70px;
  margin-left:auto;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  position:relative;
  z-index:6;
}

.trust-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:26px;
  min-height:115px;
  padding:24px 24px;
  display:flex;
  align-items:center;
  gap:18px;
  box-shadow:0 14px 34px rgba(8,15,56,.04);
}

.trust-card i{
  color:#146610;
  font-size:34px;
  font-weight:900;
  flex-shrink:0;
}

.trust-card strong{
  font-family:"Manrope",sans-serif;
  font-size:18px;
  font-weight:600;
  line-height:1.15;
}

/* PROBLEM SECTION */

.problem-section{
  padding:12px 0 88px;
  background:#fff;
}

.problem-intro{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:72px;
  align-items:start;
  margin-bottom:58px;
}

.problem-intro h2{
  font-size:clamp(36px,3.2vw,46px);
  line-height:1.03;
  font-weight:800;
  letter-spacing:-.7px;
  margin:0;
  color:var(--dark);
}

.problem-intro h2 span{
  display:block;
  font-family:"Manrope",sans-serif;
  font-size:.9em;
  font-weight:400;
  letter-spacing:-.8px;
  color:rgba(8,15,56,.92);
}

.problem-intro p{
  font-size:18px;
  line-height:1.38;
  font-weight:400;
  color:rgba(8,15,56,.88);
  margin:6px 0 0;
  max-width:680px;
}

.steps-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:82px;
  margin-bottom:46px;
}

.step-card{
  position:relative;
}

.step-visual{
  position:relative;
  height:160px;
  margin-bottom:10px;
}

.step-image1{
  position:absolute;
  top:0;
  left:86px;
  width:225px;
  height:130px;
  background-image: url("../img/probleme-porte.jpg");
  background-size: cover;
  border-radius:24px;
}
.step-image2{
  position:absolute;
  top:0;
  left:86px;
  width:225px;
  height:130px;
  background-image: url("../img/appel-serrurier-urgence.jpg");
  background-size: cover;
  border-radius:24px;
}
.step-image3{
  position:absolute;
  top:0;
  left:86px;
  width:225px;
  height:130px;
  background-image: url("../img/probleme-regle.jpg");
  background-size: cover;
  border-radius:24px;
}
.step-number{
  position:absolute;
  left:0;
  bottom:0;
  font-family:"Outfit",sans-serif;
  font-size:58px;
  line-height:.8;
  font-weight:800;
  color:var(--dark);
}

.step-card h3{
  font-family:"Outfit",sans-serif;
  font-size:25px;
  line-height:1.05;
  font-weight:800;
  color:var(--dark);
  margin:0 0 12px;
  letter-spacing:-.3px;
}

.step-card p{
  font-size:17px;
  line-height:1.25;
  font-weight:400;
  color:rgba(8,15,56,.88);
  margin:0;
  max-width:340px;
}

.section-cta,
.rapid-cta{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:26px;
  margin-top:34px;
}

.section-cta small,
.rapid-cta small{
  display:block;
  color:rgba(255,255,255,1);
  margin-top:6px;
}

.section-online-link{
  font-family:"Outfit",sans-serif;
  font-size:16px;
  font-weight:700;
  color:var(--dark);
  text-decoration:underline;
  text-underline-offset:4px;
}

/* SERVICES */

.services-section{
  padding:76px 0 92px;
  background:#fff;
}

.section-heading{
  text-align:center;
  margin-bottom:42px;
}

.section-heading h2{
  font-size:32px;
  line-height:1;
  font-weight:800;
  letter-spacing:-.4px;
  margin:0 0 8px;
  color:var(--dark);
}

.section-heading p{
  font-size:20px;
  line-height:1.25;
  font-weight:400;
  color:var(--dark);
  margin:0;
}

.services-grid{
  width:min(980px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px 28px;
}

.service-card{
  display:grid;
  grid-template-columns:132px 1fr;
  background:#fff;
  border:1px solid rgba(8,15,56,.12);
  border-radius:24px;
  overflow:hidden;
  min-height:132px;
  box-shadow:0 12px 30px rgba(8,15,56,.035);
}

.service-image{
  height:100%;
  min-height:132px;
  overflow:hidden;
}

.service-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.service-content{
  padding:20px 22px;
}

.service-price{
  display:block;
  color:var(--red);
  font-size:14px;
  font-weight:800;
  line-height:1;
  margin-bottom:6px;
}

.service-content h3{
  font-size:19px;
  line-height:1.05;
  font-weight:800;
  letter-spacing:-.2px;
  margin:0 0 8px;
  color:var(--dark);
}

.service-content p{
  font-size:17px;
  line-height:1.32;
  font-weight:400;
  color:rgba(8,15,56,.72);
  margin:0;
}

/* RAPID SECTION */

.rapid-section{
  padding:72px 0;
  background:#fff;
}

.rapid-grid{
  display:grid;
  grid-template-columns:1fr 520px;
  gap:60px;
  align-items:center;
}

.rapid-content h2{
  font-size:34px;
  line-height:1.05;
  font-weight:800;
  margin:0 0 22px;
  color:var(--dark);
}

.rapid-content h2 span{
  display:block;
  font-family:"Manrope",sans-serif;
  font-weight:400;
}

.rapid-content p{
  font-size:17px;
  line-height:1.5;
  color:rgba(8,15,56,.78);
  margin:0 0 16px;
}

.rapid-cta{
  justify-content:flex-start;
}

.rapid-image{
  border-radius:0;
  overflow:hidden;
}

.rapid-image img{
  width:100%;
  height:510px;
  object-fit:cover;
  display:block;
  border-radius: 50px;
}

/* COVERAGE */

.coverage-section{
  padding:82px 0;
  background:#fff;
}

.coverage-intro{
  max-width:1000px;
  margin:0 auto 44px;
  text-align:center;
  font-size:17px;
  line-height:1.45;
  color:rgba(8,15,56,.72);
}

.coverage-grid{
  display:grid;
  grid-template-columns:55% 45%;
  gap:70px;
  align-items:center;
  width:100%;
  max-width:none;
  margin:0 auto;
}

.map-block{
  text-align:center;
}

.france-map-link img{
  width:260px;
  display:block;
  margin:0 auto 28px;
}

.btn-phone-mini{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--red);
  color:#fff;
  border-radius:999px;
  padding:7px 15px 7px 7px;
  font-family:"Outfit",sans-serif;
  margin-bottom:10px;
}

.btn-phone-mini:hover{
  color:#fff;
}

.btn-phone-mini .phone-icon{
  width:36px;
  height:36px;
  background:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  flex-shrink:0;
}

.btn-phone-mini .phone-icon img{
  width:18px;
  height:18px;
}

.btn-phone-mini .phone-icon::after{
  content:"";
  position:absolute;
  right:-2px;
  bottom:2px;
  width:11px;
  height:11px;
  border-radius:50%;
  background:var(--green);
  border:2px solid var(--red);
}

.btn-phone-mini span:last-child{
  font-size:13px;
  font-weight:800;
  line-height:1;
}

.btn-phone-mini small{
  display:block;
  font-family:"Manrope",sans-serif;
  font-size:8px;
  font-weight:400;
  margin-top:4px;
}

.map-online-link{
  display:block;
  font-size:13px;
  font-weight:700;
  color:var(--dark);
  text-decoration:underline;
  text-underline-offset:3px;
}

.cities-card{
  background:#f6f7fc;
  border-radius:28px;
  padding:34px 38px;
}

.cities-card h3{
  font-size:23px;
  line-height:1.1;
  font-weight:800;
  margin:0 0 12px;
}

.cities-card p{
  font-size:17px;
  line-height:1.35;
  color:rgba(8,15,56,.72);
  margin:0 0 24px;
}

.cities-list{
  list-style:none;
  padding:0;
  margin:0;
  columns:4;
}

.cities-list li{
  margin:0 0 8px;
  font-size:16px;
  font-weight:600;
}

.cities-list a:hover{
  color:var(--red);
}

/* WHY */

.why-section{
  padding:76px 0 84px;
  background:#fff;
}

.why-grid{
  width:min(980px,100%);
  margin:0 auto 34px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:54px;
}

.why-image1{
  height:200px;
  background-image: url("../img/service-oriente-urgence.jpg");
  background-size: cover;
  border-radius:20px;
  margin-bottom:22px;
}
.why-image2{
  height:200px;
  background-image: url("../img/tarifs-transparents.jpg");
  background-size: cover;
  border-radius:20px;
  margin-bottom:22px;
}
.why-image3{
  height:200px;
  background-image: url("../img/reseau-partenaire-rehom.jpg");
  background-size: cover;
  border-radius:20px;
  margin-bottom:22px;
}

.why-card h3{
  font-size:22px;
  font-weight:800;
  margin:0 0 10px;
}

.why-card p{
  font-size:16px;
  line-height:1.35;
  color:rgba(8,15,56,.72);
  margin:0;
}

/* PRICES */

.prices-section{
  padding:84px 0;
  background:#f3f4fb;
}

.prices-section .section-heading p{
  max-width:720px;
  margin:0 auto;
  font-size:17px;
  color:rgba(8,15,56,.72);
}

.prices-table{
  width:min(1180px,100%);
  margin:34px auto 0;
}

.price-line{
  display:grid;
  grid-template-columns:1fr 170px 230px;
  align-items:center;
  gap:20px;
  padding:18px 0;
  border-bottom:1px solid rgba(8,15,56,.14);
}

.price-line span{
  font-size:16px;
  font-weight:700;
}

.price-line strong{
  font-size:16px;
  font-weight:800;
  text-align:center;
}

.price-line a{
  justify-self:end;
  border:1px solid rgba(8,15,56,.16);
  background:#fff;
  border-radius:999px;
  padding:8px 18px;
  font-size:16px;
  font-weight:800;
  text-align: center;
}

.price-line a:hover{
  color:var(--red);
  border-color:var(--red);
}

/* FAQ */

.faq-section{
  padding:92px 0;
  background:#fff;
}

.faq-card{
  width:min(1180px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.1fr 410px;
  border:1px solid rgba(8,15,56,.12);
  border-radius:28px;
  overflow:hidden;
  background:#fff;
}

.faq-content{
  padding:42px;
}

.faq-content h2{
  font-size:30px;
  line-height:1.05;
  font-weight:800;
  margin:0 0 24px;
}

.faq-item{
  padding:12px 0;
  border-bottom:1px solid rgba(8,15,56,.12);
}

.faq-item h3{
  font-size:18px;
  font-weight:800;
  margin:0;
}

.faq-item.active h3{
  color:var(--red);
}

.faq-item p{
  font-size:16px;
  line-height:1.4;
  color:rgba(8,15,56,.72);
  margin:10px 0 0;
}

.faq-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* BOOKING */

.booking-section{
  padding:86px 0;
  background:#f3f4fb;
  text-align:center;
}

.booking-kicker{
  display:block;
  color:var(--red);
  font-size:13px;
  font-weight:800;
  margin-bottom:8px;
}

.booking-section h2{
  font-size:34px;
  line-height:1.05;
  font-weight:800;
  margin:0 0 28px;
}

.booking-form{
  width:min(760px,100%);
  margin:0 auto;
}

.booking-step p{
  font-size:16px;
  font-weight:700;
  margin:0 0 20px;
}

.booking-options{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:18px;
}

.booking-options label{
  cursor:pointer;
}

.booking-options input{
  display:none;
}

.booking-options span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(8,15,56,.16);
  background:#fff;
  border-radius:999px;
  padding:13px 20px;
  min-width:210px;
  font-size:14px;
  font-weight:700;
}

.booking-options input:checked + span{
  border-color:var(--red);
  color:var(--red);
}

.booking-progress{
  width:min(540px,100%);
  height:4px;
  background:#d9ddea;
  margin:34px auto 0;
  border-radius:999px;
  overflow:hidden;
}

.booking-progress span{
  display:block;
  width:18%;
  height:100%;
  background:var(--red);
}

/* FOOTER */

.site-footer{
  padding:64px 0 24px;
  background:#fff;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr 1fr 1.3fr;
  gap:34px;
  align-items:start;
}

.footer-logo{
  width:200px;
}

.site-footer h3{
  font-size:16px;
  font-weight:800;
  margin:0 0 14px;
}

.site-footer ul{
  list-style:none;
  padding:0;
  margin:0;
}

.site-footer li{
  margin-bottom:7px;
  font-size:16px;
  color:rgba(8,15,56,.72);
}

.site-footer a:hover{
  color:var(--red);
}

.footer-socials{
  display:flex;
  gap:10px;
  margin-top:18px;
}

.footer-socials a{
  width:32px;
  height:32px;
  border:1px solid rgba(8,15,56,.16);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
}

.footer-bottom{
  border-top:1px solid rgba(8,15,56,.10);
  margin-top:44px;
  padding-top:18px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:16px;
  font-size:16px;
  color:rgba(8,15,56,.60);
}

.footer-bottom span:last-child{
  display:flex;
  gap:18px;
}

/* RESPONSIVE */

@media(max-width:991px){

  .hero{
    min-height:auto;
    background:
      linear-gradient(
        180deg,
        rgba(4,8,43,.90) 0%,
        rgba(4,8,43,.70) 100%
      ),
      url("../img/hero-serrurier.jpg")
      right center / cover no-repeat;
  }

  .hero-inner{
    padding:70px 0 95px;
  }

  .hero h1{
    font-size:52px;
  }

  .trust-grid{
    width:100%;
    margin-left:0;
    margin-top:-45px;
    grid-template-columns:1fr;
    gap:18px;
  }

  .problem-intro,
  .rapid-grid,
  .coverage-grid,
  .faq-card,
  .footer-grid{
    grid-template-columns:1fr;
  }

  .problem-intro{
    gap:22px;
  }

  .steps-grid,
  .services-grid,
  .why-grid{
    grid-template-columns:1fr;
  }

  .steps-grid{
    gap:42px;
  }

  .step-image{
    left:80px;
  }

  .services-grid,
  .why-grid{
    width:100%;
  }

  .rapid-image img{
    height:330px;
  }

  .cities-list{
    columns:2;
  }

  .price-line{
    grid-template-columns:1fr;
    gap:10px;
  }

  .price-line strong{
    text-align:left;
  }

  .price-line a{
    justify-self:start;
  }
}

@media(max-width:768px){

  .container-custom{
    width:calc(100% - 24px);
  }

  .navbar{
    padding:14px 0;
  }

  .logo-img{
    width:180px;
  }

  .hero h1{
    font-size:42px;
    line-height:.95;
  }

  .hero-actions{
    flex-direction:column;
    align-items:flex-start;
  }

  .rating{
    font-size:20px;
  }

  .trust-card{
    min-height:auto;
    padding:22px;
    border-radius:24px;
  }

  .trust-card strong{
    font-size:17px;
  }

  .problem-section{
    padding:10px 0 70px;
  }

  .problem-intro h2{
    font-size:36px;
  }

  .problem-intro p{
    font-size:17px;
  }

  .step-visual{
    height:150px;
  }

  .step-image{
    width:205px;
    height:120px;
    left:72px;
  }

  .step-number{
    font-size:54px;
  }

  .section-cta,
  .rapid-cta{
    justify-content:flex-start;
  }

  .service-card{
    grid-template-columns:105px 1fr;
    min-height:125px;
    border-radius:22px;
  }

  .service-image{
    min-height:125px;
  }

  .service-content{
    padding:17px 18px;
  }

  .rapid-content h2,
  .booking-section h2{
    font-size:30px;
  }

  .cities-card{
    padding:28px 24px;
  }

  .cities-list{
    columns:1;
  }

  .faq-content{
    padding:30px 24px;
  }

  .footer-bottom{
    flex-direction:column;
  }

  .footer-bottom span:last-child{
    flex-direction:column;
    gap:8px;
  }
}

.opd-map-section{
  width:100%;
  max-width:100%;
  padding:0;
  overflow:hidden;
}

#opd-france-map{
  width:100%;
  height:650px;
  min-height:320px;
  background:transparent;
  border-radius:24px;
  overflow:hidden;
}

.leaflet-container{
  font-family:"Manrope",sans-serif;
  background:transparent;
}

.leaflet-control-container{
  display:none;
}

.leaflet-tooltip{
  background:#ffffff;
  color:#080f38;
  border:none;
  border-radius:12px;
  padding:8px 12px;
  font-size:14px;
  font-weight:700;
  box-shadow:0 10px 25px rgba(0,0,0,.15);
}

@media(max-width:768px){
  #opd-france-map{
    height:450px;
  }
}
.typeform-box{
  width:min(760px,100%);
  margin:0 auto;
  background:#fff;
  border-radius:34px;
  padding:42px;
  text-align:left;
  box-shadow:0 20px 60px rgba(8,15,56,.08);
}

.form-progress{
  height:5px;
  background:#dde2ef;
  border-radius:999px;
  overflow:hidden;
  margin-bottom:34px;
}

.form-progress span{
  display:block;
  width:20%;
  height:100%;
  background:var(--red);
  transition:.25s ease;
}

.form-step{
  display:none;
}

.form-step.active{
  display:block;
}

.step-count{
  color:var(--red);
  font-weight:800;
  font-size:14px;
  margin-bottom:10px;
}

.form-step h3{
  font-size:32px;
  font-weight:800;
  margin-bottom:28px;
}

.choice-list{
  display:grid;
  gap:14px;
}

.choice-list button,
.typeform-box input,
.typeform-box textarea{
  width:100%;
  border:1px solid rgba(8,15,56,.14);
  background:#fff;
  border-radius:18px;
  padding:18px 20px;
  font-family:"Manrope",sans-serif;
  font-size:16px;
  color:var(--dark);
}

.choice-list button{
  text-align:left;
  font-weight:700;
}

.choice-list button:hover,
.choice-list button.selected{
  border-color:var(--red);
  color:var(--red);
}

.typeform-box textarea{
  min-height:130px;
  resize:none;
}

.form-nav{
  display:flex;
  justify-content:space-between;
  gap:14px;
  margin-top:30px;
}

.form-nav button,
.submit-btn{
  border:none;
  border-radius:999px;
  padding:14px 28px;
  font-weight:800;
  font-family:"Outfit",sans-serif;
}

#prevStep{
  background:#eef1f7;
  color:var(--dark);
}

#nextStep,
.submit-btn{
  background:var(--red);
  color:#fff;
}

.submit-btn{
  margin-top:22px;
  width:100%;
}
.mobile-sticky-cta{
  display:none;
}

@media(max-width:768px){

  body{
    padding-bottom:95px;
  }

  .mobile-sticky-cta{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:99999;
    display:flex;
    align-items:center;
    gap:14px;
    padding:12px 18px 16px;
    background:#fff;
    box-shadow:0 -10px 30px rgba(8,15,56,.08);
  }

  .mobile-call-btn,
  .mobile-whatsapp-btn{
    width:62px;
    height:62px;
    border-radius:50%;
    flex-shrink:0;
    display:flex;
    align-items:center;
    justify-content:center;
  }

  .mobile-call-btn{
    position:relative;
    background:#fe0545;
  }

  .mobile-call-btn img{
    width:30px;
    height:30px;
    background:#fff;
    border-radius:50%;
    padding:10px;
    box-sizing:content-box;
  }

  .mobile-call-btn span{
    position:absolute;
    right:5px;
    bottom:5px;
    width:15px;
    height:15px;
    background:#00ff55;
    border-radius:50%;
    border:3px solid #fe0545;
  }

  .mobile-whatsapp-btn{
    background:#11b83e;
    color:#fff;
    font-size:34px;
  }

  .mobile-booking-btn{
    flex:1;
    min-height:58px;
    border:1px solid rgba(8,15,56,.18);
    border-radius:999px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    color:#080f38;
    background:#fff;
    font-family:"Outfit",sans-serif;
    line-height:1.05;
  }

  .mobile-booking-btn strong{
    font-size:16px;
    font-weight:800;
  }

  .mobile-booking-btn small{
    font-family:"Manrope",sans-serif;
    font-size:12px;
    color:#fe0545;
    font-weight:700;
    margin-top:3px;
  }
}