/* =========================================================
   ABDOUL AGADIR ELITE — Responsive Stylesheet
   ========================================================= */

/* ---------------------------------------------------------
   Large Desktop — 1280px+
--------------------------------------------------------- */
@media (min-width: 1280px) {
  .hero-content { gap: 4rem; }
  .hero-cards { gap: 1.25rem; }
  .hero-info-card { min-width: 240px; }
}

/* ---------------------------------------------------------
   Tablet Landscape — 1024px and below
--------------------------------------------------------- */
@media (max-width: 1024px) {
  :root { --container: 960px; }

  .section { padding-block: 4rem; }

  /* Header */
  .topbar-left span:first-child { display: none; }
  .main-navigation { display: none; }
  .mobile-menu-toggle { display: flex; }
  .header-cta span { display: none; }
  .header-cta { padding: .65rem .9rem; }
  .header-inner { height: 70px; }
  .custom-logo-link img, .custom-logo { height: 58px; }

  /* Hero */
  .hero-section { min-height: 80vh; }
  .hero-content { flex-direction: column; text-align: center; }
  .hero-features { grid-template-columns: 1fr 1fr; justify-items: center; }
  .hero-buttons { justify-content: center; }
  .hero-cards { flex-direction: row; justify-content: center; flex-wrap: wrap; }
  .hero-info-card { min-width: 180px; }

  /* Stats */
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }

  /* Excursions grid */
  .excursions-grid { grid-template-columns: repeat(2, 1fr); }
  .excursions-grid--3 { grid-template-columns: repeat(2, 1fr); }

  /* About */
  .about-grid { grid-template-columns: 1fr; gap: 3rem; }
  .about-image-wrap { max-width: 460px; margin-inline: auto; }

  /* Why us */
  .why-us-grid { grid-template-columns: repeat(2, 1fr); }

  /* Testimonials */
  .testimonials-grid { grid-template-columns: repeat(2, 1fr); }

  /* Archive / Blog */
  .archive-grid { grid-template-columns: 1fr; }
  .single-post-grid { grid-template-columns: 1fr; }
  .single-post-sidebar { order: -1; }

  /* Single excursion & Sejour Builder */
  .excursion-single-grid { grid-template-columns: 1fr; }
  .excursion-single-sidebar { order: -1; }
  .sticky-card { position: static; }
  .booking-card { max-width: 480px; }
  /* Sejour Builder: stack the 2-column layouts on tablet */
  .sejour-planner-grid  { grid-template-columns: 1fr !important; gap: 1.5rem !important; }
  .sejour-confirm-grid  { grid-template-columns: 1fr !important; gap: 1.5rem !important; }
  /* Show itinerary (right col) first on mobile */
  .sejour-itinerary  { order: 1; position: static !important; }
  .sejour-catalog    { order: 2; }
  /* Confirm step: summary first, form second */
  .sejour-summary-col { order: 1; }
  .sejour-form-col    { order: 2; }
  /* Catalog list: limit height on tablet */
  .sejour-catalog-list { max-height: 360px; }
  /* Stepper: compress on tablet */
  .sejour-step-label { font-size: .75rem; }
  .sejour-step-line  { width: 1.5rem; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}

