*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --navy:#344B6C;--navy-light:#435d80;
  --gold:#9C8B58;--gold-light:#b8a87a;
  --cream:#F7F3ED;--cream-dark:#EDE7DC;
  --sky:#E2F4FF;--sky-mid:#c8d9e6;
  --white:#FFFFFF;--text:#2c2c2c;--text-soft:#6b7280;
  --fd:'Cormorant Garamond',Georgia,serif;
  --fb:'DM Sans',system-ui,sans-serif;
}
html{scroll-behavior:smooth;overflow-x:hidden;max-width:100%;background:white;}
body{font-family:var(--fb);background:white;color:var(--text);overflow-x:hidden;}
a{color:inherit;}
a[href^="tel"]{color:inherit!important;text-decoration:none!important;cursor:pointer;}
/* Désactive le surlignage bleu iOS */
* {-webkit-tap-highlight-color: transparent;}
::-webkit-scrollbar{width:5px;}::-webkit-scrollbar-track{background:var(--cream);}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(255,255,255,0.98);backdrop-filter:blur(20px);border-bottom:1px solid rgba(184,150,90,0.15);padding:0 60px;height:76px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;transition:box-shadow .3s;}
nav .nav-links{justify-self:center;}
nav .nav-cta-wrap{justify-self:end;}
nav.scrolled{box-shadow:0 2px 20px rgba(28,58,74,.08);border-bottom:2px solid #E2F4FF;}
.nav-logo{text-decoration:none;display:flex;align-items:center;}
.nav-logo span{color:var(--gold);}
.nav-links{display:flex;gap:24px;list-style:none;align-items:center;}
.nav-links a{font-size:13px;font-weight:400;letter-spacing:.3px;color:var(--navy);text-decoration:none;opacity:.75;transition:all .2s;}
.nav-links a:hover{opacity:1;color:var(--navy);}
.nav-cta{background:var(--gold)!important;color:white!important;opacity:1!important;padding:10px 22px;border-radius:40px;font-weight:500!important;transition:background .2s!important;}
.nav-cta:hover{background:var(--navy)!important;}

/* HERO */
.hero{min-height:100vh;background:#E2F4FF;display:flex;align-items:center;position:relative;overflow:hidden;}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 50%,rgba(52,75,108,0.06),transparent 60%),radial-gradient(ellipse 50% 80% at 10% 80%,rgba(52,75,108,0.04),transparent 50%);}
.hero-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(52,75,108,0.06) 1px,transparent 0);background-size:40px 40px;}
.hero-content{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:130px 48px 80px;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(52,75,108,0.08);border:1px solid rgba(52,75,108,0.2);color:var(--navy);padding:7px 16px;border-radius:40px;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:28px;}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--navy);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(1.5);}}
.hero h1{font-family:var(--fd);font-size:clamp(38px,5vw,66px);font-weight:300;line-height:1.1;color:var(--navy);margin-bottom:20px;}
.hero h1 em{font-style:italic;color:var(--gold-light);}
.hero-desc{font-size:15px;line-height:1.8;color:var(--text-soft);margin-bottom:40px;max-width:440px;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;}
.hero-stats{display:flex;gap:40px;margin-top:48px;padding-top:36px;border-top:1px solid rgba(52,75,108,0.15);}
.stat-num{font-family:var(--fd);font-size:42px;font-weight:600;color:var(--navy);line-height:1;}
.stat-label{font-size:11px;color:var(--text-soft);letter-spacing:.5px;text-transform:uppercase;margin-top:5px;}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:200px 200px;gap:10px;}
.hero-img{border-radius:14px;overflow:hidden;position:relative;}
.hero-img:first-child{grid-row:span 2;}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:top;display:block;}
.hero-img-label{position:absolute;bottom:10px;left:10px;background:rgba(28,58,74,0.82);color:rgba(255,255,255,0.8);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:5px 10px;border-radius:20px;backdrop-filter:blur(8px);}

/* BUTTONS */
.btn-p{background:var(--gold);color:white;padding:14px 28px;border-radius:50px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:7px;transition:all .25s;border:none;cursor:pointer;font-family:var(--fb);}
.btn-p:hover{background:#d4a96a;transform:translateY(-2px);box-shadow:0 8px 24px rgba(184,150,90,0.3);}
.btn-g{background:transparent;color:var(--navy);padding:14px 28px;border-radius:50px;font-size:13px;font-weight:400;text-decoration:none;display:inline-flex;align-items:center;gap:7px;transition:all .25s;border:1px solid rgba(52,75,108,.3);}
.btn-g:hover{border-color:var(--navy);color:var(--navy);background:rgba(52,75,108,.06);}

/* SECTION HELPERS */
.sec-tag{font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.sec-tag::before{content:'';display:block;width:24px;height:2px;background:var(--gold);flex-shrink:0;border-radius:2px;}
.sec-title{font-family:var(--fd);font-size:clamp(30px,4vw,50px);font-weight:300;line-height:1.2;color:var(--navy);margin-bottom:16px;}
.sec-title em{font-style:italic;color:var(--gold);}
.sec-desc{font-size:14px;line-height:1.8;color:var(--text-soft);max-width:520px;}

/* SECTION DIVIDERS */
.section-divider-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);opacity:.6;margin:52px auto 0;position:relative;}
.section-divider-dot::before,.section-divider-dot::after{content:'';position:absolute;top:50%;transform:translateY(-50%);width:60px;height:1px;background:var(--gold);opacity:.55;}
.section-divider-dot::before{right:calc(100% + 12px);}
.section-divider-dot::after{left:calc(100% + 12px);}
.section-divider-line{display:none;}
.sep-mobile{display:none;}

/* SERVICES */
.svc-inner{max-width:1200px;margin:0 auto;padding:0 48px;}
.svc-header{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:56px;}
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.svc-card{background:var(--cream);border-radius:18px;padding:32px 24px;position:relative;overflow:hidden;transition:all .35s cubic-bezier(.4,0,.2,1);cursor:pointer;border:1px solid transparent;}
.svc-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--navy),var(--navy-light));opacity:0;transition:opacity .35s;border-radius:18px;}
.svc-card:hover::before{opacity:1;}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(28,58,74,0.18);}
.svc-card *{position:relative;z-index:1;}
.svc-icon{width:48px;height:48px;background:var(--sky);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:20px;transition:background .35s;}
.svc-card:hover .svc-icon{background:rgba(255,255,255,.12);}
.svc-name{font-family:var(--fd);font-size:19px;font-weight:600;color:var(--navy);margin-bottom:8px;transition:color .35s;}
.svc-card:hover .svc-name{color:white;}
.svc-desc{font-size:13px;line-height:1.7;color:var(--text-soft);transition:color .35s;}
.svc-card:hover .svc-desc{color:rgba(255,255,255,.6);}
.svc-arrow{margin-top:20px;font-size:12px;color:var(--gold);display:flex;align-items:center;gap:5px;font-weight:500;transition:color .35s,gap .25s;}
.svc-card:hover .svc-arrow{color:var(--gold-light);gap:10px;}
.svc-card.featured{background:var(--navy);border-color:rgba(184,150,90,.3);}
.svc-card.featured::before{opacity:0!important;}
.svc-card.featured .svc-name{color:white;}
.svc-card.featured .svc-desc{color:rgba(255,255,255,.55);}
.svc-card.featured .svc-arrow{color:var(--gold-light);}
.svc-card.featured:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(28,58,74,.3);}

