/* ─── VARIABLES ─── */
:root{
  --beige-light:#F5F0E8;--beige-mid:#EDE6D3;--beige-dark:#D6C9B0;
  --green-dark:#ABAD9E;--green-mid:#2D6A4F;--green-light:#40916C;
  --gold:#ABAD9E;--gold-light:#C4C6B9;
  --accent:#ABA67F;--accent-light:#C8C4A0;--accent-dark:#8E8A68;
  --text-dark:#1A1A1A;--text-mid:#4A4A4A;--text-light:#7A7A7A;
  --white:#fff;
  --font-title:'Cormorant Garamond',Georgia,serif;
  --font-body:'Jost',system-ui,sans-serif;
  --radius-sm:8px;--radius-md:16px;--radius-lg:28px;--radius-pill:100px;
  --shadow-card:0 8px 40px rgba(171,173,158,.12);
  --shadow-hover:0 24px 64px rgba(171,173,158,.2);
  --transition:all .38s cubic-bezier(.25,.46,.45,.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--text-dark);background:var(--beige-light);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-mid);text-decoration:none;transition:var(--transition)}

/* ─── UTILITIES ─── */
.container{max-width:1160px;margin:0 auto;padding:0 2rem}
.container-sm{max-width:820px;margin:0 auto;padding:0 2rem}
.text-center{text-align:center}
.section-label{display:inline-flex;align-items:center;gap:.75rem;font-size:.72rem;font-weight:500;letter-spacing:.17em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.section-label::before,.section-label::after{content:'';display:block;width:28px;height:1px;background:var(--gold)}
.section-title{font-family:var(--font-title);font-size:clamp(2rem,4vw,3.2rem);color:var(--green-dark);line-height:1.1;margin-bottom:1.5rem}
.section-title em{font-style:italic;color:var(--green-mid)}
.section-subtitle{font-size:1rem;color:var(--text-mid);max-width:560px;margin:0 auto 3rem;line-height:1.9}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:13px 30px;border-radius:var(--radius-pill);font-family:var(--font-body);font-size:.87rem;font-weight:500;cursor:pointer;border:none;transition:var(--transition);text-decoration:none;letter-spacing:.03em}
.btn-primary{background:var(--green-dark);color:var(--white);box-shadow:0 4px 20px rgba(27,67,50,.26)}
.btn-primary:hover{background:var(--green-mid);color:var(--white);transform:translateY(-2px);box-shadow:0 12px 34px rgba(27,67,50,.36)}
.btn-gold{background:var(--gold);color:var(--white)}
.btn-gold:hover{background:var(--gold-light);color:var(--green-dark);transform:translateY(-2px)}
.btn-white{background:var(--white);color:var(--green-dark)}
.btn-white:hover{background:var(--beige-light)}
.btn-secondary{background:transparent;color:var(--green-dark);border:1.5px solid var(--green-dark)}
.btn-secondary:hover{background:var(--green-dark);color:var(--white)}
.btn-lg{padding:16px 40px;font-size:.95rem}
.pill-badge{display:inline-flex;align-items:center;padding:6px 16px;border-radius:var(--radius-pill);border:1.5px solid var(--beige-dark);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mid);background:var(--white)}
.pill-badge.gold{border-color:var(--gold);color:var(--gold);background:rgba(200,169,110,.07)}

/* ─── REVEAL ANIMATIONS ─── */
.reveal{opacity:0;transform:translateY(44px);transition:opacity .9s cubic-bezier(.2,.6,.4,1),transform .9s cubic-bezier(.2,.6,.4,1)}
.reveal.in{opacity:1;transform:none}
.reveal-l{opacity:0;transform:translateX(-44px);transition:opacity .9s cubic-bezier(.2,.6,.4,1),transform .9s cubic-bezier(.2,.6,.4,1)}
.reveal-l.in{opacity:1;transform:none}
.reveal-r{opacity:0;transform:translateX(44px);transition:opacity .9s cubic-bezier(.2,.6,.4,1),transform .9s cubic-bezier(.2,.6,.4,1)}
.reveal-r.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.22s}.d3{transition-delay:.34s}.d4{transition-delay:.46s}

