/* ============================================================
   MON MOBIL-HOME AU SOLEIL — theme.css
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#0C0C0C;
  --off-black:#141414;
  --white:#FAFAFA;
  --off-white:#F2EFE9;
  --gold:#B8952A;
  --gold-light:#D4AF5A;
  --gray:#888;
  --light-gray:#e8e8e8;
  --border:rgba(255,255,255,0.1);
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Jost',sans-serif;background:var(--white);color:var(--black);overflow-x:hidden;font-weight:300}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── NAV ── */
#nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:1.8rem 4rem;display:flex;align-items:center;justify-content:space-between;transition:all .4s}
#nav.solid{background:rgba(12,12,12,.96);backdrop-filter:blur(20px);padding:1.1rem 4rem;border-bottom:1px solid var(--border)}
.nav-logo{font-family:'Tenor Sans',serif;font-size:1.05rem;letter-spacing:.05em;text-transform:none;color:white}
.nav-logo span{color:var(--gold)}
.nav-menu{display:flex;gap:2.5rem;list-style:none}
.nav-menu a{font-size:.7rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6);transition:color .3s;padding-bottom:2px;border-bottom:1px solid transparent}
.nav-menu a:hover,.nav-menu li.current-menu-item>a,.nav-menu li.current_page_item>a{color:var(--gold);border-bottom-color:var(--gold)}
.nav-book{background:var(--gold);border:1px solid var(--gold);color:var(--black);padding:9px 22px;font-family:'Jost',sans-serif;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:all .3s;display:inline-block}
.nav-book:hover{background:var(--gold-light);color:var(--black)}

/* ── HERO (page d'accueil) ── */
.hero{height:100vh;min-height:600px;position:relative;overflow:hidden;background:var(--black)}
.hero-slides{position:absolute;inset:0}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.8s ease;background-size:cover;background-position:center;filter:blur(2.5px);transform:scale(1.05)}
.slide.on{opacity:1}
.slide::after{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(12,12,12,.72) 0%,rgba(12,12,12,.25) 55%,rgba(12,12,12,.5) 100%)}
.hero-content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:0 4rem 5.5rem}
.hero-eyebrow{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}
.hero-line{width:40px;height:1px;background:var(--gold)}
.hero-eyebrow span{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}
.hero h1{font-family:'Tenor Sans',serif;font-size:clamp(3.2rem,7.5vw,6.5rem);color:white;line-height:.95;letter-spacing:-.01em;margin-bottom:2rem;max-width:680px}
.hero h1 em{font-style:normal;color:var(--gold-light)}
.hero-sub{font-size:1rem;color:rgba(255,255,255,.55);font-weight:300;max-width:400px;line-height:1.7;margin-bottom:3rem}
.hero-actions{display:flex;align-items:center;gap:3rem;flex-wrap:wrap}
.btn-hero{background:var(--gold);color:var(--black);padding:15px 38px;font-family:'Jost',sans-serif;font-size:.73rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;border:none;cursor:pointer;transition:all .3s;display:inline-block}
.btn-hero:hover{background:var(--gold-light)}
.slide-counter{position:absolute;bottom:3rem;right:4rem;z-index:3;font-family:'Tenor Sans',serif;font-size:.75rem;color:rgba(255,255,255,.3);letter-spacing:.1em}
.slide-counter strong{color:var(--gold-light);font-size:1.1rem}

/* ── TICKER ── */
.ticker{background:var(--gold);padding:.65rem 0;overflow:hidden}
.ticker-track{display:flex;gap:4rem;animation:tick 22s linear infinite;white-space:nowrap}
.ticker-track span{font-size:.67rem;letter-spacing:.22em;text-transform:uppercase;color:var(--black);font-weight:500}
.ticker-track .sep{color:rgba(0,0,0,.25)}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── PAGE BANNER (pages intérieures) ── */
.page-banner{height:50vh;min-height:350px;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.page-banner .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-banner .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(12,12,12,.85) 0%,rgba(12,12,12,.3) 100%)}
.page-banner .bc{position:relative;z-index:2;padding:0 4rem 3.5rem;width:100%}
.page-banner .bc .overline{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.8rem}
.page-banner h1{font-family:'Tenor Sans',serif;font-size:clamp(2.5rem,5vw,4.5rem);color:white;line-height:1}

