/* =====================================================================
   SejourAntilles — Design System Front B2C
   public/css/sejourantilles.css   (F0 base + F1.2 homepage)
   SÉPARÉ de coberhub.css. Multi-tenant : :root = défaut SejourAntilles,
   surchargé par agence via le <style> injecté par base.html.twig.
   ===================================================================== */

/* ===== TOKENS ======================================================== */
:root{
  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;
  --space-6:32px;--space-7:48px;--space-8:64px;--space-9:96px;
  --r-sm:10px;--r:16px;--r-lg:24px;--r-xl:32px;--pill:999px;
  --shadow-s:0 2px 8px rgba(12,39,71,.08);
  --shadow-m:0 12px 28px rgba(12,39,71,.13);
  --shadow-l:0 26px 60px rgba(12,39,71,.22);
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-body:"DM Sans",-apple-system,BlinkMacSystemFont,sans-serif;
  --font-display:"Poppins",sans-serif;
  --font-script:"Caveat",cursive;
  --maxw:1240px;--header-h:78px;
  --c-navy:#16264A;--c-navy-deep:#0C2747;--c-coral:#E8542F;
  --c-sunset-from:#8E2A3F;--c-sunset-to:#F0913F;--c-orange:#F0913F;
  --c-turquoise:#16A6B6;--c-sand:#FBF4E6;--c-gold:#E9A23C;
  --c-ink:#16264A;--c-ink-soft:#5C708A;--c-line:#E7DEC9;
  --c-surface:#FFFFFF;--c-bg:#FFFCF6;
}

/* ===== RESET / BASE ================================================== */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--c-bg);color:var(--c-ink);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);font-style:italic;font-weight:800;
  line-height:1.12;color:var(--c-navy)}
i[data-lucide]{width:1em;height:1em;vertical-align:-.12em}
[x-cloak]{display:none!important}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--space-5)}
.display{font-family:var(--font-display);font-style:italic;font-weight:800}
.accent{color:var(--c-coral)}

/* image plein cadre (secours dégradé si l'image ne charge pas) */
.imgfill{position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--c-turquoise),var(--c-navy-deep))}
.imgfill img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ===== BOUTONS ======================================================= */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;
  padding:14px 26px;border-radius:var(--pill);transition:.25s var(--ease);white-space:nowrap}
.btn i{width:18px;height:18px}
.btn-sunset{background:linear-gradient(95deg,var(--c-sunset-from),var(--c-sunset-to));
  color:#fff;box-shadow:0 10px 24px rgba(142,42,63,.32)}
.btn-sunset:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(142,42,63,.42);filter:brightness(1.05)}
.btn-navy{background:var(--c-navy);color:#fff}
.btn-navy:hover{background:var(--c-navy-deep);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--c-navy);border:1.6px solid var(--c-navy)}
.btn-outline:hover{background:var(--c-navy);color:#fff}
.btn-ghost{background:var(--c-sand);color:var(--c-navy)}
.btn-ghost:hover{background:var(--c-line)}
.btn-lg{padding:17px 34px;font-size:1.02rem}
.btn-sm{padding:10px 18px;font-size:.86rem}

/* ===== LOGO ========================================================== */
.logo{display:inline-flex;align-items:flex-end;gap:9px}
.logo .bird{width:38px;height:38px;flex:none}
.logo .wm{display:flex;flex-direction:column;line-height:.95}
.logo .wm b{font-family:var(--font-display);font-style:italic;font-weight:800;
  font-size:1.4rem;color:var(--c-navy)}
.logo .wm small{font-family:var(--font-display);font-style:italic;font-weight:700;
  font-size:.66rem;color:var(--c-coral);align-self:flex-end;margin-top:-3px}
.logo--light .wm b{color:#fff}

/* ===== HEADER ======================================================== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:.3s var(--ease)}
.site-header .wrap{display:flex;align-items:center;gap:var(--space-6);height:var(--header-h)}
.site-header.is-transparent{background:transparent}
.site-header.is-solid{background:var(--c-surface);box-shadow:var(--shadow-m)}
.main-nav{display:flex;gap:2px}
.main-nav a{font-weight:500;font-size:.94rem;padding:9px 14px;border-radius:var(--pill);
  transition:.2s;display:flex;align-items:center;gap:6px;color:#fff}
.main-nav a i{width:15px;height:15px;opacity:.75}
.site-header.is-solid .main-nav a{color:var(--c-ink)}
.main-nav a:hover{background:rgba(255,255,255,.16)}
.site-header.is-solid .main-nav a:hover{background:var(--c-sand)}
.header-tools{margin-left:auto;display:flex;align-items:center;gap:8px}
.icon-btn{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  color:#fff;background:rgba(255,255,255,.14);transition:.2s}
.icon-btn:hover{background:rgba(255,255,255,.28)}
.icon-btn i{width:19px;height:19px}
.site-header.is-solid .icon-btn{background:var(--c-sand);color:var(--c-ink)}
.burger{display:none}

/* ===== BOTTOM-NAV MOBILE ============================================= */
.bottom-nav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:95;
  background:var(--c-surface);box-shadow:0 -6px 20px rgba(12,39,71,.12);
  padding:8px 6px env(safe-area-inset-bottom,8px)}
.bottom-nav ul{display:flex;justify-content:space-around}
.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;
  font-size:.68rem;font-weight:600;color:var(--c-ink-soft);padding:6px 10px}