/* ─── NAVBAR ─── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .45s,box-shadow .45s}
.navbar.scrolled{background:rgba(245,240,232,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 2px 28px rgba(27,67,50,.07)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:78px}
.logo{display:flex;align-items:center;text-decoration:none}
.logo-wrap{position:relative;height:46px;width:148px}
.logo-img{height:46px;width:auto;max-width:148px;display:block;position:absolute;top:0;left:0;transition:opacity .45s ease}
.logo-beige{opacity:1}
.logo-vert{opacity:0}
.navbar.scrolled .logo-beige{opacity:0}
.navbar.scrolled .logo-vert{opacity:1}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.82rem;font-weight:500;letter-spacing:.05em;color:rgba(255,255,255,.88);transition:color .3s}
.navbar.scrolled .nav-links a{color:var(--text-dark)}
.nav-links a:hover{color:var(--gold)}
.nav-cta{background:var(--gold);color:var(--white)!important;padding:9px 22px;border-radius:var(--radius-pill);font-size:.8rem}
.nav-cta:hover{background:var(--gold-light);color:var(--green-dark)!important}

/* ─── HERO ─── */
.hero{height:100vh;min-height:700px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;}
  .mobile_banner{display: none;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(165deg,rgba(171,173,158,.62) 0%,rgba(171,173,158,.28) 55%,rgba(0,0,0,.16) 100%);}
.hero-content{position:relative;z-index:2;text-align:center;color:var(--white);padding:0 2rem;max-width:880px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.75rem;font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-light);margin-bottom:1.75rem;font-weight:500}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';display:block;width:40px;height:1px;background:var(--gold-light)}
.hero-title{font-family:var(--font-title);font-size:clamp(3.2rem,7.5vw,6.4rem);font-weight:300;line-height:1.05;color:var(--white);margin-bottom:1.5rem;text-shadow:0 2px 30px rgba(0,0,0,.14)}
.hero-title em{font-style:italic;color:#1B4332;}
.hero-sub{font-size:clamp(.95rem,2vw,1.08rem);color:rgba(255,255,255,.8);max-width:660px;margin:0 auto 2.75rem;line-height:1.92;font-weight:300}
.hero-actions{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;color:rgba(255,255,255,.45);font-size:.67rem;letter-spacing:.16em;text-transform:uppercase;animation:bounce 2.8s ease-in-out infinite}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(9px)}}

/* ─── FEATURES STRIP ─── */
.features-strip{padding:80px 0;background:var(--white)}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;text-align:center}
.feat-item{display:flex;flex-direction:column;align-items:center;gap:1.25rem}
.feat-icon{width:70px;height:70px;border-radius:50%;background:var(--beige-light);display:flex;align-items:center;justify-content:center;font-size:1.7rem;flex-shrink:0;transition:var(--transition)}
.feat-item:hover .feat-icon{background:var(--green-dark);transform:scale(1.1) rotate(-6deg)}
.feat-item h3{font-family:var(--font-title);font-size:1.38rem;color:var(--green-dark);font-weight:400}
.feat-item p{font-size:.87rem;color:var(--text-mid);line-height:1.85;max-width:240px}

/* ─── STATS BAND ─── */
.stats-band{background:var(--beige-light);padding:90px 0;position:relative;overflow:hidden}
.stats-band::before,.stats-band::after{content:'';position:absolute;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.stats-band::before{top:0}.stats-band::after{bottom:0}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:960px;margin:0 auto}
.stat-item{display:flex;flex-direction:column;align-items:center;gap:1.1rem;padding:2rem 1.5rem;position:relative;text-align:center}
.stat-item:not(:last-child)::after{content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:64px;background:linear-gradient(180deg,transparent,var(--accent),transparent)}
.stat-icon-wrap{width:56px;height:56px;border-radius:50%;border:1.5px solid var(--accent);display:flex;align-items:center;justify-content:center;color:var(--accent);transition:var(--transition);flex-shrink:0}
.stat-icon-wrap svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.stat-item:hover .stat-icon-wrap{background:var(--accent);color:var(--white);transform:scale(1.1) rotate(-6deg)}
.stat-val{font-family:var(--font-title);font-size:clamp(2.2rem,3.5vw,3rem);color:var(--green-dark);line-height:1;font-weight:400;letter-spacing:-.01em}
.stat-val-unit{font-family:var(--font-title);font-size:1.4rem;color:var(--accent);vertical-align:super;line-height:0}
.stat-lbl{font-size:.71rem;color:var(--text-light);letter-spacing:.12em;text-transform:uppercase;line-height:1.5;max-width:140px}