/* ── COMMON ── */
.sec{padding:7rem 4rem}
.sec-inner{max-width:1150px;margin:0 auto}
.overline{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:1rem}
h2.serif{font-family:'Tenor Sans',serif;font-size:clamp(2rem,3.8vw,3.2rem);line-height:1.05;margin-bottom:1.5rem}
.gold-rule{width:40px;height:1px;background:var(--gold);margin-bottom:2.5rem}
p.lead{font-size:1.05rem;color:var(--black);font-weight:300;line-height:1.8;margin-bottom:1rem}
p.body-text{font-size:.93rem;color:var(--gray);line-height:1.85;margin-bottom:1rem}
.btn-main{background:var(--gold);color:var(--black);padding:15px 38px;font-family:'Jost',sans-serif;font-size:.73rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;border:none;cursor:pointer;transition:all .3s;display:inline-block}
.btn-main:hover{background:var(--gold-light);color:var(--black)}
.btn-outline-dark{background:transparent;color:var(--black);padding:14px 36px;font-family:'Jost',sans-serif;font-size:.73rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;border:1px solid var(--black);cursor:pointer;transition:all .3s;display:inline-block}
.btn-outline-dark:hover{background:var(--black);color:var(--white)}

/* ── ACCUEIL : ABOUT SPLIT ── */
.about-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:7rem;align-items:center}
.about-img-wrap{position:relative;overflow:visible}
.about-main{width:100%;height:520px;background-size:cover;background-position:center;display:block}
.about-float{position:absolute;bottom:-2.5rem;left:-2.5rem;width:190px;height:190px;background-size:cover;background-position:center;border:5px solid var(--white)}
.about-cta{display:inline-flex;align-items:center;gap:.8rem;margin-top:2rem;font-size:.73rem;letter-spacing:.18em;text-transform:uppercase;color:var(--black);border-bottom:1px solid var(--black);padding-bottom:.25rem;transition:all .3s}
.about-cta:hover{color:var(--gold);border-bottom-color:var(--gold)}
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--light-gray);margin-top:4rem}
.stat-b{padding:1.5rem;text-align:center;border-right:1px solid var(--light-gray)}
.stat-b:last-child{border-right:none}
.stat-b .sn{font-family:'Tenor Sans',serif;font-size:2.2rem;color:var(--black);line-height:1}
.stat-b .sn em{color:var(--gold);font-style:normal;font-size:1.1rem}
.stat-b .sl{font-size:.67rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray);margin-top:.3rem}

/* ── ACCUEIL : TEASERS ACTIVITÉS ── */
.teasers-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px}
.teaser{position:relative;height:350px;overflow:hidden;cursor:pointer;display:block}
.teaser .t-bg{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .7s}
.teaser:hover .t-bg{transform:scale(1.06)}
.teaser::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75),transparent)}
.teaser-body{position:absolute;bottom:1.8rem;left:1.8rem;z-index:2}
.teaser-body .tag{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.teaser-body .title{font-family:'Tenor Sans',serif;font-size:1.5rem;color:white}

/* ── LOGEMENT : GALLERY ── */
.gal-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:4px;height:460px}
.gal-grid2{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;height:280px;margin-top:4px}
.gc{overflow:hidden;position:relative;cursor:zoom-in}
.gc .gi{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .7s ease}
.gc:hover .gi{transform:scale(1.06)}
.gc .gl{position:absolute;bottom:.8rem;left:.8rem;background:rgba(12,12,12,.65);backdrop-filter:blur(4px);color:white;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;padding:4px 10px;opacity:0;transform:translateY(5px);transition:all .3s}
.gc:hover .gl{opacity:1;transform:translateY(0)}

/* ── LOGEMENT : ÉQUIPEMENTS ── */
.equip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--light-gray);margin-top:3rem}
.equip-item{padding:2rem 1.5rem;border-right:1px solid var(--light-gray);border-bottom:1px solid var(--light-gray);transition:background .25s}
.equip-item:hover{background:var(--off-white)}
.equip-item:nth-child(4n){border-right:none}
.equip-item:nth-last-child(-n+4){border-bottom:none}
.equip-ico{font-size:1.8rem;margin-bottom:.8rem}
.equip-item h4{font-size:.88rem;font-weight:500;color:var(--black);margin-bottom:.3rem}
.equip-item p{font-size:.78rem;color:var(--gray);line-height:1.6}

