:root{
    --ivory:#FAF7F0;--ivory-d:#F0EBE0;--ivory-dd:#E8DFD0;
    --gold:#C4891A;--gold-l:#E8C878;--gold-d:#8B6010;
    --teal:#1A6B5E;--teal-l:#E0F2EF;--teal-d:#0D4A40;
    --earth:#8B5E3C;--charcoal:#2A2520;--charcoal-m:#5A524A;
    --stone:#9A9088;--white:#FFFFFF;
    --font-d:'Cormorant Garamond',Georgia,serif;
    --font-b:'Jost',sans-serif;
    --max:1200px;--r:4px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--ivory);color:var(--charcoal);font-family:var(--font-b);font-weight:300;line-height:1.7;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

/* ── Typography ── */
h1,h2,h3,h4{font-family:var(--font-d);font-weight:400;line-height:1.2;}
h1{font-size:clamp(2.6rem,5.5vw,5rem);}
h2{font-size:clamp(1.8rem,3.5vw,3rem);}
h3{font-size:clamp(1.3rem,2vw,1.8rem);}
h4{font-size:1.1rem;}
p{font-size:0.95rem;color:var(--charcoal-m);line-height:1.8;}
.eyebrow{font-family:var(--font-b);font-size:0.65rem;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);}
.gold-line{display:block;width:48px;height:1px;background:var(--gold);margin:14px 0;}
.gold-line.center{margin:14px auto;}

/* ── Layout ── */
section{padding:88px 24px;}
.container{max-width:var(--max);margin:0 auto;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}

/* ── Buttons ── */
.btn{display:inline-block;font-family:var(--font-b);font-size:0.72rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;padding:13px 32px;border-radius:var(--r);transition:all 0.2s;cursor:pointer;border:none;}
.btn-primary{background:var(--gold);color:var(--white);}
.btn-primary:hover{background:var(--gold-d);transform:translateY(-1px);}
.btn-outline{background:transparent;color:var(--charcoal);border:0.5px solid rgba(42,37,32,0.35);}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);}
.btn-outline-light{background:transparent;color:var(--ivory);border:0.5px solid rgba(250,247,240,0.4);}
.btn-outline-light:hover{border-color:var(--gold-l);color:var(--gold-l);}
.btn-teal{background:var(--teal);color:var(--white);}
.btn-teal:hover{background:var(--teal-d);}
.btn-white{background:var(--white);color:var(--teal-d);font-weight:500;}
.btn-white:hover{background:var(--teal-l);}

/* ── Nav ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 40px;display:flex;align-items:center;justify-content:space-between;transition:all 0.4s;}
nav.scrolled{background:rgba(250,247,240,0.97);padding:14px 40px;border-bottom:0.5px solid rgba(196,137,26,0.18);}
.nav-logo{font-family:var(--font-d);font-size:1.3rem;color:var(--ivory);transition:color 0.4s;}
nav.scrolled .nav-logo{color:var(--charcoal);}
.nav-logo span{color:var(--gold-l);}
nav.scrolled .nav-logo span{color:var(--gold);}
.nav-links{display:flex;gap:28px;list-style:none;}
.nav-links a{font-size:0.7rem;font-weight:400;letter-spacing:0.12em;text-transform:uppercase;color:rgba(250,247,240,0.8);transition:color 0.2s;}
nav.scrolled .nav-links a{color:var(--charcoal-m);}
.nav-links a:hover{color:var(--gold-l);}
nav.scrolled .nav-links a:hover{color:var(--gold);}
.nav-book{background:var(--gold) !important;color:var(--white) !important;padding:9px 22px;border-radius:var(--r);}
.nav-book:hover{background:var(--gold-d) !important;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px;}
.hamburger span{width:22px;height:1px;background:var(--ivory);display:block;transition:0.3s;}
nav.scrolled .hamburger span{background:var(--charcoal);}

/* ── Mobile nav ── */
.mobile-nav{position:fixed;inset:0;background:var(--charcoal);z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;transform:translateX(100%);transition:transform 0.4s ease;}
.mobile-nav.open{transform:translateX(0);}
.mobile-nav a{font-family:var(--font-d);font-size:1.8rem;color:var(--ivory);font-weight:300;}
.mobile-nav a:hover{color:var(--gold-l);}
.mnav-close{position:absolute;top:24px;right:28px;background:none;border:none;color:var(--ivory);font-size:1.4rem;cursor:pointer;line-height:1;}

