/* ====== RESET & ROOT ====== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --color-marine:#1a3d38;
  --color-horizon:#2d7a6e;
  --color-brume:#4aa89a;
  --color-ciel:#edf7f5;
  --color-champagne:#c9a96e;
  --color-text:#0d1e2f;
  --color-text-light:#456080;
  --color-white:#ffffff;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-subtitle:'Josefin Sans',system-ui,sans-serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;
  --text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.75rem;--text-5xl:3.5rem;
  --space-xs:.5rem;--space-sm:1rem;--space-md:1.5rem;--space-lg:2.5rem;
  --space-xl:4rem;--space-2xl:6rem;--space-section:5rem;
  --radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-full:9999px;
  --shadow-sm:0 2px 8px rgba(26,61,56,.08);
  --shadow-md:0 4px 20px rgba(26,61,56,.12);
  --shadow-lg:0 10px 40px rgba(26,61,56,.18);
  --transition-fast:.2s ease;--transition-base:.3s ease;
  --max-width-content:860px;--max-width-site:1200px;--nav-height:80px;
}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{font-family:var(--font-body);color:var(--color-text);background:var(--color-ciel);line-height:1.7;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
section{scroll-margin-top:90px}

/* ====== PROGRESS BAR ====== */
#scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--color-horizon);z-index:10000}