/* GALLERY STRIP */
.gallery-strip{background:var(--cream-dark);padding:6px 0;overflow:hidden;}
.gallery-scroll{display:flex;gap:8px;animation:scrollG 28s linear infinite;width:max-content;}
@keyframes scrollG{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ABOUT */
.about-inner{max-width:1200px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-visual{position:relative;height:480px;}
.about-main-img{position:absolute;inset:0;border-radius:24px;overflow:hidden;}
.about-main-img img{width:100%;height:100%;object-fit:cover;display:block;}
.about-float{position:absolute;bottom:-20px;right:-20px;background:var(--gold);color:white;border-radius:18px;padding:20px 24px;box-shadow:0 16px 40px rgba(184,150,90,.35);}
.about-float .n{font-family:var(--fd);font-size:38px;font-weight:600;line-height:1;}
.about-float .l{font-size:11px;opacity:.85;margin-top:3px;}
.about-circle{position:absolute;top:40px;left:-24px;width:110px;height:110px;background:var(--cream);border-radius:50%;box-shadow:0 12px 32px rgba(28,58,74,.12);display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;}
.about-circle .n{font-family:var(--fd);font-size:26px;font-weight:600;color:var(--navy);line-height:1;}
.about-circle .l{font-size:10px;color:var(--text-soft);}
.values{margin-top:44px;display:flex;flex-direction:column;gap:16px;}
.val-item{display:flex;gap:18px;align-items:flex-start;padding:22px;background:white;border-radius:14px;border-left:3px solid var(--gold);transition:transform .2s,box-shadow .2s;}
.val-item:hover{transform:translateX(4px);box-shadow:0 8px 24px rgba(28,58,74,.08);}
.val-icon{font-size:22px;flex-shrink:0;margin-top:2px;}
.val-title{font-family:var(--fd);font-size:17px;font-weight:600;color:var(--navy);margin-bottom:3px;}
.val-text{font-size:13px;color:var(--text-soft);line-height:1.6;}

/* TEAM */
.team-inner{max-width:1200px;margin:0 auto;padding:0 48px;}
.team-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;flex-wrap:wrap;gap:20px;}
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;}
.fbtn{padding:8px 18px;border-radius:40px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;border:1.5px solid var(--sky-mid);background:white;color:var(--text-soft);font-family:var(--fb);}
.fbtn.active,.fbtn:hover{background:var(--navy);border-color:var(--navy);color:white;}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:start;}
.team-card{background:white;border-radius:18px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--cream-dark);display:flex;flex-direction:column;}
.team-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(28,58,74,.1);}
.team-card.expanded{transform:none;box-shadow:0 20px 48px rgba(28,58,74,.15);border-color:var(--gold);}
.team-card-img{height:190px;position:relative;overflow:hidden;border-radius:18px 18px 0 0;background:#d0d0d0;}
.team-card-img img{width:100%;height:100%;object-fit:cover;object-position:center 15%;display:block;transition:transform .4s,filter .4s;filter:grayscale(100%)!important;}
@media(min-width:769px){
  .team-card.expanded{grid-column:1/-1;display:grid;grid-template-columns:300px 1fr;grid-template-rows:auto auto 1fr;grid-template-areas:"img body" "img footer" "img profile";}
  .team-card.expanded .team-card-img{grid-area:img;height:100%;min-height:260px;border-radius:18px 0 0 18px;}
  .team-card.expanded .team-card-img img{object-position:center 20%;}
  .team-card.expanded .team-card-body{grid-area:body;min-height:unset;}
  .team-card.expanded .team-card-footer{grid-area:footer;}
  .team-card.expanded .team-profile{grid-area:profile;}
}
.team-card:hover .team-card-img img{transform:scale(1.04);filter:grayscale(0%);}
.team-card.expanded .team-card-img img,.team-card.expanded:hover .team-card-img img{filter:grayscale(100%);transform:none;}
.team-specialty-badge{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:rgba(28,58,74,.85);color:rgba(255,255,255,.85);font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:5px 12px;border-radius:20px;backdrop-filter:blur(8px);white-space:nowrap;}
.team-card-body{padding:20px 18px 0;flex:1;min-height:110px;}
.team-name{font-family:var(--fd);font-size:18px;font-weight:600;color:var(--navy);margin-bottom:3px;}
.team-role{font-size:12px;color:var(--gold);font-weight:500;letter-spacing:.4px;margin-bottom:12px;}
.team-lang{display:inline-block;font-size:10px;background:var(--sky);color:var(--navy);padding:3px 10px;border-radius:20px;font-weight:500;}
.team-card-footer{padding:14px 18px 16px;border-top:1px solid var(--cream-dark);margin-top:14px;}
.btn-voir{font-size:12px;font-weight:500;color:var(--navy);background:none;border:none;cursor:pointer;font-family:var(--fb);display:flex;align-items:center;gap:5px;padding:0;transition:color .2s;}
.btn-voir:hover{color:var(--gold);}
.voir-arr{display:inline-block;transition:transform .3s;}
.btn-voir.open .voir-arr{transform:rotate(180deg);}
.btn-voir.open{color:var(--gold);}
.team-profile{
  max-height:0;
  overflow:hidden;
  transition:max-height .35s ease, opacity .3s ease;
  opacity:0;
  padding:0 18px;
}
.team-profile.open{
  opacity:1;
  padding:0 18px 18px;
}
.team-profile-inner{
  padding-top:16px;
  border-top:1px solid var(--cream-dark);
  margin-top:4px;
}
.profile-section-title{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:600;margin:14px 0 8px;}
.spec-tags{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px;}
.spec-tags li{background:var(--sky);color:var(--navy);font-size:11px;padding:4px 10px;border-radius:20px;font-weight:500;}
.profile-bio{font-size:13px;line-height:1.75;color:var(--text-soft);margin-bottom:14px;}
.profile-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.profile-email{display:inline-flex;align-items:center;gap:5px;background:var(--cream);color:var(--navy);font-size:12px;font-weight:500;padding:8px 16px;border-radius:40px;text-decoration:none;border:1px solid var(--cream-dark);transition:background .2s;}
.profile-email:hover{background:var(--sky);}
.profile-rdv{display:inline-flex;align-items:center;gap:5px;background:var(--navy);color:white;font-size:12px;font-weight:500;padding:8px 16px;border-radius:40px;text-decoration:none;transition:background .2s;}
.profile-rdv:hover{background:var(--gold);}

/* TESTIMONIALS */
.testi-inner{max-width:1200px;margin:0 auto;padding:0 48px;}
.testi-header{text-align:center;margin-bottom:52px;}
.testi-header .sec-tag{justify-content:center;}
.testi-header .sec-tag::before{display:none;}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.testi-card{background:white;border:1px solid rgba(52,75,108,.08);border-radius:18px;padding:32px 28px;transition:all .3s;box-shadow:0 4px 20px rgba(52,75,108,.06);}
.testi-card:hover{box-shadow:0 8px 32px rgba(52,75,108,.12);transform:translateY(-4px);}
.testi-stars{color:var(--gold);font-size:13px;letter-spacing:2px;margin-bottom:16px;}
.testi-quote{font-family:var(--fd);font-size:40px;color:var(--gold);opacity:.4;line-height:.5;display:block;margin-bottom:12px;}
.testi-text{font-size:14px;line-height:1.8;color:var(--text-soft);margin-bottom:24px;font-style:italic;}
.testi-author{display:flex;align-items:center;gap:12px;}
.testi-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-light));display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:15px;font-weight:600;color:white;}
.testi-name{font-size:13px;font-weight:500;color:var(--navy);}
.testi-sub{font-size:11px;color:var(--text-soft);margin-top:2px;}

