:root{
  --foret:#1b3a2f;
  --foret-fonce:#0f241d;
  --lac:#2e7d8c;
  --lac-clair:#79b8c4;
  --sable:#f3ede2;
  --pierre:#e7dfd0;
  --ocre:#c98f4e;
  --texte:#21302b;
  --blanc:#fdfcf9;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;color:var(--texte);background:var(--sable);overflow-x:hidden;line-height:1.7}
h1,h2,h3{font-family:'Cormorant Garamond',serif}

/* ---------- NAV ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:1rem 5vw;transition:background .4s,box-shadow .4s,padding .4s}
nav.scrolled{background:rgba(15,36,29,.92);backdrop-filter:blur(10px);box-shadow:0 2px 20px rgba(0,0,0,.25);padding:.6rem 5vw}
nav .logo{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:700;color:var(--blanc);text-decoration:none;letter-spacing:.5px}
nav .logo span{color:var(--lac-clair)}
nav ul{display:flex;gap:1.8rem;list-style:none}
nav ul a{color:rgba(255,255,255,.85);text-decoration:none;font-size:.85rem;font-weight:500;text-transform:uppercase;letter-spacing:1.5px;transition:color .3s;position:relative}
nav ul a::after{content:'';position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--lac-clair);transition:width .3s}
nav ul a:hover{color:#fff}
nav ul a:hover::after{width:100%}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;z-index:1001}
.burger span{width:26px;height:2px;background:#fff;transition:.3s}

/* ---------- HERO ---------- */
.hero{position:relative;height:100vh;min-height:640px;overflow:hidden;background:linear-gradient(180deg,#a8d4dd 0%,#cfe6e3 45%,#e8efdf 100%)}
.hero .layer{position:absolute;left:0;width:100%;bottom:0;will-change:transform}
.hero .sun{position:absolute;top:13%;right:16%;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle,#fff8e0 0%,#ffe9a8 55%,rgba(255,233,168,0) 75%);box-shadow:0 0 90px 50px rgba(255,240,190,.55);animation:pulse 7s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.cloud{position:absolute;background:rgba(255,255,255,.85);border-radius:100px;filter:blur(2px);animation:drift linear infinite}
@keyframes drift{from{transform:translateX(-25vw)}to{transform:translateX(120vw)}}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:10;padding:0 1.5rem}
.hero-content .surtitle{color:var(--foret);text-transform:uppercase;letter-spacing:6px;font-size:.85rem;font-weight:600;opacity:0;animation:fadeUp 1.2s .3s forwards}
.hero-content h1{font-size:clamp(2.8rem,8vw,6.2rem);color:var(--foret-fonce);font-weight:700;line-height:1.05;margin:.7rem 0;opacity:0;animation:fadeUp 1.2s .6s forwards;text-shadow:0 2px 30px rgba(255,255,255,.5)}
.hero-content p{font-size:clamp(1rem,2.2vw,1.35rem);color:var(--foret);font-weight:300;max-width:620px;opacity:0;animation:fadeUp 1.2s .9s forwards}
.hero-content .cta{margin-top:2.2rem;display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;opacity:0;animation:fadeUp 1.2s 1.2s forwards}
.btn{padding:.9rem 2.2rem;border-radius:50px;text-decoration:none;font-weight:500;font-size:.95rem;transition:transform .3s,box-shadow .3s;display:inline-block}
.btn-primary{background:var(--foret);color:#fff;box-shadow:0 8px 25px rgba(27,58,47,.35)}
.btn-secondary{background:rgba(255,255,255,.75);color:var(--foret);backdrop-filter:blur(4px)}
.btn:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(27,58,47,.4)}
@keyframes fadeUp{from{opacity:0;transform:translateY(35px)}to{opacity:1;transform:translateY(0)}}
.scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:11;color:var(--foret);font-size:.75rem;letter-spacing:3px;text-transform:uppercase;text-align:center;animation:bob 2.2s ease-in-out infinite}
.scroll-hint::after{content:'';display:block;width:1px;height:38px;background:var(--foret);margin:8px auto 0}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,10px)}}

