.elementor-1746 .elementor-element.elementor-element-72a62df{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--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-1746 .elementor-element.elementor-element-cc163b8{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1746 .elementor-element.elementor-element-32a76c3{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-1746 .elementor-element.elementor-element-33c82cd{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:50px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1746 .elementor-element.elementor-element-6b75c9f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1746 .elementor-element.elementor-element-6d0cf93{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1746 .elementor-element.elementor-element-22bf75f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1746 .elementor-element.elementor-element-832686d{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1746 .elementor-element.elementor-element-0297706{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1746 .elementor-element.elementor-element-ae3d65f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1746 .elementor-element.elementor-element-931109e{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}/* Start custom CSS for html, class: .elementor-element-b2465a5 */:root{
  --cd-blue:#009fe3;     /* bleu City-Drop */
  --cd-orange:#f95b33;   /* CTA principal */
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

/* ===== Section ===== */
.hero{
  background:var(--cd-white);
  padding:4rem 2rem;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-container{
  width:100%;
  max-width:1200px;
  display:grid;
  grid-template-columns:1fr 1fr;   /* 50 / 50 desktop */
  gap:3rem;
}

/* ===== Colonne gauche ===== */
.hero-left h1{
  font-size:2rem;
  margin-bottom:.5rem;
  color:#222;
}
.hero-tagline{
  font-size:1.125rem;
  font-weight:600;
  margin-bottom:1.5rem;
  color:#555;
}

/* --- Widget simplifié --- */
.booking-widget{
  background:var(--cd-gray);
  padding:1.5rem;
  border-radius:var(--cd-radius);
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:1rem;
}
.booking-widget label{
  display:flex;
  flex-direction:column;
  font-size:.875rem;
  color:#333;
}
.booking-widget select{
  margin-top:.25rem;
  padding:.75rem .5rem;
  border:1px solid #d4d8dd;
  border-radius:var(--cd-radius);
  font-size:.875rem;
  background:var(--cd-white);
}
.booking-widget .cta-primary{
  align-self:end;
  padding:1rem;
  background:var(--cd-orange);
  border:none;
  color:var(--cd-white);
  font-size:1rem;
  font-weight:700;
  border-radius:var(--cd-radius);
  cursor:pointer;
  transition:opacity .2s;
}
.booking-widget .cta-primary:hover{
  opacity:.9;
}

/* --- Micro-trust --- */
.trust-bullets{
  display:flex;
  gap:1.5rem;
  font-size:.75rem;
  margin-top:.75rem;
  flex-wrap:wrap;
  color:#555;
  background: var(--cd-gray);   /* fond gris clair */
  padding: .75rem 1rem;
  border-radius: var(--cd-radius);
  justify-self: center;
  list-style: none;   /* supprime les puces par défaut */
  padding-left: 0;
}

/* ===== Colonne droite ===== */
.hero-right{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:1rem;
}
.vehicle-card{
  display:flex;
  align-items:stretch;          /* pour que span prenne la hauteur de l’image */
  text-decoration:none;
  color:#111;
  border-radius:var(--cd-radius);
  overflow:hidden;              /* rondes arêtes partagées */
  transition:transform .2s,box-shadow .2s;
}

.vehicle-card img{
  width:150px;
  height:auto;
  flex-shrink:0;
}

.vehicle-card span{
  display:flex;
  align-items:center;           /* centre verticalement le texte */
  padding:0 0.7rem;
  background:var(--cd-gray);    /* fond seulement autour du texte */
  font-weight:600;
  flex: 1;            /* le texte s’étire sur toute la place restante */
  white-space: normal;/* autorise le retour à la ligne si nécessaire */
}


.vehicle-card:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 12px rgba(0,0,0,.08);
}

/* ===== Responsive ===== */
@media(max-width:992px){
  .hero-container{grid-template-columns:1fr;}
  .hero-right{margin-top:2rem;}
}
@media(max-width:576px){
  .hero{padding:3rem 1rem;}
  .hero-left h1{font-size:1.6rem;}
}

@media(max-width:576px){

  /* (1) Fond bleu City-Drop derrière bloc moteur + catch-phrases */
  .booking-widget,
  .trust-bullets{
    background:var(--cd-blue);
  }

  /* (2) Moteur : 50 / 50 – sélecteur et bouton côte à côte */
  .booking-widget{
    grid-template-columns:1fr 1fr;   /* 2 colonnes égales */
    gap:.5rem;
    padding:1rem;                    /* respiration */
    border-radius:var(--cd-radius);
  }
  .booking-widget label,
  .booking-widget .cta-primary{
    width:100%;                      /* occupe toute la cellule */
  }
  .booking-widget select{
    font-size:.9rem;
    padding:.8rem .5rem;
  }
  .booking-widget .cta-primary{
    font-size:.9rem;
    padding:.8rem .5rem;
  }

  /* (3) Catch-phrases alignées sur une seule ligne */
  .trust-bullets{
    margin-top:.75rem;
    border-radius:7px;
    padding:.5rem;
    display:flex;
    justify-content:space-between;   /* répartition horizontale */
    gap:.5rem;
  }
  .trust-bullets li{
    flex:1 1 auto;                   /* même largeur, pas de saut de ligne */
    text-align:center;
    background:rgba(255,255,255,.25);/* pastille plus lisible sur fond bleu */
    color:var(--cd-white);
    padding:.4rem .3rem;
    border-radius:var(--cd-radius);
    font-size:.7rem;
    white-space:nowrap;              /* aucune coupure */
  }
}

/* ===== Bloc avis sous le H1 ===== */
.hero-reviews{
  display:flex;
  align-items:center;
  gap:.65rem;
  margin:.9rem 0 1.4rem;          /* espace au-dessus du widget */
}
.hero-reviews .stars{
  font-size:1.2rem;               /* taille des ★ */
  line-height:1;
  color:#f4b400;                  /* jaune “Google stars” */
}
.hero-reviews .stars span{
  margin-right:1px;               /* micro-espacement */
}
.hero-reviews .review-text{
  font-size:.9rem;
  color:#444;
}

/* ===== Vignettes véhicules agrandies ===== */
.hero-right{
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));  /* cartes + larges */
}
.vehicle-card img{
  width:180px;          /* image plus grande, ratio conservé */
  height:auto;
  object-fit:cover;     /* évite toute déformation */
}
.vehicle-card span{
  font-size:.9rem;      /* taille texte harmonisée */
}

/* ===== Mobile : ajuste la largeur image si besoin ===== */
@media(max-width:576px){
  .vehicle-card img{width:140px;}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-6b42783 */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

/* ===== Section ===== */
.reviews{
  background:var(--cd-gray);
  padding:4rem 2rem;
  position:relative;
  overflow:hidden;              /* masque les slides sortantes */
}
.reviews-container{
  max-width:1100px;
  margin-inline:auto;
  text-align:center;
}

/* ===== Titres ===== */
.reviews h2{
  font-size:1.8rem;
  margin-bottom:2rem;
  color:#222;
}

/* ===== Slider ===== */
.slider-wrapper{overflow:hidden;}
.slider-track{
  display:flex;
  gap:1rem;                     /* espace entre cartes */
  transition:transform .6s ease;
}
.review-card{
  flex:0 0 calc((100% - 2rem)/3);   /* 3 cartes, 2 gaps de 1rem */
  box-sizing:border-box;
  background:var(--cd-white);
  border-radius:var(--cd-radius);
  box-shadow:0 4px 10px rgba(0,0,0,.05);
  padding:1.75rem 1.5rem;
  text-align:left;
  position:relative;
}
.review-card::before{
  content:"“";
  position:absolute;
  top:-25px;
  left:18px;
  font-size:4rem;
  color:var(--cd-blue);
  opacity:.15;
  line-height:1;
}
.stars{
  color:#f4b400;
  font-size:1.1rem;
  margin-bottom:.5rem;
}
.review-card p{
  font-size:.95rem;
  line-height:1.55;
  color:#444;
  margin:0 0 1rem;
}
.review-author{
  font-weight:700;
  color:#222;
  font-size:.9rem;
}

/* ===== Flèches ===== */
.arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  background:var(--cd-blue);
  color:var(--cd-white);
  border:none;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:1.25rem;
  box-shadow:0 4px 10px rgba(0,0,0,.15);
  transition:opacity .2s;
}
.arrow:hover{background-color: #f95b33;}
.arrow:disabled{opacity:.3;cursor:default;}
.arrow-prev{left:1rem;}
.arrow-next{right:1rem;}

/* ===== Responsive ===== */
@media(max-width:991px){                     /* tablette : 1 carte */
  .review-card{flex:0 0 100%;}
}
@media(max-width:576px){                     /* mobile : flèches off */
  .reviews h2{font-size:1.6rem;}
  .arrow{display:none;}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-5420b6e */.locations-section {
    padding: 0px 0;
    background-color: var(--color-background-white);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

.locations-section .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.locations-section .section-header {
    text-align: center;
    margin-bottom: 50px;
}

.locations-section .section-header h2 {
    font-size: 36px;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 10px;
}

.locations-section .section-header p {
    font-size: 18px;
    color: var(--color-text-light);
    max-width: 700px;
    margin: 0 auto;
}

/* --- Contenu principal (carte + liste) --- */
.locations-content {
    display: flex;
    gap: 40px;
    align-items: flex-start;
}

/* --- Colonne de la carte --- */
.locations-map {
    flex: 1;
    min-width: 0; /* Empêche le rétrécissement excessif dans un flex container */
    position: sticky; /* La carte reste visible au scroll */
    top: 100px; /* Espace depuis le haut de la page */
}

.locations-map img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    border: 1px solid var(--color-border);
}

/* --- Colonne de la liste --- */
.locations-list-wrapper {
    flex: 1;
    min-width: 0;
}

.location-search-bar {
    position: relative;
    margin-bottom: 20px;
}

.location-search-bar .search-icon {
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    color: #aaa;
}

.location-search-bar input {
    width: 100%;
    padding: 15px 15px 15px 50px;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    font-size: 16px;
    outline: none;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.location-search-bar input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.15);
}

/* Liste scrollable */
.locations-list {
    list-style: none;
    padding: 0;
    margin: 0;
    max-height: 500px; /* Hauteur max avant que le scroll n'apparaisse */
    overflow-y: auto;
    border: 1px solid var(--color-border);
    border-radius: 8px;
}

/* Élément de la liste */
.locations-list li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    text-decoration: none;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border);
    transition: background-color 0.2s ease;
}
.locations-list li:last-child a {
    border-bottom: none;
}
.locations-list li a:hover {
    background-color: #f8f9fa;
}

.location-info h3 {
    margin: 0 0 5px 0;
    font-size: 18px;
    font-weight: 600;
}
.location-info p {
    margin: 0;
    font-size: 14px;
    color: var(--color-text-light);
}

.location-status {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--color-text-light);
    flex-shrink: 0; /* Empêche la réduction du statut */
}
.status-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
}
.status-dot.available {
    background-color: var(--color-success);
}
.status-dot.limited {
    background-color: var(--color-warning);
}
.arrow-icon {
    width: 24px;
    height: 24px;
    color: #ccc;
    transition: transform 0.2s ease;
}
.locations-list li a:hover .arrow-icon {
    transform: translateX(3px);
    color: var(--color-primary);
}


/* ============================================ */
/* RESPONSIVE (pour tablettes et mobiles)     */
/* ============================================ */

@media (max-width: 992px) {
    .locations-content {
        flex-direction: column;
        gap: 40px;
    }
    .locations-map {
        position: static; /* On annule le sticky sur mobile */
        width: 100%;
    }
    .locations-list {
        max-height: none; /* On affiche toute la liste sur mobile */
    }
}

@media (max-width: 768px) {
    .locations-section {
        padding: 50px 0;
    }
    .locations-section .section-header h2 {
        font-size: 28px;
    }
    .locations-section .section-header p {
        font-size: 16px;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-c0a46de */:root {
    --color-primary: #009fe3;      /* Bleu pour les CTA et titres */
    --color-secondary: #f95b33;    /* Bleu plus foncé pour le hover */
    --color-text: #333;             /* Texte principal */
    --color-text-light: #666;       /* Texte secondaire */
    --color-background: #f8f9fa;    /* Fond de la section */
    --color-white: #ffffff;         /* Fond des cellules */
    --color-border: #e9ecef;        /* Bordures du tableau */
    --color-success: #28a745;       /* Vert pour les icônes "check" */
    --color-danger: #f95b33;       
}

/* --- Style général de la section --- */
.comparison-section {
    padding: 80px 0;
    background-color: var(--color-background);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

.comparison-section .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

.comparison-section .section-header {
    text-align: center;
    margin-bottom: 50px;
}

.comparison-section .section-header h2 {
    font-size: 36px;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 10px;
}

.comparison-section .section-header p {
    font-size: 18px;
    color: var(--color-text-light);
    max-width: 700px;
    margin: 0 auto;
}

/* --- Style du tableau de comparaison --- */
.comparison-table {
    border: 1px solid var(--color-border);
    border-radius: 8px;
    overflow: hidden;
    background-color: var(--color-border); /* Couleur des "gaps" */
    display: grid;
    grid-template-columns: 1fr 2fr 2fr; /* 3 colonnes */
}

/* --- Style des cellules --- */
.table-header > div,
.table-row > div {
    padding: 20px;
    background-color: var(--color-white);
    display: flex;
    align-items: center;
}

/* Entêtes */
.table-header {
    display: contents; /* Permet aux enfants d'être des cellules de la grille */
}
.header-item {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text);
    background-color: #f1f3f5 !important;
}
.header-item.citydrop {
    color: var(--color-primary);
}


/* Lignes */
.table-row {
     display: contents; /* Permet aux enfants d'être des cellules de la grille */
}

.row-criteria {
    font-weight: 600;
    color: var(--color-text);
}

.row-citydrop span,
.row-traditional span {
    font-size: 15px;
    line-height: 1.6;
    color: var(--color-text-light);
}
.row-citydrop span strong,
.row-traditional span strong {
    color: var(--color-text);
    font-weight: 600;
}

/* Icônes */
.icon {
    width: 24px;
    height: 24px;
    margin-right: 15px;
    flex-shrink: 0;
}
.icon-check {
    color: var(--color-success);
}
.icon-cross {
    color: var(--color-danger);
}

/* Bordure entre CityDrop et Traditionnel */
.row-citydrop {
    border-right: 1px solid var(--color-border);
}


/* --- Bouton CTA --- */
.comparison-cta {
    text-align: center;
    margin-top: 50px;
}

.cta-button {
    display: inline-block;
    padding: 15px 35px;
    background-color: var(--color-primary);
    color: var(--color-white);
    font-size: 18px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 5px;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.cta-button:hover {
    background-color: var(--color-secondary);
    color:white;
    transform: translateY(-2px);
}

/* ============================================ */
/* RESPONSIVE (pour les mobiles)              */
/* ============================================ */

@media (max-width: 768px) {
    .comparison-section {
        padding: 50px 0;
    }
    .comparison-section .section-header h2 {
        font-size: 28px;
    }

    /* On cache les entêtes du tableau sur mobile */
    .table-header {
        display: none;
    }

    /* On passe la grille en une seule colonne */
    .comparison-table {
        grid-template-columns: 1fr;
        border: none;
        border-radius: 0;
    }
    
    .table-row > div {
        padding: 15px;
        border-bottom: 1px solid var(--color-border);
    }
    .row-citydrop, .row-traditional {
        align-items: flex-start; /* Aligne les icônes en haut */
    }

    .row-criteria {
        background-color: #f1f3f5;
        font-size: 16px;
        justify-content: center;
        border-top: 5px solid var(--color-background);
    }
    .table-row:first-child .row-criteria {
         border-top: none;
    }

    .row-citydrop {
        border-right: none;
    }
    
    /* On ajoute des pseudo-éléments pour indiquer "CityDrop" et "Traditionnel" */
    .row-citydrop::before,
    .row-traditional::before {
        content: "City-Drop";
        font-weight: 600;
        display: block;
        margin-bottom: 8px;
        color: var(--color-primary);
        font-size: 14px;
        width: 100%;
    }
    .row-traditional::before {
        content: "Location Traditionnelle";
        color: var(--color-text);
    }

    /* Pour ré-aligner le contenu sous les labels */
    .row-citydrop, .row-traditional {
        flex-direction: column;
        align-items: flex-start;
    }
    .row-citydrop > div, .row-traditional > div {
        display: flex;
        align-items: flex-start;
    }
    .icon {
         margin-top: 2px;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-574bc13 */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

/* --- Style général de la section --- */
.specs-section {
    padding: 80px 0;
    
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

.specs-section .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

.specs-section .section-header {
    text-align: center;
    margin-bottom: 40px;
}

.specs-section .section-header h2 {
    font-size: 36px;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 10px;
}

.specs-section .section-header p {
    font-size: 18px;
    color: var(--color-text-light);
    max-width: 700px;
    margin: 0 auto;
}

/* --- Barre de navigation des onglets --- */
.tabs-wrapper {
    display: flex;
    justify-content: center;
    margin-bottom: 40px;
    border-bottom: 1px solid var(--color-border);
}

.specs-tabs {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: 10px;
}

.specs-tabs button {
    font-family: inherit;
    font-size: 16px;
    font-weight: 600;
    padding: 15px 20px;
    border: none;
    background-color: transparent;
    cursor: pointer;
    color: var(--color-text-light);
    border-bottom: 3px solid transparent;
    margin-bottom: -1px; /* Pour que la bordure se superpose à celle du wrapper */
    transition: color 0.3s ease, border-color 0.3s ease;
}

.specs-tabs button:hover {
    color: var(--color-primary);
}

.specs-tabs button[aria-selected="true"] {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

/* --- Panneaux de contenu --- */
.tab-panel {
    display: none; /* Caché par défaut */
    animation: fadeIn 0.5s ease-in-out;
}

.tab-panel.is-active {
    display: block; /* Visible quand actif */
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.panel-layout {
    display: grid;
    grid-template-columns: 400px 1fr;
    gap: 50px;
    align-items: center;
}

.panel-image img {
    width: 100%;
    height: auto;
    border-radius: 8px;
    background-color: var(--color-background-alt);
}

.panel-details h3 {
    font-size: 28px;
    font-weight: 600;
    color: var(--color-text);
    margin: 0 0 25px 0;
}

/* Liste des specs */
.specs-list {
    margin: 0 0 30px 0;
}
.specs-list div {
    display: flex;
    justify-content: space-between;
    padding: 12px 0;
    border-bottom: 1px solid #f0f0f0;
}
.specs-list dt { /* La propriété (ex: Charge Utile) */
    font-size: 15px;
    color: var(--color-text-light);
}
.specs-list dd { /* La valeur (ex: 600 kg) */
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text);
    margin: 0;
}

.panel-details h4 {
    font-size: 16px;
    font-weight: 600;
    margin: 0 0 10px 0;
}
.panel-details ul {
    list-style: '✓  ';
    padding-left: 20px;
    margin: 0 0 35px 0;
}
.panel-details ul li {
    font-size: 15px;
    color: var(--color-text-light);
    margin-bottom: 8px;
}

.cta-button {
    display: inline-block;
    padding: 12px 28px;
    background-color: var(--color-primary);
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 5px;
    transition: background-color 0.3s ease;
}
.cta-button:hover {
    background-color: var(--color-secondary);
}

/* ============================================ */
/* RESPONSIVE                                 */
/* ============================================ */

@media (max-width: 992px) {
    .panel-layout {
        grid-template-columns: 1fr; /* Passe en une seule colonne */
        gap: 30px;
        text-align: center;
    }
    .panel-image {
        max-width: 450px;
        margin: 0 auto;
    }
    .panel-details h3 {
        font-size: 24px;
    }
    .specs-list div {
        flex-direction: column;
        align-items: center;
        gap: 5px;
    }
     .panel-details ul {
        display: inline-block;
        text-align: left;
    }
}

@media (max-width: 768px) {
    .specs-section { padding: 50px 0; }
    .specs-section .section-header h2 { font-size: 28px; }
    .specs-section .section-header p { font-size: 16px; }

    .tabs-wrapper {
        overflow-x: auto; /* Permet de scroller les onglets horizontalement */
        justify-content: flex-start;
    }
     .specs-tabs button {
        padding: 12px 15px;
        font-size: 15px;
        white-space: nowrap;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-7eed785 */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

/* ===== Section ===== */
.booking-process{
  background:var(--cd-gray);
  padding:4rem 2rem;
}
.booking-container{
  max-width:1200px;
  margin-inline:auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:center;
}

/* ===== Colonne gauche : image ===== */
.booking-image img{
  width:40%;
  justify-self: center;
  display:block;       /* retire l’espace inline */
  margin:0 auto;
  height:auto;
  border-radius:var(--cd-radius);
  box-shadow:0 4px 12px rgba(0,0,0,.08);
}

/* ===== Colonne droite : étapes ===== */
.booking-steps h2{
  font-size:1.8rem;
  margin-bottom:1.25rem;
  color:#222;
}
.booking-steps p{
  font-size:1rem;
  line-height:1.6;
  margin-bottom:2rem;
  color:#444;
}

/* --- Timeline --- */
.timeline{
  position:relative;
  margin-left:1.5rem;          /* espace pour la ligne verticale */
}
.timeline::before{
  content:"";
  position:absolute;
  left:-.75rem;
  top:0;
  width:3px;
  height:100%;
  background:var(--cd-blue);
}
.step{
  position:relative;
  padding:0 0 1.75rem 1rem;
}
.step:last-child{padding-bottom:0;}
.step::before{
  content:"";
  position:absolute;
  left:-1.05rem;
  top:.2rem;
  width:.9rem;
  height:.9rem;
  border:3px solid var(--cd-blue);
  background:var(--cd-white);
  border-radius:50%;
}
.step h3{
  font-size:1.125rem;
  margin:0 0 .25rem;
  color:#222;
}
.step p{
  margin:0;
  font-size:.9rem;
  color:#555;
}

/* --- CTA --- */
.booking-cta{
  margin-top:2rem;
  display:inline-block;
  padding:1rem 1.5rem;
  background:var(--cd-orange);
  color:var(--cd-white);
  font-weight:700;
  border-radius:var(--cd-radius);
  text-decoration:none;
  transition:opacity .2s;
}
.booking-cta:hover{opacity:.9;}

/* ===== Responsive ===== */
@media(max-width:992px){
  .booking-container{grid-template-columns:1fr;}
  .booking-image{order:-1; margin-bottom:2rem;}
}
@media(max-width:576px){
  .booking-steps h2{font-size:1.6rem;}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-c89986b */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

/* ===== Section ===== */
.pickup{
  background:var(--cd-white);
  padding:4rem 2rem;
  scroll-margin-top:80px; /* ancre confortable */
}
.pickup-container{
  max-width:1200px;
  margin-inline:auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:start;
}

/* ===== Colonne gauche (texte + CTA) ===== */
.pickup-left h2{
  font-size:1.8rem;
  margin-bottom:1.25rem;
  color:#222;
}
.pickup-left p{
  font-size:1rem;
  line-height:1.6;
  margin-bottom:2rem;
  color:#444;
}
.pickup-left .cta{
  display:inline-block;
  padding:1rem 1.5rem;
  background:var(--cd-orange);
  color:var(--cd-white);
  font-weight:700;
  border-radius:var(--cd-radius);
  text-decoration:none;
  transition:opacity .2s;
}
.pickup-left .cta:hover{opacity:.9;}

/* ===== Colonne droite (cartes agences) ===== */
.pickup-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:1rem;
}
.agency-card{
  background:var(--cd-gray);
  border-radius:var(--cd-radius);
  padding:1.25rem 1rem;
  display:flex;
  flex-direction:column;
  gap:.5rem;
  box-shadow:0 4px 10px rgba(0,0,0,.05);
  transition:transform .2s,box-shadow .2s;
  text-decoration:none;
  color:#111;
}
.agency-card:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 14px rgba(0,0,0,.08);
}
.agency-card h3{
  font-size:1.125rem;
  margin:0;
  color:#222;
}
.agency-card p{
  margin:0;
  font-size:.9rem;
  color:#555;
}
.agency-card .tags{
  margin-top:auto;
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  font-size:.75rem;
}
.agency-card .tag{
  background:var(--cd-blue);
  color:var(--cd-white);
  padding:.25rem .5rem;
  border-radius:999px;
}

/* ===== Responsive ===== */
@media(max-width:992px){
  .pickup-container{grid-template-columns:1fr;}
}
@media(max-width:576px){
  .pickup-left h2{font-size:1.6rem;}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-ed917f8 */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

/* ===== Section ===== */
.tips{
  background:var(--cd-white);
  padding:4rem 2rem;
}
.tips-container{
  max-width:1200px;
  margin-inline:auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:center;
}

/* ===== Colonne gauche : tips cards ===== */
.tip-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.25rem;
}
.tip-card{
  background:var(--cd-gray);
  padding:1.25rem 1rem 1.25rem 4rem;
  border-radius:var(--cd-radius);
  position:relative;
  box-shadow:0 4px 10px rgba(0,0,0,.05);
}
.tip-card i{
  position:absolute;
  left:1rem;
  top:1.25rem;
  font-size:1.2rem;
  width:2rem;
  height:2rem;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--cd-blue);
  color:var(--cd-white);
  border-radius:50%;
}
.tip-card h3{
  margin:0 0 .25rem;
  font-size:1.125rem;
  color:#222;
}
.tip-card p{
  margin:0;
  font-size:.9rem;
  color:#555;
}

/* ===== Colonne droite : illustration ===== */
.tips-image{
  align-self: center;
  text-align:center;
  order:1;
}
.tips-image img{
  max-width:100%;
  height:auto;
  border-radius:var(--cd-radius);
  box-shadow:0 4px 12px rgba(0,0,0,.08);
}

/* ===== Responsive ===== */
@media(max-width:992px){
  .tips-container{grid-template-columns:1fr;}
  .tips-image{order:-1; margin-bottom:2rem;}
}
@media(max-width:576px){
  .tips-card h2{font-size:1.6rem;}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-6de9acf */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

.security-section {
    padding: 80px 0;
    background-color: var(--color-background);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

.security-section .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.security-section .section-header {
    text-align: center;
    margin-bottom: 60px;
}

.security-section .section-header h2 {
    font-size: 36px;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 10px;
}

.security-section .section-header p {
    font-size: 18px;
    color: var(--color-text-light);
    max-width: 700px;
    margin: 0 auto;
}

/* --- Grille des cartes --- */
.security-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

/* --- Style des cartes --- */
.security-card {
    background-color: var(--color-white);
    padding: 40px;
    border-radius: 12px;
    border: 1px solid var(--color-border);
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.security-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.08);
}

.security-card .card-icon {
    margin-bottom: 25px;
}

.security-card .card-icon svg {
    width: 50px;
    height: 50px;
    color: var(--color-primary);
}

.security-card h3 {
    font-size: 22px;
    font-weight: 600;
    color: var(--color-text);
    margin: 0 0 15px 0;
}

.security-card p {
    font-size: 16px;
    color: var(--color-text-light);
    line-height: 1.6;
    margin-bottom: 25px;
    min-height: 50px; /* Pour aligner les listes même si les paragraphes ont des longueurs différentes */
}

/* Style de la liste à puces */
.security-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
    text-align: left;
}

.security-card ul li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 15px;
    color: var(--color-text-light);
    line-height: 1.5;
}

.security-card ul li:not(:last-child) {
    margin-bottom: 12px;
}

.security-card .check-icon {
    width: 20px;
    height: 20px;
    color: var(--color-success);
    flex-shrink: 0;
    margin-top: 2px;
}

/* --- Lien en bas de section --- */
.section-footer-link {
    text-align: center;
    margin-top: 60px;
}

.section-footer-link a {
    color: var(--color-text-light);
    text-decoration: none;
    border-bottom: 1px solid #ccc;
    transition: color 0.3s ease, border-color 0.3s ease;
}

.section-footer-link a:hover {
    color: var(--color-primary);
    border-color: var(--color-primary);
}


/* ============================================ */
/* RESPONSIVE (pour tablettes et mobiles)     */
/* ============================================ */

@media (max-width: 992px) {
    .security-grid {
        grid-template-columns: 1fr; /* Passe à une seule colonne */
    }
    .security-card p {
        min-height: auto; /* Annule la hauteur minimum sur mobile */
    }
}

@media (max-width: 768px) {
    .security-section {
        padding: 50px 0;
    }
    .security-section .section-header h2 {
        font-size: 28px;
    }
    .security-section .section-header p {
        font-size: 16px;
    }
    .security-card {
        padding: 30px;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-087ba24 */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

/* ===== Section ===== */
.reason{
  background:var(--cd-white);
  padding:4rem 2rem;
}
.reason-container{
  max-width:1200px;
  margin-inline:auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:center;
}

/* ===== Colonne gauche : contenu ===== */
.reason-left h2{
  font-size:1.8rem;
  margin-bottom:1.25rem;
  color:#222;
}
.reason-left p{
  font-size:1rem;
  line-height:1.6;
  margin-bottom:1.5rem;
  color:#444;
}
/* --- Liste des bénéfices --- */
.benefits{
  display:grid;
  grid-template-columns:1fr;
  gap:1rem;
  margin-bottom:2rem;
}
.benefits article{
  display:flex;
  gap:1rem;
}
.benefits i{
  width:48px;
  height:48px;
  flex-shrink:0;
  border-radius:var(--cd-radius);
  background:var(--cd-blue);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--cd-white);
  font-size:1.25rem;
}
.benefits h3{
  font-size:1.125rem;
  margin:0 0 .25rem 0;
  color:#222;
}
.benefits p{
  margin:0;
  font-size:.9rem;
  color:#555;
}

/* --- CTA --- */
.reason-cta{
  display:inline-block;
  padding:1rem 1.5rem;
  background:var(--cd-orange);
  color:var(--cd-white);
  font-weight:700;
  border-radius:var(--cd-radius);
  text-decoration:none;
  transition:opacity .2s;
}
.reason-cta:hover{opacity:.9;}

/* ===== Colonne droite : image ===== */
.reason-right img{
  width:100%;
  height:auto;
  border-radius:var(--cd-radius);
  
}

/* ===== Responsive ===== */
@media(max-width:992px){
  .reason-container{grid-template-columns:1fr;}
  .reason-right{order:-1; margin-bottom:2rem;}
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-561285f */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

/* ===== Section ===== */
.faq{
  background:var(--cd-white);
  padding:4rem 2rem;
}
.faq-container{
  max-width:900px;
  margin-inline:auto;
}

/* ===== Titres ===== */
.faq h2{
  font-size:1.8rem;
  margin-bottom:2rem;
  text-align:center;
  color:#222;
}

/* ===== Accordion ===== */
.faq details{
  background:var(--cd-gray);
  border-radius:var(--cd-radius);
  margin-bottom:1rem;
  padding:1rem 1.25rem;
  position:relative;
  box-shadow:0 4px 10px rgba(0,0,0,.05);
}
.faq details[open]{box-shadow:0 6px 14px rgba(0,0,0,.08);}
.faq summary{
  list-style:none;           /* retire le triangle par défaut */
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:.75rem;
}
.faq summary::-webkit-details-marker{display:none;} /* Safari */
.faq summary::before{
  content:"+";
  font-weight:700;
  color:var(--cd-blue);
  font-size:1.25rem;
  width:1rem;
  transition:transform .2s;
}
.faq details[open] summary::before{
  content:"−";
  transform:rotate(0deg);
}
.faq summary h3{
  font-size:1.125rem;
  margin:0;
  color:#222;
}
.faq p{
  margin:1rem 0 .5rem 1.9rem;
  font-size:.9rem;
  color:#555;
}

/* ===== Responsive ===== */
@media(max-width:576px){
  .faq h2{font-size:1.6rem;}
}/* End custom CSS */