.bottom-nav a i{width:21px;height:21px}
.bottom-nav a.active{color:var(--c-coral)}

/* ===== FOOTER ======================================================== */
.site-footer{background:var(--c-navy-deep);color:rgba(255,255,255,.72);
  padding:var(--space-8) 0 var(--space-5)}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:var(--space-6)}
.footer-brand p{font-size:.9rem;line-height:1.7;max-width:32em;margin-top:14px}
.footer-social{display:flex;gap:9px;margin-top:18px}
.footer-social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);
  display:grid;place-items:center;color:#fff;transition:.2s}
.footer-social a:hover{background:var(--c-coral)}
.footer-social a i{width:17px;height:17px}
.footer-col h5{color:#fff;font-family:var(--font-body);font-weight:700;font-size:.8rem;
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.footer-col a{display:block;font-size:.9rem;padding:5px 0;transition:.2s}
.footer-col a:hover{color:var(--c-coral)}
.footer-bottom{margin-top:var(--space-7);padding-top:var(--space-5);
  border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;
  gap:16px;flex-wrap:wrap;font-size:.83rem}
.footer-bottom .links{display:flex;gap:16px;flex-wrap:wrap}
.footer-bottom a:hover{color:#fff}

.tchip{display:inline-flex;align-items:center;gap:8px;background:var(--c-surface);
  border:1px solid var(--c-line);border-radius:var(--pill);padding:9px 16px;
  font-size:.85rem;font-weight:600}
.tchip i{width:16px;height:16px;color:var(--c-turquoise)}

/* =====================================================================
   F1.2 — COMPOSANTS HOMEPAGE  (blocks CMS, préfixe .hp-)
   ===================================================================== */

/* --- section générique --- */
.hp-section{padding:var(--space-8) 0}
.hp-section--cream{background:var(--c-surface)}
.hp-sec-head{text-align:center;max-width:640px;margin:0 auto var(--space-6)}
.hp-sec-head h2{font-size:clamp(1.9rem,3.4vw,2.7rem)}
.hp-sec-head h2 em{font-style:italic;color:var(--c-coral)}
.hp-sec-head p{color:var(--c-ink-soft);margin-top:8px}
.hp-kicker{font-family:var(--font-script);font-size:1.7rem;color:var(--c-coral);
  display:block;line-height:1}
.hp-kicker--gold{color:var(--c-gold)}
.hp-center-cta{text-align:center;margin-top:var(--space-6)}

/* --- HERO --- */
.hp-hero{position:relative;min-height:720px;display:flex;align-items:center;
  padding:calc(var(--header-h) + var(--space-7)) 0 var(--space-8);color:#fff}
.hp-hero__bg{position:absolute;inset:0;z-index:-2}
.hp-hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(10,42,56,.5),rgba(10,42,56,.2) 38%,rgba(10,42,56,.8))}
.hp-hero__inner{max-width:680px}
.hp-eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.8rem;
  letter-spacing:.12em;text-transform:uppercase;padding:7px 15px;border-radius:var(--pill);
  background:rgba(255,255,255,.16);backdrop-filter:blur(6px);margin-bottom:20px}