/* ── Hero ── */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;justify-content:center;background:var(--charcoal);overflow:hidden;}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#1a1510 0%,#2d2218 45%,#1a2520 100%);}
.hero-pattern{position:absolute;inset:0;opacity:0.035;background-image:repeating-linear-gradient(45deg,#C4891A 0,#C4891A 1px,transparent 0,transparent 50%),repeating-linear-gradient(-45deg,#C4891A 0,#C4891A 1px,transparent 0,transparent 50%);background-size:36px 36px;}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 25%,rgba(26,21,16,0.65) 100%);}
.hero-content{position:relative;z-index:2;text-align:center;padding:120px 24px 80px;max-width:860px;animation:fadeUp 1.2s ease both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
.hero-eyebrow{display:block;font-family:var(--font-b);font-size:0.6rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--gold-l);margin-bottom:20px;opacity:0.85;animation:fadeUp 1.2s ease 0.15s both;}
.hero h1{color:var(--ivory);font-weight:300;margin-bottom:6px;animation:fadeUp 1.2s ease 0.25s both;}
.hero h1 em{font-style:italic;color:var(--gold-l);}
.hero-sub{font-family:var(--font-d);font-size:clamp(1rem,2vw,1.4rem);color:rgba(250,247,240,0.6);font-style:italic;margin-bottom:44px;animation:fadeUp 1.2s ease 0.35s both;}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;animation:fadeUp 1.2s ease 0.45s both;}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;animation:fadeUp 1.2s ease 0.6s both;}
.hero-scroll span{font-size:0.58rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(250,247,240,0.35);}
.scroll-line{width:1px;height:36px;background:rgba(196,137,26,0.4);animation:scrollPulse 2.2s ease infinite;}
@keyframes scrollPulse{0%,100%{opacity:0.3;}50%{opacity:1;}}

/* ── Direct booking banner ── */
.direct-banner{background:var(--teal);padding:20px 40px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.direct-banner p{color:rgba(255,255,255,0.85);font-size:0.88rem;}
.direct-banner strong{color:var(--white);}

/* ── Key facts bar ── */
.facts-bar{background:var(--charcoal);padding:20px 40px;}
.facts-grid{display:flex;justify-content:center;gap:0;flex-wrap:wrap;max-width:var(--max);margin:0 auto;}
.fact-item{flex:1;min-width:120px;text-align:center;padding:12px 20px;border-right:0.5px solid rgba(196,137,26,0.2);}
.fact-item:last-child{border-right:none;}
.fact-val{font-family:var(--font-d);font-size:1.4rem;color:var(--ivory);display:block;margin-bottom:3px;}
.fact-lbl{font-size:0.6rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(250,247,240,0.4);}

/* ── Rate card section ── */
.rate-card-section{background:var(--ivory-d);padding:72px 24px;}
.rate-card-img{width:100%;max-width:900px;margin:0 auto;border-radius:var(--r);border:0.5px solid rgba(196,137,26,0.2);}
.rate-note{text-align:center;margin-top:20px;font-size:0.8rem;color:var(--stone);font-style:italic;}

/* ── Rooms ── */
.rooms{background:var(--ivory);}
.rooms-header{text-align:center;margin-bottom:56px;}
.rooms-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;}
.room-card{background:var(--white);border:0.5px solid rgba(196,137,26,0.15);border-radius:var(--r);overflow:hidden;transition:transform 0.3s,box-shadow 0.3s;}
.room-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(26,21,16,0.09);}
.room-card.full{grid-column:1/-1;display:grid;grid-template-columns:1.2fr 1fr;}
.room-image{background:linear-gradient(135deg,#2d2218,#1a2520);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.room-card.full .room-image{aspect-ratio:auto;min-height:380px;}
.room-img-ph{font-family:var(--font-d);font-style:italic;font-size:0.8rem;color:rgba(232,200,120,0.35);text-align:center;padding:20px;}
.room-img-ph::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,#C4891A 0,#C4891A 0.5px,transparent 0,transparent 28px);opacity:0.04;}
.room-badge{position:absolute;top:14px;left:14px;background:var(--gold);color:var(--white);font-size:0.58rem;letter-spacing:0.16em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r);}
.more-photos-badge{position:absolute;bottom:14px;right:14px;background:var(--gold);color:var(--white);font-size:0.6rem;letter-spacing:0.16em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r);}
.room-content{padding:28px;}
.room-content .eyebrow{margin-bottom:6px;}
.room-content h3{margin-bottom:10px;}
.room-content>p{font-size:0.875rem;margin-bottom:16px;}
.room-meta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px;}
.rm{font-size:0.72rem;color:var(--stone);display:flex;align-items:center;gap:5px;}
.rm svg{width:13px;height:13px;stroke:var(--gold);fill:none;stroke-width:1.5;flex-shrink:0;}
.room-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px;}
.tag{font-size:0.62rem;letter-spacing:0.07em;color:var(--charcoal-m);background:var(--ivory-d);padding:3px 9px;border-radius:20px;border:0.5px solid rgba(196,137,26,0.15);}
.vfull-image-img { width: 100%; height: 100%; object-fit: cover; }