/* ====== NAV ====== */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(1rem,4vw,3rem);z-index:1000;transition:background var(--transition-base),box-shadow var(--transition-base)}
.nav.scrolled{background:rgba(237,247,245,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-sm)}
.nav-brand{display:flex;align-items:center;gap:12px}
.nav-brand img{width:40px;height:auto}
.nav-brand span{font-family:var(--font-display);font-style:italic;font-size:var(--text-xl);color:var(--color-marine);font-weight:400}
.nav-links{display:flex;align-items:center;gap:var(--space-lg)}
.nav-link{font-family:var(--font-subtitle);font-size:var(--text-sm);font-weight:500;color:var(--color-marine);position:relative;padding:4px 0;letter-spacing:.01em}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:50%;width:0;height:2px;background:var(--color-champagne);transition:width .25s ease,left .25s ease}
.nav-link:hover::after,.nav-link.active::after{width:100%;left:0}
.nav-cta{display:inline-block;padding:10px 24px;background:var(--color-champagne);color:#fff;border:2px solid var(--color-champagne);border-radius:var(--radius-full);font-weight:500;font-size:var(--text-sm);transition:background var(--transition-base),border-color var(--transition-base)}
.nav-cta:hover{background:var(--color-marine);border-color:var(--color-marine)}
.burger{display:none;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;background:none;border:none;z-index:1010;cursor:pointer;padding:10px}
.burger span{display:block;width:24px;height:2px;background:var(--color-marine);border-radius:2px;transition:transform .3s ease,opacity .3s ease}
.burger span:nth-child(1){margin-bottom:6px}
.burger span:nth-child(3){margin-top:6px}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;background:var(--color-marine);z-index:1005;display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;opacity:0;pointer-events:none;transition:opacity .3s ease;overflow-y:auto}
.mobile-menu.open{opacity:1;pointer-events:all}
.mobile-menu-header{display:flex;flex-direction:column;align-items:center;padding:2rem 2rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
.mobile-menu-logo{width:40px;height:40px;filter:brightness(0) invert(1);margin-bottom:.5rem}
.mobile-menu-tagline{font-family:var(--font-display);font-style:italic;font-size:var(--text-sm);color:rgba(255,255,255,.6);text-align:center}
.mobile-menu-links{display:flex;flex-direction:column;align-items:stretch;flex:1}
.mobile-link{font-family:var(--font-display);font-style:italic;font-size:2.2rem;font-weight:400;color:rgba(255,255,255,.9);padding:18px 2rem;border-bottom:1px solid rgba(255,255,255,.1);display:block;text-align:center;opacity:0}
.mobile-menu.open .mobile-link{animation:mobileMenuFadeInUp .35s ease forwards}
.mobile-menu.open .mobile-link:nth-child(1){animation-delay:0ms}
.mobile-menu.open .mobile-link:nth-child(2){animation-delay:80ms}
.mobile-menu.open .mobile-link:nth-child(3){animation-delay:160ms}
.mobile-menu.open .mobile-link:nth-child(4){animation-delay:240ms}
.mobile-menu.open .mobile-link:nth-child(5){animation-delay:320ms}
@keyframes mobileMenuFadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.mobile-menu-rdv{display:block;background:var(--color-champagne);color:var(--color-marine);width:80%;margin:2rem auto;padding:16px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:1.1rem;font-weight:600;text-align:center;flex-shrink:0}
.mobile-menu-rdv:hover{background:#b89659;color:var(--color-marine)}

/* ====== BUTTONS ====== */
.btn-primary{display:inline-block;padding:14px 32px;background:var(--color-champagne);color:#fff;border:2px solid var(--color-champagne);border-radius:var(--radius-full);font-family:var(--font-body);font-weight:500;font-size:var(--text-base);transition:background var(--transition-base),border-color var(--transition-base),transform var(--transition-base)}
.btn-primary:hover{background:var(--color-marine);border-color:var(--color-marine);transform:translateY(-2px)}
.btn-white{display:inline-block;padding:14px 32px;background:#fff;color:var(--color-champagne);border:2px solid #fff;border-radius:var(--radius-full);font-family:var(--font-body);font-weight:500;font-size:var(--text-base);transition:background var(--transition-base),color var(--transition-base),transform var(--transition-base)}
.btn-white:hover{background:transparent;color:#fff;transform:translateY(-2px)}

/* ====== HERO ====== */
.hero{min-height:100vh;display:flex;align-items:center;padding:calc(var(--nav-height) + var(--space-xl)) clamp(1rem,4vw,3rem) var(--space-xl);position:relative;overflow:hidden;background:linear-gradient(140deg,var(--color-ciel) 55%,rgba(26,61,56,.07) 100%)}
.hero-particles{position:absolute;inset:0;pointer-events:none;z-index:0}
.particle{position:absolute;border-radius:50%;opacity:.35;animation:particleFloat 8s ease-in-out infinite}
.particle:nth-child(1){width:12px;height:12px;background:var(--color-champagne);top:15%;left:10%;animation-duration:7s}
.particle:nth-child(2){width:8px;height:8px;background:var(--color-brume);top:25%;left:85%;animation-delay:1.2s;animation-duration:9s}
.particle:nth-child(3){width:14px;height:14px;background:var(--color-ciel);top:60%;left:5%;animation-delay:2.5s;animation-duration:6s}
.particle:nth-child(4){width:10px;height:10px;background:var(--color-champagne);top:70%;left:78%;animation-delay:.8s;animation-duration:10s}
.particle:nth-child(5){width:6px;height:6px;background:var(--color-brume);top:40%;left:50%;animation-delay:3s}
.particle:nth-child(6){width:9px;height:9px;background:var(--color-ciel);top:85%;left:30%;animation-delay:1.8s;animation-duration:7.5s}
.particle:nth-child(7){width:7px;height:7px;background:var(--color-champagne);top:10%;left:60%;animation-delay:4s;animation-duration:11s}
@keyframes particleFloat{0%,100%{transform:translate(0,0)}25%{transform:translate(15px,-20px)}50%{transform:translate(-10px,15px)}75%{transform:translate(20px,10px)}}
.hero-inner{max-width:var(--max-width-site);margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);align-items:center;position:relative;z-index:1}
.hero-text{max-width:560px}
.hero-badge{font-family:var(--font-subtitle);display:inline-flex;align-items:center;gap:8px;font-size:var(--text-sm);font-weight:500;color:var(--color-champagne);letter-spacing:.02em;margin-bottom:var(--space-md);animation:badgePulse 3s ease-in-out infinite}
@keyframes badgePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.03)}}
.hero-title{font-family:var(--font-display);font-style:italic;font-size:clamp(2.5rem,5vw,4rem);line-height:1.15;color:var(--color-marine);font-weight:400;margin-bottom:var(--space-sm)}
.hero-title .word{display:inline-block;opacity:0;transform:translateY(40px);animation:wordReveal .6s cubic-bezier(.16,1,.3,1) forwards}
@keyframes wordReveal{to{opacity:1;transform:translateY(0)}}
.hero-subtitle{font-family:var(--font-subtitle);font-weight:300;font-size:var(--text-xl);color:var(--color-horizon);margin-bottom:var(--space-md);opacity:0;animation:fadeIn .8s ease forwards 1.5s;letter-spacing:.06em}
@keyframes fadeIn{to{opacity:1}}
.hero-body{font-size:var(--text-lg);color:rgba(26,61,56,.75);line-height:1.8;margin-bottom:var(--space-lg);opacity:0;animation:fadeIn .8s ease forwards 1.8s}
.hero-body strong{color:var(--color-marine);font-weight:600}
.hero-actions{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap;opacity:0;animation:fadeIn .8s ease forwards 2s}
.hero-link{font-size:var(--text-sm);color:var(--color-horizon);font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:color var(--transition-fast)}
.hero-link:hover{color:var(--color-marine)}
.hero-photo{position:relative;width:100%}
.hero-photo::before{content:'';position:absolute;top:24px;left:50%;transform:translateX(-46%);width:90%;height:95%;border-radius:200px 200px 180px 180px;border:2px solid var(--color-champagne);opacity:.5;z-index:0;pointer-events:none}
.hero-photo img{position:relative;z-index:1;width:100%;max-width:480px;height:560px;object-fit:cover;object-position:top center;border-radius:200px 200px 180px 180px;display:block;margin:0 auto;box-shadow:var(--shadow-lg);will-change:transform}

/* ====== WAVES ====== */
.wave-separator{display:block;width:100%;height:auto;margin:-2px 0}
.wave-separator-flip{transform:scaleY(-1)}

/* ====== ABOUT, 100VH WITH OVERLAY ====== */
.about-fullbg{position:relative;height:120vh;min-height:120vh;display:flex;align-items:center;justify-content:center;overflow:hidden;scroll-margin-top:0}
.about-fullbg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;transform:scale(1.06);transition:transform .1s linear}
.about-overlay{position:absolute;inset:0;background:rgba(26,61,56,.55);z-index:1}
.about-fullbg-content{position:relative;z-index:2;max-width:680px;padding:var(--space-xl) clamp(1.5rem,6vw,4rem);text-align:center}
.about-fullbg-label{font-family:var(--font-subtitle);display:block;font-size:var(--text-xs);font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--color-champagne);margin-bottom:var(--space-sm)}
.about-fullbg-title{font-family:var(--font-display);font-style:italic;font-size:clamp(2.5rem,5vw,3.8rem);font-weight:400;color:#fff;line-height:1.15;margin-bottom:var(--space-md)}
.about-fullbg-body{font-size:var(--text-lg);line-height:1.85;color:rgba(255,255,255,.95);margin-bottom:var(--space-lg)}

/* ====== SECTION HEADER ====== */
.section-header{text-align:center;max-width:var(--max-width-content);margin:0 auto var(--space-xl)}
.section-header h2{font-family:var(--font-display);font-style:italic;font-size:clamp(2rem,4vw,var(--text-4xl));color:var(--color-marine);font-weight:400;margin-bottom:var(--space-xs);line-height:1.2}
.section-header p{font-family:var(--font-subtitle);font-size:var(--text-lg);color:var(--color-text-light);font-weight:300}

/* ====== SERVICES SLIDER ====== */
.services{padding:var(--space-section) clamp(1rem,4vw,3rem);background:#fff;position:relative}
.services-anchor-bg{position:absolute;width:400px;height:400px;top:10%;left:-120px;opacity:.04;pointer-events:none}
.services-slider-wrapper{max-width:var(--max-width-site);margin:0 auto;position:relative;padding:0 56px}
.services-slider-track-container{overflow:hidden;border-radius:var(--radius-md)}
.services-slider-track{display:flex;gap:24px;transition:transform .6s cubic-bezier(.16,1,.3,1);will-change:transform;align-items:stretch}
.service-card{flex:0 0 calc((100% - 48px) / 3);min-width:0;background:var(--color-ciel);border-radius:var(--radius-md);overflow:hidden;position:relative;transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s ease;border-left:4px solid transparent;display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-left-color:var(--color-horizon)}
.service-card-img{height:180px;flex-shrink:0;position:relative;overflow:hidden;background:var(--color-brume)}
.service-card-img img{width:100%;height:100%;object-fit:cover}
.service-card-img::after{content:'';position:absolute;inset:0;background:var(--color-horizon);opacity:.14}
.service-card-body{padding:1.2rem;position:relative;flex:1;display:flex;flex-direction:column}
.service-ghost{position:absolute;top:-8px;right:12px;font-family:var(--font-display);font-size:110px;font-weight:700;color:var(--color-horizon);opacity:.06;line-height:1;pointer-events:none;user-select:none}
.service-icon{width:44px;height:44px;border-radius:50%;background:var(--color-brume);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-sm);flex-shrink:0}
.service-icon svg{width:22px;height:22px;stroke:var(--color-marine);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.service-card h3{font-family:var(--font-display);font-style:italic;font-size:var(--text-2xl);color:var(--color-marine);font-weight:400;margin-bottom:4px}
.service-card p{font-size:var(--text-sm);color:var(--color-text-light);margin-bottom:var(--space-sm);line-height:1.7;flex:1}
.service-quote{border-left:3px solid var(--color-brume);background:rgba(74,168,154,.08);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:10px 14px;margin:0 0 var(--space-sm);font-style:italic;font-size:var(--text-sm);color:var(--color-marine);line-height:1.6}
.service-quote cite{display:block;font-style:normal;font-size:var(--text-xs);color:var(--color-text-light);margin-top:4px}

.service-price{display:inline-block;background:var(--color-champagne);color:#fff;padding:4px 14px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;margin-top:auto;align-self:flex-start}
.service-cta{display:flex;align-items:center;justify-content:center;margin-top:var(--space-sm);padding:12px 22px;background:var(--color-marine);color:#fff;border:2px solid var(--color-marine);border-radius:var(--radius-full);font-family:var(--font-body);font-weight:500;font-size:var(--text-sm);text-align:center;transition:background var(--transition-base),border-color var(--transition-base),transform var(--transition-base)}
.service-cta:hover{background:var(--color-champagne);border-color:var(--color-champagne);transform:translateY(-2px)}
.slider-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:var(--color-horizon);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:var(--shadow-md);transition:background var(--transition-base),transform var(--transition-fast)}
.slider-nav:hover{background:var(--color-marine);transform:translateY(-50%) scale(1.05)}
.slider-nav svg{stroke:#fff;fill:none;width:20px;height:20px;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.slider-nav-prev{left:0}
.slider-nav-next{right:0}

/* ====== MARINE BANNER ====== */
.marine-banner{position:relative;width:100%;height:260px;background:linear-gradient(180deg,#edf7f5 0%,#4aa89a 18%,#2d7a6e 42%,#1a3d38 70%,#0f2420 100%);overflow:hidden;display:flex;align-items:center;justify-content:center}
.marine-sun{position:absolute;width:55px;height:55px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.95) 0%,rgba(201,169,110,.8) 40%,rgba(201,169,110,.3) 70%,transparent 100%);bottom:95px;left:22%;z-index:1;box-shadow:0 0 20px 8px rgba(201,169,110,.35),0 0 50px 20px rgba(201,169,110,.15),0 0 80px 35px rgba(45,122,110,.12);animation:soleilPulse 4s ease-in-out infinite}
@keyframes soleilPulse{0%,100%{box-shadow:0 0 20px 8px rgba(201,169,110,.35),0 0 50px 20px rgba(201,169,110,.15)}50%{box-shadow:0 0 28px 12px rgba(201,169,110,.5),0 0 65px 28px rgba(201,169,110,.22)}}
.marine-reflect{position:absolute;height:2px;border-radius:2px;background:rgba(201,169,110,.4);filter:blur(2px);z-index:1;animation:reflectPulse 4s ease-in-out infinite}
@keyframes reflectPulse{0%,100%{opacity:.4;transform:scaleX(1)}50%{opacity:.7;transform:scaleX(.6)}}
.marine-banner-quote{position:relative;z-index:10;font-family:var(--font-display);font-style:italic;font-size:clamp(1.1rem,2.2vw,1.7rem);color:rgba(237,247,245,.92);text-align:center;padding:0 2rem;text-shadow:0 2px 12px rgba(15,36,32,.6);max-width:640px;white-space:nowrap;pointer-events:none}
.marine-waves-container{position:absolute;bottom:0;left:0;right:0;height:110px;z-index:4}
.marine-wave-svg{position:absolute;bottom:0;width:200%}
.marine-wave-svg.w1{height:110px;animation:marineWave 7s linear infinite}
.marine-wave-svg.w2{height:85px;animation:marineWave 11s linear infinite reverse}
.marine-wave-svg.w3{height:70px;animation:marineWave 5s linear infinite}
@keyframes marineWave{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ====== SERVICE RDV BUTTON ====== */
.service-rdv-btn{display:block;width:100%;margin-top:var(--space-sm);padding:10px;border:1.5px solid var(--color-horizon);border-radius:var(--radius-full);color:var(--color-horizon);font-family:var(--font-body);font-size:var(--text-sm);font-weight:500;text-align:center;transition:background var(--transition-fast),color var(--transition-fast)}
.service-rdv-btn:hover{background:var(--color-horizon);color:#fff}

/* ====== TARIFS WAVE BANNER ====== */
.tarifs-banner{position:relative;background:var(--color-horizon);padding:var(--space-xl) clamp(1rem,4vw,3rem);color:#fff;text-align:center;overflow:hidden}
.tarifs-banner::before{content:'';position:absolute;top:-1px;left:0;right:0;height:60px;background:var(--color-ciel);clip-path:ellipse(55% 100% at 50% 0%)}
.tarifs-banner::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:60px;background:var(--color-marine);clip-path:ellipse(55% 100% at 50% 100%)}
.tarifs-banner-inner{position:relative;z-index:1;max-width:var(--max-width-content);margin:0 auto;padding:var(--space-lg) 0}
.tarifs-banner-inner h2{font-family:var(--font-display);font-style:italic;font-size:clamp(2rem,4vw,var(--text-4xl));font-weight:400;margin-bottom:var(--space-xs);line-height:1.2}
.tarifs-banner-inner .tarifs-sub{font-family:var(--font-subtitle);font-size:var(--text-lg);opacity:.85;font-weight:300;margin-bottom:var(--space-md)}
/* ── Tarif cards ── */
.tarif-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin:var(--space-md) auto var(--space-sm);max-width:740px}
.tarif-card{background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);padding:var(--space-md) var(--space-sm);text-align:center;transition:background var(--transition-fast)}
.tarif-card:hover{background:rgba(255,255,255,.2)}
.tarif-card-name{font-family:var(--font-subtitle);font-size:var(--text-sm);font-weight:500;opacity:.85;margin-bottom:var(--space-xs);line-height:1.3}
.tarif-card-price{font-family:var(--font-display);font-style:italic;font-size:var(--text-3xl);font-weight:400;line-height:1;margin:6px 0 2px}
.tarif-card-unit{font-size:var(--text-xs);opacity:.7;letter-spacing:.04em;font-family:var(--font-subtitle)}
.tarifs-note{font-size:var(--text-sm);font-style:italic;opacity:.7;margin-top:var(--space-sm);line-height:1.6}
.tarifs-payment{margin-top:var(--space-md);display:flex;flex-direction:column;align-items:center;gap:8px}
.tarifs-payment-label{font-size:var(--text-xs);opacity:.55;font-family:var(--font-subtitle);letter-spacing:.06em;text-transform:uppercase}
.tarifs-payment-methods{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.tarifs-payment-method{display:flex;align-items:center;gap:6px;font-size:var(--text-sm);opacity:.75;background:rgba(255,255,255,.1);padding:6px 16px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.15)}
@media(max-width:640px){.tarif-cards{grid-template-columns:repeat(2,1fr)}}
.tarifs-banner-inner .tarifs-body{font-size:var(--text-base);line-height:1.8;opacity:.9;max-width:540px;margin:0 auto}

/* ====== FAQ ====== */
.faq{padding:var(--space-section) clamp(1rem,4vw,3rem);background:#fff;position:relative}
.faq-list{max-width:var(--max-width-content);margin:0 auto}
.accordion-item{border-bottom:1px solid var(--color-brume)}
.accordion-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-md) 0;background:none;border:none;font-family:var(--font-body);font-size:var(--text-lg);font-weight:500;color:var(--color-marine);text-align:left;transition:background var(--transition-fast),color var(--transition-fast),padding var(--transition-fast);border-radius:var(--radius-sm);cursor:pointer}
.accordion-header:hover{background:var(--color-ciel);padding-left:12px;padding-right:12px}
.accordion-header.active{color:var(--color-horizon)}
.accordion-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);color:var(--color-horizon);transition:transform .3s ease;flex-shrink:0}
.accordion-header.active .accordion-icon{transform:rotate(45deg)}
.accordion-body{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.16,1,.3,1)}
.accordion-body-inner{padding:0 0 var(--space-md);font-size:var(--text-base);color:var(--color-text-light);line-height:1.8}
.faq-more-btn{display:block;margin:var(--space-lg) auto 0;padding:12px 28px;background:transparent;color:var(--color-champagne);border:2px solid var(--color-champagne);border-radius:var(--radius-full);font-family:var(--font-body);font-weight:500;font-size:var(--text-base);cursor:pointer;transition:background var(--transition-base),color var(--transition-base)}
.faq-more-btn:hover{background:var(--color-champagne);color:#fff}
.faq-hidden{display:none}
.faq-hidden.show{display:block}

/* ====== CONTACT ====== */
.contact{padding:var(--space-section) clamp(1rem,4vw,3rem);background:var(--color-ciel);position:relative}
.contact-inner{max-width:var(--max-width-site);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);align-items:start}
.contact-info h2{font-family:var(--font-display);font-style:italic;font-size:clamp(2rem,4vw,var(--text-4xl));color:var(--color-marine);font-weight:400;margin-bottom:var(--space-lg);line-height:1.2}
.contact-detail{display:flex;align-items:flex-start;gap:var(--space-sm);margin-bottom:var(--space-md)}
.contact-detail svg{width:20px;height:20px;stroke:var(--color-horizon);fill:none;stroke-width:1.5;flex-shrink:0;margin-top:3px}
.contact-detail strong{display:block;font-weight:500;color:var(--color-marine);margin-bottom:2px}
.contact-detail span,.contact-detail a{font-size:var(--text-base);color:var(--color-text-light);line-height:1.6}
.contact-detail a:hover{color:var(--color-horizon)}
.contact-note{font-style:italic;font-size:var(--text-sm);color:var(--color-text-light);margin-top:var(--space-md);line-height:1.6}
.contact-cta-card{background:var(--color-horizon);border-radius:var(--radius-lg);padding:var(--space-xl);color:#fff;text-align:center;animation:ctaPulse 4s ease-in-out infinite}
@keyframes ctaPulse{0%,100%{box-shadow:0 0 0 0 rgba(45,122,110,.3)}50%{box-shadow:0 0 0 12px rgba(45,122,110,0)}}
.contact-cta-card h3{font-family:var(--font-display);font-style:italic;font-size:var(--text-3xl);font-weight:400;margin-bottom:var(--space-sm)}
.contact-cta-card p{font-size:var(--text-base);opacity:.9;margin-bottom:var(--space-lg);line-height:1.7}
.contact-cta-note{font-size:var(--text-sm);opacity:.7;margin-top:var(--space-md)}
.contact-social{display:flex;justify-content:center;gap:12px;margin-top:var(--space-md)}
.contact-social-btn{display:flex;align-items:center;opacity:.9;transition:opacity .2s,transform .2s}
.contact-social-btn:hover{opacity:1;transform:scale(1.1)}
.contact-hours{list-style:none;margin:0 0 var(--space-lg);padding:0;text-align:left;display:flex;flex-direction:column;gap:2px}
.contact-hours li{display:flex;justify-content:space-between;align-items:baseline;padding:10px 14px;background:rgba(255,255,255,.1);border-radius:8px}
.contact-hours li:first-child{border-top:1px solid rgba(255,255,255,.2)}
.contact-hours-closed{opacity:.55}
.contact-hours-day{font-size:var(--text-sm);font-weight:500;color:#fff}
.contact-hours-day em{font-style:italic;font-weight:400;font-size:.85em;opacity:.8}
.contact-hours-time{font-size:var(--text-sm);color:rgba(255,255,255,.9);font-variant-numeric:tabular-nums}

/* ====== FOOTER ====== */
.footer{background:var(--color-marine);padding:var(--space-xl) var(--space-sm) var(--space-lg);text-align:center;color:#fff;position:relative}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--color-champagne)}
.footer-logo{width:32px;height:auto;margin:0 auto var(--space-sm);filter:brightness(0) invert(1)}
.footer-name{font-family:var(--font-display);font-style:italic;font-size:var(--text-xl);margin-bottom:4px}
.footer-role{font-size:var(--text-sm);opacity:.7;margin-bottom:var(--space-xs)}
.footer-tagline{font-family:var(--font-display);font-style:italic;font-size:var(--text-base);opacity:.5;margin-bottom:var(--space-lg)}
.footer-links{display:flex;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-sm)}
.footer-links a{font-size:var(--text-sm);opacity:.6;cursor:pointer;transition:opacity var(--transition-fast)}
.footer-links a:hover{opacity:1;text-decoration:underline}
.footer-copy{font-size:var(--text-xs);opacity:.4}

/* ====== REVEAL ====== */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0) translateX(0) scale(1)}
.reveal-left{transform:translateX(-40px)}
.reveal-right{transform:translateX(40px)}
.reveal-scale{transform:scale(.94)}

