/* =========================================================
   TIF TASSAADITE — Main Stylesheet
   Ported from the original HTML design mockup.
   Same colors, same fonts, same structure — adapted for
   multi-page WordPress use (Accueil, Maison d'hôtes,
   Activités, Excursions, Blog).
   ========================================================= */

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --brown-deep:#1A0F00;
  --brown-dark:#2A1A05;
  --brown-rich:#3D2408;
  --brown-mid:#6B3E1E;
  --brown-warm:#8B5230;
  --terra:#C4784A;
  --terra-light:#D4926A;
  --sand:#E8D5B0;
  --sand-light:#F5EFE0;
  --cream:#FAF6EE;
  --white:#FFFFFF;
  --gold:#C9A96E;
  --gold-light:#E2C99A;
  --font-display:'Cormorant Garamond',serif;
  --font-body:'Jost',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--cream);color:var(--brown-dark);overflow-x:hidden}
img{max-width:100%}
a{cursor:pointer}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--brown-rich);color:#fff;padding:.8rem 1.2rem;z-index:200}
.skip-link:focus{left:1rem;top:1rem}

/* NAV */
nav{position:fixed;top:0;left:0;width:100vw;z-index:100;padding:0 5%;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;column-gap:1.5rem;height:128px;transition:background .4s,box-shadow .4s;background:rgba(26,15,0,.55)}
nav.scrolled{background:rgba(26,15,0,.95);box-shadow:0 2px 30px rgba(0,0,0,.25)}
.nav-logo{display:flex;align-items:center;height:100%;justify-self:start}
.nav-logo img{height:124px;width:auto;max-width:none;object-fit:contain;display:block}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center;justify-self:center}
.nav-links a{color:#fff;text-decoration:none;font-family:var(--font-body);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;opacity:.85;transition:opacity .2s}
.nav-links a:hover,.nav-links li.current-menu-item a{opacity:1;color:var(--gold-light)}
.nav-cta{background:var(--terra);color:#fff;padding:.65rem 1.6rem;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;border:none;cursor:pointer;transition:background .2s;white-space:nowrap}
.nav-cta:hover{background:var(--brown-warm);color:#fff}
.nav-right{display:flex;align-items:center;gap:1rem;justify-self:end}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.hamburger span{width:24px;height:1.5px;background:#fff;display:block}

/* LANGUAGE SWITCHER */
.lang-switch{display:flex;align-items:center;gap:.5rem;margin-left:.5rem}
.lang-switch a{color:rgba(255,255,255,.6);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;padding:.2rem .35rem;transition:color .2s}
.lang-switch a.active,.lang-switch a:hover{color:var(--gold-light)}
.lang-switch span.sep{color:rgba(255,255,255,.3);font-size:.7rem}

/* HERO */
.hero{position:relative;width:100vw;margin-left:calc(50% - 50vw);height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding-top:128px}
.hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,#1A0F00 0%,#2A1A05 45%,#3D2408 100%)}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.62}
.hero-pattern{position:absolute;inset:0;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23E8D5B0'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,15,0,.55) 0%,rgba(26,15,0,.22) 50%,rgba(26,15,0,.15) 100%)}
.hero-content{position:relative;z-index:2;max-width:800px;padding:0 2rem}
.hero-eyebrow{font-family:var(--font-body);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-light);margin-bottom:1rem;opacity:.9}
.hero-logo-img{width:150px;height:auto;margin:0 auto 1.2rem;display:block}
.hero h1{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,5.5rem);font-weight:300;color:#fff;line-height:1.1;margin-bottom:1.5rem;font-style:italic}
.hero h1 span{color:var(--gold-light);font-style:normal;font-weight:400}
.hero-sub{font-family:var(--font-body);font-size:.92rem;color:rgba(255,255,255,.72);letter-spacing:.08em;margin-bottom:3rem;line-height:1.8;max-width:560px;margin-left:auto;margin-right:auto}
.hero-ctas{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap}
.btn-primary{background:var(--terra);color:#fff;padding:.9rem 2.4rem;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;transition:background .2s;display:inline-block;border:none;cursor:pointer}
.btn-primary:hover{background:var(--brown-warm);color:#fff}
.btn-outline{border:1px solid rgba(255,255,255,.45);color:#fff;padding:.9rem 2.4rem;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;transition:border-color .2s,color .2s;display:inline-block}
.btn-outline:hover{border-color:var(--gold-light);color:var(--gold-light)}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.6rem;z-index:2}
.hero-scroll span{font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.45),transparent);animation:scrollAnim 2s ease-in-out infinite}
@keyframes scrollAnim{0%,100%{opacity:.3;transform:scaleY(.5);transform-origin:top}50%{opacity:1;transform:scaleY(1);transform-origin:top}}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .scroll-line{animation:none}
}

/* PAGE HEADER (for inner pages, not homepage) */
.page-hero{position:relative;width:100vw;margin-left:calc(50% - 50vw);padding:11rem 5% 5rem;text-align:center;overflow:hidden;background:linear-gradient(160deg,#1A0F00 0%,#2A1A05 45%,#3D2408 100%)}
.page-hero-img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.6}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,15,0,.6) 0%,rgba(26,15,0,.3) 100%)}
.page-hero-content{position:relative;z-index:2;max-width:760px;margin:0 auto}
.page-hero .hero-eyebrow{margin-bottom:1.2rem}
.page-hero h1{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,4rem);font-weight:300;color:#fff;line-height:1.15;font-style:italic}
.page-hero h1 em{font-style:normal;color:var(--gold-light)}
.page-hero p{margin-top:1.2rem;color:rgba(255,255,255,.7);font-size:.92rem;line-height:1.8;max-width:600px;margin-left:auto;margin-right:auto}

/* INTRO STRIP */
.intro-strip{background:var(--brown-rich);padding:1.6rem 5%;display:flex;align-items:center;justify-content:center;gap:4rem;flex-wrap:wrap;border-top:1px solid rgba(201,169,110,.15);border-bottom:1px solid rgba(201,169,110,.15)}
.intro-strip-item{display:flex;align-items:center;gap:.8rem}
.strip-icon{width:36px;height:36px;border:1px solid rgba(201,169,110,.35);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.strip-icon svg{width:15px;height:15px;stroke:var(--gold);fill:none;stroke-width:1.5}
.intro-strip-item p{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light)}

/* SECTION BASE */
section{padding:6rem 5%}
.section-eyebrow{font-family:var(--font-body);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--terra);margin-bottom:1rem;display:block}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.2rem);font-weight:300;color:var(--brown-dark);line-height:1.2;margin-bottom:1.5rem}
.section-title em{font-style:italic;color:var(--terra)}
.section-desc{font-size:.9rem;line-height:1.9;color:var(--brown-mid);max-width:560px}
.section-desc p + p{margin-top:1.1rem}
.divider{width:48px;height:1px;background:var(--gold);margin:1.5rem 0}