/* ── Collapsible READ MORE ── */
.rm-toggle{background:none;border:none;font-family:var(--font-b);font-size:0.68rem;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--teal);cursor:pointer;padding:0;display:flex;align-items:center;gap:6px;margin-bottom:12px;}
.rm-toggle svg{width:14px;height:14px;stroke:var(--teal);fill:none;stroke-width:1.5;transition:transform 0.3s;}
.rm-toggle.open svg{transform:rotate(180deg);}
.rm-body{overflow:hidden;max-height:0;transition:max-height 0.4s ease;}
.rm-body.open{max-height:800px;}
.rm-inner{padding:16px 0 4px;}
.rm-inner p{font-size:0.85rem;margin-bottom:10px;}
.rm-inner ul{padding-left:20px;margin-bottom:10px;}
.rm-inner li{font-size:0.85rem;color:var(--charcoal-m);margin-bottom:4px;}

/* ── Full villa ── */
.full-villa{background:var(--ivory-d);}
.fv-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
.fv-features{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px;}
.fv-feature{padding:18px;background:var(--ivory);border:0.5px solid rgba(196,137,26,0.15);border-radius:var(--r);}
.fv-feature h4{font-family:var(--font-b);font-size:0.82rem;font-weight:500;color:var(--charcoal);margin-bottom:4px;}
.fv-feature p{font-size:0.78rem;}
.fv-image{background:linear-gradient(135deg,#2d2218,#1a2520);aspect-ratio:4/3;border-radius:var(--r);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.fv-image::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,#C4891A 0,#C4891A 0.5px,transparent 0,transparent 26px);opacity:0.04;}
.vext-image-img { width: 100%; height: 100%; object-fit: cover; }

/* ── Eat Well ── */
.eat-well{background:var(--charcoal);}
.eat-well h2,.eat-well .eyebrow{color:var(--ivory);}
.eat-well .eyebrow{color:var(--gold-l);}
.eat-well .gold-line{background:var(--gold-l);}
.eat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;}
.eat-card{background:rgba(255,255,255,0.04);border:0.5px solid rgba(196,137,26,0.2);border-radius:var(--r);padding:32px 26px;}
.eat-card h4{font-family:var(--font-d);font-size:1.3rem;color:var(--ivory);font-weight:400;margin-bottom:10px;}
.eat-card p{font-size:0.82rem;color:rgba(250,247,240,0.55);line-height:1.75;}
.eat-card .rm-toggle{color:var(--gold-l);}
.eat-card .rm-toggle svg{stroke:var(--gold-l);}
.eat-card .rm-inner p{color:rgba(250,247,240,0.6);}
.eat-card .rm-inner li{color:rgba(250,247,240,0.55);}
.eat-num{font-family:var(--font-d);font-size:2.2rem;color:rgba(196,137,26,0.25);line-height:1;margin-bottom:8px;}

/* ── Heal Well ── */
.heal-well{background:var(--ivory);}
.heal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px;}
.heal-card{border-top:0.5px solid rgba(196,137,26,0.3);padding-top:24px;}
.heal-num{font-family:var(--font-d);font-size:2.2rem;color:rgba(196,137,26,0.25);line-height:1;margin-bottom:8px;}
.heal-card h4{font-family:var(--font-d);font-size:1.25rem;color:var(--charcoal);font-weight:400;margin-bottom:10px;}
.heal-card p{font-size:0.85rem;}