/* ── TARIFS ── */
.tarif-intro{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;margin-bottom:5rem}
.tarif-aside{background:var(--off-white);padding:2.5rem;border-left:2px solid var(--gold)}
.tarif-aside ul{list-style:none;display:flex;flex-direction:column;gap:.8rem}
.tarif-aside li{font-size:.85rem;color:var(--gray);display:flex;gap:.6rem}
.tarif-aside li span{color:var(--gold)}
table.tt{width:100%;border-collapse:collapse}
table.tt thead th{font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gray);font-weight:400;padding:0 0 1.2rem;text-align:left;border-bottom:2px solid var(--light-gray)}
table.tt tbody tr{border-bottom:1px solid var(--light-gray);transition:background .2s}
table.tt tbody tr:hover{background:var(--off-white)}
table.tt td{padding:1.4rem 0;font-size:.9rem;color:var(--black);vertical-align:middle}
table.tt td.tp{font-family:'Tenor Sans',serif;font-size:2rem;color:var(--gold);text-align:right}
table.tt td.tp span{font-family:'Jost',sans-serif;font-size:.78rem;color:var(--gray);font-weight:300}
table.tt tr.feat td{background:#fdf8ee}
.t-pill{display:inline-block;background:var(--gold);color:white;font-size:.58rem;letter-spacing:.1em;padding:2px 8px;margin-left:.6rem;text-transform:uppercase}
.extras-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--light-gray);border:1px solid var(--light-gray);margin-top:3rem}
.er{background:var(--white);padding:1.8rem 1.5rem}
.er .el{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);margin-bottom:.6rem}
.er .ev{font-family:'Tenor Sans',serif;font-size:1.4rem;color:var(--black)}
.er .ev em{color:var(--gold);font-style:normal}
.tarif-note-box{background:var(--off-white);border-left:2px solid var(--gold);padding:1.5rem 2rem;margin-top:3rem;font-size:.82rem;color:var(--gray);line-height:1.9}
.cond-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--light-gray);border:1px solid var(--light-gray);margin-top:3rem}
.cond-item{background:var(--white);padding:1.5rem 1.8rem;display:flex;gap:1rem;align-items:flex-start}
.cond-ico{font-size:1.3rem;flex-shrink:0;margin-top:.1rem}
.cond-item h4{font-size:.85rem;font-weight:500;margin-bottom:.2rem}
.cond-item p{font-size:.78rem;color:var(--gray);line-height:1.6}