/* GENERIC CONTENT PAGE (Maison d'hôtes, Excursions, etc.) */
.content-section{background:var(--cream)}
.content-block{max-width:760px;margin:0 auto 3.5rem;text-align:center}
.content-block:last-child{margin-bottom:0}
.content-block h2{font-family:var(--font-display);font-weight:700;font-size:1.9rem;color:var(--brown-rich);margin-bottom:.8rem}
.content-block h2 em{color:var(--terra);font-style:italic}
.content-block h3{font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:var(--brown-warm);margin:1.6rem 0 .6rem}
.content-block p{font-size:.92rem;line-height:1.95;color:var(--brown-mid);margin-bottom:1rem;text-align:center;margin-left:auto;margin-right:auto}
.content-block ul{margin:0 auto 1rem;color:var(--brown-mid);font-size:.92rem;line-height:1.9;text-align:left;max-width:560px;padding-left:1.2rem}
.content-block ul li{margin-bottom:.5rem}
.content-block ul li strong{color:var(--brown-rich)}
.content-block .inline-photo{display:block;width:100%;max-width:560px;height:320px;object-fit:cover;margin:1.4rem auto 2rem;border-radius:2px;box-shadow:0 8px 30px rgba(42,26,5,.12)}
.content-divider{width:48px;height:1px;background:var(--gold);margin:0 auto 3rem}
.content-block--centered{text-align:center}
.content-block--centered h2{font-weight:700}
.content-block--centered p{text-align:center;margin-left:auto;margin-right:auto}