/* ── Occasions ── */
.occasions{background:var(--ivory-d);}
.occ-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px;}
.occ-card{background:var(--ivory);border:0.5px solid rgba(196,137,26,0.15);border-radius:var(--r);padding:32px 26px;text-align:center;transition:transform 0.3s;}
.occ-card:hover{transform:translateY(-4px);}
.occ-icon{width:56px;height:56px;margin:0 auto 18px;border:0.5px solid rgba(196,137,26,0.35);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.occ-icon svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.2;}
.occ-card h4{font-family:var(--font-d);font-size:1.2rem;margin-bottom:10px;}
.occ-card p{font-size:0.82rem;}

/* ── Extras table ── */
.extras{background:var(--ivory);}
.extras-table{width:100%;border-collapse:collapse;margin-top:40px;}
.extras-table th{text-align:left;padding:10px 16px;border-bottom:0.5px solid rgba(196,137,26,0.3);font-family:var(--font-b);font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--stone);}
.extras-table td{padding:14px 16px;border-bottom:0.5px solid rgba(196,137,26,0.1);font-size:0.875rem;color:var(--charcoal-m);vertical-align:top;}
.extras-table tr:last-child td{border-bottom:none;}
.extras-table tr:nth-child(even) td{background:var(--ivory-d);}
.extras-table td:first-child{font-weight:500;color:var(--charcoal);width:220px;}

/* ── Location ── */
.location{background:var(--ivory-d);}
.loc-map{background:linear-gradient(135deg,#2d2218,#1a2520);aspect-ratio:4/3;border-radius:var(--r);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.loc-map::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(196,137,26,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(196,137,26,0.05) 1px,transparent 1px);background-size:40px 40px;}
.map-pin{position:absolute;width:10px;height:10px;background:var(--gold);border-radius:50%;top:48%;left:50%;transform:translate(-50%,-50%);}
.map-pin::after{content:'';position:absolute;width:28px;height:28px;border:1px solid rgba(196,137,26,0.5);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);animation:pulse 2s ease infinite;}
@keyframes pulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:0.6;}50%{transform:translate(-50%,-50%) scale(1.6);opacity:0;}}
.map-label{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);font-family:var(--font-d);font-style:italic;color:rgba(232,200,120,0.5);font-size:0.8rem;white-space:nowrap;}
.dist-table{width:100%;margin-top:24px;}
.dist-row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:0.5px solid rgba(196,137,26,0.1);font-size:0.875rem;}
.dist-row:last-child{border-bottom:none;}
.dist-row span:last-child{color:var(--gold);font-weight:500;}

/* ── Weligama destination ── */
.weligama{background:var(--ivory);}
.welig-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:48px;}
.welig-card{background:var(--ivory-d);border:0.5px solid rgba(196,137,26,0.15);border-radius:var(--r);padding:32px 28px;}
.welig-card h3{margin-bottom:12px;}
.welig-card p{font-size:0.875rem;margin-bottom:12px;}
.season-badge{display:inline-block;background:var(--teal-l);color:var(--teal-d);font-size:0.65rem;letter-spacing:0.12em;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:12px;font-weight:500;}