/* LOCATIONS */
.loc-inner{max-width:1200px;margin:0 auto;padding:0 48px;}
.loc-header{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:52px;}
.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.loc-card{background:white;border-radius:18px;padding:32px 26px;border:1px solid var(--cream-dark);transition:all .3s;position:relative;overflow:hidden;}
.loc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--gold);transform:scaleX(0);transition:transform .3s;transform-origin:left;}
.loc-card:hover::after{transform:scaleX(1);}
.loc-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(28,58,74,.1);}
.loc-num{font-family:var(--fd);font-size:52px;font-weight:300;color:var(--cream-dark);line-height:1;margin-bottom:14px;}
.loc-name{font-family:var(--fd);font-size:21px;font-weight:600;color:var(--navy);margin-bottom:6px;}
.loc-addr{font-size:13px;color:var(--text-soft);line-height:1.6;margin-bottom:18px;}
.loc-itinerary{display:inline-block;margin-top:16px;font-size:12px;color:var(--gold);font-weight:500;text-decoration:none;transition:color .2s;}.loc-itinerary:hover{color:var(--navy);}
.loc-tag{display:inline-flex;align-items:center;gap:5px;background:var(--sky);color:var(--navy);font-size:11px;padding:5px 13px;border-radius:20px;font-weight:500;}

/* HORAIRES */
.hor-inner{max-width:1200px;margin:0 auto;padding:0 48px;}
.hor-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:40px;}
.hor-card{background:var(--sky);border-radius:14px;padding:24px 18px;text-align:center;}
.hor-card.special{background:linear-gradient(135deg,var(--navy),var(--navy-light));}
.hor-card.closed{background:var(--cream-dark);}
.hor-day{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-soft);margin-bottom:10px;}
.hor-card.special .hor-day{color:rgba(255,255,255,.5);}
.hor-time{font-family:var(--fd);font-size:19px;font-weight:600;color:var(--navy);}
.hor-card.special .hor-time{color:var(--gold-light);}
.hor-card.closed .hor-time{color:var(--text-soft);}
.hor-row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:480px;margin:14px auto 0;}

/* CONTACT */
.contact-inner{max-width:1200px;margin:0 auto;padding:0 48px;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:52px;}
.form-box{background:white;border-radius:22px;padding:38px;box-shadow:0 8px 32px rgba(28,58,74,.07);}
.form-box h3{font-family:var(--fd);font-size:22px;font-weight:600;color:var(--navy);margin-bottom:22px;}
.form-fields{display:flex;flex-direction:column;gap:14px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-soft);display:block;margin-bottom:5px;}
input,select,textarea{width:100%;padding:11px 14px;border:1.5px solid var(--cream-dark);border-radius:10px;font-family:var(--fb);font-size:13px;outline:none;transition:border-color .2s;background:white;color:var(--text);}
input:focus,select:focus,textarea:focus{border-color:var(--gold);}
textarea{resize:vertical;}
.info-col{display:flex;flex-direction:column;gap:20px;}
.info-card{background:white;border-radius:18px;padding:28px;border:1px solid var(--cream-dark);}
.info-card h3{font-family:var(--fd);font-size:18px;font-weight:600;color:var(--navy);margin-bottom:16px;}
.info-item{display:flex;gap:12px;align-items:center;margin-bottom:12px;}
.info-icon{width:34px;height:34px;background:var(--sky);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.info-label{font-size:10px;color:var(--text-soft);letter-spacing:.5px;text-transform:uppercase;}
.info-value{font-size:14px;font-weight:500;color:var(--navy);}
.navy-card{background:var(--navy);border-radius:18px;padding:28px;color:white;}
.navy-card h3{font-family:var(--fd);font-size:18px;font-weight:600;margin-bottom:16px;color:white;}
.hor-row{display:flex;justify-content:space-between;font-size:13px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:8px;}
.hor-row:last-child{border:none;margin:0;padding:0;}
.social-row{display:flex;gap:10px;justify-content:center;}
.social-btn{display:flex;align-items:center;gap:7px;background:var(--sky);color:var(--navy);padding:9px 18px;border-radius:40px;text-decoration:none;font-size:12px;font-weight:500;transition:all .2s;}
.social-btn:hover{background:var(--navy);color:white;}

/* FOOTER */
footer{background:#243855;color:rgba(255,255,255,.45);padding:60px 48px 28px;}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:28px;}
.footer-logo-card{display:inline-block;background:white;border-radius:10px;padding:0;margin-bottom:16px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.25);}
.footer-nav-logo img{height:72px;width:auto;display:block;}
.footer-tagline{font-size:12px;line-height:1.7;max-width:220px;}
.footer-social{display:flex;gap:10px;margin-top:20px;}
.fsoc{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-size:13px;text-decoration:none;color:rgba(255,255,255,.55);transition:background .2s,color .2s;}
.fsoc:hover{background:var(--gold);color:white;}
.fcol h4{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:white;margin-bottom:16px;font-weight:500;}
.flinks{list-style:none;}
.flinks li{margin-bottom:8px;}
.flinks a{font-size:12px;color:rgba(255,255,255,.4);text-decoration:none;transition:color .2s;}
.flinks a:hover{color:var(--gold-light);}
.footer-bottom{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;font-size:11px;}

/* REVEAL */
.reveal{opacity:1;transform:translateY(0);transition:opacity .7s ease,transform .7s ease;}
.reveal.animate{opacity:0;transform:translateY(22px);}
.reveal.animate.visible{opacity:1;transform:translateY(0);}

/* SCROLL TOP */
#scrollTop{position:fixed;bottom:28px;right:28px;z-index:99;width:42px;height:42px;border-radius:50%;background:var(--navy);color:white;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(28,58,74,.25);opacity:0;transition:opacity .3s,transform .3s;transform:translateY(14px);font-size:15px;}
#scrollTop.visible{opacity:1;transform:translateY(0);}
#scrollTop:hover{background:var(--gold);}

/* =====================================================
   MOBILE NAVIGATION HAMBURGER
   ===================================================== */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;padding:8px;background:none;border:none;z-index:300;}
