:root {
    --teal:#59b7b7;--teal-dark:#3d9a9a;--teal-light:#7ecece;--teal-ultra:#edf8f8;
    --coral:#e8724a;--coral-dark:#d4603c;--gold:#c9a84c;--gold-light:#e8c96e;
    --dark:#0f2424;--dark-mid:#1a3a3a;--cream:#f9f6f0;--white:#fff;
    --gray:#6b7280;--gray-light:#f0f2f4;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:#fff;color:var(--dark);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',serif;line-height:1.2}
.container{max-width:1400px;margin:0 auto;padding:0 80px}

/* Header + mega menu : styles gérés par header-mega.css */

/* ═══════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════ */
/* scroll-progress retiré */

.hero{position:relative;height:40vh;max-height:340px;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:-20%;width:140%;height:140%;background:url('https://images.unsplash.com/photo-1535131749006-b7f58c99034b?w=1920&q=80') center/cover no-repeat;will-change:transform}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,36,36,.88) 0%,rgba(15,36,36,.5) 50%,rgba(89,183,183,.15) 100%)}
.hero-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero-particles span{position:absolute;border-radius:50%;background:rgba(89,183,183,.35);animation:float 10s infinite ease-in-out}
.hero-particles span:nth-child(1){left:10%;top:20%;width:4px;height:4px;animation-delay:0s}
.hero-particles span:nth-child(2){left:28%;top:55%;width:6px;height:6px;animation-delay:2s}
.hero-particles span:nth-child(3){left:65%;top:25%;width:4px;height:4px;animation-delay:4s}
.hero-particles span:nth-child(4){left:82%;top:65%;width:5px;height:5px;animation-delay:1s}
.hero-particles span:nth-child(5){left:48%;top:78%;width:5px;height:5px;animation-delay:3s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1);opacity:.35}50%{transform:translate(8px,-35px) scale(1.4);opacity:.65}}
@media (prefers-reduced-motion: reduce){.hero-particles span{animation:none;opacity:.4}}
.hero-content{position:relative;z-index:2;padding:64px 80px 20px;max-width:820px}
.hero-badge{display:inline-block;color:var(--teal-light);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:14px}
.hero h1{font-size:clamp(32px,4.5vw,54px);color:#fff;line-height:1.08;margin-bottom:10px;font-weight:700}
.hero h1 em{font-style:italic;color:var(--teal-light)}
.hero-tagline{font-family:'Playfair Display',serif;font-size:16px;font-style:italic;color:rgba(255,255,255,.5);margin-bottom:12px}
.hero-desc{font-size:14px;color:rgba(255,255,255,.75);line-height:1.6;font-weight:300;margin-bottom:20px;max-width:520px}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap}
.btn-primary{display:inline-block;background:var(--teal);color:#fff;padding:17px 38px;border-radius:100px;font-size:15px;font-weight:700;transition:all .3s;box-shadow:0 8px 30px rgba(89,183,183,.4)}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-3px);color:#fff}
.btn-outline{display:inline-block;color:#fff;border:2px solid rgba(255,255,255,.35);padding:15px 32px;border-radius:100px;font-size:15px;font-weight:500;transition:all .3s}
.btn-outline:hover{border-color:var(--teal-light);color:var(--teal-light)}
.hero-stats{position:absolute;bottom:12px;right:80px;display:flex;gap:36px;z-index:2}
.hero-stat{text-align:right}
.stat-num{display:block;font-family:'Playfair Display',serif;font-size:32px;font-weight:700;color:var(--teal-light);line-height:1}
.stat-lbl{display:block;font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.8px;text-transform:uppercase;margin-top:4px}

/* ═══ SEARCH BAR ═══ */
.search-section{position:relative;z-index:10;margin-top:-72px;padding:0 80px 14px}
.search-card{background:#fff;border-radius:22px;padding:28px 36px;box-shadow:0 25px 80px rgba(0,0,0,.13);display:flex;align-items:flex-end;gap:0}
.search-field{flex:1;padding:0 20px;border-right:1px solid var(--gray-light);display:flex;flex-direction:column;justify-content:flex-end}
.search-field:first-child{padding-left:0}
.search-field:last-of-type{border-right:none}
.search-field label{display:block;font-size:10px;font-weight:700;color:var(--teal-dark);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:8px;flex-shrink:0}
.search-field input,.search-field select{width:100%;border:none;border-bottom:2px solid var(--gray-light);padding:10px 0;font-size:14px;line-height:20px;color:var(--dark);background:transparent;outline:none;cursor:pointer;transition:border-color .2s;font-family:'Outfit',sans-serif;height:40px;box-sizing:border-box}
.search-field input:focus,.search-field select:focus{border-bottom-color:var(--teal)}
/* Champ date : même ligne que les autres (trigger = hauteur input) */
.search-field #fp-date-wrap{flex-shrink:0;margin:0;padding:0}
.search-field-date-trigger{width:100%;border:none;border-bottom:2px solid var(--gray-light);padding:0;font-size:14px;line-height:20px;color:#9ca3af;background:transparent;cursor:pointer;transition:border-color .2s;font-family:'Outfit',sans-serif;height:40px;box-sizing:border-box;display:flex;align-items:center}
#fp-date-wrap:focus-within .search-field-date-trigger{border-bottom-color:var(--teal)}
.btn-search{background:var(--coral);color:#fff;border:none;padding:18px 32px;border-radius:14px;font-size:15px;font-weight:700;cursor:pointer;margin-left:20px;flex-shrink:0;white-space:nowrap;transition:all .3s;box-shadow:0 6px 25px rgba(232,114,74,.35);font-family:'Outfit',sans-serif}
.btn-search:hover{background:var(--coral-dark);transform:translateY(-2px)}

/* ═══ CATÉGORIES (Séjours, Circuits, Golf, Road-Trip, Parcs) — refonte ═══ */
.categories-section{padding:72px 0 64px;background:linear-gradient(180deg,var(--teal-ultra) 0%,#fff 100%)}
.categories-section .section-label{margin-bottom:8px}
.categories-section .section-title{margin-bottom:0}
.categories-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;margin-top:48px;max-width:1280px;margin-left:auto;margin-right:auto}
.category-card{display:block;position:relative;border-radius:16px;overflow:hidden;background:var(--dark);box-shadow:0 8px 32px rgba(15,36,36,.12);transition:transform .4s cubic-bezier(.25,.46,.45,.94),box-shadow .4s ease;text-decoration:none;aspect-ratio:3/4}
.category-card::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(15,36,36,0) 0%,rgba(15,36,36,.15) 40%,rgba(15,36,36,.82) 100%);pointer-events:none;transition:opacity .4s}
.category-card:hover{transform:translateY(-8px);box-shadow:0 20px 48px rgba(15,36,36,.22)}
.category-card:hover::before{background:linear-gradient(180deg,rgba(15,36,36,0) 0%,rgba(15,36,36,.2) 35%,rgba(15,36,36,.9) 100%)}
.category-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.category-card:hover img{transform:scale(1.06)}
.category-overlay{display:none}
.category-info{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:28px 22px;display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.category-name{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;color:#fff;line-height:1.2;letter-spacing:-.02em;text-shadow:0 1px 2px rgba(0,0,0,.2)}
.category-desc{font-size:.75rem;color:rgba(255,255,255,.88);font-weight:500;letter-spacing:.02em}
.category-card .category-arrow{position:absolute;bottom:28px;right:22px;z-index:2;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;opacity:0;transform:translate(4px,4px);transition:opacity .35s,transform .35s,background .35s}
.category-card:hover .category-arrow{opacity:1;transform:translate(0,0);background:var(--teal)}
.categories-section .anim{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s cubic-bezier(.25,.46,.45,.94)}
.categories-section .anim.visible{opacity:1;transform:translateY(0)}
.categories-section .category-card.anim:nth-child(1){transition-delay:.05s}.categories-section .category-card.anim:nth-child(2){transition-delay:.1s}.categories-section .category-card.anim:nth-child(3){transition-delay:.15s}.categories-section .category-card.anim:nth-child(4){transition-delay:.2s}.categories-section .category-card.anim:nth-child(5){transition-delay:.25s}
@media(max-width:1200px){.categories-grid{grid-template-columns:repeat(3,1fr);gap:20px}}
@media(max-width:768px){.categories-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-top:36px}.category-info{padding:20px 16px}.category-name{font-size:1.15rem}.category-card .category-arrow{bottom:20px;right:16px;width:32px;height:32px;font-size:12px}}

/* ═══ COMMENT ÇA MARCHE (legacy, remplacé par categories-section) ═══ */
.how-section{padding:80px 0 0;background:var(--white)}
/* Pont How → Séjours — trait coupé avant / après le texte */
.how-sejours-bridge{background:linear-gradient(180deg,#fff 0%,var(--teal-ultra) 50%,#fff 100%);padding:40px 80px;position:relative}
.how-sejours-bridge-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:28px}
.how-sejours-bridge-inner::before,.how-sejours-bridge-inner::after{content:'';display:block;width:120px;height:1px;background:linear-gradient(90deg,transparent,rgba(89,183,183,.45));flex-shrink:0}
.how-sejours-bridge-inner::after{background:linear-gradient(90deg,rgba(89,183,183,.45),transparent);width:120px}
.how-sejours-bridge p{margin:0;font-size:13px;font-weight:600;color:var(--teal);text-transform:uppercase;letter-spacing:2px;flex-shrink:0}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:48px;position:relative}
.how-grid::before{content:'';position:absolute;top:35px;left:15%;right:15%;height:3px;background:linear-gradient(90deg,var(--teal-light),var(--teal),var(--teal-light));z-index:0;border-radius:2px}
.how-step{text-align:center;position:relative;z-index:1}
.how-num{width:70px;height:70px;border-radius:50%;margin:0 auto 22px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--teal),var(--teal-dark));box-shadow:0 8px 30px rgba(89,183,183,.35)}
.how-icon{font-size:34px;margin-bottom:14px}
.how-step h3{font-size:22px;color:var(--dark);margin-bottom:10px}
.how-step p{font-size:14px;color:var(--gray);line-height:1.7;max-width:280px;margin:0 auto}

/* ═══════════════════════════════════════════════
   CARTES SÉJOURS — V2 PREMIUM
   ═══════════════════════════════════════════════ */
.sejours-section{padding:60px 0 0;background:#fff}
/* Séparation design entre séjours et départs */
.sejours-departs-bridge{background:linear-gradient(180deg,var(--teal-ultra) 0%,#fff 100%);padding:48px 80px;position:relative;overflow:hidden}
.sejours-departs-bridge::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(89,183,183,.25) 20%,rgba(89,183,183,.4) 50%,rgba(89,183,183,.25) 80%,transparent)}
.sejours-departs-bridge-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:24px}
.sejours-departs-bridge-icon{width:56px;height:56px;border-radius:50%;background:rgba(89,183,183,.15);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}
.sejours-departs-bridge p{margin:0;font-size:15px;color:var(--dark-mid);font-weight:500;max-width:480px;text-align:center;line-height:1.5}
.sejours-departs-bridge p em{font-style:italic;color:var(--teal)}
.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:56px}
.section-label{font-size:11px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:12px}
.section-title{font-size:clamp(30px,4vw,48px);font-weight:700;color:var(--dark);line-height:1.2}
.section-title em{font-style:italic;color:var(--teal)}
.section-link{color:var(--teal-dark);font-weight:600;font-size:14px;white-space:nowrap;transition:all .2s}
.section-link:hover{color:var(--teal);letter-spacing:.3px}

/* Cartes accueil : visibles même si le JS .visible (IntersectionObserver) ne tourne pas */
.sejours-section .cards-grid .scard.anim,
.departs-section .departs-grid .dcard.anim{opacity:1!important;transform:none!important}
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-bottom:48px}
.scard{background:#fff;border:1.5px solid var(--gray-light);border-radius:22px;overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:transform .4s,box-shadow .4s,border-color .3s;position:relative}
.scard:hover{transform:translateY(-8px);box-shadow:0 30px 70px rgba(0,0,0,.14);border-color:var(--teal)}
.scard-featured{grid-column:span 3;flex-direction:row}
.scard-featured .scard-img{width:42%;flex-shrink:0}
.scard-featured .scard-img img{width:100%;height:100%;min-height:100%;object-fit:cover}
.scard-featured .scard-body{padding:30px 36px;display:flex;flex-direction:column;justify-content:center}
.scard-featured .scard-body h3{font-size:28px;margin-bottom:6px}
.scard-featured .scard-desc{-webkit-line-clamp:3}
.scard-img{overflow:hidden;position:relative;flex-shrink:0}
.scard-img img{width:100%;height:280px;object-fit:cover;transition:transform .6s}
.scard:hover .scard-img img{transform:scale(1.06)}
.scard-badges{position:absolute;top:14px;left:14px;display:flex;gap:6px;z-index:2}
.badge{padding:5px 13px;border-radius:100px;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#fff}
.badge-new{background:var(--teal-dark)}.badge-promo{background:var(--coral)}.badge-best{background:var(--gold)}
.scard-hotel-badge{position:absolute;bottom:14px;left:14px;z-index:2;display:flex;align-items:center;gap:6px;background:rgba(15,36,36,.85);backdrop-filter:blur(8px);padding:6px 14px;border-radius:100px}
.scard-hotel-badge img{width:22px;height:22px;border-radius:50%;object-fit:cover}
.scard-hotel-badge span{font-size:11px;color:#fff;font-weight:600}
.scard-hotel-badge .stars-sm{color:var(--gold);font-size:9px;letter-spacing:1px}
.scard-body{padding:24px;flex:1;display:flex;flex-direction:column}
.scard-country{font-size:12px;color:var(--teal);font-weight:700;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px}
.scard-body h3{font-size:21px;font-weight:700;color:var(--dark);margin-bottom:8px;line-height:1.3}
.scard-desc{font-size:14px;color:var(--gray);line-height:1.65;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.scard-highlights{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.scard-chip{display:flex;align-items:center;gap:4px;background:var(--teal-ultra);color:var(--teal-dark);font-size:12px;font-weight:600;padding:5px 12px;border-radius:100px;white-space:nowrap}
.scard-chip.chip-gold{background:#fdf6e3;color:#8a6d1b}
.scard-divider{height:1px;background:var(--gray-light);margin-bottom:14px}
.scard-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;flex-shrink:0}
.scard-price{text-align:left}
.scard-price .price-label{font-size:10px;color:var(--gray);text-transform:uppercase;letter-spacing:.5px}
.scard-price .price-amount{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--teal-dark);line-height:1}
.scard-price .price-per{font-size:10px;color:var(--gray)}
.scard-btn{display:flex;align-items:center;gap:6px;background:var(--dark);color:#fff;padding:12px 24px;border-radius:100px;font-size:14px;font-weight:700;transition:all .3s;white-space:nowrap}
.scard-btn:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(89,183,183,.3)}
.scard-golfs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.scard-golf-chip{display:flex;align-items:center;gap:6px;background:var(--cream);border:1px solid var(--gray-light);padding:6px 12px;border-radius:10px;white-space:nowrap;transition:border-color .2s}
.scard-golf-chip:hover{border-color:var(--teal)}
.scard-golf-chip .gchip-icon{font-size:15px}
.scard-golf-chip .gchip-name{font-size:12px;font-weight:600;color:var(--dark)}
.scard-golf-chip .gchip-holes{font-size:11px;color:var(--gray);font-weight:400}

/* ═══════════════════════════════════════════════
   PROCHAINS DÉPARTS — V2
   ═══════════════════════════════════════════════ */
.departs-section{padding:0 0 100px;background:#fff}
.departs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
.dcard{background:#fff;border:1.5px solid var(--gray-light);border-radius:20px;overflow:hidden;transition:all .3s;position:relative;display:flex;flex-direction:column}
.dcard:hover{border-color:var(--teal);transform:translateY(-5px);box-shadow:0 20px 50px rgba(89,183,183,.12)}
.dcard-img{height:130px;overflow:hidden;position:relative}
.dcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.dcard:hover .dcard-img img{transform:scale(1.08)}
.dcard-urgence{position:absolute;top:10px;right:10px;background:var(--coral);color:#fff;font-size:10px;font-weight:700;padding:4px 12px;border-radius:100px;letter-spacing:.5px;z-index:2}
.dcard-body{padding:18px;flex:1;display:flex;flex-direction:column}
.dcard-dest{font-size:10px;color:var(--teal);font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.dcard-body h4{font-size:16px;color:var(--dark);margin-bottom:12px;line-height:1.3}
.dcard-infos{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--gray);margin-bottom:auto;padding-bottom:14px}
.dcard-infos span{display:flex;align-items:center;gap:6px}
.dcard-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--gray-light)}
.dcard-price{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--teal-dark)}
.dcard-price small{font-size:11px;color:var(--gray);font-family:'Outfit',sans-serif;font-weight:400}
.dcard-btn{background:var(--dark);color:#fff;border:none;padding:8px 18px;border-radius:100px;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s}
.dcard-btn:hover{background:var(--teal-dark)}

/* ═══ SECTION WAVE DIVIDERS ═══ */
.wave-divider{position:relative;margin-top:-1px;line-height:0;display:block}
.wave-divider svg{display:block;width:100%;height:60px;vertical-align:bottom}

/* ═══ POURQUOI NOUS ═══ */
.why-section{background:var(--dark);position:relative;overflow:hidden;padding:100px 0}
.why-section::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(89,183,183,.08) 0%,transparent 70%);pointer-events:none}
.why-glow-wrap{position:absolute;top:0;left:0;right:0;bottom:100px;pointer-events:none;overflow:hidden;z-index:0;-webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 40%,black 20%,transparent 70%);mask-image:radial-gradient(ellipse 90% 70% at 50% 40%,black 20%,transparent 70%)}
.why-glow{position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(89,183,183,.14) 0%,rgba(89,183,183,.04) 38%,transparent 65%);pointer-events:none;transform:translate(-50%,-50%);transition:opacity .25s;opacity:0;filter:blur(32px)}
.label-light{color:var(--teal-light)}
.title-white{color:#fff}
.title-white em{color:var(--teal-light)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:56px}
.why-item{padding:36px 28px;border:1px solid rgba(89,183,183,.12);border-radius:20px;background:rgba(255,255,255,.02);transition:all .35s}
.why-item:hover{border-color:rgba(89,183,183,.35);background:rgba(89,183,183,.06);transform:translateY(-5px)}
.why-icon{font-size:28px;margin-bottom:22px}
.why-item h3{font-size:20px;color:#fff;margin-bottom:12px}
.why-item p{font-size:13px;color:rgba(255,255,255,.45);line-height:1.75}

/* ═══ DESTINATIONS ═══ */
.dest-section{padding:100px 0;background:#fff}
.dest-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.dest-card{border-radius:18px;overflow:hidden;position:relative;aspect-ratio:2/3;cursor:pointer;transition:transform .35s}
.dest-card:hover{transform:scale(1.03)}
.dest-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.dest-card:hover img{transform:scale(1.1)}
.dest-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,36,36,.92) 0%,transparent 55%)}
.dest-info{position:absolute;bottom:20px;left:18px;right:18px;color:#fff}
.dest-country{font-size:10px;color:var(--teal-light);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px;font-weight:700}
.dest-name{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;margin-bottom:2px}
.dest-count{font-size:11px;color:rgba(255,255,255,.55)}

/* ═══════════════════════════════════════════════
   TRUST — UNE LIGNE AVEC LOGOS
   ═══════════════════════════════════════════════ */
.trust-section{padding:40px 0;background:var(--white);border-top:1px solid var(--gray-light);border-bottom:1px solid var(--gray-light)}
.trust-row{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:nowrap}
.trust-item{display:flex;align-items:center;gap:14px;white-space:nowrap}
.trust-logo{height:44px;width:auto;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.trust-logo img,.trust-logo svg{height:44px;width:auto;object-fit:contain;filter:grayscale(20%);transition:filter .3s}
.trust-item:hover .trust-logo img,.trust-item:hover .trust-logo svg{filter:grayscale(0%)}
.trust-text{display:flex;flex-direction:column}
.trust-text strong{font-size:13px;color:var(--dark);font-weight:700}
.trust-text span{font-size:11px;color:var(--gray)}
.trust-sep{width:1px;height:36px;background:var(--gray-light);flex-shrink:0}

/* ═══ TÉMOIGNAGES — GRILLE + ROTATION ═══ */
.testi-section{padding:100px 0;background:var(--teal-ultra)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:56px}
.testi-card{background:#fff;border-radius:22px;padding:36px;position:relative;transition:transform .3s,box-shadow .3s,opacity .6s ease}
.testi-card:hover{transform:translateY(-5px);box-shadow:0 24px 60px rgba(89,183,183,.15)}
.testi-card.fade-out{opacity:0;transform:translateY(10px)}
.testi-card.fade-in{opacity:1;transform:translateY(0)}
.testi-dots{display:flex;justify-content:center;gap:8px;margin-top:32px}
.testi-dot{width:10px;height:10px;border-radius:50%;background:var(--teal-light);opacity:.3;cursor:pointer;transition:all .3s;border:none}
.testi-dot.active{opacity:1;transform:scale(1.3);background:var(--teal-dark)}
.stars{position:absolute;top:34px;right:34px;color:var(--gold);font-size:12px;letter-spacing:2px}
.quote{font-size:52px;color:rgba(89,183,183,.4);font-family:'Playfair Display',serif;line-height:1;margin-bottom:14px}
.testi-card p{font-size:15px;color:var(--dark-mid);line-height:1.75;font-style:italic;margin-bottom:26px}
.testi-author{display:flex;align-items:center;gap:14px}
.avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal-dark));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px;flex-shrink:0}
.author-name{font-weight:700;font-size:14px;color:var(--dark);margin:0;font-style:normal}
.author-trip{font-size:12px;color:var(--teal);margin:2px 0 0;font-style:normal}

/* ═══ NEWSLETTER + CTA — DEUX BLOCS DISTINCTS ═══ */
.newsletter-cta-section{padding:60px 80px 100px;background:#fff}
.newsletter-cta-band{display:flex;align-items:stretch;border-radius:28px;overflow:hidden;min-height:340px;box-shadow:0 24px 60px rgba(15,36,36,.18)}
.newsletter-cta-band .newsletter-side{flex:1;position:relative;padding:56px 48px;display:flex;flex-direction:column;justify-content:center;max-width:50%;overflow:hidden}
.newsletter-cta-band .newsletter-side::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1593111774240-d529f12cf4bb?w=800&q=80') center/cover;z-index:0}
.newsletter-cta-band .newsletter-side::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,36,36,.92) 0%,rgba(26,58,58,.88) 100%);z-index:0}
.newsletter-cta-band .newsletter-side > *{position:relative;z-index:1}
.newsletter-cta-sep{width:4px;flex-shrink:0;background:linear-gradient(180deg,transparent,var(--teal) 20%,var(--coral) 80%,transparent);opacity:.9}
.newsletter-cta-band .cta-side{flex:1;position:relative;padding:56px 48px;display:flex;flex-direction:column;justify-content:center;align-items:center;max-width:50%;overflow:hidden}
.newsletter-cta-band .cta-side::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1587174486073-ae5e5cff23aa?w=800&q=80') center/cover;z-index:0}
.newsletter-cta-band .cta-side::after{content:'';position:absolute;inset:0;background:linear-gradient(165deg,rgba(15,36,36,.92) 0%,rgba(26,58,58,.88) 100%);z-index:0}
.newsletter-cta-band .cta-side > *{position:relative;z-index:1}
/* ═══ MODULE DEVIS — DESIGN PREMIUM (insp. Awwwards / conversion) ═══ */
.cta-devis-wrap{width:100%;max-width:420px}
.cta-devis-box{text-align:center;padding:0}
.cta-devis-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--teal-light);text-transform:uppercase;letter-spacing:3px;margin-bottom:28px}
.cta-devis-eyebrow::before,.cta-devis-eyebrow::after{content:'';width:24px;height:1px;background:currentColor;opacity:.6}
.cta-devis-box h2{font-size:clamp(28px,3.2vw,38px);color:#fff;margin-bottom:18px;line-height:1.15;font-family:'Playfair Display',serif;font-weight:700;letter-spacing:-.03em}
.cta-devis-box .cta-devis-desc{color:rgba(255,255,255,.7);font-size:15px;line-height:1.65;margin-bottom:36px;max-width:320px;margin-left:auto;margin-right:auto}
.cta-devis-trust{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;margin-bottom:32px;font-size:12px;color:rgba(255,255,255,.5)}
.cta-devis-trust span{display:inline-flex;align-items:center;gap:6px}
.cta-devis-trust span::before{content:'✓';color:var(--teal-light);font-weight:800}
.cta-devis-box .btn-devis{display:inline-flex;align-items:center;justify-content:center;gap:14px;width:100%;max-width:320px;background:#fff;color:var(--dark);padding:22px 36px;border-radius:100px;font-size:17px;font-weight:800;border:none;cursor:pointer;transition:all .35s;box-shadow:0 20px 50px rgba(0,0,0,.25);font-family:'Outfit',sans-serif;text-decoration:none;letter-spacing:.02em}
.cta-devis-box .btn-devis:hover{transform:translateY(-4px) scale(1.02);color:var(--dark);box-shadow:0 28px 60px rgba(0,0,0,.35);background:var(--teal-light)}
.cta-devis-box .btn-devis span.btn-arrow{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--coral);color:#fff;font-size:16px;transition:transform .3s}
.cta-devis-box .btn-devis:hover span.btn-arrow{transform:translateX(4px);background:var(--coral-dark)}
.cta-devis-box .cta-phone-wrap{margin-top:32px}
.cta-devis-box .cta-phone-wrap span{font-size:11px;color:rgba(255,255,255,.4);display:block;margin-bottom:8px;text-transform:uppercase;letter-spacing:2px}
.cta-devis-box .cta-phone-wrap a{display:inline-flex;align-items:center;gap:10px;color:#fff;font-size:22px;font-weight:800;text-decoration:none;transition:all .25s;letter-spacing:.02em}
.cta-devis-box .cta-phone-wrap a:hover{color:var(--teal-light);transform:scale(1.02)}
.cta-devis-box .cta-phone-wrap a .phone-icon{opacity:.9}
.newsletter-badge{display:inline-block;font-size:11px;font-weight:700;color:var(--teal-light);text-transform:uppercase;letter-spacing:2px;margin-bottom:16px}
.newsletter-side h2{font-size:28px;color:#fff;margin-bottom:12px;line-height:1.25}
.newsletter-side h2 em{color:var(--teal-light);font-style:italic}
.newsletter-side > p{font-size:14px;color:rgba(255,255,255,.55);margin-bottom:24px;line-height:1.7;max-width:380px}
.newsletter-form{display:flex;gap:12px}
.newsletter-form input{flex:1;padding:14px 20px;border:2px solid rgba(255,255,255,.15);border-radius:100px;font-size:14px;outline:none;transition:border-color .2s;background:rgba(255,255,255,.08);color:#fff;font-family:'Outfit',sans-serif}
.newsletter-form input::placeholder{color:rgba(255,255,255,.35)}
.newsletter-form input:focus{border-color:var(--teal)}
.newsletter-form button{background:var(--coral);color:#fff;border:none;padding:14px 28px;border-radius:100px;font-size:13px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 6px 25px rgba(232,114,74,.4);white-space:nowrap;font-family:'Outfit',sans-serif}
.newsletter-form button:hover{background:var(--coral-dark);transform:translateY(-2px)}
.newsletter-perks{display:flex;gap:20px;margin-top:16px;flex-wrap:wrap}
.newsletter-perk{font-size:11px;color:rgba(255,255,255,.45);display:flex;align-items:center;gap:6px}
.newsletter-perk span{color:var(--teal-light);font-size:13px}
.newsletter-legal{font-size:10px;color:rgba(255,255,255,.3);margin-top:12px}
.btn-coral{display:inline-block;background:var(--coral);color:#fff;padding:16px 36px;border-radius:100px;font-size:14px;font-weight:700;transition:all .3s;box-shadow:0 8px 30px rgba(232,114,74,.4)}
.btn-coral:hover{background:var(--coral-dark);transform:translateY(-2px);color:#fff}
.btn-call{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.4);color:#fff;padding:14px 24px;border-radius:100px;font-size:14px;font-weight:600;transition:all .3s;backdrop-filter:blur(4px)}
.btn-call:hover{background:rgba(255,255,255,.25);border-color:var(--teal-light);color:var(--teal-light);transform:translateY(-2px)}

/* ═══ WHATSAPP FLOAT ═══ */
.whatsapp-float{position:fixed;bottom:28px;right:28px;z-index:999;width:60px;height:60px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 6px 24px rgba(37,211,102,.4);transition:all .3s;cursor:pointer}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 10px 32px rgba(37,211,102,.5)}
.whatsapp-tooltip{position:absolute;right:70px;top:50%;transform:translateY(-50%);background:#fff;color:var(--dark);padding:10px 16px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 4px 20px rgba(0,0,0,.1);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s}
.whatsapp-float:hover .whatsapp-tooltip{opacity:1}

/* ═══ FOOTER ═══ */
.footer{background:var(--dark);color:rgba(255,255,255,.5);padding:80px 0 40px}
.footer-inner{max-width:1400px;margin:0 auto;padding:0 80px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px}
.footer-brand .logo{font-size:26px;margin-bottom:18px;display:inline-block}
.footer-brand > p{font-size:14px;line-height:1.75;color:rgba(255,255,255,.38);max-width:280px}
.footer-col h4{font-size:11px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:2px;margin-bottom:20px;font-family:'Outfit',sans-serif}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:rgba(255,255,255,.4);font-size:14px;transition:color .2s}
.footer-col a:hover{color:var(--teal-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:28px;display:flex;justify-content:space-between;align-items:center;font-size:13px}
.footer-bottom p{color:rgba(255,255,255,.35)}
.footer-certif{display:flex;gap:16px;align-items:center}
.footer-certif-badge{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:6px 14px;border-radius:8px;font-size:11px;color:rgba(255,255,255,.5);font-weight:600;white-space:nowrap}

/* ═══ ANIMATIONS ═══ */
.anim{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.anim.visible{opacity:1;transform:translateY(0)}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){
    .container{padding:0 40px}
    .how-sejours-bridge{padding:40px 40px}
    .sejours-departs-bridge{padding:40px 40px}
    .hero-content{padding:80px 40px 50px}
    .search-section{padding:0 40px}
    .cards-grid{grid-template-columns:1fr 1fr}
    .scard-featured{grid-column:span 2}
    .why-grid{grid-template-columns:repeat(2,1fr)}
    .dest-grid{grid-template-columns:repeat(3,1fr)}
    .departs-grid{grid-template-columns:repeat(2,1fr)}
    .newsletter-cta-section{padding:0 40px 80px}
    .hero-stats{right:40px;bottom:40px;gap:28px}
    .trust-row{gap:28px;flex-wrap:wrap;justify-content:center}
    .trust-sep{display:none}
}
@media(max-width:768px){
    .hero-content{padding:70px 24px 50px;max-width:100%}
    .hero-stats{display:none}
    .search-section{margin-top:0;padding:20px 24px}
    .search-card{flex-direction:column;gap:16px}
    .search-field{padding:0;border-right:none;border-bottom:1px solid var(--gray-light);padding-bottom:16px}
    .btn-search{margin-left:0;width:100%}
    .container{padding:0 24px}
    .how-grid{grid-template-columns:1fr}.how-grid::before{display:none}
    .cards-grid{grid-template-columns:1fr}
    .scard-featured{flex-direction:column;grid-column:span 1}
    .scard-featured .scard-img{width:100%}
    .departs-grid{grid-template-columns:1fr}
    .why-grid{grid-template-columns:1fr}
    .dest-grid{grid-template-columns:repeat(2,1fr)}
    .testi-grid{grid-template-columns:1fr}
    .newsletter-cta-section{padding:0 24px 60px}
    .newsletter-cta-band{flex-direction:column;min-height:auto}
    .newsletter-cta-sep{width:100%;height:3px;background:linear-gradient(90deg,transparent,var(--teal),var(--coral),transparent)}
    .newsletter-cta-band .newsletter-side{max-width:100%;padding:32px 24px}
    .newsletter-cta-band .cta-side{max-width:100%;padding:32px 24px;align-items:flex-start}
    .newsletter-form{flex-direction:column}
    .newsletter-perks{flex-direction:column;gap:8px}
    .how-sejours-bridge{padding:32px 24px}
    .sejours-departs-bridge{padding:32px 24px}
    .sejours-departs-bridge-inner{flex-direction:column;gap:16px}
    .sejours-departs-bridge p{font-size:14px}
    .cta-devis-wrap{max-width:100%}
    .cta-devis-box .cta-devis-desc{max-width:100%}
    .cta-devis-box .btn-devis{max-width:100%}
    .cta-devis-trust{gap:14px;margin-bottom:28px}
    .footer-inner{padding:0 24px}
    .footer-grid{grid-template-columns:1fr;gap:32px}
    .footer-bottom{flex-direction:column;gap:16px;text-align:center}
}