/* ── Our story ── */
.story{background:var(--charcoal);}
.story h2,.story .eyebrow,.story .gold-line{color:var(--ivory);}
.story .eyebrow{color:var(--gold-l);}
.story .gold-line{background:var(--gold-l);}
.story p{color:rgba(250,247,240,0.65);}
.story em{font-family:var(--font-d);font-style:italic;font-size:1.05rem;color:var(--ivory);}
.story .rm-toggle{color:var(--gold-l);}
.story .rm-toggle svg{stroke:var(--gold-l);}
.story .rm-inner p{color:rgba(250,247,240,0.65);}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;}
.team-card{background:rgba(255,255,255,0.04);border:0.5px solid rgba(196,137,26,0.2);border-radius:var(--r);padding:28px 22px;text-align:center;}
.team-photo{width:80px;height:80px;border-radius:50%;background:rgba(196,137,26,0.15);border:0.5px solid rgba(196,137,26,0.35);margin:0 auto 16px;display:flex;align-items:center;justify-content:center;}
.team-photo span{font-family:var(--font-d);font-size:1.6rem;color:var(--gold-l);}
.team-card h4{font-family:var(--font-d);font-size:1.1rem;color:var(--ivory);font-weight:400;margin-bottom:6px;}
.team-card .role{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold-l);margin-bottom:10px;}
.team-card p{font-size:0.8rem;color:rgba(250,247,240,0.55);}
.ewb-banner{background:rgba(196,137,26,0.1);border:0.5px solid rgba(196,137,26,0.25);border-radius:var(--r);padding:20px 28px;margin-top:40px;}
.ewb-banner p{color:rgba(250,247,240,0.75);font-size:0.875rem;}
.ewb-banner strong{color:var(--gold-l);}

/* ── Reviews ── */
.reviews{background:var(--ivory-d);}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.rev-card{background:var(--ivory);border:0.5px solid rgba(196,137,26,0.12);border-radius:var(--r);padding:28px;}
.stars{display:flex;gap:3px;margin-bottom:14px;}
.star{width:11px;height:11px;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%);}
.rev-card blockquote{font-family:var(--font-d);font-style:italic;font-size:0.98rem;color:var(--charcoal);line-height:1.7;margin-bottom:16px;}
.rev-card cite{font-size:0.7rem;font-style:normal;color:var(--stone);letter-spacing:0.07em;text-transform:uppercase;}
.rev-source{font-size:0.62rem;color:var(--gold);letter-spacing:0.1em;text-transform:uppercase;margin-top:4px;}
.press-bar{margin-top:56px;text-align:center;}
.press-bar .eyebrow{margin-bottom:20px;}
.press-items{display:flex;justify-content:center;gap:48px;flex-wrap:wrap;align-items:center;}
.press-item{font-family:var(--font-d);font-size:1.2rem;color:var(--stone);}

/* ── Q&A ── */
.qanda{background:var(--ivory);}
.qa-list{margin-top:40px;max-width:800px;margin-left:auto;margin-right:auto;}
.qa-item{border-bottom:0.5px solid rgba(196,137,26,0.15);padding:20px 0;}
.qa-item:last-child{border-bottom:none;}
.qa-q{font-family:var(--font-d);font-size:1.1rem;color:var(--charcoal);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;}
.qa-q svg{width:16px;height:16px;stroke:var(--gold);fill:none;stroke-width:1.5;flex-shrink:0;transition:transform 0.3s;}
.qa-q.open svg{transform:rotate(180deg);}
.qa-a{overflow:hidden;max-height:0;transition:max-height 0.4s ease;}
.qa-a.open{max-height:400px;}
.qa-a p{padding-top:14px;font-size:0.875rem;}

