:root{
  --white:#FAF7F3;
  --sand:#EFE6DB;
  --bronze:#B2815E;
  --bronze-dark:#9A6C4C;
  --deep:#1F3A4D;
  --ink:#3D3833;
  --ink-soft:#6B6258;
  font-size:16px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;font-weight:300;color:var(--ink);background:var(--white);line-height:1.7;letter-spacing:.01em}
h1,h2,h3,.serif{font-family:'Marcellus',serif;font-weight:400;color:var(--deep);letter-spacing:.04em}
h1{font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.15}
h2{font-size:clamp(1.7rem,3.5vw,2.4rem);margin-bottom:.6em}
h3{font-size:1.25rem;letter-spacing:.06em}
p{margin-bottom:1em;max-width:62ch}
a{color:var(--bronze);text-decoration:none;transition:color .25s}
a:hover{color:var(--bronze-dark)}
img{max-width:100%;display:block}
.container{width:min(1140px,92%);margin:0 auto}

/* Eyebrow + horizon signature */
.eyebrow{display:block;font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--bronze);margin-bottom:.9rem;font-weight:400}
.horizon{display:flex;align-items:center;gap:10px;margin:1.6rem 0 2.2rem;max-width:280px}
.horizon::before{content:"";flex:1;height:1px;background:var(--bronze)}
.horizon::after{content:"";width:9px;height:9px;border-radius:50%;border:1px solid var(--bronze)}
.horizon.center{margin-left:auto;margin-right:auto}
.horizon.center::before{flex:1}
.horizon.center{justify-content:center}