/* ─── RETRAITES ─── */
.retreats-section{padding:120px 0;background:var(--beige-light)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem}
.card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);transition:var(--transition);display:flex;flex-direction:column}
.card:hover{transform:translateY(-9px);box-shadow:var(--shadow-hover)}
.card-img{position:relative;height:300px;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.card:hover .card-img img{transform:scale(1.06)}
.card-badge{position:absolute;top:1.2rem;left:1.2rem;background:var(--gold);color:var(--white);font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:var(--radius-pill)}
.card-flag{position:absolute;top:1.2rem;right:1.2rem;font-size:1.8rem}
.card-body{padding:2rem;flex:1;display:flex;flex-direction:column}
.card-loc{font-size:.73rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;display:flex;align-items:center;gap:.4rem}
.card-title{font-family:var(--font-title);font-size:1.7rem;color:var(--green-dark);margin-bottom:.75rem;line-height:1.2}
.card-title em{font-style:italic}
.card-desc{font-size:.87rem;color:var(--text-mid);line-height:1.8;margin-bottom:1.5rem;flex:1}
.card-meta{display:flex;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}
.card-meta span{display:flex;align-items:center;gap:.35rem;font-size:.79rem;color:var(--text-mid)}
.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:1.25rem;border-top:1px solid var(--beige-mid);gap:1rem}
.price-val{font-family:var(--font-title);font-size:2rem;color:var(--green-dark);line-height:1}
.price-lbl{font-size:.68rem;color:var(--text-light)}

/* ─── COMMUNAUTÉ ─── */
.community{padding:120px 0;background:var(--white)}
.community-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.community-avatars{display:flex;align-items:center;margin-bottom:1.75rem}
.av{width:54px;height:54px;border-radius:50%;border:3px solid var(--white);object-fit:cover;margin-right:-14px;box-shadow:0 2px 8px rgba(0,0,0,.1);transition:transform .25s}
.av:hover{transform:scale(1.15) translateY(-4px);z-index:5}
.av-count{width:54px;height:54px;border-radius:50%;border:3px solid var(--white);background:var(--green-dark);color:var(--white);font-size:.67rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-left:6px;flex-shrink:0;text-align:center;line-height:1.2}
.community-img-wrap{position:relative;border-radius:var(--radius-lg);overflow:visible}
.community-img-wrap img.main{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius-lg)}
.community-float{position:absolute;top:1.5rem;right:-2rem;width:130px;height:130px;border-radius:var(--radius-md);object-fit:cover;border:4px solid var(--white);box-shadow:var(--shadow-card)}

/* ─── GUIDES ─── */
.guides-section{padding:120px 0;background:var(--beige-light)}
.guides-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.guide-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);transition:var(--transition)}
.guide-card:hover{transform:translateY(-9px);box-shadow:var(--shadow-hover)}
.guide-card__img{position:relative;aspect-ratio:3/4;overflow:hidden}
.guide-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.guide-card:hover .guide-card__img img{transform:scale(1.05)}
.guide-arrow{position:absolute;top:1.25rem;right:1.25rem;width:48px;height:48px;border-radius:50%;background:rgba(245,240,232,.92);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;color:var(--green-dark);font-size:1.2rem;transition:var(--transition);text-decoration:none;z-index:2}
.guide-card:hover .guide-arrow{background:var(--gold);color:var(--white);transform:scale(1.1) rotate(-5deg)}
.guide-card__body{padding:1.75rem 2rem}
.guide-card__name{font-family:var(--font-title);font-size:1.55rem;color:var(--green-dark);margin-bottom:.3rem;font-weight:400}
.guide-card__role{font-size:.78rem;color:var(--text-light);letter-spacing:.04em}