.nav-burger span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s;}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mobile-menu{display:none;position:fixed;top:76px;left:0;right:0;bottom:0;background:var(--navy);z-index:150;flex-direction:column;padding:32px 28px;overflow-y:auto;}
.mobile-menu.open{display:flex;}
.mobile-menu .m-links{list-style:none;display:flex;flex-direction:column;gap:4px;}
.mobile-menu .m-links a{font-size:19px;font-family:var(--fb);font-weight:300;color:rgba(255,255,255,0.9);text-decoration:none;padding:16px 0;border-bottom:1px solid rgba(255,255,255,0.08);display:block;letter-spacing:.3px;}
.mobile-menu .m-links a:hover{color:var(--gold-light);}
.mobile-menu .m-cta{margin-top:28px;background:var(--gold);color:white;padding:16px 28px;border-radius:50px;font-size:14px;font-weight:500;text-decoration:none;display:inline-block;text-align:center;}
.mobile-menu .m-info{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.1);}
.mobile-menu .m-info p{font-size:12px;color:rgba(255,255,255,0.5);line-height:1.8;}

/* =====================================================
   TABLET — max-width: 1024px
   ===================================================== */
@media (max-width:1024px){
  nav{padding:0 28px;}
  .nav-links{gap:14px;}
  .nav-links a{font-size:12px;}

  /* HERO */
  .hero-content{padding:40px 28px 60px;gap:40px;}
  .hero h1{font-size:clamp(32px,4.5vw,54px);}

  /* SERVICES */
  .svc-inner{padding:0 28px;}
  .svc-header{grid-template-columns:1fr;gap:20px;margin-bottom:36px;}
  .svc-grid{grid-template-columns:repeat(2,1fr);gap:16px;}

  /* ABOUT */
  .about-inner{padding:0 28px;gap:48px;}
  .about-visual{height:380px;}

  /* TEAM */
  .team-inner{padding:0 28px;}
  .team-grid{grid-template-columns:repeat(3,1fr);gap:16px;}
  

  /* TESTIMONIALS */
  .testi-inner{padding:0 28px;}

  /* LOCATIONS */
  .loc-inner{padding:0 28px;}
  .loc-header{grid-template-columns:1fr;gap:20px;}

  /* HORAIRES */
  .hor-inner{padding:0 28px;}
  .hor-grid{grid-template-columns:repeat(3,1fr);}

  /* CONTACT */
  .contact-inner{padding:0 28px;}
  .contact-grid{gap:28px;}

  /* FOOTER */
  footer{padding:48px 28px 24px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
}

/* =====================================================
   MOBILE — max-width: 768px (iPad portrait + phones)
   ===================================================== */
@media (max-width:768px){
  /* NAV — logo à gauche, burger à droite */
  nav{
    padding:0 20px;
    height:64px;
    display:flex!important;
    justify-content:space-between;
    align-items:center;
  }
  .nav-links{display:none;}
  .nav-cta-wrap{display:none;}
  .nav-burger{display:flex;margin-left:auto;}
  .mobile-menu{top:64px;}

  /* HERO */
  .hero-content{grid-template-columns:1fr;padding:28px 20px 38px;gap:36px;}
  .hero-badge{margin-top:28px;}
  .hero h1{font-size:clamp(30px,8vw,44px);}
  .hero-desc{font-size:14px;margin-bottom:28px;}
  .hero-actions{flex-direction:column;gap:10px;}
  .hero-actions .btn-p,.hero-actions .btn-g{justify-content:center;text-align:center;}
  .hero-stats{gap:24px;flex-wrap:wrap;margin-top:32px;}
  .stat-num{font-size:34px;}
  .hero-grid{grid-template-rows:200px 140px;}

  /* SECTIONS padding */
  section{padding:120px 0!important;}
  .section-divider-dot,.section-divider-line{display:none;}
  .sep-mobile{display:flex;}

  /* SECTION HELPERS */
  .sec-title{font-size:clamp(26px,7vw,38px);}
  .sec-desc{font-size:13px;}

  /* SERVICES */
  .svc-inner{padding:0 20px;}
  .svc-header{grid-template-columns:1fr;gap:16px;margin-bottom:28px;}
  .svc-grid{grid-template-columns:1fr 1fr;gap:12px;}
  .svc-card{padding:22px 18px;}
  .svc-name{font-size:16px;}

  /* GALLERY */
  .gallery-scroll img{height:160px!important;}

  /* ABOUT */
  .about-inner{grid-template-columns:1fr;padding:0 20px;gap:36px;}
  .about-visual{height:280px;}
  .about-float{bottom:-10px;right:-10px;padding:14px 18px;}
  .about-float .n{font-size:28px;}
  .about-circle{width:90px;height:90px;top:20px;left:-12px;}
  .about-circle .n{font-size:20px;}
  .values{margin-top:24px;gap:12px;}
  .val-item{padding:16px;}

  /* TEAM */
  .team-inner{padding:0 20px;}
  .team-header{flex-direction:column;align-items:flex-start;margin-bottom:28px;}
  .team-header-cta{display:none;}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:14px;}
  .team-card.expanded{grid-column:span 2;}
  .team-card-img{height:160px;}
  .team-name{font-size:16px;}

  /* TESTIMONIALS */
  .testi-inner{padding:0 20px;}
  .testi-grid{grid-template-columns:1fr;gap:16px;}

  /* LOCATIONS */
  .loc-inner{padding:0 20px;}
  .loc-header{grid-template-columns:1fr;gap:16px;margin-bottom:32px;}
  .loc-grid{grid-template-columns:1fr;gap:16px;}

  /* HORAIRES */
  .hor-inner{padding:0 20px;}
  .hor-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
  .hor-card{padding:18px 14px;}
  .hor-time{font-size:16px;}

  /* CONTACT */
  .contact-inner{padding:0 20px;}
  .contact-grid{grid-template-columns:1fr;gap:20px;margin-top:36px;}
  .form-box{padding:24px 20px;}
  .field-row{grid-template-columns:1fr;}

  /* FOOTER */
  footer{padding:40px 20px 20px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .footer-tagline{max-width:100%;}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;}
}