/* ── Foozoo recommends ── */
.recommends{background:var(--ivory-d);}
.rec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:40px;}
.rec-cat{background:var(--ivory);border:0.5px solid rgba(196,137,26,0.15);border-radius:var(--r);padding:28px;}
.rec-cat h4{font-family:var(--font-d);font-size:1.15rem;margin-bottom:14px;}
.rec-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:0.5px solid rgba(196,137,26,0.08);}
.rec-item:last-child{border-bottom:none;}
.rec-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;margin-top:7px;flex-shrink:0;}
.rec-item p{font-size:0.82rem;margin:0;}
.rec-item a{color:var(--teal);font-size:0.75rem;}
.rec-item a:hover{color:var(--gold);}
.rec-soon{font-size:0.78rem;color:var(--stone);font-style:italic;}

/* ── Blog ── */
.blog{background:var(--ivory);}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px;}
.blog-card{background:var(--ivory-d);border:0.5px solid rgba(196,137,26,0.12);border-radius:var(--r);padding:28px;}
.blog-num{font-family:var(--font-d);font-size:1.8rem;color:rgba(196,137,26,0.2);margin-bottom:8px;line-height:1;}
.blog-card h4{font-family:var(--font-d);font-size:1.05rem;color:var(--charcoal);font-weight:400;line-height:1.4;margin-bottom:8px;}
.blog-card p{font-size:0.78rem;color:var(--stone);}
.blog-soon{font-size:0.65rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);margin-top:8px;display:block;}

/* ── Book direct ── */
.book-direct{background:var(--charcoal);}
.book-direct h2{color:var(--ivory);}
.book-direct .eyebrow{color:var(--gold-l);}
.book-direct .gold-line{background:var(--gold-l);}
.book-direct>div>p{color:rgba(250,247,240,0.6);}
.booking-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:36px 0;}
.book-opt{background:rgba(255,255,255,0.04);border:0.5px solid rgba(196,137,26,0.22);border-radius:var(--r);padding:28px 20px;text-align:center;transition:all 0.3s;display:block;}
.book-opt:hover{background:rgba(196,137,26,0.1);border-color:var(--gold);}
.book-opt svg{width:26px;height:26px;stroke:var(--gold-l);fill:none;stroke-width:1.2;margin:0 auto 12px;display:block;}
.book-opt h4{font-family:var(--font-d);font-size:1rem;color:var(--ivory);font-weight:400;margin-bottom:6px;}
.book-opt p{font-size:0.78rem;color:rgba(250,247,240,0.45);}
.guarantee-row{display:flex;justify-content:center;gap:28px;flex-wrap:wrap;}
.guarantee-item{font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(250,247,240,0.35);display:flex;align-items:center;gap:7px;}
.guarantee-item::before{content:'—';color:var(--gold);}

/* ── Nature disclaimer ── */
.nature-note{background:var(--teal-l);border:0.5px solid rgba(26,107,94,0.3);border-radius:var(--r);padding:22px 28px;margin-top:32px;}
.nature-note p{font-size:0.85rem;color:var(--teal-d);line-height:1.8;}

/* ── Policies ── */
.policies{background:var(--ivory-d);}
.pol-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:40px;}
.pol-item{background:var(--ivory);border:0.5px solid rgba(196,137,26,0.12);border-radius:var(--r);padding:20px 22px;}
.pol-item h4{font-family:var(--font-b);font-size:0.78rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--charcoal);margin-bottom:6px;}
.pol-item p{font-size:0.82rem;}