/* ─── PRATIQUES ACCORDÉON ─── */
.practices{padding:120px 0;background:var(--white)}
.prac-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.prac-img-wrap{position:sticky;top:100px;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5}
.prac-img-wrap img{width:100%;height:100%;object-fit:cover}
.prac-item{border-bottom:1px solid var(--beige-dark)}
.prac-item:first-of-type{border-top:1px solid var(--beige-dark)}
.prac-header{display:flex;align-items:center;justify-content:space-between;padding:1.75rem 0;cursor:pointer;user-select:none;gap:1rem}
.prac-header h3{font-family:var(--font-title);font-size:1.78rem;color:var(--text-dark);font-weight:400;transition:color .3s}
.prac-item.active .prac-header h3{color:var(--green-dark)}
.prac-toggle{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--beige-dark);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--gold);flex-shrink:0;transition:var(--transition)}
.prac-item.active .prac-toggle{background:var(--green-dark);border-color:var(--green-dark);color:var(--white);transform:rotate(45deg)}
.prac-body{max-height:0;overflow:hidden;transition:max-height .5s ease,padding .5s ease}
.prac-body.open{max-height:360px;padding-bottom:1.5rem}
.prac-body p{font-size:.9rem;color:var(--text-mid);line-height:1.88;margin-bottom:1rem}
.check-list{list-style:none;padding:0;margin:0}
.check-list li{display:flex;align-items:center;gap:.75rem;font-size:.86rem;color:var(--text-mid);padding:.4rem 0}
.check-list li::before{content:'';width:20px;height:20px;border-radius:50%;background:var(--gold) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white' width='12' height='12'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E") center/12px no-repeat;flex-shrink:0}

/* ─── PROGRAMME TYPE ─── */
.program-section{padding:120px 0;background:var(--beige-mid)}
.program-entry{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;margin-bottom:6rem}
.program-entry:last-child{margin-bottom:0}
.program-entry:nth-child(even){direction:rtl}
.program-entry:nth-child(even)>*{direction:ltr}
.prog-img{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}
.prog-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.prog-img:hover img{transform:scale(1.04)}
.prog-time{display:inline-flex;padding:6px 16px;border-radius:var(--radius-pill);border:1.5px solid var(--beige-dark);background:var(--white);font-size:.7rem;font-weight:600;letter-spacing:.12em;color:var(--text-mid);margin-bottom:1.25rem}
.prog-title{font-family:var(--font-title);font-size:2.1rem;color:var(--green-dark);margin-bottom:.75rem;font-weight:400;line-height:1.15}
.prog-desc{font-size:.9rem;color:var(--text-mid);line-height:1.9}

/* ─── À PROPOS ─── */
.about{padding:120px 0;background:var(--beige-light)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-img-wrap{position:relative}
.about-img{width:100%;border-radius:var(--radius-lg);object-fit:cover;aspect-ratio:4/5;box-shadow:var(--shadow-card)}
.about-badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--green-dark);color:var(--white);border-radius:var(--radius-md);padding:1.25rem 1.75rem;text-align:center;box-shadow:var(--shadow-card)}
.about-badge .num{font-family:var(--font-title);font-size:2.4rem;color:var(--gold-light);display:block;line-height:1}
.about-badge .lbl{font-size:.68rem;color:rgba(255,255,255,.68);display:block;margin-top:.25rem}
.stats-row{display:flex;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}
.stat-box .num{font-family:var(--font-title);font-size:2.1rem;color:var(--green-dark)}
.stat-box .lbl{font-size:.72rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.07em;margin-top:.1rem}
.signature{font-family:var(--font-title);font-size:2.4rem;font-style:italic;color:var(--green-dark);margin-top:2rem;opacity:.45}