/* =====================================================
   SMALL MOBILE — max-width: 480px
   ===================================================== */
@media (max-width:480px){
  /* HERO */
  .hero-content{padding:22px 16px 32px;}
  .hero-grid{display:none;}
  .hero-stats{gap:20px;}
  .stat-num{font-size:28px;}

  /* SERVICES — carousel mobile */
  .svc-inner{padding:0;position:relative;}
  .svc-header{padding:0 20px;}
  .svc-inner::after{content:'';position:absolute;top:0;right:0;width:60px;height:calc(100% - 20px);background:linear-gradient(to right,transparent,var(--cream));pointer-events:none;z-index:2;}
  .svc-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:14px;padding:8px 0 8px 20px;scroll-padding-left:20px;-webkit-overflow-scrolling:touch;grid-template-columns:unset;}
  .svc-grid::-webkit-scrollbar{display:none;}
  .svc-card{flex:0 0 78vw;scroll-snap-align:start;width:78vw;background:white!important;box-shadow:0 4px 20px rgba(52,75,108,.1);border:1px solid rgba(52,75,108,.06)!important;}
  .svc-card.featured{background:white!important;border-color:rgba(52,75,108,.06)!important;}
  .svc-card.featured .svc-name{color:var(--text)!important;}
  .svc-card.featured .svc-desc{color:var(--text-soft)!important;}
  .svc-card.featured .svc-arrow{color:var(--gold)!important;}
  .svc-card .svc-icon{background:var(--sky)!important;}
  .svc-card::before{display:none!important;}
  .svc-card:hover{transform:none!important;box-shadow:0 4px 20px rgba(52,75,108,.1)!important;}
  .svc-card:active{transform:scale(.98)!important;}
  .svc-carousel-hint{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 0 4px;}
  .svc-carousel-dots{display:flex;gap:6px;}
  .svc-carousel-dots span{width:6px;height:6px;border-radius:50%;background:rgba(52,75,108,.2);transition:background .3s;}
  .svc-carousel-dots span.active{background:var(--gold);width:18px;border-radius:3px;}
  .svc-swipe-label{font-size:11px;color:var(--text-soft);letter-spacing:1px;text-transform:uppercase;opacity:.7;}

  /* TEAM — single column */
  .team-inner{padding:0 16px;}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
  .team-card.expanded{grid-column:span 2;}
  .team-card-img{height:140px;}

  /* HORAIRES — single column */
  .hor-inner{padding:0 16px;}
  .hor-grid{grid-template-columns:1fr;}
  .hor-row2{grid-template-columns:1fr;}

  /* CONTACT */
  .contact-inner{padding:0 16px;}
  .form-box{padding:20px 16px;}

  /* ABOUT */
  .about-inner{padding:0 16px;}
  .about-circle{display:none;}/* avoid overlap on tiny screens */

  /* LOC */
  .loc-inner{padding:0 16px;}

  /* TESTI */
  .testi-inner{padding:0 16px;}

  /* FOOTER */
  footer{padding:32px 16px 16px;}
  .footer-grid{grid-template-columns:1fr;}

  /* FILTER BAR */
  .filter-bar{gap:6px;}
  .fbtn{padding:7px 12px;font-size:11px;}

  /* PRISE DE SANG & KIAL MOVE sections */
  .ps-inner,.km-inner{padding:0 16px!important;}
  .ps-grid,.km-grid{grid-template-columns:1fr!important;}
}

/* POPUP PRISE DE SANG */
#ps-popup {
  position: fixed;
  bottom: 32px;
  right: 32px;
  width: 300px;
  background: white;
  border-radius: 20px;
  box-shadow: 0 8px 40px rgba(28,58,74,.18);
  z-index: 9999;
  overflow: hidden;
  transform: translateY(120px);
  opacity: 0;
  transition: all .5s cubic-bezier(.4,0,.2,1);
  pointer-events: none;
}
#ps-popup.show {
  transform: translateY(0);
  opacity: 1;
  pointer-events: all;
}
#ps-popup-bar {
  background: var(--navy);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#ps-popup-bar span {
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold-light);
  font-weight: 600;
}
#ps-popup-close {
  background: none;
  border: none;
  color: rgba(255,255,255,.5);
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  padding: 0;
  transition: color .2s;
}
#ps-popup-close:hover { color: white; }
#ps-popup-body {
  padding: 18px 20px 20px;
}
#ps-popup-title {
  font-family: var(--fd);
  font-size: 18px;
  font-weight: 600;
  color: var(--navy);
  margin-bottom: 12px;
  line-height: 1.3;
}
.ps-popup-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 8px;
}
.ps-popup-icon {
  width: 28px;
  height: 28px;
  background: var(--cream);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 1px;
}
.ps-popup-info-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 2px;
}
.ps-popup-info-val {
  font-size: 13px;
  color: var(--navy);
  font-weight: 500;
  line-height: 1.4;
}
.ps-popup-info-val span {
  color: var(--text-soft);
  font-weight: 400;
}
#ps-popup-cta {
  margin-top: 14px;
  width: 100%;
  background: var(--gold);
  color: white;
  border: none;
  border-radius: 40px;
  padding: 11px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  font-family: var(--fb);
  transition: background .2s;
}
#ps-popup-cta:hover { background: #c4864a; }

/* =====================================================
   RESPONSIVE COMPLET — TOUTES SECTIONS
   Breakpoints : 1024px (tablet), 768px (mobile), 480px (small)
   ===================================================== */

/* ── TABLET 1024px ── */
@media (max-width:1024px){

  /* Section div padding */
  #valeurs,#services,#localisation,#horaires{padding:100px 0!important;}
  #prise-de-sang{padding:100px 0!important;}
  #kial-move{padding:80px 0!important;}
  #contact{padding:80px 0!important;}
  #galerie{padding:60px 0 80px!important;}
  #equipe{padding:100px 0!important;}
  #map-section{padding:0!important;}

  /* Inner padding */
  .ps-inner,.km-inner,.contact-inner-wrap{padding-left:28px!important;padding-right:28px!important;}
  .map-top{padding:60px 28px 32px!important;}
  .map-cards-grid{padding:0 28px 28px!important;}

  /* Prise de sang card */
  .ps-card{padding:28px 32px!important;gap:28px!important;}
  .ps-info-col{min-width:200px!important;}

  /* Kial Move */
  .km-header{gap:32px!important;}

  /* Map cards */
  .map-cards-grid{grid-template-columns:repeat(3,1fr)!important;}

  /* Horaires inner */
  #horaires .hor-inner{padding:0 28px;}

  /* Popup */
  #ps-popup{width:280px;bottom:20px;right:20px;}
}