/* ABOUT */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;max-width:1200px;margin:0 auto}
.about-visual{position:relative}
.about-img-main{width:100%;aspect-ratio:3/4;overflow:hidden;position:relative;background:var(--sand)}
.about-img-main img{width:100%;height:100%;object-fit:cover;display:block}
.about-img-accent{position:absolute;bottom:-2.5rem;right:-2.5rem;width:55%;aspect-ratio:4/3;overflow:hidden;border:5px solid var(--cream);box-shadow:0 8px 40px rgba(42,26,5,.2);background:var(--sand-light)}
.about-img-accent img{width:100%;height:100%;object-fit:cover;display:block}
.stat-row{display:flex;gap:2.5rem;margin-top:2.5rem;flex-wrap:wrap}
.stat{border-left:2px solid var(--terra);padding-left:1.2rem}
.stat-num{font-family:var(--font-display);font-size:2.4rem;font-weight:300;color:var(--brown-rich);display:block;line-height:1}
.stat-label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brown-mid);margin-top:.3rem}

/* ROOMS */
.rooms{background:var(--brown-dark)}
.rooms-header{text-align:center;margin-bottom:4rem;max-width:700px;margin-left:auto;margin-right:auto}
.rooms-header .section-title{color:var(--sand-light)}
.rooms-header .section-eyebrow{color:var(--terra)}
.rooms-header .section-desc{margin:0 auto;color:rgba(232,213,176,.6)}
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;max-width:1200px;margin:0 auto}
.room-card{position:relative;overflow:hidden;cursor:pointer;text-decoration:none;display:block}
.room-img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;transition:transform .5s;background:var(--brown-mid)}
.room-card:hover .room-img{transform:scale(1.04)}
.room-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,15,0,.92) 0%,transparent 55%);pointer-events:none}
.room-info{position:absolute;bottom:0;left:0;right:0;padding:2rem;z-index:1}
.room-tag{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--terra);margin-bottom:.5rem;display:block}
.room-name{font-family:var(--font-display);font-size:1.7rem;color:#fff;font-weight:300}
.room-detail{font-size:.72rem;color:rgba(255,255,255,.55);margin-top:.3rem;letter-spacing:.1em}

/* EXPERIENCE */
.experience{background:var(--sand-light)}
.exp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4rem;max-width:1200px;margin:0 auto;align-items:stretch}
.exp-text{display:flex;flex-direction:column}
.exp-features{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:2rem;flex:1;align-content:end}
.exp-feature{padding:1.5rem;border:1px solid rgba(107,62,30,.12);background:rgba(255,255,255,.7)}
.exp-feature-icon{width:30px;height:30px;margin-bottom:.8rem}
.exp-feature-icon svg{width:100%;height:100%;stroke:var(--terra);fill:none;stroke-width:1.5}
.exp-feature h4{font-family:var(--font-display);font-size:1.1rem;font-weight:400;color:var(--brown-rich);margin-bottom:.4rem}
.exp-feature p{font-size:.78rem;color:var(--brown-mid);line-height:1.7}
.exp-visual{position:relative}
.exp-visual-img{width:100%;height:580px;object-fit:cover;display:block;background:var(--brown-mid)}
.exp-quote{position:absolute;bottom:0;left:0;right:0;background:var(--brown-rich);padding:2rem}
.exp-quote blockquote{font-family:var(--font-display);font-size:1.08rem;font-style:italic;color:var(--sand);line-height:1.7;margin-bottom:.8rem}
.exp-quote cite{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold)}