/* ─── TÉMOIGNAGES VIDEO ─── */
.testimonials{padding:120px 0;background:var(--white)}
.testi-header{text-align:center;margin-bottom:3.5rem}
.video-testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.video-testi-card{border-radius:var(--radius-lg);overflow:hidden;position:relative;aspect-ratio:9/16;cursor:pointer;background:var(--green-dark);box-shadow:var(--shadow-card);transition:var(--transition)}
.video-testi-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover)}
.video-testi-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.06) 0%,rgba(27,67,50,.65) 100%);z-index:1;transition:var(--transition)}
.video-testi-card:hover::after{background:linear-gradient(180deg,rgba(0,0,0,.04) 0%,rgba(27,67,50,.78) 100%)}
.video-testi-thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s ease;position:absolute;inset:0}
.video-testi-card:hover .video-testi-thumb{transform:scale(1.06)}
.video-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);z-index:2;width:64px;height:64px;background:rgba(255,255,255,.14);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.45);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);transition:var(--transition)}
.video-play-btn svg{width:22px;height:22px;fill:var(--white);margin-left:3px;flex-shrink:0}
.video-testi-card:hover .video-play-btn{background:var(--accent);border-color:var(--accent);transform:translate(-50%,-60%) scale(1.12)}
.video-testi-info{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:1.5rem 1.25rem 1.25rem}
.video-testi-name{font-family:var(--font-title);font-size:1.1rem;color:var(--white);font-weight:400;margin-bottom:.25rem;line-height:1.2}
.video-testi-sub{font-size:.71rem;color:rgba(255,255,255,.62);letter-spacing:.04em}
/* Modal */
.video-modal{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.92);align-items:center;justify-content:center;padding:2rem}
.video-modal.open{display:flex}
.video-modal-inner{position:relative;width:100%;max-width:840px;aspect-ratio:16/9;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.7)}
.video-modal iframe,.video-modal video{width:100%;height:100%;border:none;display:block;background:#000}
.video-modal-close{position:absolute;top:-52px;right:0;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.28);color:var(--white);font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}
.video-modal-close:hover{background:var(--accent);border-color:var(--accent)}
/* Trust badge */
.trust-badge{display:inline-flex;align-items:center;gap:.75rem;background:var(--beige-light);border:1px solid var(--beige-dark);border-radius:var(--radius-pill);padding:9px 20px;font-size:.8rem;color:var(--text-mid);margin-bottom:1rem}
.trust-stars{color:#00B67A}
/* Music Toggle */
.music-toggle{position:fixed;bottom:2rem;right:2rem;z-index:998;width:48px;height:48px;border-radius:50%;background:rgba(245,240,232,.94);border:1.5px solid var(--beige-dark);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--green-dark);transition:var(--transition);box-shadow:0 4px 24px rgba(27,67,50,.14);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.music-toggle:hover{background:var(--accent);border-color:var(--accent);color:var(--white);transform:scale(1.08)}
.music-toggle svg{width:20px;height:20px;flex-shrink:0}
.music-toggle .icon-muted{display:none}
@keyframes music-pulse{0%,100%{transform:scale(1);box-shadow:0 4px 24px rgba(27,67,50,.14)}50%{transform:scale(1.18);box-shadow:0 6px 32px rgba(171,166,127,.55)}}
.music-attention{animation:music-pulse 1.4s ease-in-out 4}

/* ─── GALERIE ─── */
.gallery-sec{padding:60px 0;background:var(--beige-light)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:240px 240px;gap:.75rem}
.g-item{overflow:hidden;border-radius:var(--radius-md);cursor:zoom-in}
.g-item:first-child{grid-column:span 2;grid-row:span 2}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.g-item:hover img{transform:scale(1.07)}

/* ─── CTA BAND ─── */
.cta-band{padding:120px 0;background:var(--green-dark);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1518241353330-0f7941c2d9b5?w=1400&q=50') center/cover;opacity:.1}
.cta-band>*{position:relative;z-index:1}
.cta-band .section-title{color:var(--white)}

/* ─── FOOTER ─── */
footer{background:#ABAD9E;color:#1B4332;padding:80px 0 0}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:60px;border-bottom:1px solid rgba(27,67,50,.15);}
.foot-logo{display:block;margin-bottom:1.25rem}
.foot-logo img{height:54px;width:auto}
.foot-tag{font-size:.84rem;color:rgba(27,67,50,.7);line-height:1.78;margin-bottom:1.75rem}
.social-links{display:flex;gap:.6rem}
.social-links a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.58);font-size:.85rem;transition:var(--transition)}
.social-links a:hover{background:var(--gold);border-color:var(--gold);color:var(--white);transform:translateY(-2px)}
.foot-col h4{font-size:.7rem;font-weight:600;letter-spacing:.17em;text-transform:uppercase;color:#1B4332;margin-bottom:1.25rem}
.foot-col ul{list-style:none}
.foot-col ul li{margin-bottom:.65rem}
.foot-col ul li a{font-size:.84rem;color:rgba(27,67,50,.7);transition:color .3s}
.foot-col ul li a:hover{color:var(--gold-light)}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0;font-size:.74rem;color:rgba(27,67,50,.5);flex-wrap:wrap;gap:.75rem}
.foot-bottom a{color:rgba(27,67,50,.5)}
.foot-bottom a:hover{color:var(--gold-light)}

/* ─── RESPIRATION GUIDÉE ─── */
.breathing-section{padding:120px 0;background:var(--green-dark);text-align:center;position:relative;overflow:hidden}
.breath-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.breath-particle{position:absolute;border-radius:50%;animation:float-p 10s ease-in-out infinite}
@keyframes float-p{0%{transform:translateY(100%) scale(0);opacity:0}20%{opacity:.6}80%{opacity:.2}100%{transfrm:translateY(-120px) scale(.4);opacity:0}}
.breathing-section .section-label{color:var(--gold-light)}
.breathing-section .section-label::before,.breathing-section .section-label::after{background:var(--gold-light)}
.breathing-section .section-title{color:var(--white)}
.breathing-section .section-title em{color:#1B4332;}
.breath-subtitle{font-size:.95rem;color: #1B4332;max-width:440px;margin:0 auto 2.5rem;line-height:1.85}
.breath-circle-wrap{width:220px;height:220px;margin:0 auto 1.75rem;position:relative;display:flex;align-items:center;justify-content:center}
.breath-ring{position:absolute;inset:0;border-radius:50%;background:conic-gradient(from 0deg,rgba(200,169,110,.25),rgba(64,145,108,.3),rgba(200,169,110,.25));animation:spin-ring 10s linear infinite;filter:blur(2px)}
@keyframes spin-ring{to{transform:rotate(360deg)}}
.breath-ring2{position:absolute;inset:12px;border-radius:50%;background:conic-gradient(from 120deg,rgba(27,67,50,.4),rgba(200,169,110,.15),rgba(27,67,50,.4));animation:spin-ring 14s linear infinite reverse;filter:blur(1px)}
.breath-circle{width:130px;height:130px;border-radius:50%;background:radial-gradient(circle at 40% 40%,rgba(200,169,110,.7),rgba(45,106,79,.5),rgba(27,67,50,.6));box-shadow:0 0 50px rgba(200,169,110,.3),0 0 100px rgba(27,67,50,.4),inset 0 0 30px rgba(255,255,255,.08);transition:transform 4s cubic-bezier(.37,0,.63,1),box-shadow 4s ease;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}
.breath-circle.expand{transform:scale(1.75);box-shadow:0 0 80px rgba(200,169,110,.5),0 0 160px rgba(27,67,50,.3),inset 0 0 40px rgba(255,255,255,.12)}
.breath-inner-text{font-family:var(--font-title);font-size:1rem;font-style:italic;color:rgba(255,255,255,.85);letter-spacing:.05em}
.breath-label{font-family:var(--font-title);font-size:1.75rem;font-style:italic;color:var(--gold-light);margin-bottom:2rem;min-height:2.5rem;transition:opacity .6s ease,transform .6s ease;transform:translateY(0)}
.breath-label.hidden{opacity:0;transform:translateY(-8px)}
.breath-start{display:inline-flex;align-items:center;gap:.65rem;padding:13px 34px;border-radius:var(--radius-pill);background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.22);color:var(--white);font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);backdrop-filter:blur(10px)}
.breath-start:hover,.breath-start.active{background:var(--gold);border-color:var(--gold)}
.breath-cycles{font-size:.75rem;color:rgba(255,255,255,.35);margin-top:1.25rem;letter-spacing:.1em;text-transform:uppercase}


/* ─── CITATION SPIRITUELLE ─── */
.spiritual-section{padding:100px 0;background:var(--beige-mid);text-align:center}
.sq-card{background:var(--white);border-radius:var(--radius-lg);padding:3.5rem 3rem;max-width:740px;margin:2rem auto 2.5rem;box-shadow:var(--shadow-card);min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;position:relative;overflow:hidden}
.sq-card::before{content:'"';position:absolute;top:-20px;left:24px;font-family:var(--font-title);font-size:10rem;color:rgba(27,67,50,.05);line-height:1;pointer-events:none}
.sq-leaf{font-size:1.5rem}
.sq-text{font-family:var(--font-title);font-size:clamp(1.25rem,2.5vw,1.85rem);font-style:italic;color:var(--green-dark);line-height:1.55;transition:opacity .55s ease,transform .55s ease;transform:translateY(0)}
.sq-text.out{opacity:0;transform:translateY(14px)}
.sq-author{font-size:.82rem;color:var(--text-mid);letter-spacing:.06em;font-style:normal;transition:opacity .55s ease .1s,transform .55s ease .1s}
.sq-author.out{opacity:0;transform:translateY(8px)}
.sq-btn{display:inline-flex;align-items:center;gap:.6rem;padding:13px 30px;border-radius:var(--radius-pill);background:var(--green-dark);color:var(--white);font-family:var(--font-body);font-size:.88rem;font-weight:500;cursor:pointer;border:none;transition:var(--transition)}
.sq-btn:hover{background:var(--green-mid);transform:translateY(-2px)}
/* Hamburger button */
#nav-icon3 {
  width: 30px;
  height: 18px;
  position: absolute;
  right: 105px;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .5s ease-in-out;
  -moz-transition: .5s ease-in-out;
  -o-transition: .5s ease-in-out;
  transition: .5s ease-in-out;
  cursor: pointer;
  display: none;
}