/* ── MOBILE 768px (iPad portrait + téléphones) ── */
@media (max-width:768px){

  /* Section div padding (body already offset by 64px nav on interior pages) */
  #valeurs,#services,#localisation,#horaires,#equipe{padding:72px 0!important;}
  #prise-de-sang{padding:72px 0!important;}
  #kial-move{padding:64px 0!important;}
  #contact{padding:64px 0!important;}
  #galerie{padding:48px 0 64px!important;}
  #map-section{padding:0!important;}

  /* Inner padding */
  .ps-inner,.km-inner,.contact-inner-wrap{padding-left:20px!important;padding-right:20px!important;}
  .map-top{padding:48px 20px 24px!important;}
  .map-cards-grid{padding:0 20px 20px!important;grid-template-columns:1fr!important;gap:12px!important;}

  /* ── PRISE DE SANG ── */
  .ps-card{
    flex-direction:column!important;
    gap:20px!important;
    padding:24px 20px!important;
    align-items:stretch!important;
  }
  .ps-info-col{
    min-width:unset!important;
    flex-direction:row!important;
    flex-wrap:wrap!important;
    gap:10px!important;
  }
  .ps-info-col > div{flex:1;min-width:140px;}
  .ps-grid{grid-template-columns:1fr!important;}
  .ps-grid > div{height:200px!important;}

  /* Prise de sang header h3 */
  #prise-de-sang h3{font-size:28px!important;}

  /* ── KIAL MOVE ── */
  .km-header{grid-template-columns:1fr!important;gap:20px!important;margin-bottom:32px!important;}
  .km-grid{grid-template-columns:1fr!important;gap:20px!important;}
  .km-img-grid{grid-template-rows:220px 160px!important;gap:10px!important;}
  /* Galerie kiné mobile */
  .kine-gallery-grid{grid-template-columns:1fr!important;grid-template-rows:240px 180px 180px!important;}
  .kine-gallery-grid>div:first-child{grid-row:span 1!important;}

  /* Kial Move buttons */
  .km-header ~ div .btn-p,
  .km-header ~ div .btn-g{font-size:13px;padding:12px 20px;}

  /* Kial Move h2 */
  #kial-move h2{font-size:clamp(32px,8vw,48px)!important;}

  /* ── CONTACT ── */
  .contact-inner-wrap{padding-left:20px!important;padding-right:20px!important;}
  #contact .contact-grid{margin-top:32px;}

  /* ── MAP ── */
  #kial-map{height:340px!important;}

  /* ── POPUP ── */
  #ps-popup{
    width:calc(100vw - 32px)!important;
    right:16px!important;
    bottom:16px!important;
    left:16px!important;
  }

  /* Galerie images */
  .gallery-scroll img{height:140px!important;}
}

/* ── SMALL MOBILE 480px ── */
@media (max-width:480px){

  /* Section div padding */
  #valeurs,#services,#localisation,#horaires,#equipe{padding:56px 0!important;}
  #prise-de-sang{padding:56px 0!important;}
  #kial-move{padding:52px 0!important;}
  #contact{padding:52px 0!important;}
  #galerie{padding:36px 0 52px!important;}

  /* Inner padding */
  .ps-inner,.km-inner,.contact-inner-wrap{padding-left:16px!important;padding-right:16px!important;}
  .map-top{padding:36px 16px 20px!important;}
  .map-cards-grid{padding:0 16px 16px!important;}

  /* ── PRISE DE SANG ── */
  .ps-card{padding:20px 16px!important;}
  .ps-info-col{flex-direction:column!important;}
  .ps-info-col > div{min-width:unset!important;}
  .ps-grid > div{height:170px!important;}

  /* ── KIAL MOVE ── */
  .km-img-grid{grid-template-rows:180px 130px!important;}

  /* Kial Move cards text */
  #kial-move .reveal[style*="flex-direction:column"] > div{padding:16px 14px!important;}

  /* ── MAP ── */
  #kial-map{height:280px!important;}
  .map-cards-grid{gap:10px!important;}

  /* Contact header margin */
  #contact .reveal[style*="margin-bottom:64px"]{margin-bottom:36px!important;}

  /* Gallery */
  .gallery-scroll img{height:120px!important;}

  /* Horaires row2 */
  .hor-row2{max-width:100%;}
}

/* =====================================================
   FIX — SCROLL HORIZONTAL, NOTRE ESPACE, NOUS CONTACTER
   ===================================================== */

/* ── Fix scroll horizontal global ── */
*{box-sizing:border-box;}
html,body{overflow-x:hidden;max-width:100%;}

/* ── Fix gallery scroll débordement ── */
.gallery-strip{overflow:hidden;max-width:100vw;}

/* ── Fix about-float débordement droite ── */
@media (max-width:1024px){
  .about-float{right:0!important;bottom:-10px!important;}
}
@media (max-width:768px){
  .about-float{right:0!important;bottom:-8px!important;padding:14px 16px!important;}
  .about-circle{left:-8px!important;}
  /* Empêche débordement du conteneur visuel */
  .about-visual{overflow:visible;}
  .about-inner{overflow:hidden;}
}
@media (max-width:480px){
  .about-float{position:relative!important;bottom:auto!important;right:auto!important;margin-top:16px;display:inline-flex;gap:12px;border-radius:14px;}
  .about-circle{display:none!important;}
}

/* ── CONTACT — grille 3 cartes responsive ── */
@media (max-width:1024px){
  .contact-cards-grid{grid-template-columns:1fr!important;gap:16px!important;}
  .contact-hours-bar{padding:24px 28px!important;}
}
@media (max-width:768px){
  #contact{padding:64px 0!important;}
  .contact-cards-grid{grid-template-columns:1fr!important;gap:14px!important;margin-bottom:28px!important;}
  .contact-cards-grid .reveal{padding:28px 20px!important;}
  .contact-hours-bar{
    flex-direction:column!important;
    align-items:flex-start!important;
    gap:20px!important;
    padding:24px 20px!important;
  }
  .contact-hours-bar > div:last-child{
    flex-direction:column!important;
    gap:16px!important;
    width:100%;
  }
  /* Séparateurs verticaux en horizontaux */
  .contact-hours-bar div[style*="width:1px"]{
    width:100%!important;
    height:1px!important;
  }
}
@media (max-width:480px){
  #contact{padding:52px 0!important;}
  .contact-cards-grid .reveal{padding:24px 16px!important;}
  .contact-hours-bar{padding:20px 16px!important;}
}

/* ── NOTRE ESPACE (#valeurs) — fix débordements ── */
@media (max-width:768px){
  #valeurs{overflow:hidden;}
  .about-visual{height:260px!important;}
}

/* =====================================================
   FIX NAVBAR, GALERIE, FONDÉ EN 2021
   ===================================================== */

/* ── Navbar logo cliquable partout ── */
.nav-logo{cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0);}
.nav-logo img{height:40px;width:auto;display:block;}
@media (max-width:768px){
  .nav-logo img{height:34px;}
}