/* ---------- SECTIONS ---------- */
section{padding:6.5rem 5vw}
.container{max-width:1150px;margin:0 auto}
.section-head{text-align:center;margin-bottom:3.5rem}
.section-head .kicker{text-transform:uppercase;letter-spacing:5px;font-size:.78rem;font-weight:600;color:var(--lac)}
.section-head h2{font-size:clamp(2.1rem,5vw,3.4rem);color:var(--foret-fonce);font-weight:700;margin-top:.4rem}
.section-head .line{width:70px;height:3px;background:var(--ocre);margin:1.1rem auto 0;border-radius:2px}
.reveal{opacity:0;transform:translateY(45px);transition:opacity .9s ease,transform .9s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* stats band */
.stats{background:var(--foret-fonce);color:var(--blanc);padding:3.2rem 5vw}
.stats .container{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2rem;text-align:center}
.stat .num{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:700;color:var(--lac-clair)}
.stat .label{font-size:.85rem;text-transform:uppercase;letter-spacing:2px;opacity:.75;margin-top:.2rem}

/* village */
.split{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;align-items:center}
.split .visu{border-radius:24px;overflow:hidden;box-shadow:0 25px 60px rgba(27,58,47,.25);aspect-ratio:4/3;position:relative}
.split .visu svg{width:100%;height:100%;display:block}
.split p{margin-bottom:1.1rem;font-weight:300;font-size:1.04rem}
.split p strong{font-weight:600;color:var(--foret)}
.tag-row{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.4rem}
.tag{background:var(--pierre);border:1px solid #d8cdb8;padding:.35rem 1rem;border-radius:50px;font-size:.8rem;font-weight:500;color:var(--foret)}

/* lac */
#lac{background:linear-gradient(180deg,var(--sable) 0%,#dcebe9 100%)}
.lake-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:2rem;margin-top:1rem}
.lake-card{background:var(--blanc);border-radius:22px;overflow:hidden;box-shadow:0 15px 40px rgba(46,125,140,.15);transition:transform .4s,box-shadow .4s}
.lake-card:hover{transform:translateY(-8px);box-shadow:0 25px 55px rgba(46,125,140,.28)}
.lake-card .head{height:150px;position:relative;overflow:hidden}
.lake-card .body{padding:1.6rem 1.7rem 1.9rem}
.lake-card h3{font-size:1.55rem;color:var(--foret-fonce);margin-bottom:.5rem}
.lake-card p{font-size:.95rem;font-weight:300}
.wave-bg{width:100%;height:100%;background:linear-gradient(160deg,var(--lac) 0%,var(--lac-clair) 100%);position:relative}
.wave-bg svg{position:absolute;bottom:-2px;left:0;width:200%;animation:waveSlide 9s linear infinite}
@keyframes waveSlide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.head-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3.2rem;filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))}

/* l'Orb */
#orb{background:linear-gradient(180deg,#dcebe9 0%,var(--sable) 30%,#e3ecea 100%)}
.orb-visu{display:grid;gap:1rem}
.orb-visu img{width:100%;border-radius:20px;box-shadow:0 18px 45px rgba(46,125,140,.25);display:block;object-fit:cover}
.orb-visu .cred{font-size:.72rem;opacity:.55;text-align:right}
.course{position:relative;max-width:880px;margin:4rem auto 0}
.course::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:4px;transform:translateX(-50%);background:rgba(46,125,140,.15);border-radius:2px}
.course .flow{position:absolute;left:50%;top:0;width:4px;height:0;transform:translateX(-50%);border-radius:2px;background:repeating-linear-gradient(180deg,var(--lac-clair) 0 14px,var(--lac) 14px 28px);background-size:100% 56px;animation:flowdown 1.1s linear infinite;box-shadow:0 0 10px rgba(121,184,196,.55)}
@keyframes flowdown{from{background-position:0 0}to{background-position:0 56px}}
.c-item{position:relative;width:50%;padding:.6rem 2.4rem 1.7rem}
.c-item:nth-child(odd){left:0;text-align:right}
.c-item:nth-child(even){left:50%;text-align:left}
.c-item::before{content:'';position:absolute;top:1rem;width:15px;height:15px;border-radius:50%;background:var(--lac);border:3px solid #fff;box-shadow:0 0 0 4px rgba(46,125,140,.25)}
.c-item:nth-child(odd)::before{right:-7.5px}
.c-item:nth-child(even)::before{left:-7.5px}
.c-item .km{font-size:.7rem;text-transform:uppercase;letter-spacing:2px;font-weight:600;color:var(--ocre)}
.c-item h4{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--foret-fonce)}
.c-item p{font-size:.88rem;font-weight:300}
.c-item.here::before{background:var(--ocre);animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 4px rgba(201,143,78,.3)}50%{box-shadow:0 0 0 9px rgba(201,143,78,.12)}}
@media(max-width:860px){
  .course::before,.course .flow{left:10px}
  .c-item{width:100%;left:0!important;text-align:left!important;padding:.6rem 0 1.7rem 2.4rem}
  .c-item::before{left:3px!important;right:auto!important}
}