#nav-icon3 span{
  display: block;
  position: absolute;
  height: 2px;
  width: 100%;
  background: #ffffff;
  border-radius: 0px;
  opacity: 1;
  left: 0;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .25s ease-in-out;
  -moz-transition: .25s ease-in-out;
  -o-transition: .25s ease-in-out;
  transition: .25s ease-in-out;
}
.home .navbar.scrolled #nav-icon3 span{background: #000000;}
#nav-icon3 span:nth-child(1) {
  top: 0px;
}

#nav-icon3 span:nth-child(2),#nav-icon3 span:nth-child(3) {
  top: 8px;
}

#nav-icon3 span:nth-child(4) {
  top: 16px;
}

#nav-icon3.open span:nth-child(1) {
  top: 16px;
  width: 0%;
  left: 50%;
}

#nav-icon3.open span:nth-child(2) {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
}

#nav-icon3.open span:nth-child(3) {
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

#nav-icon3.open span:nth-child(4) {
  top: 18px;
  width: 0%;
  left: 50%;
}

/* ─── TABS RETRAITES ─── */
.retreat-tabs{display:flex;gap:.75rem;justify-content:center;margin-bottom:3.5rem;flex-wrap:wrap}
.rtab-btn{padding:12px 34px;border-radius:var(--radius-pill);font-family:var(--font-body);font-size:.84rem;font-weight:500;letter-spacing:.04em;border:1.5px solid var(--beige-dark);background:transparent;color:var(--text-mid);cursor:pointer;transition:var(--transition)}
.rtab-btn.active{background:var(--green-dark);border-color:var(--green-dark);color:var(--white);box-shadow:0 4px 20px rgba(171,173,158,.22)}
.rtab-btn:hover:not(.active){border-color:var(--green-dark);color:var(--green-dark)}
.rtab-panel{display:none}.rtab-panel.active{display:block}