/* ── ACTIVITÉS ── */
.act-feature{display:grid;grid-template-columns:1fr 1fr}
.act-feat-img{min-height:380px;background-size:cover;background-position:left bottom}
.act-feat-txt{background:var(--black);padding:4rem;display:flex;flex-direction:column;justify-content:center}
.act-feat-txt h2{font-family:'Tenor Sans',serif;font-size:clamp(2rem,3.5vw,3rem);color:white;line-height:1.05;margin-bottom:1.5rem}
.act-feat-txt p{color:rgba(255,255,255,.5);font-size:.9rem;line-height:1.85;margin-bottom:.8rem}
.act-feat-txt .hint{color:rgba(255,255,255,.25);font-size:.78rem;margin-top:1rem}
.act-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-top:4px}
.act-card{position:relative;height:380px;overflow:hidden;cursor:pointer}
.act-card .bg{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .7s ease}
.act-card:hover .bg{transform:scale(1.07)}
.act-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(12,12,12,.8) 0%,transparent 55%)}
.act-card-body{position:absolute;bottom:0;left:0;right:0;padding:1.8rem;z-index:2}
.act-card-body .tag{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.act-card-body h3{font-family:'Tenor Sans',serif;font-size:1.3rem;color:white;margin-bottom:.4rem}
.act-card-body p{font-size:.78rem;color:rgba(255,255,255,.6);line-height:1.6;max-height:0;overflow:hidden;transition:max-height .4s ease}
.act-card:hover .act-card-body p{max-height:100px}
a.act-card-link{display:block;text-decoration:none;color:inherit}
/* Webcam band */
.webcam-band{background:var(--black);width:100%}
.webcam-link{display:flex;align-items:center;gap:5rem;padding:4rem 7%;text-decoration:none;color:inherit;transition:opacity .3s;max-width:1400px;margin:0 auto}
.webcam-link:hover{opacity:.9}
.webcam-img-wrap{position:relative;flex-shrink:0}
.webcam-thumb{width:380px;height:240px;object-fit:cover;border-radius:4px;display:block;border:1px solid rgba(184,149,42,.35)}
.webcam-live-dot{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:6px;background:rgba(0,0,0,.6);color:#fff;font-size:.6rem;letter-spacing:.18em;padding:4px 10px;border-radius:20px;backdrop-filter:blur(4px)}
.webcam-live-dot span{width:7px;height:7px;background:#e03;border-radius:50%;animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.webcam-txt{flex:1}
.webcam-txt .overline{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.webcam-txt h2{font-family:'Tenor Sans',serif;font-size:2.2rem;color:var(--white);margin:.5rem 0 1rem;line-height:1.25}
.webcam-txt h2 em{color:var(--gold);font-style:normal}
.webcam-txt .gold-rule{width:40px;height:1px;background:var(--gold);margin-bottom:1.2rem}
.webcam-txt p{font-size:.9rem;color:rgba(255,255,255,.5);line-height:1.8;max-width:420px}
@media(max-width:768px){.webcam-link{flex-direction:column;gap:2rem;padding:3rem 5%}.webcam-thumb{width:100%;height:200px}.webcam-txt p{max-width:100%}}
.act-list-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid #ddd}
.ali{padding:2rem 2.2rem;border-right:1px solid #ddd;border-bottom:1px solid #ddd;display:flex;gap:1.2rem;transition:background .25s}
.ali:hover{background:white}
.ali:nth-child(2n){border-right:none}
.ali:nth-last-child(-n+2){border-bottom:none}
.ali-num{font-family:'Tenor Sans',serif;font-size:2rem;color:var(--gold);line-height:1;flex-shrink:0;width:2.5rem}
.ali h3{font-size:.9rem;font-weight:500;margin-bottom:.3rem}
.ali p{font-size:.82rem;color:var(--gray);line-height:1.7}
.photo-strip{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:4px;height:280px}
.photo-strip .ps{overflow:hidden}
.photo-strip .ps div{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .6s}
.photo-strip .ps:hover div{transform:scale(1.05)}

/* ── ACCÈS ── */
.acces-split{display:grid;grid-template-columns:1.2fr 1fr;gap:6rem;align-items:start}
.map-img{width:100%;height:700px;background-size:contain;background-position:center top;background-repeat:no-repeat;background-color:#f0ebe0;display:block;border:1px solid #e0e0e0}
.dist-table{width:100%;border-collapse:collapse;margin-top:2rem}
.dist-table tr{border-bottom:1px solid var(--light-gray)}
.dist-table td{padding:1.1rem 0;font-size:.9rem}
.dist-table td.dv{font-family:'Tenor Sans',serif;font-size:1.6rem;color:var(--gold);text-align:right}
.infos-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--light-gray);border:1px solid var(--light-gray);margin-top:4rem}
.info-block{background:var(--white);padding:2rem}
.info-block .ib-ico{font-size:1.6rem;margin-bottom:.8rem}
.info-block h4{font-size:.82rem;font-weight:500;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.08em}
.info-block p{font-size:.82rem;color:var(--gray);line-height:1.7}
.docs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:3rem}
.doc-link{padding:1.5rem;border:1px solid var(--light-gray);display:flex;flex-direction:column;gap:.5rem;transition:all .3s}
.doc-link:hover{border-color:var(--gold);background:var(--off-white)}
.doc-link .di{font-size:1.5rem}
.doc-link .ds{font-size:.75rem;letter-spacing:.05em;color:var(--gray)}
.doc-link strong{font-size:.82rem;color:var(--black)}

/* ── RÉSERVATION ── */
.resa-layout{display:grid;grid-template-columns:2fr 1fr;gap:5rem;align-items:start}
.form-card{background:white;border:1px solid var(--light-gray);padding:3rem}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.full{grid-column:1/-1}
.fg{display:flex;flex-direction:column;gap:.4rem}
.fg label:not(.orow){font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:#999}
.fg input:not([type=checkbox]),.fg select,.fg textarea{border:none;border-bottom:1.5px solid #e0e0e0;padding:.65rem 0;font-family:'Jost',sans-serif;font-size:.9rem;color:var(--black);background:transparent;outline:none;transition:border-color .3s;border-radius:0;-webkit-appearance:none;appearance:none}
.fg input:not([type=checkbox]):focus,.fg select:focus,.fg textarea:focus{border-bottom-color:var(--gold)}
.fg textarea{resize:vertical;min-height:90px;border:none;border-bottom:1.5px solid #e0e0e0}
.dr,.pr{display:grid;gap:.8rem}
.dr{grid-template-columns:1fr 1fr}
.pr{grid-template-columns:1fr 1fr 1fr}
.sub-l{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:#bbb}
.opts-block{display:flex;flex-direction:column;gap:.5rem;margin-top:.4rem}
.orow{display:flex;align-items:center;gap:14px;padding:.8rem 1rem;border:1px solid #ddd;border-radius:4px;transition:all .2s;background:white;line-height:1.4;width:100%;box-sizing:border-box;cursor:pointer}
.orow:hover{background:#fdf9f0;border-color:#B8952A}
.orow input[type=checkbox]{width:20px;height:20px;flex-shrink:0;accent-color:#B8952A;cursor:pointer;margin:0;display:inline-block !important;opacity:1 !important;visibility:visible !important;-webkit-appearance:checkbox !important;appearance:checkbox !important}

.cgu-strip{border:1px solid #ddd;border-left:3px solid #B8952A;padding:1rem 1.2rem;background:#fdf9f0;margin-top:.5rem;border-radius:0 4px 4px 0}
.cgu-row{display:flex;gap:.8rem;align-items:flex-start}
.cgu-row input[type=checkbox]{width:22px;height:22px;accent-color:#B8952A;margin-top:2px;flex-shrink:0;cursor:pointer}
.cgu-lbl{font-size:.88rem;color:#333;line-height:1.6;cursor:pointer}
.cgu-lbl a{color:var(--gold);border-bottom:1px solid transparent;transition:border-color .2s}
.cgu-lbl a:hover{border-bottom-color:var(--gold)}
.form-actions{margin-top:2.5rem;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}
.btn-submit{background:var(--black);color:white;padding:15px 44px;font-family:'Jost',sans-serif;font-size:.72rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;border:none;cursor:pointer;transition:all .3s}
.btn-submit:hover{background:var(--gold);color:var(--black)}
.form-note-txt{font-size:.75rem;color:var(--gray);line-height:1.6;max-width:280px}
.resa-sidebar{position:sticky;top:90px}
.sidebar-card{background:var(--black);color:white;padding:2.5rem}
.sidebar-card .overline{color:var(--gold)}
.sidebar-card h3{font-family:'Tenor Sans',serif;font-size:1.5rem;color:white;margin-bottom:1.2rem}
.sidebar-card p.sc-p{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.8;margin-bottom:1.5rem}
.sidebar-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}
.sidebar-list li{font-size:.8rem;color:rgba(255,255,255,.55);display:flex;gap:.6rem}
.sidebar-list li::before{content:'✦';color:var(--gold);font-size:.6rem;margin-top:.2rem;flex-shrink:0}
.sidebar-sep{width:100%;height:1px;background:rgba(255,255,255,.08);margin:1.5rem 0}
.wpcf7-response-output{border-radius:0!important;padding:1rem 1.5rem;font-size:.85rem}
.wpcf7-mail-sent-ok{background:var(--off-white)!important;border-left:3px solid var(--gold)!important;border-top:none!important;border-right:none!important;border-bottom:none!important;color:var(--black)!important}
.wpcf7-validation-errors{border-left:3px solid #c0392b!important;border-top:none!important;border-right:none!important;border-bottom:none!important;background:#fdf0f0!important}

/* ── FOOTER ── */
#site-footer{background:#070707;color:rgba(255,255,255,.3);padding:5rem 4rem 2.5rem}
.footer-top{max-width:1150px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.05)}
.f-logo{font-family:'Tenor Sans',serif;font-size:1.1rem;letter-spacing:.03em;text-transform:none;color:white;display:block;margin-bottom:1rem}
.f-logo span{color:var(--gold)}
.f-desc{font-size:.82rem;line-height:1.9}
.f-col h5{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:1.2rem}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.f-col a{color:rgba(255,255,255,.3);font-size:.82rem;transition:color .2s}
.f-col a:hover{color:var(--gold)}
.footer-bottom{max-width:1150px;margin:1.5rem auto 0;display:flex;justify-content:space-between;font-size:.7rem;flex-wrap:wrap;gap:.5rem}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .about-grid,.tarif-intro,.act-feature,.acces-split,.resa-layout{grid-template-columns:1fr}
  .act-cards{grid-template-columns:1fr 1fr}
  .act-list-grid,.cond-grid,.fgrid{grid-template-columns:1fr}
  .equip-grid{grid-template-columns:1fr 1fr}
  .extras-row,.docs-grid{grid-template-columns:1fr 1fr}
  .stats-strip{grid-template-columns:1fr 1fr}
  .gal-grid{grid-template-columns:1fr 1fr;height:auto}
  .gal-grid .gc{height:220px}
  .gal-grid2{grid-template-columns:1fr 1fr;height:auto}
  .gal-grid2 .gc{height:220px}
  .infos-strip{grid-template-columns:1fr}
  .sec,.act-feat-txt{padding:4rem 2rem}
  #nav,#nav.solid{padding:1rem 1.5rem;background:rgba(12,12,12,.96) !important;backdrop-filter:blur(20px);}
  .hero-content,.page-banner .bc{padding:0 2rem 3.5rem}
  #site-footer{padding:3rem 2rem 2rem}
  .footer-top{grid-template-columns:1fr 1fr;gap:2.5rem}
  .resa-sidebar{display:none}
  .teasers-grid{grid-template-columns:1fr}
  .photo-strip{grid-template-columns:1fr 1fr;height:auto}
  .photo-strip .ps{height:200px}
}
@media(max-width:600px){
  .nav-menu{display:none}
  .act-cards{grid-template-columns:1fr}
  .pr{grid-template-columns:1fr 1fr}
  .extras-row,.docs-grid{grid-template-columns:1fr}
  .equip-grid{grid-template-columns:1fr}
  .stats-strip{grid-template-columns:1fr 1fr}
  .hero h1{font-size:2.6rem}
}

/* ── MENU MOBILE ── */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px;z-index:600}
.nav-toggle span{display:block;width:24px;height:2px;background:white;transition:all .3s;border-radius:2px}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:600px){
  .nav-toggle{display:flex}
  .nav-menu{
    display:none;
    position:fixed;
    top:60px;left:0;right:0;
    background:rgba(12,12,12,.98);
    backdrop-filter:blur(20px);
    flex-direction:column;
    gap:0;
    padding:1rem 0;
    border-bottom:1px solid rgba(255,255,255,.1);
    z-index:499;
  }
  .nav-menu.open{display:flex}
  .nav-menu li{width:100%}
  .nav-menu a{
    display:block;
    padding:1rem 2rem;
    font-size:.85rem;
    letter-spacing:.12em;
    color:rgba(255,255,255,.7);
    border-bottom:1px solid rgba(255,255,255,.05);
    line-height:1;
  }
  .nav-menu a:hover{color:var(--gold);background:rgba(255,255,255,.03)}
  .nav-book{
    display:block;
    margin:1rem 2rem 0.5rem;
    text-align:center;
    padding:12px;
  }
}

/* Override pour les checkboxes options */
.orow input[type=checkbox] {
    display: inline-block !important;
    width: 20px !important;
    height: 20px !important;
    opacity: 1 !important;
    visibility: visible !important;
    -webkit-appearance: checkbox !important;
    appearance: checkbox !important;
    accent-color: #B8952A !important;
    cursor: pointer !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
}
.opts-block .orow {
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-size: .92rem !important;
    font-weight: 400 !important;
    color: #333 !important;
}
/* CGU */
.cgu-row input[type=checkbox] {
    display: inline-block !important;
    width: 22px !important;
    height: 22px !important;
    opacity: 1 !important;
    visibility: visible !important;
    -webkit-appearance: checkbox !important;
    appearance: checkbox !important;
    accent-color: #B8952A !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    margin-top: 2px !important;
}
.cgu-lbl {
    font-size: .88rem !important;
    color: #333 !important;
    line-height: 1.6 !important;
    cursor: pointer !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-weight: 300 !important;
}

/* Google Translate dans la nav */
#google_translate_element { display:inline-flex; align-items:center; }
.goog-te-gadget { font-size:0 !important; }
.goog-te-gadget-simple { white-space:nowrap; }
.goog-te-gadget-simple span { color:rgba(255,255,255,.7) !important; font-family:'Jost',sans-serif !important; }
.goog-te-gadget-simple .goog-te-menu-value span:first-child { color:white !important; font-size:.7rem !important; letter-spacing:.1em; }
.goog-te-banner-frame { display:none !important; }

/* Bouton traduction — cadre blanc forcé */
/* Bouton langue — drapeau seul */
a.nav-translate,
a.nav-translate:link,
a.nav-translate:visited {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 38px !important;
    height: 38px !important;
    border-radius: 50% !important;
    border: 1.5px solid rgba(255,255,255,.5) !important;
    background: rgba(255,255,255,.05) !important;
    font-size: 1.4rem !important;
    cursor: pointer !important;
    transition: all .25s !important;
    text-decoration: none !important;
    line-height: 1 !important;
    padding: 0 !important;
    overflow: hidden !important;
}
a.nav-translate:hover {
    border-color: var(--gold) !important;
    background: rgba(255,255,255,.12) !important;
    transform: scale(1.08) !important;
}

/* Items menu langue */
.mms-lang-item {
    padding: 10px 18px;
    color: #333 !important;
    font-family: 'Jost', sans-serif !important;
    font-size: .85rem !important;
    cursor: pointer;
    transition: background .2s, color .2s;
    border-bottom: 1px solid #eee;
    display: block !important;
    line-height: 1.4 !important;
    background: white;
}
.mms-lang-item:last-child { border-bottom: none; }
.mms-lang-item:hover { background: #fdf9f0 !important; color: #B8952A !important; }

/* ── BARRE MOBILE RÉSERVER ── */
.mobile-reserve-bar { display: none !important; }

/* ══════════════════════════════════
   MOBILE NAV — FINAL
   ══════════════════════════════════ */

/* Par défaut (desktop) : cacher éléments mobile */
.nav-mobile-right { display: none !important; }
.mob-resa-bar { display: none !important; }

/* Desktop : nav toujours solide */
@media(min-width:769px) {
    .nav-book { display: inline-block !important; }
    a.nav-translate { display: inline-block !important; }
    .nav-toggle { display: none !important; }
}

/* Mobile */
@media(max-width:768px) {

    /* Cacher éléments desktop */
    .nav-menu { display: none !important; }
    .nav-book { display: none !important; }
    a.nav-translate { display: none !important; }

    /* Groupe mobile à droite : langue + hamburger */
    .nav-mobile-right {
        display: flex !important;
        align-items: center;
        gap: 10px;
        margin-left: auto;
    }

    /* Bouton langue mobile */
    .mob-lang-btn {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        max-width: 32px !important;
        border-radius: 50% !important;
        border: 1.5px solid rgba(255,255,255,.5) !important;
        background: rgba(255,255,255,.05) !important;
        font-size: 1.1rem !important;
        cursor: pointer !important;
        text-decoration: none !important;
        line-height: 1 !important;
        padding: 0 !important;
        overflow: hidden !important;
        flex-shrink: 0 !important;
        box-sizing: border-box !important;
    }

    /* Hamburger */
    .nav-toggle {
        display: flex !important;
        flex-direction: column;
        gap: 5px;
        background: none;
        border: none;
        cursor: pointer;
        padding: 5px;
    }
    .nav-toggle span {
        display: block;
        width: 24px;
        height: 2px;
        background: white;
        transition: all .3s;
        border-radius: 2px;
    }
    .nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .nav-toggle.open span:nth-child(2) { opacity: 0; }
    .nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    /* Barre Réserver */
    .mob-resa-bar {
        display: block !important;
        position: fixed;
        top: 58px;
        left: 0;
        right: 0;
        z-index: 498;
        background: var(--gold);
        text-align: center;
    }
    .mob-resa-link {
        display: block;
        padding: 14px 10px;
        color: #000 !important;
        font-family: 'Jost', sans-serif;
        font-size: .78rem;
        font-weight: 700;
        letter-spacing: .2em;
        text-transform: uppercase;
        text-decoration: none;
        line-height: 1;
    }

    /* Décaler hero/banner sous nav (58px) + barre resa (37px) */
    .hero { padding-top: 37px !important; background: var(--black) !important; }
    .page-banner { margin-top: 37px !important; }

    /* Menu ouvert */
    .nav-menu.open {
        display: flex !important;
        position: fixed;
        top: 95px;
        left: 0; right: 0;
        background: rgba(12,12,12,.98);
        backdrop-filter: blur(20px);
        flex-direction: column;
        gap: 0;
        padding: .5rem 0 1rem;
        border-bottom: 1px solid rgba(255,255,255,.1);
        z-index: 497;
        max-height: calc(100vh - 95px);
        overflow-y: auto;
    }
    .nav-menu li { width: 100%; }
    .nav-menu a {
        display: block;
        padding: 1rem 2rem;
        font-size: .9rem;
        letter-spacing: .08em;
        color: rgba(255,255,255,.8) !important;
        border-bottom: 1px solid rgba(255,255,255,.06);
        text-transform: uppercase;
        line-height: 1.4;
        text-decoration: none;
    }
    .nav-menu a:hover { color: var(--gold) !important; background: rgba(255,255,255,.03); }

    /* Menu langues mobile (drapeaux) */
    .mms-desktop-only { display: none !important; }
    .mms-mobile-flags {
        display: flex !important;
        flex-wrap: wrap;
        gap: 8px;
        padding: 12px 16px;
        justify-content: center;
        background: #141414;
    }
    .mms-mobile-flags span {
        font-size: 1.8rem;
        cursor: pointer;
        transition: transform .2s;
    }
    .mms-mobile-flags span:hover { transform: scale(1.15); }
}

@media(max-width:768px) {
    .transport-grid { grid-template-columns: 1fr !important; }
}

/* Menu drapeaux compact */
.mms-flags-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
    padding: 4px;
}
.mms-flags-grid span {
    font-size: 1.6rem;
    cursor: pointer;
    transition: transform .2s;
    line-height: 1;
    padding: 4px;
    border-radius: 4px;
}
.mms-flags-grid span:hover {
    transform: scale(1.2);
    background: #fdf9f0;
}
/* Cacher les anciennes classes */
.mms-desktop-only { display: none !important; }
.mms-mobile-flags { display: none !important; }
.mms-lang-item { display: none !important; }

@media(max-width:768px) {
    /* Sur mobile, nav-translate s'affiche comme un petit bouton rond */
    a.nav-translate,
    a.nav-translate:link,
    a.nav-translate:visited {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        max-width: 32px !important;
        border-radius: 50% !important;
        border: 1.5px solid rgba(255,255,255,.5) !important;
        background: rgba(255,255,255,.05) !important;
        font-size: 1.1rem !important;
        padding: 0 !important;
        box-sizing: border-box !important;
        flex-shrink: 0 !important;
    }
    /* Cacher mob-lang-btn (plus utilisé) */
    .mob-lang-btn { display: none !important; }
}

/* ── TRANSPORT SECTION ── */
.transport-section {
    margin-top: 4rem;
    padding-top: 3rem;
    border-top: 1px solid var(--light-gray);
}
.transport-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}
.transport-card {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
    padding: 1.8rem;
    background: var(--off-white);
    border-left: 3px solid var(--gold);
}
.transport-icon {
    font-size: 2rem;
    flex-shrink: 0;
    line-height: 1;
    margin-top: .1rem;
}
.transport-title {
    font-family: 'Tenor Sans', serif;
    font-size: 1.05rem;
    color: var(--black);
    margin-bottom: .8rem;
    letter-spacing: .05em;
}
.transport-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    font-size: .85rem;
    color: var(--gray);
    line-height: 1.6;
}
.transport-list li::before {
    content: '—';
    color: var(--gold);
    margin-right: .5rem;
    font-weight: 300;
}
.transport-link {
    font-size: .78rem;
    color: var(--gold);
    text-decoration: none;
    letter-spacing: .05em;
    font-weight: 500;
}
.transport-link:hover { text-decoration: underline; }
@media(max-width:640px) {
    .transport-grid { grid-template-columns: 1fr; }
    .transport-card { padding: 1.2rem; }
}

@media(max-width:768px) {
    /* Nav : logo | [espace] | langue | hamburger */
    #nav {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: 1rem 1.5rem !important;
    }
    .nav-logo {
        flex: 0 0 auto;
        margin-right: auto;
    }
    .nav-mobile-right {
        flex: 0 0 auto;
        display: flex !important;
        align-items: center;
        gap: 14px;
    }
}

/* ── ANIMATION BOUTON RÉSERVER ── */

/* Desktop : invisible → visible */
@keyframes pulse-resa {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0; }
}

/* Mobile : texte noir → or */
@keyframes pulse-resa-text {
    0%, 100% { color: #000000; }
    50%       { color: #B8952A; }
}

/* Desktop */
.nav-book {
    animation: none;
    background: var(--gold) !important;
    color: var(--black) !important;
}
.nav-book:hover {
    animation: none;
    opacity: 1;
    background: var(--gold-light) !important;
    color: var(--black) !important;
}

/* Mobile : fond or fixe, texte clignote noir→or */
.mob-resa-bar {
    background: var(--gold) !important;
}
.mob-resa-link {
    animation: pulse-resa-text 2s ease-in-out infinite;
    padding: 14px 10px 12px !important;
}
.mob-resa-link:hover {
    animation: none;
    color: #000 !important;
}

/* Cacher widgets WordPress dans le footer */
.widget, .widget-area, #secondary,
.wp-block-group, .wp-block-columns,
.entry-content .widget,
body > .widget { display: none !important; }

/* Mobile : hamburger à gauche de langue dans nav-mobile-right */
@media(max-width:768px) {
    .nav-toggle { order: 1; }
    a.nav-translate { order: 2; }

    /* Bouton langue plus opaque (fond blanc semi-transparent) */
    a.nav-translate,
    a.nav-translate:link,
    a.nav-translate:visited {
        background: rgba(255,255,255,.35) !important;
        border: 1.5px solid rgba(255,255,255,.7) !important;
        backdrop-filter: blur(4px) !important;
    }
    a.nav-translate:hover {
        background: rgba(255,255,255,.55) !important;
    }
}

/* Espace entre hamburger et bouton langue mobile */
@media(max-width:768px) {
    .nav-toggle { margin-right: 10px; }
}