/* activités */
.act-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:1.6rem}
.act-card{background:var(--blanc);border-radius:20px;padding:2rem 1.7rem;box-shadow:0 10px 30px rgba(27,58,47,.1);transition:transform .35s,box-shadow .35s;cursor:default;border-top:4px solid transparent}
.act-card:hover{transform:translateY(-7px) scale(1.015);box-shadow:0 22px 45px rgba(27,58,47,.2);border-top-color:var(--ocre)}
.act-card .icon{width:62px;height:62px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:1.9rem;margin-bottom:1.1rem;background:linear-gradient(135deg,#e3efe9,#cfe4dc)}
.act-card h3{font-size:1.45rem;color:var(--foret-fonce);margin-bottom:.45rem}
.act-card p{font-size:.92rem;font-weight:300}
.act-card .badge{display:inline-block;margin-top:.9rem;font-size:.72rem;text-transform:uppercase;letter-spacing:1.5px;font-weight:600;color:var(--lac);background:#e4f0f2;padding:.25rem .8rem;border-radius:50px}

/* patrimoine timeline */
#patrimoine{background:var(--foret-fonce);color:var(--pierre)}
#patrimoine .section-head h2{color:var(--blanc)}
#patrimoine .section-head .kicker{color:var(--ocre)}
.timeline{position:relative;max-width:820px;margin:0 auto;padding-left:0}
.timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--ocre),rgba(201,143,78,.15));transform:translateX(-50%)}
.t-item{position:relative;width:50%;padding:1.2rem 2.6rem 2.2rem;}
.t-item:nth-child(odd){left:0;text-align:right}
.t-item:nth-child(even){left:50%;text-align:left}
.t-item::before{content:'';position:absolute;top:1.7rem;width:14px;height:14px;border-radius:50%;background:var(--ocre);box-shadow:0 0 0 5px rgba(201,143,78,.25)}
.t-item:nth-child(odd)::before{right:-7px}
.t-item:nth-child(even)::before{left:-7px}
.t-item .date{font-family:'Cormorant Garamond',serif;font-size:1.7rem;font-weight:700;color:var(--ocre)}
.t-item h3{font-size:1.25rem;color:var(--blanc);margin:.2rem 0 .4rem}
.t-item p{font-size:.92rem;font-weight:300;opacity:.85}

/* alentours */
.around-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.8rem}
.around-card{position:relative;border-radius:22px;overflow:hidden;min-height:300px;display:flex;align-items:flex-end;box-shadow:0 15px 40px rgba(27,58,47,.18);transition:transform .4s}
.around-card:hover{transform:translateY(-7px)}
.around-card .bg{position:absolute;inset:0;transition:transform .6s}
.around-card .bg img{width:100%;height:100%;object-fit:cover;display:block}
.around-card:hover .bg{transform:scale(1.07)}
.around-card .info{position:relative;z-index:2;padding:1.6rem;width:100%;background:linear-gradient(0deg,rgba(10,25,20,.88) 0%,rgba(10,25,20,.45) 60%,transparent 100%);color:#fff}
.around-card h3{font-size:1.5rem}
.around-card .dist{font-size:.75rem;text-transform:uppercase;letter-spacing:2px;color:var(--lac-clair);font-weight:600}
.around-card p{font-size:.88rem;font-weight:300;opacity:.92;margin-top:.3rem}

/* carte */
#carte{background:linear-gradient(180deg,#dcebe9,var(--sable))}
#map{height:520px;border-radius:24px;box-shadow:0 20px 50px rgba(27,58,47,.25);z-index:1}
.map-legend{display:flex;gap:1.4rem;flex-wrap:wrap;justify-content:center;margin-top:1.4rem;font-size:.85rem}
.map-legend span{display:flex;align-items:center;gap:.45rem}
.dot{width:13px;height:13px;border-radius:50%;display:inline-block}

/* infos pratiques */
.infos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.6rem}
.info-box{background:var(--blanc);border-left:4px solid var(--lac);border-radius:14px;padding:1.7rem;box-shadow:0 8px 25px rgba(27,58,47,.08)}
.info-box h3{font-size:1.3rem;color:var(--foret-fonce);margin-bottom:.5rem}
.info-box p{font-size:.92rem;font-weight:300}

/* footer */
footer{background:var(--foret-fonce);color:rgba(255,255,255,.7);padding:3.5rem 5vw 2rem;text-align:center}
footer .ftitle{font-family:'Cormorant Garamond',serif;font-size:1.9rem;color:#fff;margin-bottom:.6rem}
footer .links{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;margin:1.3rem 0}
footer .links a{color:var(--lac-clair);text-decoration:none;font-size:.85rem}
footer .links a:hover{text-decoration:underline}
footer small{font-size:.75rem;opacity:.6}

/* barre de progression */
#progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--lac-clair),var(--ocre));z-index:1500;box-shadow:0 0 12px rgba(121,184,196,.7);transition:width .1s linear}

/* titre chatoyant */
.hero-content h1{background:linear-gradient(100deg,var(--foret-fonce) 30%,var(--lac) 48%,var(--foret-fonce) 65%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:fadeUp 1.2s .6s forwards,shine 7s 2s linear infinite}
@keyframes shine{to{background-position:-220% center}}

/* oiseaux */
.bird{position:absolute;z-index:6;opacity:.7;animation:fly linear infinite}
.bird svg{width:100%;height:100%}
.bird svg path{animation:flap .55s ease-in-out infinite alternate;transform-origin:center;stroke:var(--foret);stroke-width:2.5;fill:none;stroke-linecap:round}
@keyframes fly{from{transform:translate(-12vw,2vh)}to{transform:translate(112vw,-7vh)}}
@keyframes flap{from{transform:scaleY(.45)}to{transform:scaleY(1.05)}}

/* reveals directionnels + cascade */
.t-item.reveal{transform:translateX(-55px)}
.t-item.reveal:nth-child(even){transform:translateX(55px)}
.t-item.reveal.visible{transform:translateX(0)}
.tilt{transform-style:preserve-3d;will-change:transform}

/* ken burns */
.around-card .bg img{animation:kenburns 16s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.12)}}
.around-card:hover .bg{transform:none}