.hp-eyebrow i{width:14px;height:14px;color:var(--c-orange)}
.hp-hero__title{font-size:clamp(2.6rem,5.4vw,4.2rem);color:#fff}
.hp-hero__accent{display:block;color:var(--c-orange)}
.hp-hero__lead{font-size:1.1rem;max-width:32em;margin:20px 0 26px;color:rgba(255,255,255,.92)}
.hp-hero__trust{display:flex;gap:20px;margin-top:24px;flex-wrap:wrap}
.hp-hero__trust span{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:500}
.hp-hero__trust i{width:17px;height:17px;color:var(--c-orange)}

/* --- DESTINATIONS --- */
.hp-scroller{display:flex;gap:20px;overflow-x:auto;padding:6px 4px 20px;
  scroll-snap-type:x mandatory}
.hp-scroller::-webkit-scrollbar{height:6px}
.hp-scroller::-webkit-scrollbar-thumb{background:var(--c-line);border-radius:99px}
.hp-dcard{flex:0 0 280px;height:370px;border-radius:var(--r-xl);overflow:hidden;
  position:relative;scroll-snap-align:start;transition:.35s var(--ease)}
.hp-dcard .imgfill{position:absolute;inset:0}
.hp-dcard::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 38%,rgba(12,39,71,.82))}
.hp-dcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-l)}
.hp-dcard:hover .imgfill img{transform:scale(1.07)}
.hp-dcard .imgfill img{transition:.6s var(--ease)}
.hp-dcard__info{position:absolute;left:0;right:0;bottom:0;padding:22px;z-index:2;color:#fff}
.hp-dcard__tag{font-size:.76rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  display:flex;align-items:center;gap:6px;opacity:.9}
.hp-dcard__tag i{width:13px;height:13px}
.hp-dcard__info h3{color:#fff;font-size:1.7rem;margin:4px 0 10px}
.hp-dcard__go{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:.86rem;
  background:rgba(255,255,255,.92);color:var(--c-navy);padding:8px 15px;border-radius:var(--pill)}
.hp-dcard__go i{width:15px;height:15px}

/* --- EXPÉRIENCES EN VEDETTE --- */
.hp-exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.hp-exp{background:var(--c-surface);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-s);transition:.3s var(--ease);display:flex;flex-direction:column}
.hp-exp:hover{transform:translateY(-7px);box-shadow:var(--shadow-l)}
.hp-exp__media{height:180px;position:relative}
.hp-exp__media .imgfill{position:absolute;inset:0}
.hp-exp__media .imgfill img{transition:.5s var(--ease)}
.hp-exp:hover .hp-exp__media .imgfill img{transform:scale(1.07)}
.hp-exp__badge{position:absolute;top:12px;left:12px;background:var(--c-surface);
  color:var(--c-navy);font-size:.73rem;font-weight:700;padding:5px 11px;
  border-radius:var(--pill);display:flex;align-items:center;gap:5px}
.hp-exp__badge i{width:13px;height:13px;color:var(--c-coral)}
.hp-exp__fav{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--c-ink-soft);transition:.2s}
.hp-exp__fav:hover{color:var(--c-coral)}
.hp-exp__fav i{width:16px;height:16px}
.hp-exp__flash{position:absolute;bottom:12px;left:12px;color:#fff;font-size:.72rem;
  font-weight:700;padding:5px 11px;border-radius:var(--pill);display:flex;align-items:center;gap:5px;
  background:linear-gradient(95deg,var(--c-sunset-from),var(--c-sunset-to))}
.hp-exp__flash i{width:12px;height:12px}
.hp-exp__body{padding:15px 16px 17px;display:flex;flex-direction:column;flex:1}
.hp-exp__rate{display:flex;align-items:center;gap:4px;font-size:.82rem;font-weight:600;margin-bottom:5px}
.hp-exp__rate i{width:13px;height:13px;color:var(--c-gold);fill:var(--c-gold)}
.hp-exp__rate span{color:var(--c-ink-soft);font-weight:500}
.hp-exp__body h3{font-size:1.06rem;line-height:1.25}
.hp-exp__meta{display:flex;flex-direction:column;gap:5px;margin:9px 0 12px;
  font-size:.83rem;color:var(--c-ink-soft)}
.hp-exp__meta span{display:flex;align-items:center;gap:7px}
.hp-exp__meta i{width:14px;height:14px;color:var(--c-turquoise)}
.hp-exp__foot{margin-top:auto;display:flex;align-items:flex-end;justify-content:space-between;
  border-top:1px solid var(--c-line);padding-top:12px}
.hp-exp__price small{font-size:.72rem;color:var(--c-ink-soft);display:block}
.hp-exp__price b{font-family:var(--font-display);font-style:italic;font-size:1.4rem;color:var(--c-coral)}
.hp-exp__alma{font-size:.7rem;color:var(--c-turquoise);font-weight:600;display:block}
.hp-exp__go{width:40px;height:40px;border-radius:50%;background:var(--c-navy);color:#fff;
  display:grid;place-items:center;transition:.2s;flex:none}
.hp-exp__go:hover{background:var(--c-coral)}
.hp-exp__go i{width:17px;height:17px}