/* ---------------------------------------------------------
   Tablet Portrait — 768px and below
--------------------------------------------------------- */
@media (max-width: 768px) {
  /* Top bar */
  .topbar-left { display: none; }
  .topbar-right { margin-inline: auto; }

  /* Header logo mobile */
  .header-inner { height: 64px; }
  .custom-logo-link img, .custom-logo { height: 52px; }

  /* Hero */
  .hero-section { min-height: 100vh; }
  .hero-title { font-size: 2rem; }
  .hero-features { grid-template-columns: 1fr; gap: .5rem; }
  .hero-buttons { flex-direction: column; align-items: center; }
  .hero-cards { display: none; }

  /* Section headers */
  .section-title { font-size: 1.75rem; }

  /* Stats */
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat-number { font-size: 2.2rem; }

  /* Excursions */
  .excursions-grid { grid-template-columns: 1fr; }
  .excursions-grid--3 { grid-template-columns: 1fr; }

  /* Why us */
  .why-us-grid { grid-template-columns: 1fr; }

  /* Testimonials */
  .testimonials-grid { grid-template-columns: 1fr; }

  /* Blog grid */
  .posts-grid { grid-template-columns: 1fr; }

  /* About */
  .about-badge-float { bottom: -1rem; right: 0; }

  /* Included grid */
  .excursion-included-grid { grid-template-columns: 1fr; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom-inner { flex-direction: column; text-align: center; }
  .footer-badges { justify-content: center; }

  /* CTA */
  .cta-features { gap: 1rem; }
  .cta-buttons { flex-direction: column; align-items: center; }
  .cta-feature { font-size: .82rem; }

  /* Page banner & Sejour Builder */
  .page-banner-title { font-size: 1.75rem; }
  .page-banner--excursion { min-height: 280px; }
  .sejour-dates-fields { grid-template-columns: 1fr; }
  .sejour-stepper-wrap .container { padding-inline: 0.5rem; }
  .sejour-step-label { display: none; }
  .sejour-step.active .sejour-step-label { display: inline-block; font-size: 0.75rem; }
  .sejour-step-line { width: 20px; margin: 0 0.5rem; }

  /* 404 */
  .error-404-inner { flex-direction: column; gap: 2rem; }
  .error-number { font-size: 5rem; }

  /* Post nav */
  .post-navigation { grid-template-columns: 1fr; }

  /* Filter bar */
  .filter-bar-inner { flex-direction: column; align-items: flex-start; }

  /* Blog grid */
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-card--featured { grid-template-columns: 1fr; }
  .blog-card--featured .blog-card-img-wrap { aspect-ratio: 16/7; }
}

/* ---------------------------------------------------------
   Mobile — 480px and below
--------------------------------------------------------- */
@media (max-width: 480px) {
  .container { padding-inline: 1rem; }

  .section { padding-block: 3rem; }

  .hero-section { min-height: 100svh; }
  .hero-content { padding-block: 6rem 3rem; }
  .hero-badge { font-size: .75rem; }
  .hero-title { font-size: 1.8rem; }
  .hero-subtitle { font-size: .95rem; }

  .btn-xl { padding: .9rem 1.5rem; font-size: .95rem; }
  .btn-lg { padding: .8rem 1.5rem; font-size: .92rem; }

  .stats-grid { grid-template-columns: 1fr 1fr; gap: 1rem; }
  .stat-number { font-size: 1.8rem; }
  .stat-icon { width: 44px; height: 44px; font-size: 1rem; }

  /* Blog grid */
  .blog-grid { grid-template-columns: 1fr; }
  .blog-card--featured { grid-template-columns: 1fr; }
  .blog-filter-bar { top: 0; }

  .excursion-card-footer { flex-direction: column; align-items: flex-start; gap: .75rem; }
  .excursion-card-actions { width: 100%; }
  .excursion-card-actions .btn { flex: 1; justify-content: center; }

  .about-actions { flex-direction: column; }

  .booking-card { padding: 1.25rem; }
  .sejour-dates-card, .sejour-catalog, .sejour-itinerary, .sejour-summary-card, .sejour-form-col { padding: 1.25rem; }

  .excursion-hero-meta { flex-direction: column; gap: .5rem; }

  .mobile-menu-inner { width: 100%; border-radius: 0; }

  .hero-scroll-hint { display: none; }
}

/* ---------------------------------------------------------
   CRO Build — Responsive
--------------------------------------------------------- */
@media (max-width: 1024px) {
  .trust-bar-inner { justify-content: center; }
  .trust-divider { display: none; }
  .sp-testimonials-grid { grid-template-columns: repeat(2,1fr); }
  .guarantee-grid { grid-template-columns: repeat(2,1fr); }
  .sp-footer { grid-template-columns: repeat(2,1fr); }
  .excursion-single-grid { grid-template-columns: 1fr; }
  .excursion-single-sidebar { position: static; }
  .excursions-grid--4 { grid-template-columns: repeat(2,1fr); }
  .booking-form-wrap { grid-template-columns: 1fr; gap: 2.5rem; }
  .rating-overview { flex-direction: column; align-items: flex-start; gap: 1.25rem; }
  .emotion-grid { grid-template-columns: 1fr; }
  .policy-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .trust-bar { display: none; }
  .sp-testimonials-grid { grid-template-columns: 1fr; }
  .guarantee-grid { grid-template-columns: 1fr 1fr; }
  .sp-footer { grid-template-columns: repeat(2,1fr); }
  .excursions-grid--4 { grid-template-columns: 1fr 1fr; }
  .sticky-cta-bar .sticky-cta-info strong { font-size: .85rem; }
  .sticky-cta-actions .btn { padding: .5rem .75rem; font-size: .82rem; }
  .media-bar-inner { flex-direction: column; align-items: center; text-align: center; gap: .85rem; }
  .media-bar-logos { justify-content: center; gap: 1rem; }
  .hero-trust-row { display: none; }
  .merci-card { padding: 2rem 1.25rem; }
  .booking-form-wrap { grid-template-columns: 1fr; }
  /* Toggles stack on narrow screens */
  .vsel-toggle,
  .bmodal-toggle { flex-direction: column; }
  .vsel-toggle-btn,
  .bmodal-toggle-btn { width: 100%; justify-content: flex-start; }
}
@media (max-width: 480px) {
  .guarantee-grid { grid-template-columns: 1fr; }
  .sp-footer { grid-template-columns: 1fr 1fr; gap: 1.2rem; }
  .sp-stat-num { font-size: 1.85rem; }
  .excursions-grid--4 { grid-template-columns: 1fr; }
  .sticky-cta-actions { flex-direction: column; gap: .4rem; }
  .rating-platforms { flex-direction: column; gap: 1rem; }
  .faq-question { font-size: .88rem; padding: 1rem; }
}

/* =========================================================
   MOBILE RESPONSIVE — Comprehensive Fixes
   ========================================================= */

/* ---------------------------------------------------------
   Header / Nav
--------------------------------------------------------- */
@media (max-width: 768px) {
  .mobile-menu-inner { padding: 1.5rem 1.25rem; }
}
@media (max-width: 480px) {
  .header-cta { padding: .45rem .65rem; font-size: .78rem; gap: .3rem; }
  .mobile-menu-inner { padding: 1rem; }
  .mobile-nav-item a { font-size: .95rem; padding: .65rem 0; }
}

/* ---------------------------------------------------------
   Hero
--------------------------------------------------------- */
@media (max-width: 480px) {
  .hero-title { font-size: 1.45rem; }
  .hero-subtitle { font-size: .88rem; }
  .hero-buttons { gap: .5rem; }
  .hero-feature { padding: .3rem .45rem; font-size: .76rem; }
  .hero-content { padding-block: 5rem 2rem; }
}

/* ---------------------------------------------------------
   Page banners
--------------------------------------------------------- */
@media (max-width: 480px) {
  .page-banner { padding: 3.5rem 0 2rem; }
  .page-banner-title { font-size: 1.4rem; line-height: 1.25; }
  .page-banner-subtitle { font-size: .88rem; }
  .page-banner--excursion { min-height: 240px; }
}

/* ---------------------------------------------------------
   Section headings & typography
--------------------------------------------------------- */
@media (max-width: 480px) {
  .section-title { font-size: 1.5rem; }
  .section-subtitle { font-size: .88rem; }
  h1, h2, h3 { line-height: 1.3; }
}

/* ---------------------------------------------------------
   Buttons
--------------------------------------------------------- */
@media (max-width: 480px) {
  .btn { font-size: .85rem; }
  .btn-sm { padding: .38rem .85rem; font-size: .78rem; }
}

/* ---------------------------------------------------------
   Filter bar (archive excursion & blog)
--------------------------------------------------------- */
@media (max-width: 640px) {
  .filter-bar-inner { gap: .6rem; }
  .filter-buttons { flex-wrap: wrap; gap: .4rem; }
  .filter-btn { padding: .42rem .8rem; font-size: .8rem; }
}
@media (max-width: 480px) {
  .filter-label { display: none; }
  .filter-btn { padding: .38rem .7rem; font-size: .76rem; }
  .archive-search-input { padding: .55rem .75rem; font-size: .88rem; }
}

/* ---------------------------------------------------------
   Excursion cards
--------------------------------------------------------- */
@media (max-width: 480px) {
  .excursion-card-title { font-size: 1rem; }
  .excursion-card-excerpt { font-size: .8rem; }
  .excursion-card-meta { font-size: .75rem; gap: .3rem; }
  .excursion-card-footer { gap: .4rem; }
  .excursion-card-actions .btn { font-size: .82rem; padding: .52rem .65rem; }
}

/* ---------------------------------------------------------
   Single excursion
--------------------------------------------------------- */
@media (max-width: 480px) {
  .check-list li { padding: .45rem .5rem; font-size: .83rem; }
  .excursion-tab-btn { padding: .6rem .9rem; font-size: .82rem; }
  .vsel-section { padding: 1.25rem; }
  .schedule-times { gap: .3rem; }
  .schedule-pill { padding: .35rem .55rem; font-size: .75rem; }
}

/* ---------------------------------------------------------
   Sticky CTA bar
--------------------------------------------------------- */
@media (max-width: 480px) {
  .sticky-cta-bar { padding: .65rem .75rem; }
  .sticky-cta-inner { gap: .6rem; flex-wrap: wrap; }
  .sticky-cta-info strong { font-size: .78rem; }
  .sticky-cta-info span { font-size: .72rem; }
  .sticky-cta-actions { flex-wrap: wrap; gap: .35rem; }
  .sticky-cta-actions .btn { padding: .45rem .85rem; font-size: .76rem; }
}

/* ---------------------------------------------------------
   Stats grid — page À Propos (5 colonnes → 3 → 2)
--------------------------------------------------------- */
@media (max-width: 600px) {
  .stats-grid--5 { grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
}
@media (max-width: 400px) {
  .stats-grid--5 { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
}

/* ---------------------------------------------------------
   Blog grid
--------------------------------------------------------- */
@media (max-width: 640px) {
  .blog-grid { grid-template-columns: 1fr; }
}

/* ---------------------------------------------------------
   Footer
--------------------------------------------------------- */
@media (max-width: 480px) {
  .footer-widget .widget-title { font-size: .92rem; }
  .footer-bottom-inner { font-size: .78rem; gap: .5rem; }
}

/* ---------------------------------------------------------
   About section (homepage)
--------------------------------------------------------- */
@media (max-width: 480px) {
  .about-feature { gap: .65rem; }
  .about-feature-icon { width: 36px; height: 36px; font-size: .9rem; flex-shrink: 0; }
}

/* =========================================================
   SÉJOUR BUILDER — Responsive Comprehensive
   Page: /reserver/
   ========================================================= */

/* --- Stepper: hide inactive labels on small screens --- */
@media (max-width: 640px) {
  .sejour-stepper { padding: .75rem 0; gap: 0; }
  .sejour-step-label { display: none; }
  .sejour-step.active .sejour-step-label,
  .sejour-step.done  .sejour-step-label { display: none; }
  .sejour-step-line { flex: 1; min-width: 16px; max-width: 32px; }
  .sejour-step-circle { width: 26px; height: 26px; font-size: .75rem; }
}

/* --- Hero section on mobile --- */
@media (max-width: 640px) {
  .sejour-hero { padding: 2.5rem 0 2rem; }
  .sejour-hero-title { font-size: 1.5rem; }
  .sejour-hero-subtitle { font-size: .88rem; }
  .sejour-hero-trust { gap: .5rem .85rem; }
  .sejour-hero-trust span { font-size: .75rem; }
}

/* --- Step 1 — Dates card --- */
@media (max-width: 640px) {
  .sejour-dates-card { padding: 1.5rem 1rem; }
  .sejour-dates-fields { grid-template-columns: 1fr !important; gap: .85rem; }
  .sejour-pickup-toggle { gap: .4rem; }
  .sejour-pickup-btn { font-size: .85rem; padding: .5rem .75rem; }
  .sejour-tiers-row { gap: .2rem; }
  .sejour-tier-item { min-width: 44px; padding: .35rem .5rem; }
  .sejour-tier-pct { font-size: .8rem; }
}

/* --- Step 2 — Planner (Catalog + Itinerary) --- */

/* Force single column below 1024px — already in tablet block above */
/* Catalog scroll area: shorter on mobile */
@media (max-width: 768px) {
  .sejour-catalog-header { padding: 1rem 1rem .75rem; }
  .sejour-catalog-title { font-size: 1.05rem; }
  .sejour-filters { flex-wrap: wrap; gap: .35rem; }
  .sejour-filter { font-size: .78rem; padding: .3rem .65rem; }
  .sejour-catalog-list { max-height: 280px; }
  .sejour-itinerary { padding: 1rem; }
  .sejour-itinerary-title { font-size: 1rem; }
  .sday-slot-header { padding: .35rem .6rem; }
  .sday-num { font-size: .78rem; }
  .sday-date { font-size: .75rem; }
}

@media (max-width: 480px) {
  /* Catalog cards: shrink thumbnail */
  .scat-thumb { width: 52px; height: 40px; flex-shrink: 0; }
  .scat-name { font-size: .82rem; }
  .scat-meta { font-size: .72rem; }
  .scat-add-btn { width: 28px; height: 28px; font-size: .75rem; flex-shrink: 0; }
  .scat-card { gap: .6rem; padding: .5rem .6rem; }
  /* Itinerary day slots */
  .sday-exc { gap: .5rem; padding: .5rem .6rem; flex-wrap: wrap; }
  .sday-exc-thumb { width: 44px; height: 36px; flex-shrink: 0; }
  .sday-exc-name { font-size: .8rem; }
  .sday-exc-dur, .sday-exc-price { font-size: .72rem; }
  .sday-time-pill { padding: .25rem .45rem; font-size: .72rem; }
  .sday-add-btn { font-size: .82rem; padding: .5rem .75rem; }
  /* AOV nudge */
  .sejour-aov-nudge { font-size: .78rem; }
  /* Airport reminder */
  .sejour-airport-reminder { flex-wrap: wrap; gap: .4rem; font-size: .78rem; }
  .sejour-airport-reminder button { font-size: .72rem; padding: .2rem .6rem; }
  /* Planning notice */
  .sejour-planning-notice { font-size: .78rem; }
  /* Total bar */
  .stotal-row { flex-wrap: wrap; gap: .25rem; }
  .stotal-final { font-size: 1rem; }
  /* Confirm + next buttons */
  .sejour-confirm-btn { font-size: .88rem; padding: .8rem 1rem; }
  .sejour-back-link { font-size: .82rem; }
}

/* --- Step 3 — Coordonnées + Summary --- */
@media (max-width: 768px) {
  .sejour-summary-card { padding: 1rem; }
  .sejour-trust-row { flex-direction: column; align-items: flex-start; gap: .35rem; font-size: .8rem; }
  .sejour-form-col { padding: 0; }
}

@media (max-width: 480px) {
  .sejour-section-title { font-size: 1.1rem; }
  .sejour-contact-form .sejour-input { font-size: .9rem; }
}

/* --- Step 4 — Paiement --- */
@media (max-width: 640px) {
  .sejour-payment-opts { gap: .75rem; }
  .sejour-pay-opt { padding: .9rem 1rem; gap: .75rem; }
  .sejour-pay-opt-icon { width: 36px; height: 36px; font-size: 1rem; flex-shrink: 0; }
  .sejour-pay-opt body > strong { font-size: .9rem; }
  .sejour-pay-opt body > span { font-size: .78rem; }
  .sejour-payment-recap { padding: 1rem; }
  .spay-recap-final { font-size: 1.2rem; }
}

/* --- FAQ section --- */
@media (max-width: 480px) {
  .sejour-faq { padding: 2.5rem 0 3rem; }
  .sejour-faq-title { font-size: 1.35rem; }
  .sejour-faq-question { font-size: .85rem; padding: .85rem 1rem; }
  .sejour-faq-answer p { padding: 0 1rem .85rem; font-size: .82rem; }
}

/* ---------------------------------------------------------
   Print
--------------------------------------------------------- */
@media print {
  .topbar, .site-header, .mobile-menu-overlay,
  .hero-buttons, .cta-section, .whatsapp-float,
  .back-to-top, .booking-actions { display: none !important; }

  body { font-size: 12pt; color: #000; }
  .hero-section { min-height: auto; background: none; color: #000; padding: 2rem 0; }
  .hero-overlay { display: none; }
  .hero-title { color: #000; font-size: 1.5rem; }
}