/* retour en haut */
#totop{position:fixed;bottom:1.6rem;right:1.6rem;width:52px;height:52px;border-radius:50%;border:none;background:var(--foret);color:#fff;font-size:1.3rem;cursor:pointer;z-index:1200;opacity:0;pointer-events:none;transform:translateY(15px);transition:opacity .4s,transform .4s,background .3s;box-shadow:0 10px 28px rgba(15,36,29,.4)}
#totop.show{opacity:1;pointer-events:auto;transform:none}
#totop:hover{background:var(--lac)}

/* séparateur vague */
.wave-sep{display:block;width:100%;height:70px;margin-bottom:-1px}

/* photos */
.split .visu .photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}
.banner{position:relative;height:55vh;min-height:340px;overflow:hidden;background:linear-gradient(150deg,#48684a,#2c4f41)}
.banner img{position:absolute;inset:0;width:100%;height:115%;object-fit:cover;will-change:transform}
.banner .quote{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;z-index:2;background:linear-gradient(0deg,rgba(10,25,20,.45),rgba(10,25,20,.2));padding:0 1.5rem}
.banner .quote p{font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,3.6vw,2.6rem);color:#fff;font-style:italic;max-width:760px;text-shadow:0 2px 25px rgba(0,0,0,.5)}

/* terroir */
#terroir{background:linear-gradient(180deg,var(--sable),#f0e6d2)}
.esquirol{display:grid;grid-template-columns:1.05fr 1fr;gap:0;background:var(--blanc);border-radius:26px;overflow:hidden;box-shadow:0 25px 60px rgba(27,58,47,.18);margin-bottom:3.5rem}
.esquirol .photo-side{position:relative;min-height:340px;background:linear-gradient(150deg,var(--ocre),#8a5a3a)}
.esquirol .photo-side img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.esquirol .photo-side .label{position:absolute;bottom:1.2rem;left:1.2rem;z-index:2;background:rgba(15,36,29,.85);color:#fff;padding:.45rem 1.1rem;border-radius:50px;font-size:.8rem;letter-spacing:1px}
.esquirol .text-side{padding:2.6rem 2.4rem}
.esquirol h3{font-size:2.1rem;color:var(--foret-fonce)}
.esquirol .sub{color:var(--ocre);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:2.5px;margin-bottom:1rem}
.esquirol p{font-size:.97rem;font-weight:300;margin-bottom:.9rem}
.esquirol ul{list-style:none;margin:.6rem 0 1.2rem;display:grid;grid-template-columns:1fr 1fr;gap:.45rem}
.esquirol ul li{font-size:.88rem;font-weight:300;padding-left:1.4rem;position:relative}
.esquirol ul li::before{content:'✦';position:absolute;left:0;color:var(--ocre)}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.prod-card{background:var(--blanc);border-radius:18px;padding:1.7rem;box-shadow:0 10px 28px rgba(27,58,47,.1);transition:transform .35s;border-bottom:4px solid var(--ocre)}
.prod-card:hover{transform:translateY(-6px)}
.prod-card .picto{font-size:2rem;margin-bottom:.7rem}
.prod-card h4{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--foret-fonce)}
.prod-card .where{font-size:.74rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--lac);font-weight:600;margin:.15rem 0 .5rem}
.prod-card p{font-size:.88rem;font-weight:300}

/* galerie */
#galerie{background:var(--foret-fonce)}
#galerie .section-head h2{color:var(--blanc)}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1rem}
.gal-grid figure{position:relative;border-radius:16px;overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:linear-gradient(150deg,#2c4f41,#1b3a2f)}
.gal-grid figure.wide{grid-column:span 2;aspect-ratio:8/3}
.gal-grid img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.gal-grid figure:hover img{transform:scale(1.06)}
.gal-grid figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.8rem 1.1rem .8rem;background:linear-gradient(0deg,rgba(10,25,20,.85),transparent);color:#fff;font-size:.85rem;opacity:0;transition:opacity .4s}
.gal-grid figure:hover figcaption{opacity:1}
.lightbox{position:fixed;inset:0;background:rgba(8,18,15,.95);z-index:2000;display:none;align-items:center;justify-content:center;flex-direction:column;padding:2.5rem}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:80vh;border-radius:12px;box-shadow:0 25px 80px rgba(0,0,0,.6)}
.lightbox .cap{color:#fff;margin-top:1rem;font-size:.95rem;font-weight:300}
.lightbox .close{position:absolute;top:1.2rem;right:1.6rem;background:none;border:none;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1}
.lightbox .nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;font-size:1.8rem;width:52px;height:52px;border-radius:50%;cursor:pointer;transition:background .3s}
.lightbox .nav-btn:hover{background:rgba(255,255,255,.28)}
.lightbox .prev{left:1.2rem}.lightbox .next{right:1.2rem}

/* annuaire */
.dir-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem;margin-top:2.5rem}
.dir-card{display:block;text-decoration:none;background:var(--blanc);border-radius:16px;padding:1.5rem 1.6rem;box-shadow:0 8px 24px rgba(27,58,47,.09);transition:transform .3s,box-shadow .3s;border-left:4px solid var(--ocre)}
.dir-card:hover{transform:translateY(-5px);box-shadow:0 16px 38px rgba(27,58,47,.18)}
.dir-card .cat{font-size:.7rem;text-transform:uppercase;letter-spacing:2px;color:var(--lac);font-weight:600}
.dir-card h4{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--foret-fonce);margin:.2rem 0 .35rem}
.dir-card p{font-size:.85rem;font-weight:300;color:var(--texte)}
.dir-card .go{display:inline-block;margin-top:.7rem;font-size:.8rem;font-weight:600;color:var(--ocre)}

/* responsive */
@media(max-width:860px){
  .split{grid-template-columns:1fr;gap:2.5rem}
  .esquirol{grid-template-columns:1fr}
  .esquirol ul{grid-template-columns:1fr}
  .gal-grid figure.wide{grid-column:span 1;aspect-ratio:4/3}
  .timeline::before{left:10px}
  .t-item{width:100%;left:0!important;text-align:left!important;padding:1rem 0 2rem 2.6rem}
  .t-item::before{left:3px!important;right:auto!important}
  nav ul{position:fixed;inset:0;background:rgba(15,36,29,.97);flex-direction:column;align-items:center;justify-content:center;gap:2.2rem;transform:translateX(100%);transition:transform .4s}
  nav ul.open{transform:translateX(0)}
  nav ul a{font-size:1.1rem}
  .burger{display:flex}
}

/* ============ ADDITIONS MULTI-PAGES ============ */
body.inner nav{background:rgba(15,36,29,.92);backdrop-filter:blur(10px);box-shadow:0 2px 20px rgba(0,0,0,.25)}
nav ul a.active{color:#fff}
nav ul a.active::after{width:100%}
.subhero{position:relative;padding:9rem 5vw 3.4rem;background:linear-gradient(150deg,var(--foret) 0%,var(--foret-fonce) 100%);color:var(--blanc);text-align:center;overflow:hidden}
.subhero .kicker{text-transform:uppercase;letter-spacing:5px;font-size:.78rem;font-weight:600;color:var(--ocre)}
.subhero h1{font-size:clamp(2.2rem,6vw,3.7rem);color:#fff;font-weight:700;margin-top:.5rem;line-height:1.08}
.subhero .line{width:70px;height:3px;background:var(--ocre);margin:1.1rem auto 1.2rem;border-radius:2px}
.subhero p{max-width:700px;margin:0 auto;font-weight:300;opacity:.92;font-size:1.05rem}
.crumb{font-size:.74rem;letter-spacing:1px;color:var(--lac-clair);margin-bottom:.5rem}
.crumb a{color:var(--lac-clair);text-decoration:none}
.crumb a:hover{text-decoration:underline}
.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.6rem;margin-top:1rem}
.hub-card{display:block;text-decoration:none;background:var(--blanc);border-radius:20px;padding:2rem 1.7rem;box-shadow:0 10px 30px rgba(27,58,47,.1);transition:transform .35s,box-shadow .35s;border-top:4px solid transparent;color:var(--texte)}
.hub-card:hover{transform:translateY(-7px);box-shadow:0 22px 45px rgba(27,58,47,.2);border-top-color:var(--ocre)}
.hub-card .icon{width:62px;height:62px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:1.9rem;margin-bottom:1.1rem;background:linear-gradient(135deg,#e3efe9,#cfe4dc)}
.hub-card h3{font-size:1.45rem;color:var(--foret-fonce);margin-bottom:.45rem}
.hub-card p{font-size:.92rem;font-weight:300}
.hub-card .go{display:inline-block;margin-top:.8rem;font-size:.8rem;font-weight:600;color:var(--ocre)}
.page-nav{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;max-width:1150px;margin:0 auto;padding:1rem 5vw 5rem}
.page-nav a{text-decoration:none;color:var(--foret);background:var(--pierre);border:1px solid #d8cdb8;padding:.7rem 1.3rem;border-radius:50px;font-size:.85rem;font-weight:500;transition:background .3s}
.page-nav a:hover{background:var(--lac-clair)}
.faq{max-width:820px;margin:0 auto}
.faq details{background:var(--blanc);border-radius:14px;padding:1.1rem 1.4rem;margin-bottom:.8rem;box-shadow:0 6px 18px rgba(27,58,47,.08)}
.faq summary{font-family:'Cormorant Garamond',serif;font-size:1.25rem;color:var(--foret-fonce);cursor:pointer;font-weight:600;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:'+ ';color:var(--ocre);font-weight:700}
.faq details[open] summary::before{content:'– '}
.faq details p{margin-top:.7rem;font-weight:300;font-size:.95rem}

/* ============ COMPOSANTS RICHES (v2) ============ */
.prose{max-width:780px;margin:0 auto}
.prose p{font-weight:300;font-size:1.06rem;margin-bottom:1.15rem}
.prose p strong{font-weight:600;color:var(--foret)}
.prose .lead{font-size:1.22rem;color:var(--foret)}
.dropcap::first-letter{font-family:'Cormorant Garamond',serif;font-size:3.6rem;font-weight:700;color:var(--ocre);float:left;line-height:.78;margin:.15rem .65rem 0 0}
.callout{background:var(--blanc);border-left:4px solid var(--lac);border-radius:14px;padding:1.4rem 1.6rem;margin:1.8rem auto;max-width:820px;box-shadow:0 8px 25px rgba(27,58,47,.08)}
.callout.ocre{border-left-color:var(--ocre)}
.callout h4{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--foret-fonce);margin-bottom:.4rem}
.callout p{font-weight:300;font-size:.95rem}
.feature{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;max-width:1100px;margin:3.2rem auto}
.feature .fimg{border-radius:22px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 22px 55px rgba(27,58,47,.22);position:relative;background:linear-gradient(150deg,#3a5c4d,#1b3a2f)}
.feature .fimg img{width:100%;height:100%;object-fit:cover;display:block}
.feature .fimg .emo{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:4.5rem;opacity:.9}
.feature h3{font-size:1.95rem;color:var(--foret-fonce);margin-bottom:.6rem}
.feature p{font-weight:300;margin-bottom:.9rem}
.feature.rev .ftxt{order:2}
@media(max-width:860px){.feature{grid-template-columns:1fr;gap:2rem}.feature.rev .ftxt{order:0}}
.profile-wrap{max-width:1000px;margin:3rem auto 0;background:var(--blanc);border-radius:22px;padding:1.6rem;box-shadow:0 15px 40px rgba(46,125,140,.15);overflow-x:auto}
.profile-wrap svg{display:block;min-width:720px;width:100%;height:auto}
.profile-wrap .cap{text-align:center;font-size:.78rem;opacity:.6;margin-top:.6rem}
.filter-chips{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.chip{border:1px solid #cdbfa6;background:var(--pierre);color:var(--foret);padding:.45rem 1.2rem;border-radius:50px;font-size:.82rem;font-weight:600;cursor:pointer;transition:.25s}
.chip.active,.chip:hover{background:var(--foret);color:#fff;border-color:var(--foret)}
.trail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.8rem}
.trail-card{background:var(--blanc);border-radius:20px;overflow:hidden;box-shadow:0 12px 34px rgba(27,58,47,.12);transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column}
.trail-card:hover{transform:translateY(-7px);box-shadow:0 22px 50px rgba(27,58,47,.2)}
.trail-card .top{padding:1.5rem 1.6rem .3rem}
.trail-card .lvl{display:inline-block;font-size:.66rem;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;padding:.22rem .75rem;border-radius:50px;color:#fff;margin-bottom:.6rem}
.lvl.facile{background:#5b9d6b}.lvl.moyen{background:var(--ocre)}.lvl.sportif{background:#c4684a}
.trail-card h3{font-size:1.5rem;color:var(--foret-fonce)}
.trail-card .desc{padding:.2rem 1.6rem 1.1rem;font-size:.93rem;font-weight:300;flex:1}
.trail-meta{display:flex;flex-wrap:wrap;border-top:1px solid #eee;background:#faf8f3}
.trail-meta div{flex:1;min-width:78px;text-align:center;padding:.8rem .3rem}
.trail-meta .v{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:700;color:var(--lac)}
.trail-meta .k{font-size:.64rem;text-transform:uppercase;letter-spacing:1px;opacity:.65}
.hab-tabs,.season-tabs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:1.8rem}
.hab-tab,.season-tab{border:none;background:var(--pierre);color:var(--foret);padding:.55rem 1.3rem;border-radius:50px;font-size:.85rem;font-weight:600;cursor:pointer;transition:.25s}
.hab-tab.active{background:var(--foret);color:#fff}
.season-tab.active{background:var(--ocre);color:#fff}
.species-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1.2rem}
.species{background:var(--blanc);border-radius:16px;padding:1.4rem;text-align:center;box-shadow:0 8px 24px rgba(27,58,47,.1);border-bottom:3px solid var(--lac-clair)}
.species .emo{font-size:2.4rem}
.species h4{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--foret-fonce);margin:.3rem 0 .15rem}
.species .lat{font-style:italic;font-size:.73rem;opacity:.6;margin-bottom:.4rem}
.species p{font-size:.82rem;font-weight:300}
.hab-panel,.season-panel{display:none}
.hab-panel.active{display:block}
.season-panel{max-width:760px;margin:0 auto;background:var(--blanc);border-radius:16px;padding:1.6rem 1.8rem;box-shadow:0 10px 30px rgba(27,58,47,.1)}
.season-panel.active{display:block}
.season-panel h4{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--foret-fonce);margin-bottom:.5rem}
.season-panel p{font-weight:300}
.factstrip{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.2rem;max-width:1000px;margin:2.6rem auto 0}
.factstrip .f{background:var(--blanc);border-radius:16px;padding:1.4rem;text-align:center;box-shadow:0 8px 22px rgba(27,58,47,.08)}
.factstrip .f .n{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:700;color:var(--lac)}
.factstrip .f .l{font-size:.76rem;text-transform:uppercase;letter-spacing:1px;opacity:.7;margin-top:.2rem}
nav ul{gap:1.15rem}
nav ul a{font-size:.78rem;letter-spacing:1px}
@media(min-width:861px) and (max-width:1150px){nav ul{gap:.7rem}nav ul a{font-size:.72rem;letter-spacing:.5px}}

/* ============ AGENDA + MENU DE BAS DE PAGE (v3) ============ */
.agenda-list{display:grid;gap:1rem;max-width:880px;margin:0 auto}
.ev-card{display:flex;gap:1.2rem;align-items:center;background:var(--blanc);border-radius:16px;padding:1rem 1.3rem;box-shadow:0 8px 24px rgba(27,58,47,.09);text-decoration:none;color:var(--texte);transition:transform .3s,box-shadow .3s;border-left:4px solid var(--ocre)}
.ev-card:hover{transform:translateX(4px);box-shadow:0 14px 34px rgba(27,58,47,.16)}
.ev-date{flex:0 0 60px;text-align:center;background:var(--foret-fonce);color:#fff;border-radius:12px;padding:.5rem 0}
.ev-date .d{display:block;font-family:'Cormorant Garamond',serif;font-size:1.7rem;font-weight:700;line-height:1;color:var(--lac-clair)}
.ev-date .m{display:block;font-size:.64rem;text-transform:uppercase;letter-spacing:1px;margin-top:.2rem}
.ev-body{flex:1}
.ev-tag{display:inline-block;font-size:.67rem;text-transform:uppercase;letter-spacing:1px;color:var(--lac);font-weight:600;margin-bottom:.15rem}
.ev-body h3{font-family:'Cormorant Garamond',serif;font-size:1.28rem;color:var(--foret-fonce);line-height:1.15}
.ev-go{font-size:.76rem;color:var(--ocre);font-weight:600}
.agenda-src{text-align:center;margin:2.4rem auto 0;max-width:700px}
.endmenu{max-width:1000px;margin:0 auto;padding:2.6rem 5vw 4.5rem;text-align:center}
.endmenu .em-title{display:block;text-transform:uppercase;letter-spacing:3px;font-size:.74rem;color:var(--lac);font-weight:600;margin-bottom:1rem}
.endmenu .em-links{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center}
.endmenu .em-links a{text-decoration:none;color:var(--foret);background:var(--pierre);border:1px solid #d8cdb8;padding:.55rem 1.2rem;border-radius:50px;font-size:.85rem;font-weight:500;transition:.25s}
.endmenu .em-links a:hover{background:var(--foret);color:#fff;border-color:var(--foret)}
@media(max-width:1024px){
  nav ul{position:fixed;inset:0;background:rgba(15,36,29,.97);flex-direction:column;align-items:center;justify-content:center;gap:1.8rem;transform:translateX(100%);transition:transform .4s}
  nav ul.open{transform:translateX(0)}
  nav ul a{font-size:1.1rem}
  .burger{display:flex}
}

/* ============ FILTRE ANNUAIRE + NAV (v4) ============ */
.cat-chips{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.dir-card{cursor:pointer}
.hosts-cta{background:linear-gradient(150deg,var(--foret),var(--foret-fonce));color:#fff;border-radius:20px;padding:2.2rem;text-align:center;max-width:760px;margin:2.5rem auto 0;box-shadow:0 18px 45px rgba(27,58,47,.25)}
.hosts-cta h3{font-size:1.7rem;color:#fff;margin-bottom:.5rem}
.hosts-cta p{font-weight:300;opacity:.92;margin-bottom:1.2rem}
@media(max-width:1100px){
  .burger{display:flex}
  nav ul{position:fixed;inset:0;background:rgba(15,36,29,.97);flex-direction:column;align-items:center;justify-content:center;gap:1.6rem;transform:translateX(100%);transition:transform .4s}
  nav ul.open{transform:translateX(0)}
  nav ul a{font-size:1.05rem}
}

/* ============ VIE ASSOCIATIVE + NAV large (v5) ============ */
@media(max-width:1200px){
  .burger{display:flex}
  nav ul{position:fixed;inset:0;background:rgba(15,36,29,.97);flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;transform:translateX(100%);transition:transform .4s;overflow-y:auto}
  nav ul.open{transform:translateX(0)}
  nav ul a{font-size:1.05rem}
}
.assos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.asso{background:var(--blanc);border-radius:18px;padding:1.7rem;box-shadow:0 10px 28px rgba(27,58,47,.1);border-top:4px solid var(--lac)}
.asso .picto{font-size:2rem;margin-bottom:.6rem}
.asso h4{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--foret-fonce);margin-bottom:.15rem}
.asso .role{font-size:.72rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--lac);font-weight:600;margin-bottom:.5rem}
.asso p{font-size:.9rem;font-weight:300}

/* ============ FOCUS GÎTES + PAGES SPÉCIALES (v6) ============ */
.amen{display:flex;gap:.5rem;flex-wrap:wrap;margin:.7rem 0 1.1rem}
.amen span{background:var(--pierre);border:1px solid #d8cdb8;padding:.3rem .85rem;border-radius:50px;font-size:.76rem;color:var(--foret);font-weight:500}
.gfacts{font-size:.8rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--lac);font-weight:600;margin-bottom:.5rem}
.feature .ftxt .note{font-size:.82rem;opacity:.7;margin-top:.3rem}

/* ============ RANDO ENRICHIE (v7) ============ */
.etapes{max-width:820px;margin:1.6rem auto 0;display:grid;gap:.7rem}
.etapes .et{display:flex;gap:1rem;align-items:baseline;background:var(--blanc);border-radius:12px;padding:.8rem 1.1rem;box-shadow:0 6px 18px rgba(27,58,47,.07);border-left:4px solid var(--lac)}
.etapes .et b{font-family:'Cormorant Garamond',serif;color:var(--foret-fonce);font-size:1.08rem}
.etapes .et i{font-style:normal;font-weight:300;font-size:.9rem}
.etapes .et span{font-size:.84rem;opacity:.6;margin-left:auto;white-space:nowrap}
.trail-card .trace{display:block;padding:.2rem 1.6rem 1.2rem;font-size:.78rem;font-weight:600}
.trail-card .trace a{color:var(--lac);text-decoration:none}
.trail-card .trace a:hover{text-decoration:underline}
.reslist{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:1rem;max-width:1020px;margin:0 auto}
.reslist a{display:block;text-decoration:none;background:var(--blanc);border-radius:14px;padding:1.1rem 1.3rem;box-shadow:0 8px 22px rgba(27,58,47,.08);border-left:4px solid var(--ocre);color:var(--texte);transition:transform .3s,box-shadow .3s}
.reslist a:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(27,58,47,.16)}
.reslist a b{display:block;font-family:'Cormorant Garamond',serif;font-size:1.16rem;color:var(--foret-fonce);margin-bottom:.15rem}
.reslist a em{font-style:normal;font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--lac);font-weight:600}
.reslist a span{font-size:.82rem;font-weight:300;display:block;margin-top:.2rem}

/* ============ NAV BURGER PROPRE (override final v8) ============ */
.burger{display:none;flex-direction:column;gap:5px;z-index:1300;background:none;border:none;cursor:pointer}
.burger span{display:block;width:26px;height:2px;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s,background .3s}
body:not(.inner) nav:not(.scrolled) .burger span{background:var(--foret-fonce)}
.burger.open span{background:#fff}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
body.menu-open{overflow:hidden}
@media(min-width:1025px){
  .burger{display:none}
  nav ul#menu{position:static!important;transform:none!important;height:auto;width:auto;inset:auto;background:none!important;backdrop-filter:none;flex-direction:row;justify-content:flex-end;align-items:center;gap:1.1rem;padding:0;overflow:visible}
  nav ul#menu a{font-size:.78rem;color:rgba(255,255,255,.85)}
}
@media(max-width:1024px){
  .burger{display:flex}
  nav ul#menu{position:fixed;inset:0;height:100dvh;width:100%;background:rgba(15,36,29,.98);backdrop-filter:blur(8px);flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;transform:translateX(100%);transition:transform .35s ease;overflow-y:auto;padding:5.5rem 1.5rem 2rem;margin:0}
  nav ul#menu.open{transform:translateX(0)}
  nav ul#menu li{width:auto}
  nav ul#menu a{font-size:1.2rem;color:#fff;letter-spacing:1px;text-transform:uppercase}
  nav ul#menu a::after{display:none}
}

/* ============ FIX : le menu de bas de page n'est PAS fixe (v9) ============ */
nav.endmenu{position:static;display:block;z-index:auto;background:none;box-shadow:none;backdrop-filter:none;padding:2.6rem 5vw 4.5rem}
nav.endmenu .em-links{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}

/* Menu du haut : compacter sur écrans portables pour tout faire tenir */
@media(min-width:1025px) and (max-width:1450px){
  nav ul#menu{gap:.7rem}
  nav ul#menu a{font-size:.7rem;letter-spacing:.4px}
}
