/* ===== CASATRANSFER — style.css v3 (Mobile-First, Accessible, Optimized) =====
   Keywords: taxi aeroport casablanca | transfert aeroport casablanca | navette aeroport casablanca
   ================================================================================ */

/* ===== BASE — mobile first ===== */
.fade-in,.fade-up{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.fade-in.visible,.fade-up.visible{opacity:1;transform:none}

/* Animations */
@keyframes dash{to{stroke-dashoffset:-48}}
@keyframes menuSlideIn{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}

/* Focus visible — accessibility */
:focus-visible{outline:3px solid var(--primary);outline-offset:3px;border-radius:4px}
:focus:not(:focus-visible){outline:none}

/* ===== COOKIE BANNER ===== */
.cookie-banner{
  position:fixed;bottom:12px;left:12px;right:12px;z-index:9999;
  background:var(--secondary);color:#fff;border-radius:14px;
  padding:14px 18px;display:flex;align-items:center;gap:14px;
  box-shadow:0 8px 32px rgba(0,0,0,.35);flex-wrap:wrap;
  max-width:660px;margin:0 auto;
}
.cookie-banner a{color:var(--primary);text-decoration:underline}
.cookie-btn{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:9px 20px;cursor:pointer;font-weight:600;font-size:14px;white-space:nowrap;min-height:44px;min-width:44px}
.cookie-btn:hover{background:var(--primary-dark)}
.cookie-banner.hidden{display:none}


/* ===== NAVBAR ===== */
.nav-menu{display:none}/* hidden on mobile — fullscreen menu takes over */
.nav-actions .btn-cta--nav{display:none}/* hidden on mobile */
.hamburger{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:10px;min-width:44px;min-height:44px;justify-content:center;align-items:center;border-radius:8px;transition:background var(--transition)}
.hamburger:hover{background:var(--bg-tint)}
.bar{display:block;width:22px;height:2px;background:var(--text-dark);border-radius:2px;transition:transform .3s,opacity .3s,width .3s}
.hamburger.active .bar:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active .bar:nth-child(2){opacity:0;width:0}
.hamburger.active .bar:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.lang-toggle{display:flex;align-items:center;gap:5px;border:1.5px solid var(--border);border-radius:8px;padding:6px 10px;font-size:13px;font-weight:600;cursor:pointer;background:transparent;color:var(--text-dark);transition:border-color var(--transition);min-height:44px}
.lang-toggle:hover{border-color:var(--primary)}

/* ===== FULLSCREEN MOBILE MENU ===== */
.mobile-menu{
  position:fixed;inset:0;z-index:1100;
  background:linear-gradient(160deg,var(--secondary) 0%,#0d2034 100%);
  display:flex;flex-direction:column;padding:28px 24px 36px;
  transform:translateX(100%);transition:transform .38s cubic-bezier(.25,.46,.45,.94);
  overflow-y:auto;
}
.mobile-menu.is-open{
  transform:none;
  animation:menuSlideIn .38s cubic-bezier(.25,.46,.45,.94) both;
}
.mobile-menu__backdrop{
  position:fixed;inset:0;z-index:1090;background:rgba(0,0,0,.55);
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.mobile-menu__backdrop.is-visible{opacity:1;pointer-events:auto}
.mobile-menu__close{
  align-self:flex-end;background:rgba(255,255,255,.1);border:none;
  color:#fff;border-radius:50%;width:46px;height:46px;display:flex;
  align-items:center;justify-content:center;cursor:pointer;margin-bottom:8px;
  transition:background var(--transition);flex-shrink:0;
}
.mobile-menu__close:hover{background:rgba(255,255,255,.2)}
.mobile-menu__brand{
  display:flex;align-items:center;gap:10px;font-family:'Poppins',sans-serif;
  font-weight:700;font-size:22px;color:var(--primary);margin-bottom:32px;
}
.mobile-menu__list{display:flex;flex-direction:column;gap:4px;flex:1}
.mobile-menu__link{
  display:flex;align-items:center;gap:14px;
  color:rgba(255,255,255,.82);font-size:17px;font-weight:500;
  padding:13px 14px;border-radius:12px;
  transition:background var(--transition),color var(--transition);
  font-family:'Poppins',sans-serif;
}
.mobile-menu__link svg{flex-shrink:0;opacity:.7}
.mobile-menu__link:hover,.mobile-menu__link:focus-visible{
  background:rgba(255,255,255,.08);color:#fff;
}
.mobile-menu__cta{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.mobile-menu__book{
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--accent);color:#fff;font-family:'Poppins',sans-serif;
  font-weight:700;font-size:17px;padding:16px 24px;border-radius:50px;
  transition:background var(--transition),transform var(--transition);
  box-shadow:0 6px 24px rgba(255,107,53,.4);min-height:56px;
}
.mobile-menu__book:hover{background:var(--accent-hover);transform:translateY(-2px)}
.mobile-menu__whatsapp{
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.25);
  color:#fff;font-weight:600;font-size:15px;padding:13px 24px;
  border-radius:50px;transition:background var(--transition);min-height:50px;
}
.mobile-menu__whatsapp:hover{background:rgba(255,255,255,.18)}
.mobile-menu__lang{
  margin-top:20px;background:none;border:1.5px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.6);padding:10px;border-radius:8px;cursor:pointer;
  font-size:14px;text-align:center;transition:border-color var(--transition);
}
.mobile-menu__lang:hover{border-color:var(--primary);color:#fff}

/* ===== HERO — mobile first ===== */
.hero-content{
  position:relative;z-index:1;width:100%;
  padding:40px 10px 60px;
  display:flex;flex-direction:column;gap:32px;
  align-items:center;
}
.hero-text{text-align:center}
.hero-badge{display:inline-block;background:var(--primary);color:#fff;font-size:12px;font-weight:700;padding:5px 16px;border-radius:50px;margin-bottom:16px;letter-spacing:.03em}
.hero-text h1{color:#fff;margin-bottom:14px}
.hero-accent{color:var(--primary)}
.hero-sub{color:rgba(255,255,255,.88);font-size:16px;line-height:1.75;margin-bottom:20px}
.hero-trust-row{display:flex;flex-wrap:wrap;gap:8px 16px;justify-content:center;padding:0;list-style:none;margin:0}
.hero-trust-row li{color:rgba(255,255,255,.9);font-size:13px;font-weight:500;display:flex;align-items:center;gap:5px}
/* Mobile CTA buttons in hero text area */
.hero-mobile-cta{display:flex;flex-direction:column;gap:10px;margin-top:24px;width:100%}
.btn-hero-cta{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;font-family:'Poppins',sans-serif;font-weight:700;font-size:17px;padding:17px 28px;border-radius:50px;transition:background var(--transition),transform var(--transition);box-shadow:0 6px 24px rgba(255,107,53,.4);min-height:56px}
.btn-hero-cta:hover{background:var(--accent-hover);transform:translateY(-2px)}
.btn-hero-wa{display:flex;align-items:center;justify-content:center;gap:8px;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.35);color:#fff;font-weight:600;font-size:15px;padding:14px 24px;border-radius:50px;transition:background var(--transition);min-height:50px}
.btn-hero-wa:hover{background:rgba(255,255,255,.25)}
/* Booking card */
.booking-card{background:#fff;border-radius:var(--radius-card);box-shadow:0 20px 60px rgba(0,0,0,.2);padding:24px 20px;width:100%;max-width:400px}
.booking-title{font-size:18px;font-weight:700;margin-bottom:18px;color:var(--text-dark)}
.booking-form-inner{min-height:60px}
.trust-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:-22px;padding-top:8px;border-top:1px solid var(--border);list-style:none;padding-left:0}
.trust-badges li{font-size:12px;color:var(--text-body);font-weight:500;display:flex;align-items:center;gap:5px}

/* ===== STATS BAND ===== */
.stats-band{background:var(--primary);padding:44px 0}
.stats-container{display:grid;grid-template-columns:repeat(2,1fr);gap:28px 16px}
.stat-item{text-align:center;color:#fff}
.stat-num{display:block;font-family:'Poppins',sans-serif;font-size:clamp(28px,8vw,48px);font-weight:700;line-height:1;margin-bottom:6px}
.stat-label{font-size:13px;opacity:.88;font-weight:500}

/* ===== SECTION HEADERS ===== */
.section-header{text-align:center;margin-bottom:44px}
.section-tag{display:inline-block;background:var(--bg-tint);color:var(--primary);font-size:12px;font-weight:600;padding:5px 16px;border-radius:50px;margin-bottom:12px;border:1px solid rgba(0,184,169,.2);letter-spacing:.04em}
.section-header h2{margin-bottom:12px}
.section-header p{color:var(--text-body);font-size:16px;max-width:560px;margin:0 auto}

/* ===== SERVICES ===== */
.services{background:var(--bg-light)}
.services-grid{display:grid;grid-template-columns:1fr;gap:22px}
.service-card{background:#fff;border-radius:var(--radius-card);box-shadow:var(--shadow-card);overflow:hidden;transition:transform var(--transition),box-shadow var(--transition)}
.service-card:hover,.service-card:focus-within{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.card-img-wrap{position:relative;overflow:hidden;height:200px}
.card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-card:hover .card-img-wrap img{transform:scale(1.04)}
.card-badge{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:50px}
.card-body{padding:22px 20px}
.card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.card-body h3{margin-bottom:9px}
.card-body>p{color:var(--text-body);font-size:14px;margin-bottom:14px;line-height:1.65}
.card-features{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;list-style:none;padding:0}
.card-features li{font-size:12px;background:var(--bg-tint);color:var(--primary);padding:4px 11px;border-radius:50px;font-weight:500}
.btn-outline{display:inline-flex;align-items:center;border:2px solid var(--primary);color:var(--primary);padding:10px 22px;border-radius:50px;font-weight:600;font-size:14px;transition:all var(--transition);min-height:44px}
.btn-outline:hover,.btn-outline:focus-visible{background:var(--primary);color:#fff}

/* ===== HOW IT WORKS ===== */
.how-it-works{background:#fff}
.steps-wrapper{position:relative}
.steps-line{position:absolute;top:60px;left:0;width:100%;display:none}
.steps-dash{animation:dash 3s linear infinite}
.steps-grid{display:grid;grid-template-columns:1fr;gap:0;list-style:none;padding:0;counter-reset:step}
.step{text-align:center;padding:24px 16px;position:relative}
.step::after{content:'';display:block;width:2px;height:32px;background:linear-gradient(to bottom,var(--primary),transparent);margin:0 auto}
.step:last-child::after{display:none}
.step-icon{width:88px;height:88px;border-radius:50%;background:var(--bg-tint);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;border:2px solid rgba(0,184,169,.2)}
.step-num{font-family:'Poppins',sans-serif;font-size:40px;font-weight:700;color:rgba(0,184,169,.15);line-height:1;margin-bottom:10px}
.step h3{margin-bottom:7px}
.step p{color:var(--text-body);font-size:14px}

/* ===== PRICING ===== */
.pricing{background:var(--bg-light)}
.booking-form-widget{background:#fff;border-radius:var(--radius-card);padding:28px 20px;box-shadow:var(--shadow-card);min-height:80px}

/* ===== TESTIMONIALS ===== */
.testimonials{background:var(--bg-tint)}
.rating-global{display:flex;align-items:center;gap:10px;justify-content:center;margin-top:10px;flex-wrap:wrap}
.stars-big{color:#FFB800;font-size:20px;letter-spacing:2px}
.carousel-outer{position:relative}
.carousel-viewport{overflow:hidden;width:100%}
.carousel-track{display:flex;gap:0;transition:transform .5s cubic-bezier(.25,.46,.45,.94);will-change:transform}
.testi-card{flex:0 0 100%;min-width:0;background:#fff;border-radius:var(--radius-card);padding:22px 18px;box-shadow:var(--shadow-card)}
.testi-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:nowrap}
.testi-meta{flex:1;min-width:0;overflow:hidden}
.testi-meta strong{display:block;font-size:14px;font-weight:600;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.testi-meta span{font-size:12px;color:var(--text-body)}
.avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}
.stars{color:#FFB800;font-size:13px;letter-spacing:1px;white-space:nowrap;flex-shrink:0}
.testi-card blockquote{margin:0}
.testi-card p{font-size:13px;color:var(--text-body);line-height:1.7;font-style:italic}
.carousel-controls{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:24px}
.carousel-btn{width:44px;height:44px;border-radius:50%;border:2px solid var(--primary);background:transparent;color:var(--primary);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}
.carousel-btn:hover,.carousel-btn:focus-visible{background:var(--primary);color:#fff}
.carousel-dots{display:flex;gap:7px;align-items:center}
.dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:background var(--transition),transform var(--transition);border:none;padding:0;min-width:8px;min-height:8px}
.dot.active{background:var(--primary);transform:scale(1.4)}

/* ===== MAP ===== */
.map-section{background:#fff}
.map-layout{display:grid;grid-template-columns:1fr;gap:28px}
#leafletMap{height:300px!important}
.coverage-list h3{margin-bottom:16px}
.coverage-list ul{margin-bottom:20px}
.coverage-list li{padding:9px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text-body);display:flex;align-items:center;gap:8px}
.btn-cta-solid{display:inline-flex;align-items:center;background:var(--primary);color:#fff;padding:13px 24px;border-radius:50px;font-weight:600;font-size:14px;transition:background var(--transition);min-height:48px}
.btn-cta-solid:hover{background:var(--primary-dark)}

/* ===== FAQ ===== */
.faq-section{background:var(--bg-light)}
.faq-container{max-width:760px}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{background:#fff;border-radius:14px;box-shadow:var(--shadow-card);overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;padding:17px 20px;background:none;border:none;cursor:pointer;font-size:15px;font-weight:600;color:var(--text-dark);text-align:left;font-family:'Poppins',sans-serif;gap:12px;min-height:56px;line-height:1.4}
.faq-q:hover{color:var(--primary)}
.faq-q:focus-visible{outline:3px solid var(--primary);outline-offset:-3px}
.faq-arrow{flex-shrink:0;color:var(--primary);transition:transform var(--transition)}
.faq-q[aria-expanded="true"] .faq-arrow{transform:rotate(90deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a.open{max-height:350px}
.faq-a p{padding:0 20px 18px;color:var(--text-body);font-size:14px;line-height:1.8}

/* ===== CTA ===== */
.cta-section{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);padding:80px 0;text-align:center;position:relative;overflow:hidden}
.cta-svg-bg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.cta-content{position:relative;z-index:1}
.cta-content h2{color:#fff;margin-bottom:12px}
.cta-content p{color:rgba(255,255,255,.85);font-size:16px;margin-bottom:32px;max-width:520px;margin-left:auto;margin-right:auto}
.cta-actions{display:flex;flex-direction:column;gap:12px;align-items:center}
.btn-cta-white{background:#fff;color:var(--primary);padding:15px 32px;border-radius:50px;font-weight:700;font-size:16px;font-family:'Poppins',sans-serif;transition:all var(--transition);box-shadow:0 4px 20px rgba(0,0,0,.15);min-height:52px;display:inline-flex;align-items:center}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.2)}
.btn-cta-outline{border:2px solid rgba(255,255,255,.65);color:#fff;padding:13px 28px;border-radius:50px;font-weight:600;font-size:15px;transition:all var(--transition);display:inline-flex;align-items:center;gap:6px;min-height:50px}
.btn-cta-outline:hover{border-color:#fff;background:rgba(255,255,255,.12)}
.btn-cta{background:var(--accent);color:#fff;font-weight:700;font-size:14px;padding:10px 20px;border-radius:50px;transition:background var(--transition),transform var(--transition);white-space:nowrap;display:inline-flex;align-items:center;min-height:44px}
.btn-cta:hover{background:var(--accent-hover);transform:translateY(-1px)}

/* ===== FOOTER ===== */
.footer{background:var(--secondary);color:rgba(255,255,255,.72);padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1fr;gap:32px;padding-bottom:44px}
.footer-logo{font-family:'Poppins',sans-serif;font-size:19px;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:7px;margin-bottom:12px}
.footer-col>p{font-size:13px;line-height:1.8;margin-bottom:18px}
.footer-col h4{font-family:'Poppins',sans-serif;color:#fff;font-size:14px;margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:9px}
.footer-col li a{font-size:13px;transition:color var(--transition)}
.footer-col li a:hover{color:var(--primary)}
.social-links{display:flex;gap:10px;margin-top:4px}
.social-links a{width:38px;height:38px;border-radius:8px;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);transition:all var(--transition)}
.social-links a:hover,.social-links a:focus-visible{color:var(--primary);border-color:var(--primary)}
.contact-list{display:flex;flex-direction:column;gap:0}
.contact-list li{font-size:13px;line-height:2.2;display:flex;align-items:center;gap:8px}
.contact-list a{color:rgba(255,255,255,.72);transition:color var(--transition)}
.contact-list a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:18px 20px;text-align:center;font-size:12px}
.footer-bottom a{color:var(--primary)}

/* Leaflet */
.leaflet-container{font-family:'Inter',sans-serif}
.leaflet-popup-content-wrapper{border-radius:12px;box-shadow:var(--shadow-card)}
.leaflet-popup-content{font-family:'Inter',sans-serif;font-size:14px}

.e8fb {
    background-color: #00B8A9 !important; 
}

._2f9b {
    width: 0px;
    height: 0px;
    left: 0;
    opacity: 0 !important;
}

.tp_powered_by  {
    display: none;
    opacity: 0 !important;
}

 .btn-choisir {
            display: block; margin: 40px auto; background: linear-gradient(45deg, #ff6b6b, #feca57);
            color: white; border: none; padding: 18px 40px; font-size: 20px; font-weight: 600;
            border-radius: 50px; cursor: pointer; box-shadow: 0 12px 35px rgba(255,107,107,0.4);
            transition: all 0.3s ease; position: relative; overflow: hidden;
        }

.btn-choisir:hover { transform: translateY(-4px); box-shadow: 0 18px 45px rgba(255,107,107,0.6); }
        .page-ville { 
            display: none; background: white; border-radius: 24px; padding: 40px; 
            box-shadow: 0 25px 60px rgba(0,0,0,0.2); margin-top: 20px;
        }
        .page-ville.active { display: block; animation: slideIn 0.5s ease; }
        .page-ville h1 { font-family: 'Poppins', sans-serif; font-size: 36px; margin-bottom: 20px; color: #333; }
        .page-ville p { font-family: 'Poppins', sans-serif; font-size: 18px; line-height: 1.6; color: #666; margin-bottom: 30px; }
        .btn-retour { 
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); color: white;
            border: none; padding: 14px 28px; border-radius: 12px; cursor: pointer; font-weight: 500;
            text-decoration: none; display: inline-block; transition: all 0.2s;
        }
        .btn-retour:hover { transform: scale(1.05); opacity: 0.9; }
        .modal {
            display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%;
            background-color: rgba(0,0,0,0.6); backdrop-filter: blur(8px); animation: fadeIn 0.3s ease;
        }
        .modal-content { 
            background: white; margin: 8% auto; padding: 0; border-radius: 24px; width: 92%;
            max-width: 520px; max-height: 85vh; overflow: hidden; box-shadow: 0 30px 70px rgba(0,0,0,0.3);
            animation: slideIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        }
        .modal-header { 
            background: #00B8A9;
            padding: 28px; text-align: center;
        }
        .modal-header h2 { font-family: 'Inter', sans-serif; font-size: 26px; margin: 0; color: #ffffff}
        .villes-grid {
            display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 10px;
            padding: 20px; max-height: 450px; overflow-y: auto;
        }
        .ville-link {
            display: block; background: #f8f9ff; border: 2px solid #e1e5ff; border-radius: 18px;
            padding: 12px 14px; text-align: center; text-decoration: none; transition: all 0.25s ease;
            'Poppins', sans-serif; font-weight: 500; font-size: 17px; color: #333; position: relative; overflow: hidden;
        }
        .ville-link::before {
            content: attr(data-emoji); font-size: 24px; display: block; margin-bottom: 8px;
        }
        .ville-link:hover { 
            background: #00B8A9; color: white;
            transform: translateY(-3px) scale(1.03); border-color: transparent; box-shadow: 0 10px 25px rgba(102,126,234,0.4);
        }
        .ville-link:hover::before { filter: brightness(1.2); }
        .modal-footer { padding: 0 28px 28px; text-align: right; }
        .btn-close {
            font-family: 'Inter', sans-serif; background: #00B8A9; color: white; border: none; padding: 14px 28px; border-radius: 14px; margin-top: 15px;
            cursor: pointer; font-weight: 500; transition: all 0.2s;
        }
        .btn-close:hover { background: #00B8A9; transform: scale(1.04); }
        @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
        @keyframes slideIn { 
            from { opacity: 0; transform: translateY(-40px) scale(0.95); } 
            to { opacity: 1; transform: translateY(0) scale(1); } 
        }
       


/* ===== TABLET — 600px+ ===== */
@media(min-width:600px){
  .stats-container{grid-template-columns:repeat(4,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .hero-mobile-cta{flex-direction:row;justify-content:center}
  .btn-hero-cta,.btn-hero-wa{flex:0 auto}
  .cta-actions{flex-direction:row;justify-content:center}
  .testi-card{flex:0 0 calc(50% - 12px)}
  .carousel-track{gap:24px}
  #leafletMap{height:380px!important}
}

/* ===== TABLET LANDSCAPE — 768px+ ===== */
@media(min-width:768px){
  .section-pad{padding:80px 0}
  .steps-grid{grid-template-columns:repeat(3,1fr)}
  .step::after{display:none}
  .steps-line{display:block}
  .map-layout{grid-template-columns:1fr 280px;gap:32px}
  #leafletMap{height:420px!important}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}

/* ===== DESKTOP — 1024px+ ===== */
@media(min-width:1024px){
  /* Show desktop nav, hide hamburger */
  .nav-menu{display:flex;gap:2px;margin-left:auto}
  .nav-actions .btn-cta--nav{display:inline-flex}
  .hamburger{display:none}
  .nav-link{padding:8px 13px;border-radius:8px;font-size:14px;font-weight:500;color:var(--text-body);transition:color var(--transition),background var(--transition)}
  .nav-link:hover{color:var(--primary);background:var(--bg-tint)}
  /* Hero 2-col grid */
  .hero-content{
    max-width:1200px;margin:0 auto;
    flex-direction:row;align-items:center;
    gap:56px;padding:60px 24px;justify-content:space-between;
  }
  .hero-text{text-align:left;flex:1}
  .hero-trust-row{justify-content:flex-start}
  .hero-mobile-cta{justify-content:flex-start}
  .booking-card{width:400px;flex-shrink:0;max-width:35%}
  /* Services 3-col */
  .services-grid{grid-template-columns:repeat(3,1fr)}
  /* Testimonials 3 visible */
  .testi-card{flex:0 0 calc(33.333% - 14px)}
  .carousel-track{gap:22px}
  /* Map wider */
  .map-layout{grid-template-columns:1fr 300px;gap:40px}
  /* Footer 4-col */
  .footer-grid{grid-template-columns:2fr 1fr 1fr 1.4fr;gap:44px}
  /* CTA actions row */
  .cta-actions{flex-direction:row;justify-content:center}
}

/* ===== LARGE DESKTOP ===== */
@media(min-width:1280px){
  .hero-content{padding:60px 20px}
  .booking-card{width:400px, max-width:35%}
}

/* ===== REDUCED MOTION — accessibility ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}
  .steps-dash{animation:none}
}

/* ===== HIGH CONTRAST — accessibility ===== */
@media(forced-colors:active){
  .btn-cta,.btn-hero-cta,.mobile-menu__book{forced-color-adjust:none}
}


 @media (max-width: 480px) {
            .villes-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; padding: 10px; }
            .page-ville { padding: 30px 20px; }
            .page-ville h1 { font-size: 28px; }			
			.modal-header { 
             padding: 28px; text-align: center; }
        }