/* ── GALERIE "Notre Espace" ── */
.galerie-inner{padding:0 48px;}
.galerie-dots{display:none;}

/* ── Galerie items (Notre espace) ── */
.gi-item{
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 8px 32px rgba(52,75,108,.11);
  position:relative;
  cursor:pointer;
}
.gi-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .65s cubic-bezier(.25,.46,.45,.94);
}
.gi-item:hover img{transform:scale(1.06);}
.gi-lbl{
  position:absolute;
  bottom:16px;
  left:16px;
  background:rgba(18,28,46,.70);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  color:#fff;
  font-family:var(--fb);
  font-size:10.5px;
  font-weight:500;
  letter-spacing:.9px;
  text-transform:uppercase;
  padding:6px 14px;
  border-radius:30px;
  opacity:0;
  transform:translateY(8px);
  transition:opacity .3s ease,transform .3s ease;
  pointer-events:none;
}
.gi-item:hover .gi-lbl{opacity:1;transform:translateY(0);}

/* Items visibles uniquement sur mobile (cachés sur desktop) */
.gi-mobile-only{display:none;}

/* Tablet */
@media (max-width:1024px){
  .galerie-inner{padding:0 28px!important;}
  .galerie-header{gap:20px!important;}
  #galerie{padding:72px 0 88px!important;}
}

/* Mobile */
@media (max-width:768px){
  .galerie-inner{padding:0 20px!important;}
  #galerie{padding:160px 0 96px!important;}

  /* Header passe en colonne */
  .galerie-header{
    flex-direction:column!important;
    align-items:flex-start!important;
    gap:20px!important;
    margin-bottom:32px!important;
  }
  .galerie-btn{
    align-self:flex-start!important;
    flex-shrink:unset!important;
    padding:12px 22px!important;
    font-size:12px!important;
  }

  /* Items mobile-only visibles dans le carousel */
  .gi-mobile-only{display:block!important;}

  /* Galerie : carousel horizontal mobile */
  .galerie-grid{
    display:flex!important;
    overflow-x:auto!important;
    scroll-snap-type:x mandatory!important;
    gap:12px!important;
    grid-template-columns:unset!important;
    grid-template-rows:unset!important;
    padding-bottom:4px!important;
    scrollbar-width:none!important;
    -ms-overflow-style:none!important;
  }
  .galerie-grid::-webkit-scrollbar{display:none!important;}
  .galerie-grid > div{
    flex:0 0 82%!important;
    grid-row:unset!important;
    grid-column:unset!important;
    height:240px!important;
    border-radius:14px!important;
    scroll-snap-align:start!important;
  }
  .galerie-grid img{
    width:100%!important;
    height:100%!important;
    object-fit:cover!important;
    display:block!important;
  }
  .galerie-grid > div:first-child img,
  .galerie-grid .gi-item:first-child img{
    object-position:center 25%!important;
  }
  /* Labels hidden on mobile */
  .gi-lbl{display:none!important;}
  /* Dots carousel galerie */
  .galerie-dots{
    display:flex!important;
    justify-content:center;
    gap:6px;
    margin-top:14px;
  }
  .galerie-dots span{
    width:6px;height:6px;border-radius:50%;
    background:rgba(52,75,108,.25);transition:background .25s,transform .25s;
    display:inline-block;
  }
  .galerie-dots span.active{background:var(--navy);transform:scale(1.3);}
}

/* Petit mobile */
@media (max-width:480px){
  .galerie-inner{padding:0 16px!important;}
  #galerie{padding:80px 0 60px!important;}
  .galerie-grid > div{
    flex:0 0 88%!important;
    height:210px!important;
    border-radius:12px!important;
  }
}

/* ── FONDÉ EN 2021 (about-float) — version mobile propre ── */
@media (max-width:768px){
  /* Repositionne le float pour qu'il reste dans le cadre */
  .about-float{
    right:10px!important;
    bottom:10px!important;
    padding:14px 18px!important;
  }
  .about-float .n{font-size:28px!important;line-height:1!important;}
  .about-float .l{font-size:11px!important;}
}
@media (max-width:480px){
  /* Sur très petit écran : en bas sous l'image en flex horizontal */
  .about-float{
    position:relative!important;
    bottom:auto!important;
    right:auto!important;
    margin-top:12px!important;
    display:inline-flex!important;
    gap:10px!important;
    align-items:center!important;
    padding:12px 18px!important;
    border-radius:14px!important;
  }
  .about-float .n{font-size:22px!important;margin-right:4px;}
  .about-visual{height:220px!important;}
}


/* =====================================================
   PLANNING DES THÉRAPEUTES
   ===================================================== */
.planning-inner{max-width:1200px;margin:0 auto;padding:0 48px;}
.plan-legend{display:flex;align-items:center;gap:20px;flex-wrap:wrap;font-size:12px;color:var(--text-soft);margin-bottom:36px;}
.plan-legend span{display:flex;align-items:center;gap:7px;}
.plan-dot-legend{width:11px;height:11px;border-radius:50%;display:inline-block;flex-shrink:0;}

/* Tab bar */
.plan-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px;}

/* Table scroll wrapper */
.plan-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:16px;box-shadow:0 4px 28px rgba(28,58,74,.09);}

/* Table */
.plan-table{min-width:600px;border-radius:16px;overflow:hidden;background:white;}
.plan-section{display:none;}
.plan-section.active{display:block;}

/* Header row */
.plan-head{
  display:grid;
  grid-template-columns:180px repeat(6,1fr);
  background:var(--navy);
}
.plan-head > div{
  padding:13px 8px;
  text-align:center;
  font-size:11px;
  font-weight:500;
  color:rgba(255,255,255,.6);
  letter-spacing:.8px;
  text-transform:uppercase;
}
.plan-head .plan-specialty-name{
  background:var(--gold);
  color:white!important;
  font-family:var(--fd);
  font-size:14px;
  font-weight:600;
  letter-spacing:1.5px;
  text-align:left;
  padding:13px 18px;
  display:flex;
  align-items:center;
}

/* Sub-header (Matin / AM labels) */
.plan-sub{
  display:grid;
  grid-template-columns:180px repeat(6,1fr);
  background:rgba(226,244,255,.5);
  border-bottom:1px solid var(--sky-mid);
}
.plan-sub > div{
  font-size:10px;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:var(--text-soft);
  text-align:center;
  padding:6px 4px;
}
.plan-sub .lbl{text-align:left;padding-left:18px;color:transparent;}

/* Therapist row */
.plan-row{
  display:grid;
  grid-template-columns:180px repeat(6,1fr);
  border-bottom:1px solid var(--cream-dark);
  transition:background .15s;
}
.plan-row:last-child{border-bottom:none;}
.plan-row:hover{background:rgba(226,244,255,.3);}