/* ACTIVITIES */
.activities{background:var(--cream)}
.activities-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3.5rem;flex-wrap:wrap;gap:1.5rem;max-width:1200px;margin-left:auto;margin-right:auto}
.activities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1200px;margin:0 auto}
.activity-card{background:var(--white);overflow:hidden;transition:transform .3s;box-shadow:0 2px 20px rgba(42,26,5,.07)}
.activity-card:hover{transform:translateY(-6px)}
.activity-thumb{height:240px;overflow:hidden;position:relative;background:var(--brown-mid)}
.activity-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.activity-card:hover .activity-thumb img{transform:scale(1.05)}
.act-num{position:absolute;top:1.2rem;left:1.2rem;font-family:var(--font-display);font-size:3rem;font-weight:300;color:rgba(255,255,255,.18);line-height:1}
.activity-body{padding:1.6rem}
.activity-cat{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--terra);margin-bottom:.5rem;display:block}
.activity-card h3{font-family:var(--font-display);font-size:1.3rem;font-weight:400;color:var(--brown-rich);margin-bottom:.6rem}
.activity-card p{font-size:.8rem;color:var(--brown-mid);line-height:1.75}
.activity-link{display:inline-block;margin-top:1rem;font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--terra);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
.activity-link:hover{border-color:var(--terra)}

/* GALLERY */
.gallery{padding:0;background:var(--brown-deep);overflow:hidden}
.gallery-header{padding:5rem 5% 3rem;text-align:center}
.gallery-header .section-title{color:var(--sand-light)}
.gallery-header .section-eyebrow{color:var(--terra)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:280px 280px}
.gallery-cell{overflow:hidden;position:relative;background:var(--brown-mid)}
.gallery-cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.gallery-cell:hover img{transform:scale(1.06)}
.gallery-cell.wide{grid-column:span 2}

/* TESTIMONIALS */
.testimonials{background:var(--sand)}
.test-header{text-align:center;margin-bottom:4rem}
.test-header .section-title{color:var(--brown-rich)}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1100px;margin:0 auto}
.test-card{background:var(--white);padding:2rem;border-top:2px solid var(--terra)}
.test-stars{display:flex;gap:3px;margin-bottom:1.2rem}
.star{width:12px;height:12px;background:var(--gold);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.test-card blockquote{font-family:var(--font-display);font-size:1.05rem;font-style:italic;color:var(--brown-rich);line-height:1.7;margin-bottom:1.2rem}
.test-author{display:flex;align-items:center;gap:.8rem;border-top:1px solid rgba(107,62,30,.1);padding-top:1rem;margin-top:1rem}
.test-avatar{width:36px;height:36px;border-radius:50%;background:var(--brown-rich);display:flex;align-items:center;justify-content:center;color:var(--sand);font-family:var(--font-display);font-size:.9rem;flex-shrink:0}
.test-name{font-size:.78rem;font-weight:500;color:var(--brown-rich);letter-spacing:.05em}
.test-from{font-size:.68rem;color:var(--brown-mid);margin-top:.1rem;letter-spacing:.08em}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1200px;margin:0 auto}
.blog-card{background:var(--white);overflow:hidden;transition:transform .3s;box-shadow:0 2px 20px rgba(42,26,5,.07);text-decoration:none;display:block}
.blog-card:hover{transform:translateY(-6px)}
.blog-thumb{height:220px;overflow:hidden;background:var(--brown-mid)}
.blog-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.blog-card:hover .blog-thumb img{transform:scale(1.05)}
.blog-body{padding:1.6rem;display:flex;flex-direction:column}
.blog-cat{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--terra);margin-bottom:.5rem;display:block}
.blog-card h3{font-family:var(--font-display);font-size:1.25rem;font-weight:400;color:var(--brown-rich);margin-bottom:.6rem;line-height:1.3}
.blog-card p{font-size:.8rem;color:var(--brown-mid);line-height:1.75}
.blog-card .activity-link{margin-top:1.1rem}
.blog-date{font-size:.68rem;color:var(--brown-mid);letter-spacing:.08em;margin-top:.6rem;display:block}