/* ====== DECORATIVE ASSETS ====== */
.deco-asset{position:absolute;pointer-events:none;z-index:0;will-change:transform}

/* Asset B, Étoile florale (about left) */
.deco-etoile{left:2%;top:20%;animation:decoRotate 18s linear infinite;opacity:.42;z-index:3}
@keyframes decoRotate{to{transform:rotate(360deg)}}

/* Asset C, Lune + nuage (services right) */
.deco-lune{right:2%;top:10%;animation:decoFloat 4s ease-in-out infinite;opacity:.48}

/* Asset D, Fleur étoilée (FAQ left) */
.deco-fleur-etoilee{left:1.5%;top:15%;animation:decoPulse 3.5s ease-in-out infinite;opacity:.42}
@keyframes decoPulse{0%,100%{transform:scale(.9)}50%{transform:scale(1.12)}}

/* Asset E, Trio d'étoiles (contact right) */
.deco-trio-etoiles{right:2%;top:20%}
.deco-etoile-el{animation:decoTwinkle 2.8s ease-in-out infinite}
@keyframes decoTwinkle{0%,100%{opacity:.15}50%{opacity:.7}}

/* Asset F, Petite silhouette (about right) */
.deco-silhouette-sm{right:4%;bottom:25%;animation:decoOsc 6s ease-in-out infinite;opacity:.4;z-index:3}
@keyframes decoOsc{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}