/* Name cell */
.plan-nm{
  padding:0 18px;
  font-family:var(--fd);
  font-size:15px;
  font-weight:600;
  color:var(--navy);
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-right:2px solid var(--cream-dark);
  min-height:64px;
  line-height:1.3;
}
.plan-nm small{
  font-family:var(--fb);
  font-size:11px;
  font-weight:400;
  color:var(--text-soft);
  margin-top:2px;
}

/* Day cell */
.plan-dy{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:10px 6px;
  border-right:1px solid var(--cream-dark);
}
.plan-dy:last-child{border-right:none;}

/* Individual slot dot */
.pd{
  width:11px;height:11px;border-radius:50%;
  border:1.5px solid var(--sky-mid);
  background:transparent;
  flex-shrink:0;
  transition:transform .15s;
}
.pd.m{border-color:var(--gold);}
.pd.m.on{background:var(--gold);border-color:var(--gold);}
.pd.a{border-color:var(--navy);}
.pd.a.on{background:var(--navy);border-color:var(--navy);}

/* Caption below dots */
.plan-slot-wrap{display:flex;flex-direction:column;align-items:center;gap:5px;}
.plan-slot-wrap .slot-lbl{font-size:9px;letter-spacing:.3px;color:var(--text-soft);text-transform:uppercase;}

/* Responsive */
@media(max-width:1024px){.planning-inner{padding:0 28px;}}
@media(max-width:768px){
  .planning-inner{padding:0 20px;}
  #planning{padding:72px 0!important;}
  .plan-head{grid-template-columns:130px repeat(6,1fr);}
  .plan-sub{grid-template-columns:130px repeat(6,1fr);}
  .plan-row{grid-template-columns:130px repeat(6,1fr);}
  .plan-nm{padding:0 12px;font-size:13px;min-height:56px;}
  .plan-head .plan-specialty-name{padding:12px 14px;font-size:13px;}
}
@media(max-width:480px){
  #planning{padding:56px 0!important;}
  .planning-inner{padding:0 16px;}
  .plan-legend{gap:12px;}
}

/* Pathologies Modal */
#patho-modal{display:none;position:fixed;inset:0;z-index:9999;align-items:center;justify-content:center;padding:20px;}
#patho-modal.open{display:flex;}
#patho-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);}
#patho-modal-box{position:relative;background:#fff;border-radius:20px;max-width:860px;width:100%;max-height:88vh;overflow-y:auto;padding:40px 44px;box-shadow:0 24px 80px rgba(0,0,0,.3);}
#patho-modal-box::-webkit-scrollbar{width:5px;}
#patho-modal-box::-webkit-scrollbar-thumb{background:var(--gold);border-radius:4px;}
.patho-close{position:absolute;top:18px;right:20px;background:none;border:none;font-size:22px;cursor:pointer;color:#888;line-height:1;}
.patho-close:hover{color:#333;}
.patho-modal-title{font-family:var(--fd);font-size:clamp(22px,3vw,32px);font-weight:300;color:var(--navy);margin-bottom:6px;}
.patho-modal-intro{font-size:13px;color:var(--text-soft);line-height:1.8;margin-bottom:28px;max-width:600px;}
.patho-regions{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.patho-region{background:#f8f6f2;border-radius:12px;padding:18px 20px;}
.patho-region h4{font-family:var(--fd);font-size:15px;font-weight:600;color:var(--navy);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(156,139,88,.25);}
.patho-region ul{list-style:none;padding:0;margin:0;}
.patho-region ul li{font-size:12px;color:var(--text-soft);line-height:1.7;padding:2px 0 2px 14px;position:relative;}
.patho-region ul li::before{content:"·";position:absolute;left:4px;color:var(--gold);font-size:14px;}
@media(max-width:640px){.patho-regions{grid-template-columns:1fr;}#patho-modal-box{padding:28px 22px;}}

/* Active nav link */
.nav-links a.active{opacity:1;color:var(--gold)!important;font-weight:500;}
.nav-links a.active::after{content:'';display:block;height:2px;background:var(--gold);border-radius:1px;margin-top:2px;}

/* ══ KINE SPECS + EQUIP RESPONSIVE ══ */
@media(max-width:1024px){
  .km-specs-grid{grid-template-columns:repeat(2,1fr)!important;}
  .km-equip-row{gap:36px!important;}
}
@media(max-width:768px){
  /* Spécialités: 1 colonne */
  .km-specs-grid{grid-template-columns:1fr!important;}
  /* Équipements */
  .km-equip-row{grid-template-columns:1fr!important;gap:24px!important;margin-bottom:48px!important;}
  .km-equip-reverse>div:first-child{order:2;}
  .km-equip-reverse>div:last-child{order:1;}
  .km-equip-row>div[style*="height:320px"]{height:200px!important;}
  /* Galerie mobile — nouveau layout éditorial */
  .kg-hero{height:240px!important;margin-bottom:10px!important;}
  .kg-duo{gap:10px!important;margin-bottom:10px!important;}
  .kg-duo>div{height:170px!important;}
  .kg-asym{grid-template-columns:1fr 1fr!important;gap:10px!important;margin-bottom:10px!important;}
  .kg-asym>div{height:200px!important;}
  .kg-wide{height:190px!important;}
  /* Extra breathing room between gallery items */
  .km-gallery-section .km-inner{padding:0 20px!important;}
  /* Sections padding */
  .km-specs-section{padding:48px 0!important;}
  .km-equip-section{padding:48px 0!important;}
  .km-gallery-section{padding:48px 0 36px!important;}
}

/* ═══ Alexandre Del Barrio — Mobile ═══ */
@media(max-width:768px){
  .alex-intro-grid,
  .alex-split-grid{
    grid-template-columns:1fr!important;
    gap:32px!important;
  }
  /* Image toujours en premier sur mobile */
  .alex-split-grid>div:first-child:not([style*="border-radius"]){
    order:2;
  }
  .alex-split-grid>div[style*="border-radius"]{
    order:1;
    aspect-ratio:16/10!important;
    max-height:260px!important;
  }
  .alex-intro-grid>div[style*="border-radius"]{
    aspect-ratio:16/10!important;
    max-height:260px!important;
  }
  /* Padding sections */
  #kial-move~div[style*="background:var(--navy)"] .alex-intro-grid,
  #kial-move~div[style*="background:var(--navy)"] .alex-split-grid{
    padding:48px 0!important;
  }
  /* Espace intro QUI SUIS-JE géré via clamp() inline */
  /* Dry Needling mobile */
  .dry-section .dry-content-grid{
    grid-template-columns:1fr!important;
    gap:32px!important;
  }
  .dry-section [style*="aspect-ratio:16/7"]{
    aspect-ratio:16/9!important;
    margin-bottom:32px!important;
  }
  .dry-new-grid{
    grid-template-columns:1fr!important;
    gap:32px!important;
  }
  .dry-new-grid > div:first-child{
    height:240px!important;
  }
}