/* SINGLE BLOG POST */
.single-post{background:var(--cream);max-width:760px;margin:0 auto}
.single-post .post-meta{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--terra);margin-bottom:1rem}
.single-post .post-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;margin-bottom:2.5rem;background:var(--sand)}
.single-post-content h2{font-family:var(--font-display);font-weight:400;font-size:1.7rem;color:var(--brown-rich);margin:2rem 0 .8rem}
.single-post-content h3{font-family:var(--font-display);font-weight:500;font-size:1.25rem;color:var(--brown-warm);margin:1.6rem 0 .6rem}
.single-post-content p{font-size:.94rem;line-height:1.95;color:var(--brown-mid);margin-bottom:1.1rem}
.single-post-content ul{margin:0 0 1.1rem 1.2rem;color:var(--brown-mid);line-height:1.9}
.single-post-content blockquote{border-left:2px solid var(--terra);padding-left:1.5rem;font-family:var(--font-display);font-style:italic;color:var(--brown-rich);font-size:1.1rem;margin:1.5rem 0}

/* CTA */
.cta-section{background:var(--brown-rich);padding:7rem 5%;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23C9A96E' fill-opacity='0.04'%3E%3Cpath d='M20 0L40 20L20 40L0 20z'/%3E%3C/g%3E%3C/svg%3E")}
.cta-content{position:relative;z-index:1;max-width:700px;margin:0 auto}
.cta-section .section-eyebrow{color:var(--terra)}
.cta-section .section-title{color:var(--sand-light)}
.cta-section .section-desc{color:rgba(232,213,176,.6);margin:0 auto 3rem;max-width:480px}
.cta-form{display:flex;max-width:480px;margin:0 auto}
.cta-form input{flex:1;padding:.9rem 1.2rem;background:rgba(255,255,255,.07);border:1px solid rgba(201,169,110,.2);color:#fff;font-family:var(--font-body);font-size:.82rem;outline:none;transition:border-color .2s}
.cta-form input::placeholder{color:rgba(255,255,255,.35)}
.cta-form input:focus{border-color:var(--gold)}
.cta-form button{background:var(--terra);color:#fff;border:none;padding:0 1.8rem;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;font-family:var(--font-body);transition:background .2s;white-space:nowrap}
.cta-form button:hover{background:var(--brown-warm)}
.cta-or{color:rgba(255,255,255,.35);font-size:.72rem;margin:1.5rem 0;letter-spacing:.1em;text-transform:uppercase}
.cta-form-feedback{color:var(--gold-light);font-size:.8rem;margin-top:1rem}

/* CONTACT FORM (page) */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4rem;max-width:1100px;margin:0 auto;align-items:start}
.contact-form-box{background:var(--white);padding:2.5rem;box-shadow:0 2px 20px rgba(42,26,5,.07)}
.contact-form-box label{display:block;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brown-mid);margin-bottom:.4rem;margin-top:1.1rem}
.contact-form-box label:first-child{margin-top:0}
.contact-form-box input,.contact-form-box textarea,.contact-form-box select{width:100%;padding:.8rem 1rem;border:1px solid rgba(107,62,30,.18);background:var(--sand-light);font-family:var(--font-body);font-size:.85rem;color:var(--brown-dark);outline:none;transition:border-color .2s}
.contact-form-box input:focus,.contact-form-box textarea:focus,.contact-form-box select:focus{border-color:var(--terra)}
.contact-form-box textarea{resize:vertical;min-height:120px}
.contact-form-box button{margin-top:1.6rem;background:var(--terra);color:#fff;border:none;padding:.9rem 2.2rem;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;transition:background .2s}
.contact-form-box button:hover{background:var(--brown-warm)}
.contact-info-box{padding-top:1rem}
.contact-info-box h3{font-family:var(--font-display);font-size:1.4rem;color:var(--brown-rich);margin-bottom:1rem;font-weight:400;opacity:1;visibility:visible}
.contact-info-box address{font-size:.9rem;color:var(--brown-mid);line-height:2;font-style:normal}
.contact-info-box a{color:var(--terra);text-decoration:none}

/* FOOTER */
footer{background:var(--brown-deep);width:100vw;margin-left:calc(50% - 50vw);padding:4rem 5% 2.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem;max-width:1300px;margin-left:auto;margin-right:auto}
.footer-brand img{height:170px;width:auto;max-width:340px;object-fit:contain;margin-bottom:1.2rem;display:block}
.footer-brand p{font-size:.78rem;color:rgba(232,213,176,.5);line-height:1.8;max-width:240px}
.footer-col h5{font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--terra);margin-bottom:1.2rem}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.6rem}
.footer-col a{font-size:.78rem;color:rgba(232,213,176,.5);text-decoration:none;transition:color .2s}
.footer-col a:hover{color:var(--gold-light)}
.footer-col address{font-size:.78rem;color:rgba(232,213,176,.5);font-style:normal;line-height:1.9}
.footer-bottom{border-top:1px solid rgba(201,169,110,.1);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;max-width:1300px;margin-left:auto;margin-right:auto}
.footer-bottom p{font-size:.7rem;color:rgba(232,213,176,.3);letter-spacing:.05em}
.social-links{display:flex;gap:1rem}
.social-links a{width:32px;height:32px;border:1px solid rgba(201,169,110,.2);display:flex;align-items:center;justify-content:center;transition:border-color .2s;text-decoration:none}
.social-links a:hover{border-color:var(--terra)}
.social-links svg{width:14px;height:14px;stroke:rgba(232,213,176,.45);fill:none;stroke-width:1.5}