/* Asset G, Ligne ondulée verticale (services left) */
.deco-waveline-vert{left:1%;top:40%;opacity:.45}
.deco-waveline-vert path{stroke-dasharray:8;stroke-dashoffset:0;animation:decoWaveDash 2s linear infinite}
@keyframes decoWaveDash{to{stroke-dashoffset:16}}

@media(max-width:768px){.deco-asset{display:none}}

/* ====== RESPONSIVE ====== */

/* ── Tablette paysage (≤1024px) ── */
@media(max-width:1024px){
  .nav-link{display:none}
  .burger{display:flex}
  .hero-inner{grid-template-columns:1fr 1.2fr}
  .hero-photo img{height:420px}
  .service-card{flex:0 0 calc(50% - 12px)}
}

/* ── Tablette portrait (≤768px) ── */
@media(max-width:768px){
  html{font-size:15px}
  .nav-links{display:none}
  /* ── Hero ── */
  .hero-photo,.hero-photo-bg{display:none}
  .hero{min-height:100svh;min-height:100vh;padding:0;position:relative;display:flex;align-items:flex-end}
  .hero::before{content:'';position:absolute;inset:0;z-index:0;background-image:url(/assets/images/photo-emilie.jpeg);background-size:cover;background-position:center 20%}
  .hero::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(26,61,56,.95) 0%,rgba(26,61,56,.7) 40%,rgba(26,61,56,.3) 70%,transparent 100%)}
  .hero-inner{position:relative;z-index:2;grid-template-columns:1fr;padding:0 1.5rem 3rem;width:100%;min-height:100svh;min-height:100vh;align-items:flex-end;text-align:left}
  /* ── Nav blanc avant scroll ── */
  .nav:not(.scrolled) .nav-brand span{color:#ffffff}
  .nav:not(.scrolled) .nav-brand img{filter:brightness(0) invert(1)}
  .nav:not(.scrolled) .burger span{background:#ffffff}
  .nav.scrolled .nav-brand span{color:var(--color-marine)}
  .nav.scrolled .nav-brand img{filter:none}
  .nav.scrolled .burger span{background:var(--color-marine)}
  .hero-text{max-width:100%;text-align:left}
  .hero-badge{font-size:.75rem;color:#c9a96e}
  .hero-title{color:#ffffff;font-size:clamp(2rem,8vw,2.6rem);text-align:left;margin-bottom:.5rem}
  .hero-subtitle{color:rgba(237,247,245,.85);font-size:1rem;letter-spacing:.04em;margin-bottom:.75rem}
  .hero-body{color:rgba(255,255,255,.8);font-size:.95rem;text-align:left;margin-bottom:1.25rem}
  .hero-actions{flex-direction:column;align-items:stretch;gap:.75rem}
  .hero-actions .btn-primary{display:block;text-align:center;width:100%}
  .hero .btn-primary{background:var(--color-champagne)!important;border-color:var(--color-champagne)!important;color:#ffffff!important;width:100%;text-align:center;padding:16px;font-size:1rem}
  .hero-link{color:rgba(255,255,255,.7)}
  /* ── About ── */
  .about-fullbg{height:auto;min-height:100svh;min-height:100vh}
  .about-fullbg-content{padding:0 1.5rem}
  /* ── Services slider ── */
  .services-slider-wrapper{padding:0 6vw;overflow:hidden}
  .service-card{flex:0 0 88vw;max-width:340px}
  .service-card-img{height:160px}
  .slider-nav{width:40px;height:40px;top:80px;transform:none;background:var(--color-marine);opacity:.85}
  .slider-nav:hover{transform:scale(1.05);background:var(--color-champagne);opacity:1}
  /* ── Marine banner ── */
  .marine-banner{height:180px}
  .marine-banner-quote{font-size:clamp(1.35rem,5.5vw,1.9rem);padding:0 1.5rem}
  .tarifs-banner{display:none}
  /* ── Tarifs (mobile redesign) ── */
  .tarifs-banner{background:var(--color-marine);padding:3rem 1.25rem}
  .tarifs-banner::before,.tarifs-banner::after{display:none}
  .tarifs-banner-inner{padding:0}
  .tarifs-banner-inner h2::before{content:'TARIFS';display:block;font-family:var(--font-subtitle);font-size:.7rem;font-weight:600;letter-spacing:3px;color:var(--color-champagne);text-transform:uppercase;margin-bottom:.75rem}
  .tarifs-banner-inner h2{font-size:2rem;color:#fff}
  .tarifs-banner-inner .tarifs-sub{font-size:.95rem;opacity:.7;color:#fff}
  .tarif-cards{grid-template-columns:1fr;gap:0;max-width:none}
  .tarif-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:1.5rem;margin-bottom:.75rem;display:grid;grid-template-columns:1fr auto;align-items:center;text-align:left}
  .tarif-card:hover{background:rgba(255,255,255,.12)}
  .tarif-card-name{grid-column:1;grid-row:1/3;font-family:var(--font-body);font-size:1rem;font-weight:500;color:rgba(255,255,255,.85);text-align:left}
  .tarif-card-price{grid-column:2;grid-row:1;font-family:var(--font-display);font-style:italic;font-size:2rem;color:var(--color-champagne);text-align:right;line-height:1.2}
  .tarif-card-unit{grid-column:2;grid-row:2;font-size:.8rem;color:rgba(255,255,255,.5);text-align:right}
  .tarifs-note{font-size:.8rem;color:rgba(255,255,255,.45);margin-top:1rem}
  /* ── Contact ── */
  .contact-inner{grid-template-columns:1fr}
  /* ── Footer ── */
  .footer-links{flex-direction:column;align-items:center;gap:.75rem}
  .footer{padding:var(--space-lg) var(--space-sm)}
  /* ── Cookie banner ── */
  #cookie-banner > div{padding:24px 20px 28px!important}
  #cookie-banner button{flex:1 1 100%!important;min-width:unset!important}
}

/* ── Mobile large (≤640px) ── */
@media(max-width:640px){
  .section-header{padding:0 1rem}
}

/* ── Mobile standard (≤480px) ── */
@media(max-width:480px){
  .marine-banner-quote{font-size:clamp(.8rem,3.8vw,1rem);white-space:normal;text-align:center}
  .service-ghost{font-size:80px}
  .about-fullbg{padding:4rem 1.5rem;min-height:auto}
  .about-fullbg-title{font-size:2rem}
  .about-fullbg-body{font-size:1rem}
  .faq{padding:var(--space-section) 1rem}
  .accordion-header{font-size:var(--text-base)}
  .contact{padding:var(--space-section) 1rem}
  .contact-info h2{font-size:2rem}
  .footer-role,.footer-tagline{font-size:var(--text-xs)}
}

/* ── Mobile small (≤380px) ── */
@media(max-width:380px){
  .hero-title{font-size:1.75rem}
  .nav-brand span{font-size:var(--text-base)}
  .hero-actions .btn-primary{padding-left:16px;padding-right:16px}
}

/* ── Large desktop (≥1440px) ── */
@media(min-width:1440px){
  :root{--max-width-site:1300px}
}

/* ── Reduced motion ── */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .hero-title .word{opacity:1;transform:none}
  .hero-subtitle,.hero-body,.hero-actions{opacity:1}
  .mobile-link{opacity:1;transform:none}
}

/* ====== LEGAL POPUPS ====== */
.legal-popup{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,3vw,2rem);opacity:0;transition:opacity .25s ease;pointer-events:none}
.legal-popup:not([hidden]){pointer-events:auto}
.legal-popup.is-open{opacity:1}
.legal-popup[hidden]{display:none}
.legal-popup-overlay{position:absolute;inset:0;background:rgba(13,30,47,.62);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.legal-popup-modal{position:relative;width:100%;max-width:860px;max-height:90vh;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:clamp(1.5rem,3vw,2.5rem);overflow-y:auto;transform:translateY(12px);transition:transform .25s ease}
.legal-popup.is-open .legal-popup-modal{transform:translateY(0)}
.legal-popup-close{position:absolute;top:14px;right:14px;width:40px;height:40px;border-radius:50%;border:none;background:var(--color-marine);color:#fff;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),transform var(--transition-fast);z-index:2}
.legal-popup-close:hover{background:var(--color-horizon);transform:rotate(90deg)}
.legal-popup-header{text-align:center;padding-bottom:var(--space-md);margin-bottom:var(--space-lg);border-bottom:1px solid rgba(26,61,56,.1)}
.legal-popup-logo{width:48px;height:48px;margin:0 auto var(--space-xs)}
.legal-popup-tagline{font-family:var(--font-display);font-style:italic;font-size:var(--text-base);color:var(--color-text-light);margin-bottom:var(--space-sm)}
.legal-popup-title{font-family:var(--font-subtitle);font-size:clamp(1.3rem,2.5vw,1.75rem);font-weight:600;color:var(--color-marine);letter-spacing:.08em;display:inline-block;padding-bottom:6px;border-bottom:3px solid var(--color-champagne)}
.legal-popup-subtitle{margin-top:var(--space-sm);font-size:var(--text-sm);color:var(--color-text-light);font-style:italic}
.legal-popup-intro{font-size:var(--text-base);color:var(--color-text-light);line-height:1.7;margin-bottom:var(--space-lg);text-align:center;max-width:680px;margin-left:auto;margin-right:auto}
.legal-popup-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.legal-popup-col{display:flex;flex-direction:column;gap:var(--space-md)}
.legal-popup-block h3{font-family:var(--font-subtitle);font-size:var(--text-sm);font-weight:600;color:var(--color-horizon);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--space-xs)}
.legal-popup-block p{font-size:var(--text-sm);color:var(--color-text);line-height:1.65;margin-bottom:.5rem}
.legal-popup-block p:last-child{margin-bottom:0}
.legal-popup-block ul{list-style:disc;padding-left:1.1rem;margin-bottom:.5rem}
.legal-popup-block li{font-size:var(--text-sm);color:var(--color-text);line-height:1.65;margin-bottom:4px}
.legal-popup-block a{color:var(--color-horizon);text-decoration:underline}
.legal-popup-block a:hover{color:var(--color-marine)}
.legal-popup-footer{margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid rgba(26,61,56,.1);text-align:center;font-family:var(--font-display);font-style:italic;font-size:var(--text-sm);color:var(--color-text-light)}
@media(max-width:720px){
  .legal-popup-grid{grid-template-columns:1fr;gap:var(--space-md)}
  .legal-popup-modal{padding:1.25rem;max-height:92vh}
  .legal-popup-close{width:36px;height:36px;font-size:22px;top:10px;right:10px}
}
@media(max-width:480px){
  .legal-popup{padding:0}
  .legal-popup-modal{border-radius:0;max-height:100dvh;min-height:100dvh;overflow-y:scroll}
  .legal-popup-close{position:sticky;top:10px;z-index:100;margin-left:auto}
}