/* Header */
header{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.9rem 4vw;transition:background .35s,box-shadow .35s}
header.scrolled{background:rgba(250,247,243,.96);box-shadow:0 1px 14px rgba(31,58,77,.10)}
header .logo img{height:44px;width:auto;transition:filter .35s}
header:not(.scrolled) .logo img{filter:brightness(0) invert(1)}
nav{display:flex;align-items:center;gap:1.8rem}
nav a{font-size:.86rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;font-weight:400}
header.scrolled nav a{color:var(--deep)}
nav a:hover,header.scrolled nav a:hover{color:var(--bronze)}
nav a.active{color:var(--bronze)}
.dropdown{position:relative}
.dropdown>a::after{content:" ▾";font-size:.7em}
.dropdown-menu{position:absolute;top:130%;left:50%;transform:translateX(-50%);background:var(--white);box-shadow:0 8px 28px rgba(31,58,77,.16);padding:.7rem 0;min-width:240px;opacity:0;visibility:hidden;transition:.25s}
.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;top:115%}
.dropdown-menu a{display:block;padding:.55rem 1.3rem;color:var(--deep)!important;text-transform:none;letter-spacing:.04em;font-size:.92rem}
.dropdown-menu a:hover{background:var(--sand);color:var(--bronze)!important}
.btn{display:inline-block;background:var(--bronze);color:#fff!important;padding:.78rem 1.9rem;font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;border:1px solid var(--bronze);transition:.3s;cursor:pointer;font-family:'Jost',sans-serif;font-weight:400}
.btn:hover{background:var(--bronze-dark);border-color:var(--bronze-dark)}
.btn.ghost{background:transparent;color:#fff!important;border-color:#fff}
.btn.ghost:hover{background:#fff;color:var(--deep)!important}
.btn.outline{background:transparent;color:var(--bronze)!important;border-color:var(--bronze)}
.btn.outline:hover{background:var(--bronze);color:#fff!important}

/* Mobile nav */
.burger{display:none;background:none;border:none;cursor:pointer;width:30px;height:22px;position:relative;z-index:110}
.burger span{position:absolute;left:0;width:100%;height:2px;background:#fff;transition:.3s}
header.scrolled .burger span,header.open .burger span{background:var(--deep)}
.burger span:nth-child(1){top:0}.burger span:nth-child(2){top:10px}.burger span:nth-child(3){top:20px}
@media(max-width:900px){
  .burger{display:block}
  nav{position:fixed;inset:0;background:var(--white);flex-direction:column;justify-content:center;gap:1.4rem;transform:translateX(100%);transition:.35s}
  header.open nav{transform:none}
  nav a{color:var(--deep);font-size:1.05rem}
  .dropdown-menu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;background:transparent;text-align:center}
  header .btn{display:none}
  nav .btn{display:inline-block!important}
}

/* Hero */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;background-size:cover;background-position:center}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(20,38,52,.38),rgba(20,38,52,.45))}
.hero>div{position:relative;padding:0 6vw}
.hero h1{color:#fff}
.hero p{margin:1.1rem auto 1.8rem;font-size:1.08rem;max-width:46ch}
.hero .eyebrow{color:#E8D5B7}
.hero.short{min-height:54vh}

/* Sections */
section{padding:5.2rem 0}
section.sand{background:var(--sand)}
.center{text-align:center}
.center p{margin-left:auto;margin-right:auto}

/* Cards */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:2.4rem}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
@media(max-width:820px){.grid2,.grid3{grid-template-columns:1fr}}
.card{background:#fff;box-shadow:0 4px 22px rgba(31,58,77,.08);overflow:hidden;display:flex;flex-direction:column}
.card img{aspect-ratio:3/2;object-fit:cover;width:100%;transition:transform .5s}
.card:hover img{transform:scale(1.04)}
.card .body{padding:1.6rem 1.6rem 1.9rem}
.card .meta{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bronze);margin:.4rem 0 .9rem}
.card .actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:auto}

/* Split rows */
.split{display:grid;grid-template-columns:1.1fr 1fr;gap:3.4rem;align-items:center}
.split.rev{grid-template-columns:1fr 1.1fr}
.split.rev .text{order:-1}
@media(max-width:820px){.split,.split.rev{grid-template-columns:1fr}.split.rev .text{order:0}}
.split img{box-shadow:0 10px 34px rgba(31,58,77,.14)}

/* Feature strip */
.strip{background:var(--deep);color:#E9E2D8;padding:2.6rem 0}
.strip .grid3{text-align:center;gap:1.4rem}
.strip h3{color:#fff;font-size:1.05rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:.3rem}
.strip p{font-size:.95rem;margin:0;color:#C8BFB2;max-width:none}
.strip .num{font-family:'Marcellus',serif;font-size:2rem;color:var(--bronze);display:block}

/* Amenities */
.amenities{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.7rem 2rem;margin:1.4rem 0}
.amenities li{padding-left:1.5rem;position:relative;font-size:.98rem}
.amenities li::before{content:"";position:absolute;left:0;top:.72em;width:14px;height:1px;background:var(--bronze)}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1rem}
.gallery-grid a{overflow:hidden;display:block}
.gallery-grid img{aspect-ratio:4/3;object-fit:cover;width:100%;transition:transform .5s}
.gallery-grid a:hover img{transform:scale(1.05)}
.lightbox{position:fixed;inset:0;background:rgba(20,30,40,.93);display:none;align-items:center;justify-content:center;z-index:200;cursor:zoom-out}
.lightbox.show{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;box-shadow:0 20px 60px rgba(0,0,0,.5)}

/* Forms */
form{display:grid;gap:1.1rem;max-width:640px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:600px){.row2{grid-template-columns:1fr}}
label{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:.35rem}
input,select,textarea{width:100%;padding:.85rem 1rem;border:1px solid #D8CCBD;background:#fff;font-family:'Jost',sans-serif;font-size:1rem;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--bronze);outline-offset:0;border-color:var(--bronze)}

/* Map */
.map iframe{width:100%;height:430px;border:0;display:block}

/* Footer */
footer{background:var(--deep);color:#C8BFB2;padding:4rem 0 2rem;font-size:.95rem}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.6rem;margin-bottom:2.6rem}
@media(max-width:820px){footer .cols{grid-template-columns:1fr}}
footer img.flogo{height:52px;width:auto;margin-bottom:1.1rem}
footer h3{color:#fff;font-size:.92rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:1rem}
footer a{color:#E9E2D8}
footer a:hover{color:var(--bronze)}
footer ul{list-style:none}
footer li{margin-bottom:.5rem}
footer .bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:1.5rem;text-align:center;font-size:.82rem;letter-spacing:.06em}

/* CTA band */
.cta-band{background:var(--bronze);color:#fff;text-align:center;padding:4rem 6vw}
.cta-band h2{color:#fff;margin-bottom:1.4rem}
.cta-band .btn{background:#fff;color:var(--bronze)!important;border-color:#fff}
.cta-band .btn:hover{background:transparent;color:#fff!important}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{scroll-behavior:auto!important}}