/* MOBILE NAV */
.mobile-menu{display:none;position:fixed;inset:0;background:rgba(26,15,0,.98);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:2rem}
.mobile-menu.open{display:flex}
.mobile-menu a{color:#fff;text-decoration:none;font-family:var(--font-display);font-size:1.8rem;font-weight:300;font-style:italic;opacity:.85}
.mobile-menu .lang-switch{margin-top:1rem}
.mobile-menu .lang-switch a{font-family:var(--font-body);font-size:.85rem;font-style:normal}
.mobile-close{position:absolute;top:2rem;right:2rem;background:none;border:none;cursor:pointer;color:#fff;font-size:1.5rem}

/* WORDPRESS DEFAULTS / ACCESSIBILITY */
.screen-reader-text{position:absolute!important;left:-9999px}
.alignleft{float:left;margin:0 1.5rem 1rem 0}
.alignright{float:right;margin:0 0 1rem 1.5rem}
.aligncenter{display:block;margin:0 auto 1rem}
.wp-pagenavi,.pagination{text-align:center;margin-top:3rem;font-size:.8rem;letter-spacing:.08em}
.pagination a,.pagination span{display:inline-block;padding:.6rem 1.1rem;margin:0 .2rem;border:1px solid rgba(107,62,30,.2);color:var(--brown-mid);text-decoration:none;transition:border-color .2s}
.pagination a:hover,.pagination .current{border-color:var(--terra);color:var(--terra)}

@media(max-width:900px){
  .about-grid,.exp-grid,.contact-wrap{grid-template-columns:1fr}
  .rooms-grid{grid-template-columns:1fr 1fr}
  .activities-grid,.test-grid,.footer-grid,.blog-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gallery-cell.wide{grid-column:span 1}
  .gallery-cell{height:220px}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .about-img-accent{display:none}
  .exp-visual-img{height:350px}
  nav{height:90px}
  .nav-logo img{height:80px;max-width:200px}
}
@media(max-width:600px){
  .rooms-grid,.activities-grid,.test-grid,.footer-grid,.intro-strip,.exp-features,.blog-grid{grid-template-columns:1fr}
  section{padding:4rem 5%}
  .cta-form{flex-direction:column}
  .cta-form button{padding:.9rem 1.5rem}
  .activities-header{flex-direction:column;align-items:flex-start}
  .page-hero{padding:9rem 5% 4rem}
  nav{height:84px;padding:0 4%}
  .nav-logo img{height:74px;max-width:180px}
  .footer-brand img{height:140px;max-width:280px}
}

/* FLOATING WHATSAPP BUTTON */
.whatsapp-float{position:fixed;bottom:24px;right:24px;width:58px;height:58px;background:#25D366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.25);z-index:200;transition:transform .2s,box-shadow .2s}
.whatsapp-float svg{width:30px;height:30px}
.whatsapp-float:hover{transform:scale(1.08);box-shadow:0 6px 20px rgba(0,0,0,.3)}
@media(max-width:600px){
  .whatsapp-float{width:52px;height:52px;bottom:18px;right:18px}
  .whatsapp-float svg{width:26px;height:26px}
  .content-block .inline-photo{height:220px}
}
