:root{
  --teal:#145668; --teal-deep:#0e3d4a; --ink:#16323a;
  --brass:#b0823f; --brass-lt:#c9a36a;
  --paper:#fcfbf8; --mist:#e7efed; --mist-2:#dde9e7;
  --white:#ffffff;
  --maxw:1200px;
  --r:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:"Mulish",system-ui,sans-serif;font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.05;margin:0;color:var(--teal-deep);letter-spacing:-.01em}
p{margin:0 0 1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-family:"Mulish";font-weight:700;text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;color:var(--brass)}
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:"Mulish";font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;padding:.95em 1.7em;border-radius:999px;border:1.5px solid var(--teal);background:var(--teal);color:#fff;cursor:pointer;transition:.35s var(--ease)}
.btn:hover{background:var(--teal-deep);border-color:var(--teal-deep);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--teal)}
.btn--ghost:hover{background:var(--teal);color:#fff}
.btn--brass{background:var(--brass);border-color:var(--brass)}
.btn--brass:hover{background:#96702f;border-color:#96702f}
.btn--light{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn--light:hover{background:#fff;color:var(--teal-deep);border-color:#fff}

/* logo */
.logo{display:block;color:var(--teal)}
.logo svg{display:block;height:100%;width:auto}

/* header */
header{position:fixed;inset:0 0 auto;z-index:50;transition:.4s var(--ease)}
.bar{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 28px;max-width:var(--maxw);margin:0 auto}
.bar .logo{height:52px;color:#fff;transition:.4s var(--ease)}
nav.main{display:flex;align-items:center;gap:30px}
nav.main a{font-family:"Mulish";font-weight:600;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;opacity:.92;transition:.3s}
nav.main a:hover{opacity:1;color:var(--brass-lt)}
header.solid{background:var(--paper);box-shadow:0 1px 0 rgba(16,50,58,.08)}
header.solid .bar .logo{color:var(--teal)}
header.solid nav.main a{color:var(--teal-deep)}
header.solid nav.main a:hover{color:var(--brass)}
header.solid .btn--light{color:var(--teal);border-color:var(--teal)}
header.solid .btn--light:hover{background:var(--teal);color:#fff}
.navtoggle{display:none;background:none;border:0;color:#fff;cursor:pointer;padding:6px}
.navtoggle span{display:block;width:26px;height:2px;background:currentColor;margin:5px 0;transition:.3s}
header.solid .navtoggle{color:var(--teal-deep)}
.navtoggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.navtoggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.navtoggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero .bg{position:absolute;inset:0;background:linear-gradient(120deg,#0e3d4a,#1a6273)}
.hero .bg img{width:100%;height:100%;object-fit:cover;opacity:.86}
.hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(9,34,42,.84) 0%,rgba(9,34,42,.64) 30%,rgba(9,34,42,.28) 56%,rgba(9,34,42,0) 80%),
  linear-gradient(180deg,rgba(9,34,42,.38) 0%,rgba(9,34,42,.05) 34%,rgba(9,34,42,.48) 100%)}
.hero .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 28px;width:100%}
.hero .eyebrow{color:var(--brass-lt);text-shadow:0 1px 12px rgba(7,26,33,.6)}
.hero h1{color:#fff;font-size:clamp(2.9rem,7vw,5.6rem);font-weight:500;margin:.18em 0 .35em;max-width:14ch;text-shadow:0 2px 28px rgba(7,26,33,.5)}
.hero h1 em{font-style:italic;color:#dcb877}
.hero p.lede{font-size:1.18rem;max-width:46ch;margin-bottom:2rem;color:rgba(255,255,255,.94);text-shadow:0 1px 16px rgba(7,26,33,.55)}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.scrollcue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;font-size:.66rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.7);writing-mode:vertical-rl}

/* section scaffold */
section{padding:clamp(70px,9vw,130px) 0}
.sec-head{max-width:60ch}
.sec-head h2{font-size:clamp(2.1rem,4.4vw,3.4rem);margin:.3em 0 .4em}
.lead{font-size:1.14rem}

/* divider */
.divider{display:flex;align-items:center;gap:22px;color:var(--brass);max-width:var(--maxw);margin:0 auto;padding:0 28px}
.divider .rule{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--brass-lt),transparent)}
.divider .seal{height:46px;color:var(--brass);opacity:.9}
.divider .seal svg{height:100%}

/* arch motif */
.arch{position:relative;border-radius:48% 48% var(--r) var(--r)/24% 24% 4% 4%;overflow:hidden;background:linear-gradient(150deg,#1a6273,#0e3d4a);box-shadow:0 24px 60px -28px rgba(14,61,74,.55)}
.arch::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18)}
.arch::before{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;background-image:linear-gradient(180deg,rgba(8,28,35,.03),rgba(8,28,35,.13)),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.3'/%3E%3C/svg%3E");background-size:auto,160px 160px;mix-blend-mode:multiply}
.arch img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.arch.ph--fallback::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,rgba(201,163,106,.22),transparent 60%)}
.arch .seal-fall{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;color:rgb(219 219 219 / 40%);pointer-events:none}
.arch.ph--fallback .seal-fall{display:flex}
.arch .seal-fall svg{height:40%;filter:drop-shadow(0 1px 9px rgba(7,26,33,.4))}

/* welcome */
.welcome-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,90px);align-items:center}
.welcome-grid .arch{max-width:440px;margin-left:auto;aspect-ratio:4/5}
.stay{display:flex;gap:34px;flex-wrap:wrap;margin-top:1.4rem;padding-top:1.6rem;border-top:1px solid var(--mist-2)}
.stay div{min-width:140px}
.stay .k{font-family:"Fraunces";font-size:1.5rem;color:var(--teal)}
.stay .l{font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--brass);font-weight:700}