/* --- POURQUOI NOUS + STATS --- */
.hp-usp{background:var(--c-navy);color:#fff}
.hp-usp__grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.hp-usp__photo .imgfill{height:420px;border-radius:var(--r-xl)}
.hp-usp__text h2{color:#fff;font-size:clamp(2rem,3.4vw,2.7rem)}
.hp-usp__text h2 em{font-style:italic;color:var(--c-gold)}
.hp-usp__text>p{color:rgba(255,255,255,.85);margin-top:14px;font-size:1.04rem}
.hp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px}
.hp-stat{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r);padding:20px}
.hp-stat b{font-family:var(--font-display);font-style:italic;font-size:2.2rem;
  color:var(--c-gold);line-height:1;display:block}
.hp-stat small{font-size:.85rem;color:rgba(255,255,255,.82);display:block;margin-top:6px}

/* --- PARTENAIRES --- */
.hp-partners{background:var(--c-surface);padding:var(--space-6) 0}
.hp-partners__inner{display:flex;align-items:center;gap:40px;flex-wrap:wrap;justify-content:center}
.hp-partners__label{font-family:var(--font-display);font-style:italic;font-size:1.1rem;
  color:var(--c-ink-soft);flex:none}
.hp-partners__strip{display:flex;gap:38px;align-items:center;flex-wrap:wrap;justify-content:center}
.hp-plogo{display:flex;align-items:center;gap:9px;font-weight:700;font-size:1.02rem;
  color:var(--c-ink-soft);opacity:.7;transition:.2s}
.hp-plogo:hover{opacity:1;color:var(--c-turquoise)}
.hp-plogo__dot{width:30px;height:30px;border-radius:8px;background:var(--c-sand);
  display:grid;place-items:center}
.hp-plogo__dot i{width:16px;height:16px;color:var(--c-navy)}

/* --- TÉMOIGNAGES --- */
.hp-reviews{background:var(--c-sand)}
.hp-reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.hp-review{background:var(--c-surface);border-radius:var(--r-lg);padding:26px;
  box-shadow:var(--shadow-s);transition:.3s var(--ease)}
.hp-review:hover{transform:translateY(-6px);box-shadow:var(--shadow-m)}
.hp-review__mark{font-family:var(--font-display);font-size:4rem;color:var(--c-line);
  line-height:.5;height:28px;display:block}
.hp-review__stars{display:flex;gap:3px;margin:6px 0 12px}
.hp-review__stars i{width:16px;height:16px;color:var(--c-gold);fill:var(--c-gold)}
.hp-review p{font-size:.95rem}
.hp-review__author{display:flex;align-items:center;gap:12px;margin-top:18px;
  border-top:1px solid var(--c-line);padding-top:15px}
.hp-review__av{width:46px;height:46px;border-radius:50%;flex:none;display:grid;place-items:center;
  font-family:var(--font-display);font-style:italic;font-weight:700;color:#fff;font-size:1rem;
  background:var(--c-coral)}
.hp-review__author small{color:var(--c-ink-soft);font-size:.82rem;display:flex;align-items:center;gap:4px}
.hp-review__author small i{width:12px;height:12px}

/* --- NEWSLETTER --- */
.hp-newsletter{position:relative;color:#fff;text-align:center;
  padding:var(--space-8) var(--space-5)}
.hp-newsletter__bg{position:absolute;inset:0;z-index:-2}
.hp-newsletter::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(10,86,98,.86),rgba(10,42,56,.92))}
.hp-newsletter h2{color:#fff;font-size:clamp(2rem,3.6vw,2.8rem)}
.hp-newsletter p{color:rgba(255,255,255,.88);margin-top:6px}
.hp-nl-form{display:flex;gap:8px;max-width:480px;margin:24px auto 0;background:#fff;
  padding:7px;border-radius:var(--pill);box-shadow:var(--shadow-l)}
.hp-nl-form input{flex:1;border:none;background:none;font-family:inherit;font-size:.98rem;
  padding:0 18px;outline:none;color:var(--c-ink)}
.hp-nl-consent{font-size:.78rem;color:rgba(255,255,255,.7);margin-top:12px}

/* ===== RESPONSIVE ==================================================== */
@media(max-width:1024px){
  .hp-exp-grid{grid-template-columns:repeat(2,1fr)}
  .hp-usp__grid{grid-template-columns:1fr;gap:32px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:760px){
  .main-nav,.header-tools .icon-btn{display:none}
  .burger{display:grid}
  .bottom-nav{display:block}
  body{padding-bottom:64px}
  .site-header .wrap{height:66px}
  :root{--header-h:66px}
  .hp-section{padding:var(--space-7) 0}
  .hp-hero{min-height:auto}
  .hp-exp-grid,.hp-reviews__grid{grid-template-columns:1fr}
  .hp-stats{grid-template-columns:repeat(3,1fr);gap:10px}
  .hp-stat{padding:14px 10px}
  .hp-stat b{font-size:1.6rem}
}