/* ── Footer ── */
footer{background:#1A1510;padding:72px 24px 36px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:52px;max-width:var(--max);margin:0 auto 52px;}
.footer-brand h3{font-family:var(--font-d);font-size:1.5rem;color:var(--ivory);font-weight:400;margin-bottom:14px;}
.footer-brand p{font-size:0.82rem;color:rgba(250,247,240,0.45);line-height:1.8;margin-bottom:20px;}
.footer-contact a{display:block;font-size:0.8rem;color:rgba(250,247,240,0.5);margin-bottom:7px;transition:color 0.2s;}
.footer-contact a:hover{color:var(--gold-l);}
.footer-col h4{font-family:var(--font-b);font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:18px;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:9px;}
.footer-col a{font-size:0.82rem;color:rgba(250,247,240,0.45);transition:color 0.2s;}
.footer-col a:hover{color:var(--gold-l);}
.social-row{display:flex;gap:14px;margin-top:16px;}
.social-link{width:34px;height:34px;border:0.5px solid rgba(196,137,26,0.3);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:border-color 0.2s;}
.social-link:hover{border-color:var(--gold-l);}
.social-link svg{width:15px;height:15px;stroke:rgba(250,247,240,0.5);fill:none;stroke-width:1.5;}
.social-link:hover svg{stroke:var(--gold-l);}
.footer-bottom{max-width:var(--max);margin:0 auto;padding-top:28px;border-top:0.5px solid rgba(196,137,26,0.12);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-bottom p{font-size:0.72rem;color:rgba(250,247,240,0.3);}
.footer-pillars{font-size:0.62rem;letter-spacing:0.14em;color:rgba(196,137,26,0.4);}

/* ── Sticky booking bar ── */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;background:rgba(42,37,32,0.97);border-top:0.5px solid rgba(196,137,26,0.25);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;z-index:99;transform:translateY(100%);transition:transform 0.4s;gap:14px;flex-wrap:wrap;}
.sticky-bar.visible{transform:translateY(0);}
.sticky-bar p{font-size:0.78rem;color:rgba(250,247,240,0.65);}
.sticky-bar strong{color:var(--gold-l);}
.sticky-actions{display:flex;gap:10px;}

/* ── WhatsApp float ── */
.wa-float{position:fixed;bottom:80px;right:24px;z-index:98;width:52px;height:52px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,0.2);transition:transform 0.2s;}
.wa-float:hover{transform:scale(1.08);}
.wa-float svg{width:26px;height:26px;fill:white;}

/* ── Scroll reveal ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.7s ease,transform 0.7s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.d1{transition-delay:0.1s;}.d2{transition-delay:0.2s;}.d3{transition-delay:0.3s;}

.nav-logo {
    position: relative;
    display: inline-block;
    width: clamp(100px, 10%, 150px);
    height: auto;
}

.brand-logo {
    display: block;
    max-width: 100%;
    height: auto;
    transition: opacity 0.25s ease;
}

/* Second logo sits on top of the first one */
.brand-logo--scrolled {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    pointer-events: none;
}

/* When navbar has .scrolled, swap visibility */
#navbar.scrolled .brand-logo--default {
    opacity: 0;
    width: clamp(80px, 5%, 120px);
}

#navbar.scrolled .brand-logo--scrolled {
    opacity: 1;
    width: clamp(80px, 5%, 120px);
}

.room-image .room-img {
    object-fit: contain;
}
/* ── Responsive ── */
@media(max-width:960px){
    .grid-2,.fv-grid,.rooms-grid{grid-template-columns:1fr;gap:40px;}
    .room-card.full{display:block;}
    .grid-3,.eat-grid,.heal-grid,.occ-grid,.team-grid,.booking-grid{grid-template-columns:1fr 1fr;}
    .grid-4{grid-template-columns:1fr 1fr;}
    .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
    nav{padding:16px 20px;}
    nav.scrolled{padding:12px 20px;}
    .nav-links{display:none;}
    .hamburger{display:flex;}
    .direct-banner,.facts-bar{padding:16px 20px;}
    .facts-grid{gap:0;}
    .fact-item{min-width:90px;padding:10px 12px;}
}
@media(max-width:600px){
    section{padding:64px 16px;}
    .grid-3,.eat-grid,.heal-grid,.occ-grid,.team-grid,.booking-grid,.rec-grid,.blog-grid,.pol-grid,.welig-grid{grid-template-columns:1fr;}
    .grid-4{grid-template-columns:1fr 1fr;}
    .footer-grid{grid-template-columns:1fr;}
    .facts-grid{display:grid;grid-template-columns:repeat(3,1fr);}
    .press-items{gap:28px;}
    .rev-grid{grid-template-columns:1fr;}
    .footer-bottom{flex-direction:column;text-align:center;}
    .extras-table td:first-child{width:140px;}
}