/* ─── PAST RETREATS GRID ─── */
.grid-3-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.card-past{background:var(--white);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-card);transition:var(--transition)}
.card-past:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover)}
.card-past__img{height:190px;overflow:hidden;position:relative}
.card-past__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card-past:hover .card-past__img img{transform:scale(1.07)}
.card-past__done{position:absolute;top:.75rem;left:.75rem;background:rgba(0,0,0,.48);color:#fff;font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:var(--radius-pill)}
.card-past__body{padding:1.25rem 1.5rem}
.card-past__loc{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem}
.card-past__title{font-family:var(--font-title);font-size:1.2rem;color:var(--green-dark);margin-bottom:.3rem;line-height:1.2}
.card-past__date{font-size:.78rem;color:var(--text-light)}






@media(max-width:960px){
  .grid-2,.community-grid,.prac-grid,.about-grid,.testi-grid,.guides-grid,.features-grid{grid-template-columns:1fr}
  .testi-grid .testi-card:nth-child(2){order:-1}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,220px)}
  .g-item:first-child{grid-column:span 2;grid-row:span 1}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .stat-item:not(:last-child)::after{display:none}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .about-badge{right:0;bottom:-.75rem}
  .program-entry,.program-entry:nth-child(even){direction:ltr;grid-template-columns:1fr}
  .community-float{right:.5rem}
  .video-testi-grid{grid-template-columns:repeat(2,1fr)}
   .grid-3-cards{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  html,body{overflow-x: hidden;}
  .nav-links{display:none}
  .foot-grid{grid-template-columns:1fr}
  .hero-title{font-size:2.8rem}
  .prac-img-wrap{display:none}
  .prac-grid{grid-template-columns:1fr}
  .video-testi-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
  .stats-inner{grid-template-columns:repeat(4,1fr)}
  .music-toggle{bottom:1.25rem;right:1.25rem;width:42px;height:42px}
  .card,.card:hover,.guide-card,.guide-card:hover,.video-testi-card,.video-testi-card:hover{box-shadow:none;}
  .stats-row{gap: 10px;}
  .stat-box .num{font-size: 1.6rem;min-height: 36px;}
  .stat-box .lbl{font-size: 10px;}
  .features-grid{display: flex;flex-wrap: wrap;justify-content: center;gap: 10px;}
  .features-grid .feat-item{flex: 0 0 30%;gap: 10px;}
  .features-grid .feat-item .feat-icon{width: 50px;height: 50px;}
  .features-grid .feat-item p{font-size: 11px;line-height: 17px;}
  .video-play-btn{width: 44px;height: 44px;}
  .stat-icon-wrap{width: 46px;height: 46px;}
  .stat-val{font-size: 18px;}
  .stat-val-unit{font-size: 12px;}
  .stat-lbl{font-size: 9px;}
  .stat-item{padding: 0 6px;gap: 8px;}
  .stats-band,.features-strip,.breathing-section,.retreats-section,.community,.guides-section,.about,.testimonials{padding: 40px 0;}
  .feat-item h3{font-size: 17px;}
.owl-carousel .owl-stage-outer{overflow: visible !important;}
.mobile_banner{display: block;}
.desktop_banner{display: none;}
.card.reveal .btn{padding: 9px 16px;width: 164px;}
.price-val{font-size: 28px;}
#nav-icon3{display: block;}
.navbar.scrolled .nav-links a,.worxcreative-inner .navbar .nav-links a,.worxcreative-inner .navbar.scrolled .nav-links a,.worxcreative-inner .navbar .nav-links a{color: #fff !important;}
.worxcreative-inner #nav-icon3 span{background: #000;}
.navbar .nav-links { 
  position: fixed;
  left: -250px; /* match width */
  top: 0;
  width: 250px;
  background: rgba(0, 0, 0, 0.8);
  padding: 20px;
  transition: left 0.5s ease-in-out;
  display: block;
  height: 100vh;

}

.navbar .nav-links.active {
  left: 0;
}
.navbar .nav-links a{
  display: block;
  padding: 10px 0px;
}
.navbar .nav-links a.nav-cta{
  padding: 12px 20px;
}
.retreat-tabs{flex-direction:column;align-items:center}
.gallery-albums-grid,.grid-3-cards{grid-template-columns:1fr}

}
