*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --sand:#F5EFE0;--sand-dark:#EDE3CC;
  --terracotta:#C8553D;--terra-light:#E8765E;--terracotta-light:#E8765E;
  --forest:#1C3028;--forest-mid:#2A4A38;
  --gold:#D4A843;--gold-pale:#F0D898;
  --ink:#0E1512;--white:#FDFAF4;--muted:#6B7B6E;
  --display:'Playfair Display',Georgia,serif;
  --body:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth; overflow-x:clip; max-width:100%;}
body{font-family:var(--body);background:var(--white);color:var(--ink);overflow-x:hidden; overflow-x:clip; max-width:100%; width:100%;}
body.bg-sand{background:var(--sand)}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
.bc{background:var(--sand);padding:14px clamp(24px,5vw,80px);display:flex;align-items:center;gap:10px;font-size:12px;color:var(--muted);border-bottom:1px solid var(--sand-dark)}
.bc a{color:var(--forest-mid);transition:color .25s}.bc a:hover{color:var(--terracotta)}
.bc span{opacity:0.5}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:0px 5vw;display:flex;align-items:center;justify-content:space-between;transition:all .4s ease}
.nav.solid{background:var(--forest);box-shadow:0 2px 40px rgba(0,0,0,.3)}
.header-logo-img{height:38px !important;width:auto !important;object-fit:contain !important;display:block;transition:height .3s}
.nav-logo{font-family:var(--display);font-size:clamp(16px,2vw,22px);font-weight:700;color:#fff;letter-spacing:.02em;line-height:1.1}
.nav-logo span{color:var(--gold);font-style:italic;font-weight:400}
.nav-links{display:flex;gap:clamp(16px,3vw,40px);list-style:none;align-items:center}
.nav-links a{color:rgba(255,255,255,.75);font-size:13px;letter-spacing:.08em;transition:color .25s}
.nav-links a:hover, .nav-links a.active{color:var(--gold)}
.nav-book{background:var(--terracotta) !important;color:#fff !important;padding:7px 16px;border-radius:4px;font-weight:500 !important;letter-spacing:.03em !important;transition:background .25s !important;font-size:11px !important;line-height:1.2 !important;white-space:nowrap !important}
.nav-book:hover{background:var(--terracotta-light) !important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.hamburger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s;display:block}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--forest);z-index:190;flex-direction:column;align-items:center;justify-content:center;gap:40px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--display);font-size:36px;color:#fff;font-weight:400}
.mobile-menu a:hover{color:var(--gold)}