/* facilities */
.facilities{position:relative;background:var(--teal);color:#fff;padding-top:clamp(98px,10vw,156px)}
.seal-badge{position:absolute;top:0;left:50%;transform:translate(-50%,-52%);width:106px;height:106px;border-radius:50%;background:var(--teal);border:1px solid rgba(201,163,106,.55);display:flex;align-items:center;justify-content:center;color:var(--brass-lt);box-shadow:0 16px 38px -16px rgba(7,26,33,.6)}
.seal-badge svg{height:52%}
.fac-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:26px;text-align:center;max-width:980px;margin:0 auto;align-items:start}
.fac{padding:8px;min-width:0}
.fac svg{height:46px;width:46px;color:var(--brass-lt);margin:0 auto 16px}
.fac .t{font-family:"Fraunces";font-size:1.24rem;color:#fff}
.fac .s{font-size:.9rem;color:rgba(255,255,255,.72);margin-top:.15rem}
@media (max-width:1080px){.fac-row{grid-template-columns:repeat(3,minmax(0,1fr));max-width:640px;gap:34px 18px}}

/* rooms */
.rooms{background:var(--mist)}
.rooms-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(40px,6vw,80px);align-items:center;margin-top:14px}
.rooms-grid .arch{aspect-ratio:3/4;max-width:420px}
.roomlist{display:grid;grid-template-columns:1fr 1fr;gap:2px 36px}
.room{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--mist-2)}
.room .n{font-family:"Fraunces";font-size:1.16rem;color:var(--teal-deep)}
.room .sleeps{font-size:.7rem;text-transform:uppercase;letter-spacing:.13em;font-weight:700;color:var(--brass);white-space:nowrap}
.rooms .note{margin-top:1.6rem;font-size:.95rem;color:#587079}
.rooms .cta{margin-top:1.6rem;display:flex;gap:12px;flex-wrap:wrap}

/* events */
.spaces{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:46px}
.space{background:var(--white);border:1px solid var(--mist-2);border-radius:var(--r);padding:30px 26px;transition:.35s var(--ease)}
.space:hover{transform:translateY(-4px);border-color:var(--brass-lt);box-shadow:0 20px 44px -30px rgba(14,61,74,.45)}
.space h3{font-size:1.3rem;margin-bottom:.5rem}
.space .cap{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--brass);font-weight:700;margin-bottom:.9rem}
.space ul{margin:0;padding-left:1.1em;font-size:.94rem;color:#4c656d}
.space li{margin:.2em 0}

/* leisure */
.leisure{background:var(--teal-deep);color:#fff;overflow:hidden;position:relative}
.leisure-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.leisure h2{color:#fff}
.leisure .eyebrow{color:var(--brass-lt)}
.leisure .arch{aspect-ratio:5/4;border-radius:var(--r) var(--r) 48% 48%/4% 4% 24% 24%}
.leisure p{color:rgba(255,255,255,.85)}
.leisure .pill{display:inline-block;font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;font-weight:700;color:var(--brass-lt);border:1px solid rgba(201,163,106,.4);border-radius:999px;padding:.4em 1em;margin:.2rem .3rem .2rem 0}

/* explore */
.explore-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:46px;counter-reset:x}
.place{border-top:2px solid var(--brass);padding-top:18px;counter-increment:x}
.place::before{content:counter(x,decimal-leading-zero);font-family:"Fraunces";font-size:.95rem;color:var(--brass);display:block;margin-bottom:14px}
.place h3{font-size:1.28rem;margin-bottom:.5rem}
.place p{font-size:.93rem;color:#4c656d}
.place a{font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;color:var(--teal);border-bottom:1px solid var(--brass-lt);padding-bottom:2px}
.place a:hover{color:var(--brass)}

/* stay note */
.stay-note{font-size:.76rem;color:#7c919a;margin:.85rem 0 0}

/* gallery */
#gallery{background:var(--mist)}
.gal-tabs{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:8px;margin:26px 0 36px}
.gal-tab{font-family:"Mulish";font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--teal-deep);background:transparent;border:1px solid transparent;border-radius:999px;padding:.6em 1.25em;cursor:pointer;transition:.3s var(--ease)}
.gal-tab:hover{color:var(--brass)}
.gal-tab.is-active{background:var(--teal);color:#fff}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gal-item{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:10px;cursor:pointer;background:#0e3d4a;margin:0}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);display:block}
.gal-item:hover img{transform:scale(1.06)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,28,35,.4));opacity:0;transition:.35s}
.gal-item:hover::after{opacity:1}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(7,26,33,.93);display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.lb.open{display:flex;opacity:1}
.lb-stage{margin:0;display:flex;align-items:center;justify-content:center}
.lb-stage img{max-width:90vw;max-height:82vh;width:auto;height:auto;border-radius:6px;box-shadow:0 30px 80px -20px rgba(0,0,0,.6)}
.lb-close,.lb-nav{position:absolute;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.25s}
.lb-close:hover,.lb-nav:hover{background:var(--brass);border-color:var(--brass)}
.lb-close{top:22px;right:24px;width:46px;height:46px;font-size:1.6rem;line-height:1}
.lb-nav{top:50%;transform:translateY(-50%);width:54px;height:54px;font-size:2rem;line-height:1}
.lb-prev{left:24px}
.lb-next{right:24px}
.lb-count{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.85);font-family:"Mulish";font-weight:700;letter-spacing:.2em;font-size:.8rem}
@media (max-width:920px){.gal-grid{grid-template-columns:repeat(2,1fr)}.lb-nav{width:44px;height:44px;font-size:1.6rem}.lb-prev{left:10px}.lb-next{right:10px}}

/* footer */
footer{background:var(--teal);color:#fff;padding:clamp(60px,7vw,90px) 0 40px}
.foot-cta{text-align:center;max-width:46ch;margin:0 auto 60px}
.foot-cta .logo{height:120px;color:#fff;margin:0 auto 26px;width:max-content}
.foot-cta h2{color:#fff;font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:1.2rem}
.foot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:40px;border-top:1px solid rgba(255,255,255,.16);padding-top:44px}
.foot-grid.legal-off .foot-legal{display:none}
@media(min-width:921px){.foot-grid.legal-off{grid-template-columns:repeat(3,1fr)}}
.foot-grid h4{font-family:"Mulish";text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--brass-lt);margin:0 0 1rem}
.foot-grid a,.foot-grid p{color:rgba(255,255,255,.82);font-size:.95rem;margin:.3rem 0}
.foot-grid a:hover{color:#fff}
.colophon{max-width:var(--maxw);margin:46px auto 0;padding:22px 28px 0;border-top:1px solid rgba(255,255,255,.14);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.78rem;color:rgba(255,255,255,.6)}
.colophon a{color:var(--brass-lt)}
.credit{display:inline-flex;align-items:center;gap:.55em;flex-wrap:wrap}
.credit a{display:inline-flex;align-items:center}
.credit .dv-logo{height:1.4em;width:auto;display:block}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:.9s var(--ease)}
.reveal.in{opacity:1;transform:none}

@media (max-width:920px), (max-height:600px){
  .welcome-grid,.rooms-grid,.leisure-grid{grid-template-columns:1fr}
  .welcome-grid .arch,.rooms-grid .arch{max-width:520px;margin:0 auto}
  .fac-row{grid-template-columns:repeat(3,1fr);gap:30px 12px}
  .spaces{grid-template-columns:repeat(2,1fr)}
  .explore-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{gap:30px}
  nav.main{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:var(--teal-deep);flex-direction:column;align-items:flex-start;justify-content:center;padding:40px;gap:22px;transform:translateX(100%);transition:.4s var(--ease)}
  nav.main.open{transform:none}
  nav.main a{color:#fff;font-size:1rem}
  nav.main .btn{color:#fff;border-color:rgba(255,255,255,.5)}
  header.solid nav.main a{color:#fff}
  header.solid nav.main a:hover{color:var(--brass-lt)}
  header.solid nav.main .btn--light{color:#fff;border-color:rgba(255,255,255,.5)}
  .navtoggle{display:block;z-index:60;margin-right:8px}
  .bar .logo{margin-left:8px}
  header.solid .navtoggle{color:var(--teal-deep)}
  header.solid .navtoggle[aria-expanded="true"]{color:#fff}
  .roomlist{grid-template-columns:1fr}
}
@media (max-width:560px){
  .fac-row{grid-template-columns:repeat(2,1fr)}
  .spaces,.explore-grid{grid-template-columns:1fr}
  .stay{gap:24px}
}
@media (orientation:landscape) and (max-height:600px){
  .hero{min-height:100svh;align-items:flex-start}
  .hero .inner{padding-top:104px;padding-bottom:40px}
  .hero h1{font-size:clamp(1.9rem,5vw,2.6rem);margin:.1em 0 .3em}
  .hero p.lede{font-size:.98rem;margin-bottom:1.2rem}
  .scrollcue{display:none}
  section{padding:64px 0}
  .sec-head h2{font-size:clamp(1.7rem,4vw,2.3rem)}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .btn:hover,.space:hover{transform:none}
}

/* legal / policy pages */
.legal{padding:150px 0 100px}
.legal .wrap{max-width:760px}
.legal h1{font-size:clamp(2rem,4vw,3rem);margin:.2em 0 .6em}
.legal h2{font-size:1.35rem;margin:2rem 0 .6rem}
.legal p,.legal li{color:#3f5860}
.legal a{color:var(--teal);border-bottom:1px solid var(--brass-lt)}
.legal .updated{font-size:.85rem;color:#7c919a;margin-bottom:2rem}