:root{
  --navy:#001F3F;
  --grey:#F5F5F5;
  --dark:#333333;
  --border:#E5E5E5;
  --blue:#1e3a8a;
  --wa:#25D366;
  --shadow: 0 20px 50px rgba(0,0,0,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--dark);
  background:#fff;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.container{max-width:1120px;margin:0 auto;padding:0 24px}

/* Flash */
.flash{padding:12px 0;border-bottom:1px solid var(--border)}
.flash-success{background:#ecfdf5}
.flash-error{background:#fef2f2}
.flash p{margin:0;font-weight:600}

/* Nav */
.nav{position:sticky;top:0;z-index:50;background:var(--navy);border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 10px 30px rgba(0,0,0,.15)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0;gap:16px}
.brand{display:flex;align-items:center;gap:14px}
.brand__logo{width:56px;height:56px;display:block;overflow:hidden}
.brand__logo img{width:100%;height:100%;object-fit:contain;display:block}
.brand__name{display:block;font-family:"Playfair Display",serif;font-weight:700;letter-spacing:.02em;color:#fff;text-transform:uppercase;font-size:22px;line-height:1.05}
.brand__tagline{display:none;color:rgba(255,255,255,.7);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:600}

.nav__links{display:flex;align-items:center;gap:22px}
.nav__link{color:#fff;opacity:.95;font-weight:800;font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:6px 2px;border-bottom:2px solid transparent}
.nav__link:hover{color:#93c5fd}
.nav__link.is-active{color:#93c5fd;border-bottom-color:#93c5fd}

.nav__burger{display:none;background:transparent;border:0;padding:8px;cursor:pointer}
.nav__burger span{display:block;width:26px;height:2px;background:#fff;margin:6px 0;border-radius:999px}

/* Buttons */
.btn{display:inline-flex;cursor:pointer;align-items:center;justify-content:center;gap:10px;border-radius:14px;padding:14px 22px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;font-size:12px;border:1px solid transparent;cursor:pointer;transition:transform .15s ease, background .15s ease, opacity .15s ease}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--navy);color:#fff;box-shadow:var(--shadow)}
.btn--primary:hover{background:var(--blue)}
.btn--light{background:#fff;color:var(--navy);box-shadow:0 10px 25px rgba(0,0,0,.12)}
.btn--wa{background:var(--wa);color:#fff;box-shadow:var(--shadow)}
.btn--full{width:100%}

/* Hero */
.hero{position:relative;overflow:hidden;background:#fff}
.hero__inner{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center;min-height:auto;padding:72px 0 44px}
.pill{display:inline-flex;gap:10px;align-items:center;border:1px solid var(--border);background:var(--grey);padding:10px 14px;border-radius:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:11px;color:var(--navy)}
.pill__dot{width:10px;height:10px;border-radius:999px;background:var(--navy);box-shadow:0 0 0 6px rgba(0,31,63,.10);animation:pulse 1.6s infinite}
@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.15)}100%{transform:scale(1)}}
.hero__title{margin:18px 0 18px;font-family:"Playfair Display",serif;color:var(--navy);font-size:clamp(42px,5.3vw,84px);line-height:.92}
.text-gradient{background:linear-gradient(90deg,var(--navy),var(--blue));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__subtitle{margin:0 0 28px;font-size:18px;line-height:1.7;color:rgba(51,51,51,.82);max-width:540px;font-weight:300}
.hero__cta{display:flex;flex-wrap:wrap;gap:12px}
.ctaRow{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px}
.hero__facts{margin-top:36px;padding-top:18px;border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.fact__k{font-size:10px;text-transform:uppercase;letter-spacing:.18em;font-weight:900;opacity:.55;margin-bottom:6px;color:var(--navy)}
.fact__v{font-weight:900;font-size:14px;color:var(--navy)}
.hero__media{position:relative;display:block}
.hero__glow{position:absolute;inset:-40px;background:rgba(147,197,253,.35);filter:blur(50px);border-radius:999px}
.card--media{position:relative;padding:10px;border-radius:18px;background:var(--grey);border:2px solid rgba(0,31,63,.10)}
.card--media img{border-radius:12px;box-shadow:var(--shadow)}

/* Sections */
.section{padding:80px 0}
.section--tight{padding:64px 0}
.section--afterHero{padding-top:42px}
.section--grey{background:var(--grey)}
.section--borderTop{border-top:1px solid var(--border)}
.section__head{margin-bottom:34px}
.section__head--center{text-align:center}
.section__head h1,.section__head h2{margin:0 0 14px;font-family:"Playfair Display",serif;color:var(--navy);font-size:clamp(34px,4.6vw,64px);line-height:1.05}
.section__head p{margin:0;color:rgba(51,51,51,.65);font-size:18px;max-width:680px}
.section__head--center p{margin:0 auto}

.grid{display:grid;gap:24px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

.card{background:var(--grey);border:1px solid var(--border);border-radius:18px;padding:24px;box-shadow:0 10px 25px rgba(0,0,0,.05)}
.card h3{margin:0 0 14px;font-family:"Playfair Display",serif;color:var(--navy);font-size:22px}
.card p{margin:0;color:rgba(51,51,51,.7);line-height:1.7}

.card--feature{transition:transform .2s ease,border-color .2s ease;background:#fff}
.card--feature:hover{transform:translateY(-2px);border-color:rgba(0,31,63,.45)}
.card--feature .icon{width:56px;height:56px;border-radius:16px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px;box-shadow:var(--shadow)}

/* Before/After */
.ba-slider{position:relative;overflow:hidden;border-radius:18px;border:1px solid var(--border);box-shadow:var(--shadow);aspect-ratio:16/10;cursor:ew-resize;background:#000;touch-action:pan-y}
/* Before/After — effet rideau (clip-path) */
.ba-after,.ba-before{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;user-select:none;-webkit-user-drag:none}
.ba-beforeWrap{position:absolute;inset:0;pointer-events:none}
.ba-before{clip-path:inset(0 50% 0 0);will-change:clip-path}
.ba-divider{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;pointer-events:none;transform:translateX(-50%);will-change:left}
.ba-divider:after{content:'↔';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:999px;background:#fff;color:var(--navy);display:flex;align-items:center;justify-content:center;font-weight:900;box-shadow:0 10px 25px rgba(0,0,0,.25)}
.ba-label{position:absolute;bottom:14px;padding:6px 8px;border-radius:10px;background:rgba(0,0,0,.45);color:#fff;font-size:10px;text-transform:uppercase;letter-spacing:.18em;font-weight:900}
.ba-label--left{left:14px}
.ba-label--right{right:14px}

/* Contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact__title{margin:0 0 14px;font-family:"Playfair Display",serif;color:var(--navy);font-size:clamp(34px,4.1vw,58px);line-height:1.08}
.contact__lead{margin:0 0 28px;color:rgba(51,51,51,.65);max-width:520px;line-height:1.7}

.contact__info{display:grid;gap:16px;margin:22px 0 0}
.infoRow{display:flex;gap:12px;align-items:flex-start}
.infoIcon{width:48px;height:48px;border-radius:14px;background:var(--grey);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--navy)}
.infoLabel{font-size:10px;font-weight:900;letter-spacing:.2em;text-transform:uppercase;color:var(--navy);opacity:.9;margin-bottom:4px}
.infoValue{font-weight:900;font-size:18px;color:var(--navy)}

.card--hint{margin-top:26px;border:2px solid rgba(34,197,94,.25);background:var(--grey)}
.card--hint h3{font-size:20px;margin-bottom:12px}

.card--form{background:var(--grey);border-radius:26px;padding:26px}
.form label{display:block;font-size:10px;font-weight:900;letter-spacing:.18em;text-transform:uppercase;opacity:.55;margin-bottom:8px}
.form input,.form select,.form textarea{
  width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border);
  background:#fff;font:inherit;outline:none;transition:border-color .15s ease, box-shadow .15s ease
}
.form textarea{resize:none}
.form input:focus,.form select:focus,.form textarea:focus{border-color:rgba(0,31,63,.6);box-shadow:0 0 0 4px rgba(0,31,63,.08)}
.form__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form__hint{margin:10px 0 0;font-size:12px;opacity:.65;line-height:1.5}
.hp{position:absolute;left:-9999px;opacity:0}

/* Pricing table */
.tableWrap{overflow:auto;border-radius:18px;border:1px solid var(--border);box-shadow:0 10px 25px rgba(0,0,0,.05)}
.pricing{width:100%;border-collapse:collapse;background:var(--grey)}
.pricing thead th{background:var(--navy);color:#fff;padding:18px;text-align:left;font-family:"Playfair Display",serif;font-size:18px}
.pricing td{padding:16px;border-top:1px solid var(--border);background:#fff}
.pricing tr:hover td{background:var(--grey)}
.center{text-align:center}
.strong{font-weight:900;color:var(--navy)}
.tableHint{padding:10px 14px;font-size:12px;color:rgba(51,51,51,.65);background:#fff;border-top:1px solid var(--border)}

.k{color:var(--navy)}
.list{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:16px}
.list li{display:flex;gap:14px;align-items:flex-start}
.badge{min-width:52px;height:36px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:rgba(0,31,63,.08);color:var(--navy);font-weight:900}
.muted{color:rgba(51,51,51,.7);line-height:1.6;font-size:14px}
.travelBox{display:flex;gap:14px;align-items:center;margin-top:18px;padding:16px;border-radius:16px;background:#fff;border:1px solid var(--border)}
.travelBox__price{width:54px;height:54px;border-radius:999px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px;box-shadow:var(--shadow)}

/* Quiz */
.quiz{max-width:760px;margin:0 auto}
.quiz__progress{display:flex;gap:8px;margin-bottom:18px}
.quiz__bar{height:8px;border-radius:999px;background:var(--grey);width:100%;overflow:hidden;border:1px solid var(--border)}
.quiz__bar.is-on{background:var(--navy)}
.quiz__panel{display:none}
.quiz__panel.is-active{display:block}
.quiz__title{font-family:"Playfair Display",serif;color:var(--navy);font-size:26px;text-align:center;margin:0 0 16px}
.quiz__grid{display:grid;gap:12px}
.quiz__choice{background:#fff;border:2px solid var(--border);border-radius:18px;padding:18px;text-align:left;cursor:pointer;transition:border-color .15s ease, transform .15s ease, background .15s ease}
.quiz__choice:hover{border-color:rgba(0,31,63,.5);transform:translateY(-1px)}
.quiz__choice.is-selected{border-color:var(--navy);background:rgba(0,31,63,.04)}
.quiz__choice .small{opacity:.65;font-size:12px;margin-top:4px}
.quiz__nav{display:flex;justify-content:space-between;align-items:center;margin-top:16px;gap:12px}
.linkBtn{background:transparent;border:0;color:var(--navy);font-weight:900;cursor:pointer;padding:8px 0}

.optBox{background:#fff;border:2px solid var(--border);border-radius:18px;padding:14px;cursor:pointer;transition:border-color .15s ease, background .15s ease}
.optBox.is-on{border-color:var(--navy);background:rgba(0,31,63,.04)}
.optBox__top{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:6px}
.optBox__price{font-weight:900;color:var(--navy)}

.checkboxRow{margin-top:12px;padding:14px;border-radius:18px;border:2px dashed var(--border);background:rgba(245,245,245,.6);display:flex;gap:12px;align-items:center}
.checkboxRow input{width:18px;height:18px}

.result{background:var(--grey);border:1px solid var(--border);border-radius:18px;padding:24px;text-align:center}
.result__label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:900;opacity:.55;margin:0 0 10px}
.result__price{font-family:"Playfair Display",serif;color:var(--navy);font-size:64px;line-height:1;margin:0 0 12px}
.result__sub{margin:0 0 18px;color:var(--navy);font-weight:800}

.payRow{display:flex;justify-content:center;gap:16px;border-top:1px solid var(--border);padding-top:14px;margin-top:18px;opacity:.7;font-weight:900;font-size:11px;letter-spacing:.18em;text-transform:uppercase}

/* Footer */
.footer{background:var(--navy);color:#fff;padding:70px 0 24px}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:34px;margin-bottom:40px}
.footer__brandRow{display:flex;align-items:center;gap:16px;margin-bottom:14px}
.footer__logo{width:90px;height:90px;border-radius:16px;object-fit:cover}
.footer__title{font-family:"Playfair Display",serif;font-weight:800;font-size:24px}
.footer__subtitle{font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.65}
.footer__desc{opacity:.65;line-height:1.7;max-width:420px}
.footer__heading{font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:900;color:#93c5fd;margin-bottom:14px}
.footer__list{list-style:none;padding:0;margin:0;display:grid;gap:10px;font-size:14px;opacity:.7}
.footer__list a:hover{opacity:1}
.footer__social{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.10);font-weight:900;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.chip:hover{background:rgba(255,255,255,.16)}
.footer__bottom{padding-top:18px;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:center;font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.6}
.footer__bottom a:hover{opacity:1}
.footer__sep{opacity:.35}

/* Prose pages */
.prose{max-width:880px}
.prose h1{font-family:"Playfair Display",serif;color:var(--navy);font-size:48px;margin:0 0 18px}
.prose h2{font-family:"Playfair Display",serif;color:var(--navy);font-size:28px;margin:26px 0 10px}
.prose p,.prose li{line-height:1.75;color:rgba(51,51,51,.85)}
.prose code{background:var(--grey);border:1px solid var(--border);padding:2px 6px;border-radius:8px}

/* WhatsApp float */
.whatsapp-float{display:none;position:fixed;right:18px;bottom:18px;background:var(--wa);color:#fff;border-radius:999px;padding:14px 16px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;font-size:11px;box-shadow:var(--shadow);z-index:60}

/* Responsive */




/* Modal RDV */
.no-scroll{overflow:hidden}
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:80;padding:18px}
.modal.is-open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px)}
.modal__panel{position:relative;width:min(520px,100%);background:#fff;border-radius:22px;padding:22px;border:1px solid var(--border);box-shadow:0 30px 80px rgba(0,0,0,.35)}
.modal__title{margin:0 0 6px;font-family:"Playfair Display",serif;color:var(--navy);font-size:28px}
.modal__text{margin:0 0 6px;color:rgba(51,51,51,.7)}
.modal__close{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:999px;border:1px solid var(--border);background:var(--grey);font-size:22px;line-height:1;cursor:pointer}
.modal__close:hover{filter:brightness(.98)}
.modal__actions{display:grid;gap:10px;margin-top:14px}
.modal__meta{margin-top:14px;font-size:13px;color:rgba(51,51,51,.75);display:grid;gap:6px}

/* FAQ */
.faq{display:grid;gap:12px;max-width:900px}
.faq__item{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 10px 25px rgba(0,0,0,.05)}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;background:transparent;border:0;font:inherit;color:var(--navy);font-weight:900;cursor:pointer;text-align:left}
.faq__icon{width:28px;height:28px;border-radius:999px;background:rgba(0,31,63,.08);display:flex;align-items:center;justify-content:center;font-weight:900;transition:transform .2s ease}
.faq__a{padding:0 18px 16px;color:rgba(51,51,51,.75);line-height:1.7}
.faq__item.is-open .faq__icon{transform:rotate(45deg)}

/* Icônes SVG */
.icon svg{width:24px;height:24px}
.infoIcon svg{width:22px;height:22px}

/* Ajuste logo navbar */
.brand__logo{width:62px;height:62px}
.brand__logo img{object-fit:cover}

/* Avis */
.section--reviews{background:radial-gradient(1200px 500px at 20% 10%, rgba(0,153,255,.18), transparent 60%),
  radial-gradient(900px 400px at 80% 20%, rgba(255,255,255,.10), transparent 55%),
  linear-gradient(180deg, #05070a, #0b0f17);
  color:#fff;
  padding:56px 0;
}
.reviews{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:stretch}
.reviews__summary{border-radius:22px;padding:22px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);backdrop-filter:blur(10px);box-shadow:0 30px 80px rgba(0,0,0,.45)}
.reviews__score{font-size:64px;line-height:1;font-weight:900;letter-spacing:-.03em}
.reviews__score span{font-size:18px;opacity:.75;margin-left:6px;font-weight:700}
.reviews__title{margin-top:10px;font-weight:900;font-size:18px}
.reviews__meta{margin-top:6px;opacity:.8;font-size:13px}
.reviews__carousel{position:relative}
.reviews__track{display:flex;gap:14px;overflow-x:auto;padding:6px 4px 12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.reviews__track::-webkit-scrollbar{height:10px}
.reviews__track::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}
.reviewCard{min-width:280px;max-width:330px;scroll-snap-align:start;border-radius:20px;padding:16px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.35);box-shadow:0 20px 50px rgba(0,0,0,.35)}
.reviewCard__head{display:flex;gap:12px;align-items:center}
.reviewCard__avatar{width:40px;height:40px;border-radius:999px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-weight:900}
.reviewCard__name{font-weight:900}
.reviewCard__meta{font-size:12px;opacity:.7;margin-top:2px}
.reviewCard__stars{margin-top:10px}
.reviewCard__text{margin:10px 0 0;opacity:.9;line-height:1.6}
.reviews__dots{display:flex;gap:8px;justify-content:center;margin-top:10px}
.dot{width:8px;height:8px;border-radius:999px;border:0;background:rgba(255,255,255,.25);cursor:pointer;transition:all .2s ease}
.dot.is-active{width:22px;background:rgba(255,255,255,.95)}

/* Étoiles */
.stars{display:inline-flex;gap:4px;vertical-align:middle}
.star{display:inline-flex}
.star.is-on{color:#f6c95c}
.star.is-off{color:rgba(255,255,255,.35)}
.section--tight .star.is-off{color:rgba(0,31,63,.25)}
.section--tight .star.is-on{color:#f6c95c}



/* Form (admin) */
.form{display:grid;gap:12px}
.field{display:grid;gap:6px}
.field__label{font-size:13px;font-weight:800;color:rgba(0,31,63,.85)}
.input{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff;font:inherit;outline:none}
.input:focus{border-color:rgba(0,31,63,.55);box-shadow:0 0 0 4px rgba(0,153,255,.08)}





/* Hero Slider */
.heroSlider{position:relative;aspect-ratio:900/1100;overflow:hidden;border-radius:12px}
.heroSlider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:opacity .45s ease}
.heroSlider.is-fading img{opacity:0}
.heroSlider__dots{position:absolute;left:0;right:0;bottom:12px;display:flex;gap:8px;justify-content:center;pointer-events:auto}
.heroDot{width:8px;height:8px;border-radius:999px;border:0;background:rgba(255,255,255,.45);cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px rgba(0,0,0,.25)}
.heroDot.is-active{width:22px;background:rgba(255,255,255,.95)}

/* Chip disabled */
.chip--disabled{opacity:.6;cursor:not-allowed}


/* Calendrier */
.calNav{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:22px 0}
.calNav__title{font-weight:900;color:var(--navy)}
.calLegend{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin:10px 0 18px}
.calLegend__item{display:inline-flex;align-items:center;gap:8px;font-weight:800;color:rgba(0,31,63,.8)}
.calDot{width:10px;height:10px;border-radius:999px;display:inline-block}
.calDot--on{background:rgba(22,163,74,.95)}
.calDot--off{background:rgba(148,163,184,.95)}

.cal{border:1px solid var(--border);border-radius:18px;background:#fff;overflow:hidden}
.cal__week{display:grid;grid-template-columns:repeat(7,1fr);background:var(--grey);border-bottom:1px solid var(--border)}
.cal__dow{padding:12px 10px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:900;color:rgba(0,31,63,.65);text-align:center}
.cal__grid{display:grid;grid-template-columns:repeat(7,1fr)}
.cal__cell{min-height:86px;padding:10px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:6px}
.cal__cell:nth-child(7n){border-right:0}
.cal__cell--empty{background:#fff}
.cal__day{font-weight:900;color:var(--navy)}
.cal__status{font-size:12px;font-weight:800;opacity:.85}
.cal__cell.is-on{background:rgba(22,163,74,.07)}
.cal__cell.is-off{background:rgba(148,163,184,.12)}

.cal__btn{all:unset;display:block;width:100%;height:100%;padding:10px;cursor:pointer}
.cal__btn:focus{outline:2px solid rgba(0,153,255,.35);outline-offset:-2px;border-radius:12px}

/* ============================================================
   RESPONSIVE — Mobile first
   breakpoints : 980px (tablette) · 720px (mobile) · 480px (petit mobile)
   ============================================================ */

/* ── Tablette ≤ 980px ─────────────────────────────────────── */
@media (max-width: 980px) {

  /* Hero */
  .hero__inner        { grid-template-columns:1fr; padding:32px 0 20px; gap:24px }
  .hero__media        { order:-1 }
  .hero__copy         { order:1 }

  /* Grilles */
  .grid--4            { grid-template-columns:repeat(2,1fr) }

  /* Contact */
  .contact            { grid-template-columns:1fr }

  /* Footer : 2 colonnes */
  .footer__grid       { grid-template-columns:1fr 1fr; gap:28px }

  /* Reviews */
  .reviews            { grid-template-columns:1fr }
  .reviews__summary   { order:0 }

  /* Brand tagline cachée */
  .brand__tagline     { display:none }
}

/* ── Mobile ≤ 720px ───────────────────────────────────────── */
@media (max-width: 720px) {

  /* Container */
  .container          { padding:0 16px }

  /* Sections */
  .section            { padding:52px 0 }
  .section--tight     { padding:44px 0 }
  .section--afterHero { padding-top:24px }
  .section__head      { margin-bottom:24px }
  .section__head h1,
  .section__head h2   { font-size:clamp(28px,8vw,44px) }
  .section__head p    { font-size:16px }

  /* Navbar burger */
  .nav__burger        { display:inline-block }
  .nav__links         {
    position:absolute; left:0; right:0; top:100%;
    background:var(--navy);
    display:none; flex-direction:column; align-items:stretch;
    padding:16px; gap:4px;
    border-top:1px solid rgba(255,255,255,.12);
    box-shadow:0 20px 40px rgba(0,0,0,.3)
  }
  .nav__links.is-open { display:flex }
  .nav__link          {
    font-size:17px; letter-spacing:.02em;
    text-transform:none; font-family:"Playfair Display",serif;
    padding:10px 12px; border-radius:10px
  }
  .nav__links .btn--wa { width:100%; margin-top:6px }

  /* Grilles → 1 col */
  .grid--2            { grid-template-columns:1fr }
  .grid--4            { grid-template-columns:1fr }
  .form__grid         { grid-template-columns:1fr }

  /* Avant/Après : gap réduit en 1 col */
  .grid--2[style*="gap:40px"] { gap:20px !important }

  /* Slider avant/après sur mobile : ratio plus compact */
  .ba-slider          { aspect-ratio:4/3 }

  /* Cards */
  .card               { padding:18px }
  .card--form         { padding:18px }

  /* Hero */
  .hero__subtitle     { font-size:16px }
  .hero__cta .btn     { width:100% }
  .hero__facts        { grid-template-columns:repeat(3,1fr); gap:10px }

  /* Reviews cards moins larges */
  .reviewCard         { min-width:240px; max-width:280px }

  /* Footer → 1 col sur mobile */
  .footer__grid       { grid-template-columns:1fr; gap:28px }
  .footer             { padding:44px 0 20px }
  .footer__logo       { width:72px; height:72px }
  .footer__desc       { font-size:13px }

  /* Calendrier */
  .cal__cell          { min-height:58px; padding:6px }
  .cal__status        { font-size:10px }
  .cal__dow           { font-size:10px; padding:8px 4px }
  .calNav             { gap:8px }
  .calNav .btn        { padding:10px 12px; font-size:11px }

  /* Formulaires */
  .btn--light         { width:100% }

  /* WhatsApp float */
  .whatsapp-float     { display:inline-flex }

  /* Contact info */
  .infoValue          { font-size:15px }

  /* Pricing table */
  .tableWrap          { border-radius:12px }
  .pricing thead th   { padding:12px; font-size:15px }
  .pricing td         { padding:12px; font-size:14px }

  /* Modal créneaux calendrier */
  #modalSlots         { grid-template-columns:repeat(auto-fill,minmax(72px,1fr)) !important }
}

/* ── Petit mobile ≤ 480px ─────────────────────────────────── */
@media (max-width: 480px) {

  /* Hero title */
  .hero__title        { font-size:clamp(32px,10vw,48px) }
  .hero__facts        { grid-template-columns:1fr; gap:8px }
  .fact__v            { font-size:13px }

  /* Slider encore plus compact */
  .ba-slider          { aspect-ratio:3/2 }

  /* Logo navbar plus petit */
  .brand__logo        { width:40px; height:40px }
  .brand__name        { font-size:18px }

  /* Sections */
  .section            { padding:40px 0 }
  .section--tight     { padding:32px 0 }

  /* Result price quiz */
  .result__price      { font-size:48px }

  /* Hero image */
  .card--media img    { max-height:240px; object-fit:cover }

  /* Reviews */
  .reviews__score     { font-size:52px }
  .reviewCard         { min-width:220px }

  /* Footer */
  .footer__grid       { gap:22px }
  .footer__brandRow   { flex-direction:column; align-items:flex-start }

  /* Grid features 2 → 1 col sur très petit écran */
  .grid--4            { grid-template-columns:repeat(2,1fr) }
}

@media (min-width: 981px) {
  .brand__tagline     { display:block }
}