/* HERO */
.hero{height:100svh;min-height:600px;position:relative;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--ink)}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.5s ease}
.hero-slide.on{opacity:1}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom, rgba(14,21,18,0.7) 0%, rgba(14,21,18,0.2) 20%, rgba(14,21,18,0.2) 75%, rgba(14,21,18,0.9) 100%)}
.ticker-wrap{position:absolute;top:80px;left:0;right:0;overflow:hidden;background:rgba(212,168,67,.1);backdrop-filter:blur(4px);border-top:1px solid rgba(212,168,67,.25);border-bottom:1px solid rgba(212,168,67,.25);padding:10px 0;z-index:5}
.ticker{display:flex;white-space:nowrap;animation:ticker 28s linear infinite}
.ticker-item{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-pale);padding:0 40px;display:flex;align-items:center;gap:40px}
.ticker-item::after{content:'◆';color:var(--gold)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.hero-content{position:relative;z-index:10;padding:clamp(40px,8vw,80px) clamp(24px,5vw,80px) clamp(48px,8vw,80px);max-width:900px}
.hero-tag{display:inline-flex;align-items:center;gap:12px;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:24px}
.hero-tag::before{content:'';width:32px;height:1px;background:var(--gold)}
.hero-h1{font-family:var(--display);font-size:clamp(52px,9vw,110px);font-weight:900;color:#fff;line-height:.95;letter-spacing:-.02em;margin-bottom:28px}
.hero-h1 em{color:var(--gold);font-style:italic;font-weight:400}
.hero-sub{font-size:clamp(15px,1.8vw,18px);color:rgba(255,255,255,.65);font-weight:300;line-height:1.65;max-width:480px;margin-bottom:44px; white-space: pre-wrap;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.btn-cta{background:var(--terracotta);color:#fff;padding:16px 36px;border-radius:4px;font-size:13px;font-weight:500;letter-spacing:.08em;transition:all .3s;display:inline-flex;align-items:center;gap:10px}
.btn-cta:hover{background:var(--terracotta-light);transform:translateY(-2px)}
.btn-cta svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
.btn-outline{color:#fff;padding:16px 28px;border-radius:4px;border:1px solid rgba(255,255,255,.25);font-size:13px;font-weight:400;letter-spacing:.06em;transition:all .3s}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.hero-price-badge{position:absolute;right:clamp(24px,5vw,80px);bottom:clamp(48px,8vw,80px);background:var(--forest);border:1px solid rgba(212,168,67,.35);padding:24px 28px;z-index:10;text-align:center;border-radius:8px}
.hero-price-badge .from{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:4px}
.hero-price-badge .amount{font-family:var(--display);font-size:36px;font-weight:700;color:var(--gold);display:block;line-height:1}
.hero-price-badge .per{font-size:12px;color:rgba(255,255,255,.5);display:block;margin-top:2px}
.hero-dots{position:absolute;right:clamp(24px,5vw,80px);top:50%;transform:translateY(-50%);z-index:10;display:flex;flex-direction:column;gap:10px}
.hero-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:all .3s;border:none}
.hero-dot.on{background:var(--gold);height:24px;border-radius:3px}

/* LOCATION HERO (Legacy support) */
.loc-hero{padding-top:64px;height:88vh;min-height:520px;position:relative;display:flex;align-items:flex-end;background:var(--ink);overflow:hidden}
.loc-hero .hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.55}
.loc-hero .hero-ov{position:absolute;inset:0;background:linear-gradient(to bottom, rgba(14,21,18,0.72) 0%, rgba(14,21,18,0.2) 25%, rgba(14,21,18,0.3) 70%, rgba(14,21,18,0.92) 100%)}
.loc-hero .hero-c{position:relative;z-index:2;padding:clamp(48px,7vw,80px) clamp(24px,5vw,80px);max-width:860px}
.loc-hero .ey{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:12px;margin-bottom:16px}
.loc-hero .ey::before{content:'';width:28px;height:1px;background:var(--gold)}
.loc-hero .h1{font-family:var(--display);font-size:clamp(44px,9vw,100px);font-weight:900;color:#fff;line-height:.92;letter-spacing:-.02em;margin-bottom:22px}
.loc-hero .h1 em{color:var(--gold-pale);font-style:italic;font-weight:400}
.loc-hero .h-sub{font-size:clamp(15px,1.8vw,18px);color:rgba(255,255,255,.6);font-weight:300;line-height:1.7;max-width:500px;margin-bottom:36px}
.loc-hero .h-btns{display:flex;gap:14px;flex-wrap:wrap}
.loc-hero .price-badge{position:absolute;right:clamp(24px,5vw,80px);bottom:clamp(48px,7vw,72px);background:var(--forest);border:1px solid rgba(212,168,67,.3);padding:22px 26px;border-radius:10px;text-align:center;z-index:3}
.loc-hero .price-badge .from{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:4px}
.loc-hero .price-badge .amt{font-family:var(--display);font-size:34px;font-weight:700;color:var(--gold);display:block;line-height:1}
.loc-hero .price-badge .per{font-size:12px;color:rgba(255,255,255,.4);display:block;margin-top:2px}

/* SHARED */
.section{padding:clamp(60px,10vw,120px) clamp(24px,5vw,80px)}
.eyebrow{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--terracotta);display:flex;align-items:center;gap:12px;margin-bottom:18px}
.eyebrow::before{content:'';width:28px;height:1px;background:var(--terracotta)}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:'';width:28px;height:1px;background:var(--terracotta)}
.display-title{font-family:var(--display);font-size:clamp(32px,5vw,64px);font-weight:700;line-height:1.05;letter-spacing:-.02em;color:var(--ink)}
.display-title em{color:var(--terracotta);font-style:italic;font-weight:400}
.body-text{font-size:clamp(15px,1.5vw,18px);color:var(--muted);line-height:1.75;font-weight:300}

/* ROOMS LIST & CARDS */
.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(260px,28vw,360px),1fr));gap:24px}
.room-card{border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 4px 24px rgba(0,0,0,.07);transition:transform .35s ease,box-shadow .35s ease;cursor:pointer; display:flex;flex-direction:column}
.room-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.14)}
.room-card.hidden{display:none}
.room-img-wrap, .rim{aspect-ratio:4/3;overflow:hidden;position:relative;flex-shrink:0}
.room-img-wrap img, .rim img{transition:transform .6s ease; width:100%; height:100%; object-fit:cover;}
.room-card:hover .room-img-wrap img, .room-card:hover .rim img{transform:scale(1.06)}
.room-location-tag, .rlt{position:absolute;top:14px;left:14px;background:var(--forest);color:var(--gold-pale);font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:5px 12px;border-radius:100px; z-index:2;}
.rbadge{position:absolute;top:14px;right:14px;background:var(--terracotta);color:#fff;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:100px; z-index:2;}
.room-body, .rb{padding:22px 24px 28px; display:flex;flex-direction:column;flex:1;}
.room-name, .rn{font-family:var(--display);font-size:22px;font-weight:700;margin-bottom:6px; color:var(--ink)}
.room-sleeps, .rm{font-size:12px;color:var(--muted);letter-spacing:.06em;margin-bottom:20px}
.room-footer, .rfoot{display:flex;justify-content:space-between;align-items:center; margin-top:auto; padding-top:14px;}
.room-price .price, .rp .price{font-family:var(--display);font-size:26px;font-weight:700;color:var(--forest)}
.room-price .night, .rp .night{font-size:12px;color:var(--muted)}
.room-book-btn, .btn-view{background:var(--terracotta);color:#fff;border:none;border-radius:6px;padding:10px 20px;font-size:12px;font-weight:500;letter-spacing:.06em;cursor:pointer;transition:background .25s;font-family:var(--body); display:inline-flex; align-items:center; gap:6px;}
.room-book-btn:hover, .btn-view:hover{background:var(--terracotta-light)}
.btn-view svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* FOOTER */
footer{background:var(--ink);padding:clamp(40px,6vw,64px) clamp(24px,5vw,80px); color:#fff;}
.ft{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.08)}
.flogo{font-family:var(--display);font-size:20px;color:#fff;font-weight:700;margin-bottom:14px;display:block}
.flogo span{color:var(--gold);font-style:italic;font-weight:400}
.fbrand p{font-size:13px;color:rgba(255,255,255,.35);line-height:1.7;max-width:240px}
.fcol h4{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.fcol ul a{font-size:13px;color:rgba(255,255,255,.4)}.fcol ul a:hover{color:var(--gold)}
.fcol address{font-style:normal;font-size:13px;color:rgba(255,255,255,.4);line-height:1.8}
.fb{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;padding-top:24px}
.fcopy{font-size:12px;color:rgba(255,255,255,.2)}
.pays{display:flex;gap:8px}
.pay{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:4px 10px;font-size:10px;font-weight:600;color:rgba(255,255,255,.35);letter-spacing:.05em}

/* REVEAL */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .75s ease,transform .75s ease}
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity .75s ease,transform .75s ease}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .75s ease,transform .75s ease}
.reveal.up,.reveal-left.up,.reveal-right.up{opacity:1;transform:none}

/* LEGACY REVEAL ALIASES */
.rv{opacity:0;transform:translateY(24px);transition:opacity .7s,transform .7s}
.rv-l{opacity:0;transform:translateX(-24px);transition:opacity .7s,transform .7s}
.rv-r{opacity:0;transform:translateX(24px);transition:opacity .7s,transform .7s}
.rv.vis,.rv-l.vis,.rv-r.vis{opacity:1;transform:none}
.rv.up, .rv-l.up, .rv-r.up{opacity:1;transform:none}

/* CTA SECTIONS */
.cta-sec, .cta-band{background:var(--terracotta);padding:clamp(48px,7vw,80px) clamp(24px,5vw,80px);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:32px}
.cta-sec h2, .cta-band-title{font-family:var(--display);font-size:clamp(28px,4vw,52px);font-weight:700;color:#fff;line-height:1.1;margin-top:8px}
.cta-sec p, .cta-eyebrow{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:8px}
.btn-wh, .btn-white{background:#fff;color:var(--terracotta);padding:18px 40px;border-radius:6px;font-size:13px;font-weight:500;letter-spacing:.08em;transition:all .3s;white-space:nowrap;display:inline-block; border:none; cursor:pointer; font-family:var(--body)}
.btn-wh:hover, .btn-white:hover{background:var(--sand);transform:scale(1.02)}

/* LOCATION PANELS (Used in about sections) */
.loc-panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}
.loc-desc{color:var(--muted);font-size:clamp(15px,1.5vw,18px);line-height:1.75;font-weight:300;margin:20px 0 28px}
.loc-facts{display:flex;flex-direction:column;gap:12px;margin-bottom:36px}
.loc-fact{display:flex;align-items:center;gap:14px;font-size:15px;color:var(--muted)}
.loc-fact::before{content:'';width:20px;height:1px;background:var(--gold);flex-shrink:0}
.loc-gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.lg-tall{border-radius:12px;overflow:hidden;grid-row:span 2;min-height:300px}
.lg-short{border-radius:8px;overflow:hidden;aspect-ratio:4/3}
.lg-tall img,.lg-short img{transition:transform .5s ease}
.lg-tall:hover img,.lg-short:hover img{transform:scale(1.04)}

/* RESPONSIVE */
@media(max-width:1024px){
  .loc-panel-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav{padding:3px 4vw}
  .header-logo-img{height:32px !important;width:auto !important}
  .nav-book{padding:5px 12px !important;font-size:10px !important;line-height:1.2 !important;white-space:nowrap !important}
  .cta-sec, .cta-band{flex-direction:column; text-align:center; align-items:center;}
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero-price-badge,.hero-dots{display:none}
  .ft{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .ft{grid-template-columns:1fr}
  .brow{grid-template-columns:1fr !important}
}
