.elementor-1739 .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-1739 .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-1739 .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-1739 .elementor-element.elementor-element-6cbe2a4{--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-1739 .elementor-element.elementor-element-2698e33{--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-1739 .elementor-element.elementor-element-064f5d1{--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-1739 .elementor-element.elementor-element-2e6d8a0{--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-1739 .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-1739 .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-1739 .elementor-element.elementor-element-76593e2{--display:flex;--margin-top:50px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-size:var( --e-global-typography-primary-font-size );font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-1739 .elementor-element.elementor-element-598bf34 .elementor-heading-title{font-family:"Lato", Sans-serif;font-size:25px;font-weight:500;color:var( --e-global-color-text );}.elementor-1739 .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-1739 .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;}.elementor-1739 .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;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}@media(max-width:1024px){.elementor-widget-heading .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );}}@media(max-width:767px){.elementor-widget-heading .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );}}/* 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 1rem;
  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 */
  }
}/* 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-86e94a6 */: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;       
}

.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-77c9b4d */: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-3a34f93 */: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);
  box-shadow:0 4px 12px rgba(0,0,0,.08);
}

/* ===== 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-6efddac */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

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

/* ===== Titres ===== */
.fleet h2{
  font-size:1.8rem;
  margin-bottom:2rem;
  text-align:center;
  color:#222;
}
.fleet p.intro{
  max-width:700px;
  margin:0 auto 3rem;
  font-size:1rem;
  color:#444;
  text-align:center;
}

/* ===== Grille de cartes ===== */
.fleet-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:1.5rem;
}

/* --- Carte véhicule --- */
.fleet-card{
  background:var(--cd-white);
  border-radius:var(--cd-radius);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  box-shadow:0 4px 10px rgba(0,0,0,.05);
  transition:transform .2s,box-shadow .2s;
  text-decoration:none;
  color:#111;
}
.fleet-card:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 16px rgba(0,0,0,.08);
}
.fleet-card img{
  width:100%;
  aspect-ratio:5/3;
  object-fit:cover;
}
.fleet-card-content{
  padding:1rem 1.25rem 1.5rem;
  display:flex;
  flex-direction:column;
  flex:1;
}
.fleet-card h3{
  font-size:1.125rem;
  margin:0 0 .5rem;
  color:#222;
}
.fleet-card ul{
  margin:0 0 1rem;
  padding-left:1.25rem;
  list-style:square;
  font-size:.875rem;
  color:#555;
}
.fleet-card .cta{
  margin-top:auto;
  align-self:start;
  background:var(--cd-orange);
  color:var(--cd-white);
  padding:.65rem 1rem;
  border-radius:var(--cd-radius);
  font-weight:700;
  font-size:.875rem;
  transition:opacity .2s;
}
.fleet-card .cta:hover{opacity:.9;}

/* ===== Responsive ===== */
@media(max-width:576px){
  .fleet h2{font-size:1.6rem;}
  .fleet-grid{
  display:grid;
  grid-template-columns: repeat(1, 1fr);
  gap:1.5rem;
}}/* 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-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-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-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 */
/* Start custom CSS for html, class: .elementor-element-c0a46de */:root{
  --cd-blue:#009fe3;
  --cd-orange:#f95b33;
  --cd-white:#ffffff;
  --cd-gray:#f5f7fa;
  --cd-radius:6px;
}

/* ============ Wrapper ============ */
.guide{
  background:var(--cd-white);
  padding:0 2rem;
  font-size:1rem;
  line-height:1.6;
  color:#444;
}
.guide-container{
  max-width:900px;
  margin-inline:auto;
}

/* ============ Headings ============ */
.guide h2{
  font-size:1.8rem;
  margin:3rem 0 1.5rem;
  color:#222;
}
.guide h3{
  font-size:1.2rem;
  margin:1.75rem 0 .5rem;
  color:#222;
}

/* ============ Lists & Paragraphs ============ */
.guide ul{
  margin:.5rem 0 1rem 1.25rem;
  padding-left:0;
}
.guide li{margin-bottom:.35rem;}
.guide p{margin:.5rem 0 1rem;}

/* ============ Table ============ */
.guide table{
  width:100%;
  border-collapse:collapse;
  margin:1rem 0 2rem;
  font-size:.9rem;
}
.guide th,
.guide td{
  border:1px solid #d4d8dd;
  padding:.6rem .75rem;
  text-align:left;
}
.guide th{
  background:var(--cd-gray);
  color:#222;
  font-weight:600;
}

/* ============ Download badge ============ */
.download-btn{
  display:inline-block;
  margin:1rem 0 2rem;
  padding:.8rem 1.25rem;
  background:var(--cd-orange);
  color:var(--cd-white);
  font-weight:700;
  border-radius:var(--cd-radius);
  text-decoration:none;
}

/* ============ FAQ accordion ============ */
.faq-block details{
  background:var(--cd-gray);
  padding:1rem 1.25rem;
  border-radius:var(--cd-radius);
  margin-bottom:.75rem;
}
.faq-block summary{
  cursor:pointer;
  list-style:none;
  font-weight:600;
}
.faq-block summary::marker,
.faq-block summary::-webkit-details-marker{display:none;}
.faq-block summary::after{
  content:"+";
  float:right;
  color:var(--cd-blue);
  font-weight:700;
}
.faq-block details[open] summary::after{content:"−";}
.faq-block p{margin:1rem 0 .5rem;}

/* ===== Bouton calculateur ===== */
.calc-btn{
  display:inline-block;
  margin:1rem 0 2rem;
  padding:.8rem 1.25rem;
  background:var(--cd-orange);
  color:var(--cd-white);
  font-weight:700;
  border-radius:var(--cd-radius);
  text-decoration:none;
}
.calc-btn:hover{opacity:.9;}
  
@media(max-width:576px){
  .guide h2{font-size:1.6rem;}
  .guide h3{font-size:1.05rem;}
}/* End custom CSS */