.section-reviews .item{
  min-height: 160px;
}
/* HERO */
.title-hero{ font-size:43px; color:#fff; font-weight:800; letter-spacing:1px; margin-bottom:0; }
.st-hero{ padding:60px 0 60px; display:flex; align-items:flex-start; height:auto!important; }
.option-hero{ list-style:none; padding:0; margin:0 0 15px; }
.option-hero li{ position:relative; padding-left:28px; margin-bottom:10px; color:#fff; font-weight:500; font-size:17px; }
.option-hero li::before{ content:""; position:absolute; left:0; top:50%; width:19px; height:19px; transform:translateY(-50%); background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 19 19"><path d="M9.5,19c5.24671,0 9.5,-4.25329 9.5,-9.5c0,-5.24671 -4.25329,-9.5 -9.5,-9.5c-5.24671,0 -9.5,4.25329 -9.5,9.5c0,5.24671 4.25329,9.5 9.5,9.5zM13.69336,7.75586l-4.75,4.75c-0.34883,0.34883 -0.91289,0.34883 -1.25801,0l-2.375,-2.375c-0.34883,-0.34883 -0.34883,-0.91289 0,-1.25801c0.34883,-0.34512 0.91289,-0.34883 1.25801,0l1.74414,1.74414l4.11914,-4.12285c0.34883,-0.34883 0.91289,-0.34883 1.25801,0c0.34512,0.34883 0.34883,0.91289 0,1.25801z" fill="white"/></svg>') no-repeat center/contain; }
.option-hero-line{ display:flex; align-items:center; gap:10px; font-size:16px; font-weight:600; color:#fff; flex-wrap:wrap; margin:15px 0; }
.option-hero-line span:not(:last-child)::after{ content:"•"; margin-left:8px; color:#fff; }
.btns-hero{ display:flex; align-items:flex-start; gap:15px; flex-wrap:wrap; flex-direction:column; }
.btns-hero a{ border-radius:15px; padding:10px 20px; width:400px; max-width:400px; height:auto; }
.btn-reserve-hero,.btn-call-hero{ display:inline-flex; align-items:center; gap:10px; font-weight:600; font-size:17px; padding:12px 24px; color:#fff; transition:color .3s ease; }
.btn-call-hero{ font-size:18px; gap:8px; }
.btn-reserve-hero:hover,.btn-call-hero:hover{ color:var(--primary); }
.bagde-green-hero{ background:var(--success); padding:5px 12px; color:#fff; font-weight:500; border-top-right-radius:10px; border-bottom-right-radius:10px; position:absolute; left:0; bottom:25vh; }

.row_hero{
      display: flex;
    align-items: center;
}
/* FORM HERO */
.col-form-hero{ padding:0px;}
.reservation-express-form{ background:#fff; padding:24px; border-radius:20px; box-shadow:0 10px 30px rgba(0,0,0,.12); }
.reservation-express-form .form-title{ text-align:center; color:var(--primary); font-weight:800; font-size:28px; margin:0 0 18px; }
.reservation-express-form .steps{ display:flex; justify-content:space-between; gap:8px; margin-bottom:16px; }
.reservation-express-form .step{ flex:1; display:flex; align-items:center; gap:1px; justify-content:center; color:var(--muted); font-weight:700; flex-direction:column; }
.reservation-express-form .step-badge{ width:34px; height:34px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; background:var(--primary); color:#fff; font-weight:800; }
.reservation-express-form .step-label{ font-size:13px; font-weight:500; }
.reservation-express-form .form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
.reservation-express-form .field{ display:flex; flex-direction:column; gap:6px; }
.reservation-express-form label{ font-weight:700; color:var(--ink); font-size:14px; }
.reservation-express-form .req{ color:var(--primary); }
.reservation-express-form input,.reservation-express-form select{ appearance:none; width:100%; padding:8px 14px; background:var(--bg-soft); border:1px solid var(--border); border-radius:12px; font-size:14px; color:var(--ink); }
.reservation-express-form input::placeholder{ color:#a3a3a3; }
.reservation-express-form fieldset.urgency{ margin:14px 0 18px; border:0; padding:0; }
.reservation-express-form .urgency legend{ font-weight:700; color:var(--ink); margin-bottom:10px; font-size:14px; }
.reservation-express-form .urgency-options{ display:flex; gap:12px; justify-content:space-between; }
.reservation-express-form .urgency-option{ flex:1; }
.reservation-express-form .urgency-option input{ display:none; }
.reservation-express-form .urgency-btn{ display:block; text-align:center; padding:12px 14px; border:2px solid var(--primary); border-radius:12px; color:var(--primary); font-weight:700; background:#fff; cursor:pointer; transition:.2s; }
.reservation-express-form .urgency-btn.urgent{ border-color:#d93025; color:#d93025; }
.reservation-express-form .urgency-option input:checked + .urgency-btn{ color:var(--primary); background:rgba(233,96,2,.1); }
.reservation-express-form .urgency-option input:checked + .urgency-btn.urgent{ background:#d93025; color:#fff; }
.reservation-express-form .btn-book-hero{ width:100%; font-size:16px; font-weight:800; padding:14px 18px; display:inline-flex; align-items:center; justify-content:center; gap:10px; color:#fff; max-width:unset; }
.reservation-express-form .btn-book-hero svg{ flex-shrink:0; }

/* SECTION ENGAGE */
.title-section{ color:var(--primary); font-size:25px; font-weight:800; font-style:italic; }
.title-section-second{ color:#8c8c8c99; font-size:25px; font-weight:800; font-style:italic; }
.title-style-five .title-section{ color:var(--primary); font-weight:800; font-size:40px; /*text-shadow:-3px 29px 0 rgba(140,140,140,.6); */ margin-bottom: -8px;}
.section-engage{ padding:50px 0; }
.item-sengage{ background:#fff!important; border-radius:20px; box-shadow:0 2px 20px rgba(0,0,0,.4); padding:20px!important; min-height:217px; }
.section-engage .disc{ color:#000; }
.section-engage .disc span{ color:var(--primary); font-weight:600; }
.section-engage .items{ padding:0 160px; }

.item-sengage .icon_custom{
    height: 50px;
    display: flex;
    justify-content: center;
    margin-bottom: 15px;
    margin-top: 15px;
}

/* ASSURANCE */
.party-assurance{ padding:50px 180px 0;    display: flex;justify-content: center; }
.assurance-wrap{ display:flex; align-items:center; gap:0; }
.assurance-left{ flex:0 0 auto; display:flex; align-items:center; }
.assurance-left img{ display:block; height:78px; width:auto; }
.assurance-right{ flex:1; min-width:0; display:flex; align-items:center; gap:12px; border:2px solid var(--primary); border-radius:48px 48px 48px 48px; box-sizing:border-box; white-space:nowrap; padding:9px 2px; margin-left:-4px; justify-content:center; }
.assurance-right .text-main{ font-weight:800; color:var(--primary); font-size:20px; }
.assurance-right .link{ color:#111; text-decoration:underline; font-size:18px; font-weight:500; }

.btn-cta-engage {
    width: 300px;
    font-size: 18px !important;
}
/* SERVICES */
.section-service{ padding:20px 0 50px; }
.title-style-five.with-lines{ position:relative; text-align:center; width:100%; margin-bottom: -24px; }
.title-section-line{ position:relative; color:var(--primary); font-weight:800; font-size:40px; display:inline-block; padding:0 20px; background:#fff; z-index:2; }
.title-section-line .shadow-text{ position:absolute; left:50%; top:78%; transform:translate(-50%,10px); font-size:32px; font-weight:800; color:rgba(140,140,140,.6); white-space:nowrap; pointer-events:none; }
.title-style-five.with-lines::before,.title-style-five.with-lines::after{ content:""; position:absolute; top: calc(35%); width:100%; height:1px; background:var(--primary); z-index:0; }
.title-style-five.with-lines::before{ left:0; right:50%; } .title-style-five.with-lines::after{ right:0; left:50%; }
.section-service .items{ padding:0 140px; }
.service-card{ position:relative; border-radius:16px; overflow:hidden; isolation:isolate; }
.service-card .thumbnail{ display:block; }
.service-card .thumbnail img{ width:100%; height:300px; object-fit:cover; display:block; transition:transform .35s ease; }
.service-card::after{ content:""; position:absolute; inset:0; background:url('../images/gradient-service.svg') center bottom/cover no-repeat; z-index:1; pointer-events:none; opacity:1; }
.service-card .inner-content .title{ margin:0; color:#fff; font-weight:800; font-size:20px; line-height:1.1; text-shadow:0 1px 0 rgba(0,0,0,.1); }
.service-card:hover .thumbnail img{ transform:scale(1.04); }

/* REVIEWS */
.section-reviews{ position:relative; padding:90px 0; background-repeat:no-repeat,no-repeat; background-size:cover,cover; background-position:center,center; background-image:linear-gradient(-90deg, rgba(233,96,13,.91) 18%, rgba(233,96,13,0) 100%), url('../images/bg-reviews.png'); background-color:#ccc; }
.section-reviews .title-reviews{ color:#fff; font-weight:800; font-size:40px; display:flex; justify-content:center; }
.section-reviews .title-reviews svg{ margin-left:-90px; margin-top:-20px; }
.reviews-swiper{ overflow:hidden; margin-bottom:20px; }
.reviews-swiper .swiper-wrapper{ align-items:stretch; }
.reviews-swiper .swiper-slide{ width:100%!important; box-sizing:border-box; }
.bloc-content-review-left{ position:absolute; max-width:480px; background:#fff; border-radius:18px; padding:40px 30px; box-shadow:0 18px 40px rgba(0,0,0,.14); margin-top:-30px; }
.why-title{ margin:0 0 8px; color:var(--primary); font-weight:800; font-size:22px; }
.why-intro{ margin:0 0 14px; color:#000; font-size:15px; line-height:1.6; }
.why-list{ list-style:none; margin:0 0 16px; padding:0; display:grid; gap:12px; }
.why-item{ display:grid; grid-template-columns:28px 1fr; align-items:start; gap:12px; }
.why-ico{ width:28px; height:28px; object-fit:contain; margin-top:2px; }
.why-item p{ margin:0; color:#333; font-size:15px; line-height:1.6; }
.why-item .accent{ color:var(--primary); font-weight:700; }
.btn-rdv-reviews{ display:flex; justify-content:center; }
.btn-rdv-reviews a{ border-radius:30px; padding:8px 25px; height:auto; text-decoration:underline; }
.badge-google{ position:absolute; width:150px; background:#fff; bottom:0; right:30px; border-top-right-radius:10px; border-top-left-radius:10px; }
.section-reviews .stars-area{ display:flex; justify-content:center; margin-bottom:10px; }
.section-reviews .item{ padding:28px 50px; }
.section-reviews .fa-star{ color:#ffd500; }
.section-reviews .content-review{ color:var(--ink-2)!important; font-size:15px!important; padding-bottom:0!important; margin-bottom:5px!important; line-height:1.5; border-bottom:0!important; }
.section-reviews .name-review{ display:flex; justify-content:flex-end; }
.section-reviews .name-review .value{ font-size:15px; font-weight:700; color:var(--ink-2); }

/* FAQ */
.section-faq{ padding:120px 0 50px; }
.section-faq .item{ color:#000!important; font-weight:600!important; }
.section-faq .accordion-body{ color:var(--ink-2); font-size:15px; display:flex; padding:0 40px 20px!important; }
.title-faq{ color:var(--primary); font-size:40px; font-weight:800; margin:0; }
.title-second-faq{ color:#7a7a7a; font-size:30px; font-weight:800; }
.btn-faq-contact span{ font-size:15px; font-weight:400; }
.faq-media{ margin-top:-55px; margin-right:40px; }
.faq-media img{ width:300px; height:auto; border-radius:10px; min-width:300px; }
.btn-faq-more{ display:flex; justify-content:center; margin-top:20px; }
.btn-faq-more a{ text-decoration:none; padding:10px 30px; height:auto; border-radius:30px; }
.faq-wrapper-inner-page .accordion-item{ margin-bottom:10px!important; }


/* ============================================================
   2) DESKTOP (≥ 992px)
   ============================================================ */
@media (min-width:992px){
  .st-hero{ padding:60px 0 60px; }
  .btns-hero a{ max-width:400px; }
  .bagde-green-hero{ left:0; bottom:25vh; }
  .reservation-express-form .form-grid{ grid-template-columns:1fr; }
  .section-engage .items{ padding:0 160px; }
  .section-service .items{ padding:0 140px; }
  .service-card .thumbnail img{ height:300px; }
  .section-faq .accordion-body{ padding:0 40px 20px!important; }
  .faq-media{ margin-top:-55px; margin-right:40px; }
  .faq-media img{ width:300px; min-width:300px; }
  .footer-custom{ padding:50px 100px; }
  .col-group-links{ gap:60px; }
  .col-group-parent{ gap:50px; }
}

/* ============================================================
   3) MOBILE (≤ 991.98px)
   ============================================================ */

@media (max-width:991.98px){

   .btns-hero{
    align-content: center;
   }
  .st-hero{ padding:50px 0 40px; }
  .btns-hero a{ width:100%; max-width: 335px; border-radius: 50px;  }
  .bagde-green-hero{ position:static; margin-top:10px; border-radius:8px; }
  .reservation-express-form{ margin-top:24px; padding: 20px 10px }
  .reservation-express-form .form-grid{ grid-template-columns: 1fr; gap:12px }
  .party-assurance{ padding:40px 0px 0; }
  .assurance-wrap{ flex-direction:column;         gap: 20px; }
  .assurance-left img{ width:100%; height:auto; }
  .assurance-right{ border-radius:30px; border-left:2px solid var(--primary); white-space:normal; justify-content:center; padding:12px 30px; height:auto; margin-left:0;     flex-direction: column;        gap: 4px;}
  .assurance-right .text-main{ font-size:18px; font-weight: 600}
  .assurance-right .link{ font-size:16px; }
  .section-service .items{ padding:0 12px; }
  .service-card .thumbnail img{ height:220px; }
  .service-card .thumbnail img{ height:200px; }
  .service-card .inner-content .title{ font-size:18px; text-align: left; margin-left: 20px; }
  .title-section-line{ font-size:25px; padding:0 20px; margin-bottom: 0; }
  /* .title-section-line .shadow-text{ font-size:22px; transform:translate(-50%,6px); } */
  .bloc-content-review-left{ position:static; max-width:100%; padding:25px 25px; margin-top:-80px;box-shadow: 0px 3px 50px rgba(0, 0, 0, 0.4);}
  .why-title{ font-size:20px; }
  .why-item{ grid-template-columns:26px 1fr; gap:10px; }
  .why-ico{ width:26px; height:26px; }
  .section-faq{ padding:70px 0 30px; }
  .section-faq .accordion-body{ padding:0 16px 16px!important; flex-direction:column; }
  .faq-media{ margin:10px 0 10px 0; }
  .faq-media img{ width:100%; min-width:0; }



  .title-hero{
    font-size: 25px;
    font-weight: 900;
    letter-spacing: 0.9px;
    margin-bottom: 0;
    line-height:1.1;
  }
  h2.title-hero{
    margin-top: 5px;
  }
  .option-hero-line{
    gap: 4px;
    font-size: 11px;
  }

  .option-hero li{
    font-size: 14px;
    line-height: 1.5;
  }

.option-hero-line span:not(:last-child)::after
{
  margin-left: 4px;
}
  .btn-reserve-hero, .btn-call-hero{
    gap: 5px;
    font-size: 14px;
  }

  .bagde-green-hero{
    display: none;
  }


 .rts-banner-ten-area.banner-bg_12 {
    background: none; /* on enlève du parent */
  }

  .banner-inner-content-12 {
    background: linear-gradient(rgba(0,0,0,.5), rgba(0,0,0,.5)), url(../images/13.webp);
    background-size: cover;
    background-position: center;
    padding: 40px 20px; /* padding pour respirer */
    color: #fff;
  }

  .col-form-hero {
    margin-top: 20px;
    padding: 0 20px;
  }

  .st-hero{
    padding: 0px;
  }
  .st-hero .container{
    padding: 0;
  }

  .reservation-express-form label{
    font-weight: 500;
    font-size: 12px;
  }
  .reservation-express-form input, .reservation-express-form select
  {
    padding: 5px 10px;
  }

  .reservation-express-form .urgency legend {
        font-weight: 500;
            margin-bottom: 3px;
    font-size: 13px;
}

.reservation-express-form .urgency-btn{
  font-weight: 600;
  padding: 12px 5px;
}

.reservation-express-form .btn-book-hero{
  font-weight: 600;
}

.title-style-five .title-section{
  font-size: 25px;
      /* text-shadow: -3px 19px 0 rgba(140, 140, 140, .6); */
}

.section-engage .items{
  padding: 0 20px;
  margin-top: 0px!important;
}
.item-sengage{
  min-height:183px;
}

.assurance-left{
      justify-content: center;
}
.assurance-left img{
          max-width: 280px;
}

.section-service{
  padding: 0 0 50px;
}

.title-style-five.with-lines{ margin-bottom: -20px; }

.title-style-five.with-lines::before, .title-style-five.with-lines::after{
  top: calc(45%);
}

.service-card::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0; /* coller en bas */
  height: 100%; /* ne prend que 20% de la hauteur */
  background: linear-gradient(
    0deg,
    #e9600d 21%,
    rgba(233, 96, 13, 0) 100%
  );
  z-index: 1;
  pointer-events: none;
}

.section-reviews{
  padding: 0px 0 50px;
   margin-top: 80px;
}

.why-intro{
  font-size: 13px;
  line-height: 1.3;
}
.why-item p{
  font-size: 13px;
  line-height: 1.3;
}
.why-list{
  gap: 0;
}
.why-item .accent{
  font-weight: 600;
}

.section-reviews .title-reviews{
      flex-direction: column-reverse;
    align-items: center;
            font-size: 30px;
        line-height: 1;
}
.section-reviews .title-reviews svg{
  margin:0!important;
 margin-bottom: 15px !important;

}

.badge-google{
     position: absolute;
    width: 150px;
    bottom: -40px;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 40px;
}
.section-reviews .item {
  padding: 20px;
}
.title-faq{
  font-size: 25px;
}
.title-second-faq{
  font-size: 25px;
}

.faq-wrapper-inner-page .accordion-item{
  margin:0;
}
.section-faq .item{
  font-size: 18px;
  font-weight: 700;
}
.section-faq .accordion-body{
        font-size: 14px;
        line-height: 1.4;
        font-weight: 300;
}
.faq-wrapper-inner-page .accordion-item .accordion-header button {
        padding: 24px 15px 15px;
                font-size: 16px;
}

.btn-faq-contact{
          flex-direction: column;
}

.site-logo{
   position: absolute;
    top: 50%;
    left: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    /* display: none; */
}
   
  
}
