*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0b1c28;--ink-mid:#132333;--ink-soft:#1d3346;
  --gold:#c4a35a;--gold-lt:#dfc48a;--gold-dk:#9a7a32;
  --sand:#f5f0e8;--sand-dk:#ede6d5;
  --off:#faf8f4;--white:#fff;
  --txt:#2a3d4f;--txt-lt:#5a7080;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Raleway',system-ui,sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --sh:0 4px 24px rgba(0,0,0,.10);
  --sh-deep:0 14px 50px rgba(0,0,0,.18);
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--sans);background:var(--off);color:var(--txt);overflow-x:hidden;line-height:1.75}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:var(--sans)}
.container{max-width:1260px;margin-inline:auto;padding-inline:5vw}
section{padding:6rem 5vw}

/* Typography */
.eyebrow{font-size:.63rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:.8rem;display:block}
.section-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3.1rem);font-weight:300;line-height:1.15;color:var(--ink);margin-bottom:1.2rem}
.section-title em{font-style:italic;color:#1a5f8a}
.divider{width:46px;height:1px;background:var(--gold);margin-bottom:2rem}
.lead{font-size:1rem;color:var(--txt-lt);line-height:1.9;max-width:600px}
.rich-text h3{font-family:var(--serif);font-size:1.3rem;font-weight:400;color:#1a5f8a;margin:2rem 0 .7rem}
.rich-text p{font-size:.94rem;color:var(--txt-lt);line-height:1.95;margin-bottom:1rem}
.rich-text strong{color:var(--ink)}

/* Buttons */
.btn{display:inline-block;font-size:.71rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;transition:all .35s var(--ease)}
.btn-gold{background:var(--gold);color:var(--ink);padding:.85rem 2.4rem}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px);box-shadow:0 6px 20px rgba(196,163,90,.35)}
.btn-outline{border:1px solid rgba(255,255,255,.5);color:#fff;padding:.85rem 2.4rem}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.btn-outline-dark{border:1.5px solid var(--ink);color:var(--ink);padding:.82rem 2.1rem}
.btn-outline-dark:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-group{display:flex;gap:1rem;flex-wrap:wrap}

/* Nav */
#nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1.3rem 5vw;transition:all .4s var(--ease)}
#nav.scrolled,#nav.solid{background:rgba(11,28,40,.97);backdrop-filter:blur(18px);padding:.85rem 5vw;box-shadow:0 2px 28px rgba(0,0,0,.28)}
#nav .nav-logo{font-family:var(--serif);font-size:1.2rem;font-weight:300;letter-spacing:.12em;color:#fff;text-transform:uppercase;white-space:nowrap}
.nav-logo span{color:var(--gold)}
#nav .nav-links{display:flex;gap:1.8rem;list-style:none;align-items:center}
#nav .nav-links a{font-size:.62rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.8);transition:color .25s;white-space:nowrap}
#nav .nav-links a:hover,#nav .nav-links a.active{color:var(--gold)}
#nav .nav-cta{background:var(--gold);color:var(--ink)!important;padding:.42rem 1.1rem;font-weight:700!important}
#nav .nav-cta:hover{background:var(--gold-lt)!important}
.burger{display:none;flex-direction:column;gap:5px}
.burger span{width:22px;height:1.5px;background:#fff;display:block;transition:all .35s}
.mob-menu{display:none;position:fixed;inset:0;background:var(--ink);flex-direction:column;align-items:center;justify-content:center;z-index:199;gap:2rem}
.mob-menu.open{display:flex}
.mob-menu a{font-family:var(--serif);font-size:1.9rem;color:var(--sand);font-style:italic;transition:color .2s}
.mob-menu a:hover{color:var(--gold)}
.mob-close{position:absolute;top:1.5rem;right:5vw;font-size:2rem;color:#fff}

/* Page hero (non-home) */
.page-hero{background:linear-gradient(to bottom,rgba(11,28,40,.65) 0%,rgba(11,28,40,.35) 60%,rgba(11,28,40,.7) 100%),var(--bg-img,url('')) center/cover no-repeat;padding:10rem 5vw 5rem;color:#fff}
.page-hero .eyebrow{color:var(--gold-lt)}
.page-hero .section-title{color:#fff}
.page-hero .section-title em{color:var(--gold-lt)}
.page-hero .lead{color:rgba(255,255,255,.78)}
.breadcrumb{font-size:.65rem;letter-spacing:.12em;color:rgba(255,255,255,.45);margin-bottom:1.5rem}
.breadcrumb a{color:rgba(255,255,255,.5)}
.breadcrumb a:hover{color:var(--gold)}

/* Stats bar */
.stats-bar{background:var(--ink);padding:3rem 5vw;display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1.5rem;text-align:center}
.stat-n{font-family:var(--serif);font-size:2.8rem;color:var(--gold);font-weight:300;line-height:1;margin-bottom:.3rem}
.stat-l{font-size:.58rem;letter-spacing:.22em;color:rgba(255,255,255,.4);text-transform:uppercase}

/* Cards */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-top:3rem}
.card{background:var(--white);overflow:hidden;transition:all .38s var(--ease);box-shadow:var(--sh)}
.card:hover{box-shadow:var(--sh-deep);transform:translateY(-4px)}
.card img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover img{transform:scale(1.05)}
.card-body{padding:1.3rem 1.5rem 1.6rem}
.card-label{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem}
.card-title{font-family:var(--serif);font-size:1.15rem;color:var(--ink);font-weight:300;margin-bottom:.4rem}
.card-desc{font-size:.8rem;color:var(--txt-lt);line-height:1.7}

/* Feature grid */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.7rem;margin-top:2rem}
.feat{display:flex;align-items:center;gap:.6rem;font-size:.8rem;color:var(--txt-lt)}
.feat::before{content:'—';color:var(--gold);flex-shrink:0}

/* Service cards (dark bg) */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2px;background:rgba(255,255,255,.04)}
.svc-card{background:var(--ink);padding:2rem 1.8rem;text-align:center;transition:all .38s var(--ease);border:1px solid transparent}
.svc-card:hover{background:var(--ink-mid);border-color:rgba(196,163,90,.2);transform:translateY(-4px)}
.svc-icon{font-size:2rem;margin-bottom:.9rem;display:block}
.svc-name{font-family:var(--serif);font-size:1.05rem;color:var(--gold-lt);margin-bottom:.4rem;font-weight:300}
.svc-desc{font-size:.76rem;color:rgba(255,255,255,.42);line-height:1.65}

/* Room cards */
.room-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:3rem}
.room-card{overflow:hidden}
.room-card .img-wrap{overflow:hidden}
.room-card img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .65s var(--ease)}
.room-card:hover img{transform:scale(1.06)}
.room-info{padding:1.2rem 0;border-bottom:1px solid rgba(0,0,0,.07)}
.room-num{font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:.28rem}
.room-name{font-family:var(--serif);font-size:1.2rem;color:var(--ink);font-weight:300}
.room-desc{font-size:.8rem;color:var(--txt-lt);margin-top:.4rem;line-height:1.65}

/* Two-col layout */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.two-col.start{align-items:start}
.img-badge-wrap{position:relative}
.img-badge-wrap img{width:100%;aspect-ratio:4/3;object-fit:cover}
.badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--gold);padding:1.3rem 1.6rem;text-align:center}
.badge strong{font-family:var(--serif);font-size:1.9rem;display:block;color:var(--ink);line-height:1}
.badge small{font-size:.54rem;letter-spacing:.22em;color:var(--ink-mid);text-transform:uppercase}

/* Info box */
.info-box{padding:1.8rem;border-left:3px solid var(--gold);background:var(--sand)}
.info-box p{font-size:.86rem;color:var(--txt-lt);line-height:2.1}
.info-box strong{color:var(--ink);font-weight:500}

/* Keyword cloud */
.kw-cloud{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.5rem}
.kw{background:var(--white);border:1px solid rgba(196,163,90,.28);padding:.26rem .72rem;font-size:.66rem;color:var(--txt-lt);letter-spacing:.04em}

/* Save strip */
.save-strip{background:var(--gold);padding:.85rem 5vw;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.save-strip-msg{font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.save-strip-msg small{font-weight:300;letter-spacing:0;text-transform:none;font-size:.88rem}
.save-pill{background:var(--ink);color:var(--gold);padding:.22rem .85rem;font-size:.64rem;font-weight:700;letter-spacing:.12em}

/* FAQ */
.faq-list{max-width:820px}
.faq-item{border-bottom:1px solid rgba(0,0,0,.08)}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:1.3rem 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:var(--serif);font-size:1.08rem;color:var(--ink);font-weight:400;gap:1rem}
.faq-arr{color:var(--gold);font-size:1.1rem;transition:transform .32s;flex-shrink:0}
.faq-q.open .faq-arr{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .42s ease,padding .32s}
.faq-a.open{max-height:400px;padding-bottom:1.2rem}
.faq-a p{font-size:.9rem;color:var(--txt-lt);line-height:1.9}

/* Calendar */
.cal-months{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.cal-month{background:var(--white);padding:1.5rem;box-shadow:var(--sh)}
.cal-month-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.cal-month-title{font-family:var(--serif);font-size:1.05rem;color:var(--ink);font-weight:400}
.cal-nav-btn{background:none;border:none;cursor:pointer;color:var(--gold);font-size:1.2rem;padding:.2rem .5rem}
.cal-wds{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:.4rem}
.cal-wd{font-size:.56rem;text-align:center;color:var(--txt-lt);letter-spacing:.1em;text-transform:uppercase;padding:.26rem 0}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cd{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.74rem;border-radius:3px;transition:all .15s}
.cd.empty{background:none}
.cd.avail{background:#dff0e3;color:#1a5c38;cursor:pointer}
.cd.avail:hover{background:#2a8a52;color:#fff}
.cd.book{background:#fce8e8;color:#922b21;cursor:not-allowed}
.cd.today{background:var(--gold);color:var(--ink);font-weight:600}
.cd.past{background:rgba(0,0,0,.03);color:rgba(0,0,0,.18);cursor:default}
.cal-legend{display:flex;gap:1.4rem;margin-bottom:1.5rem;flex-wrap:wrap}
.leg{display:flex;align-items:center;gap:.42rem;font-size:.73rem;color:var(--txt-lt)}
.leg-dot{width:12px;height:12px;border-radius:2px;flex-shrink:0}

/* Contact cards */
.cc-grid{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:3rem}
.cc{background:rgba(255,255,255,.05);border:1px solid rgba(196,163,90,.2);padding:1.8rem 2.2rem;text-align:center;transition:all .38s var(--ease);min-width:180px}
.cc:hover{background:rgba(196,163,90,.1);border-color:rgba(196,163,90,.5);transform:translateY(-3px)}
.cc-icon{font-size:1.5rem;margin-bottom:.65rem}
.cc-lbl{font-size:.56rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:.38rem}
.cc-val{font-family:var(--serif);font-size:.98rem;color:var(--sand);font-weight:300}
.cc a{color:inherit}

/* Corporate */
.corp-card{background:var(--white);padding:2rem;border-left:3px solid var(--gold);transition:all .38s var(--ease);box-shadow:var(--sh)}
.corp-card:hover{transform:translateY(-4px);box-shadow:var(--sh-deep);border-left-color:#1a5f8a}
.corp-card .icon{font-size:1.8rem;margin-bottom:.9rem;display:block}
.corp-card .title{font-family:var(--serif);font-size:1.12rem;color:var(--ink);font-weight:400;margin-bottom:.42rem}
.corp-card .desc{font-size:.79rem;color:var(--txt-lt);line-height:1.7}
.feats-box{background:var(--ink);padding:2.8rem}
.feats-box-title{font-family:var(--serif);font-size:1.35rem;color:var(--gold-lt);font-weight:300;margin-bottom:1.6rem}
.feats-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}
.feat-item{display:flex;align-items:flex-start;gap:.65rem}
.feat-dot{width:5px;height:5px;background:var(--gold);border-radius:50%;margin-top:.55rem;flex-shrink:0}
.feat-text{font-size:.79rem;color:rgba(255,255,255,.6);line-height:1.6}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
.gallery-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:all .4s var(--ease);cursor:zoom-in}
.gallery-grid img:hover{filter:brightness(1.1);transform:scale(1.01)}
.gallery-grid .wide{grid-column:span 2;aspect-ratio:2/1}
.gallery-grid .tall{grid-row:span 2;aspect-ratio:3/4}

/* Distance list */
.dist-list{list-style:none;margin-top:1rem}
.dist-list li{font-size:.84rem;color:var(--txt-lt);padding:.46rem 0;border-bottom:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between}
.dist{color:var(--gold);font-size:.78rem;font-weight:600}

/* Map */
.map-embed{width:100%;height:400px;border:0;filter:grayscale(12%);display:block}

/* Footer */
footer{background:#060d14;color:rgba(255,255,255,.3);padding:2rem 5vw}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.7rem;letter-spacing:.06em;margin-bottom:1.5rem}
.foot-brand{font-family:var(--serif);color:var(--gold);font-size:1rem}
.foot-links{display:flex;gap:1.3rem;flex-wrap:wrap}
.foot-links a{color:rgba(255,255,255,.3);transition:color .2s}
.foot-links a:hover{color:var(--gold)}
.foot-nav{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.3rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.06)}
.foot-nav a{font-size:.68rem;color:rgba(255,255,255,.25);letter-spacing:.06em;transition:color .2s}
.foot-nav a:hover{color:var(--gold)}

/* Reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .72s var(--ease),transform .72s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ical box */
.ical-box{background:var(--ink);padding:2.5rem 3rem;margin-top:3rem}
.ical-title{font-family:var(--serif);font-size:1.35rem;color:var(--gold-lt);font-weight:300;margin-bottom:.5rem}
.ical-sub{font-size:.78rem;color:rgba(255,255,255,.44);margin-bottom:1.7rem}
.ical-plats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}
.ical-plat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);padding:1rem 1.2rem;display:flex;align-items:center;gap:.85rem}
.ical-icon{font-size:1.4rem}
.ical-name{font-size:.78rem;color:#fff;font-weight:500;margin-bottom:.14rem}
.ical-note{font-size:.62rem;color:rgba(255,255,255,.3)}
.ical-footer{margin-top:1.2rem;font-size:.73rem;color:rgba(255,255,255,.33);border-top:1px solid rgba(255,255,255,.07);padding-top:1rem}
.ical-footer a{color:var(--gold)}

/* Save block */
.save-block{background:var(--ink);padding:5rem 5vw;text-align:center}
.save-title{font-family:var(--serif);font-size:clamp(1.9rem,4vw,2.9rem);color:#fff;font-weight:300;margin-bottom:1rem}
.save-title em{color:var(--gold);font-style:italic}
.save-sub{color:rgba(255,255,255,.5);font-size:.9rem;max-width:460px;margin-inline:auto;margin-bottom:3.2rem}
.compare{display:grid;grid-template-columns:1fr 1fr;max-width:620px;margin-inline:auto;gap:1.5rem;margin-bottom:2.5rem}
.cmp-card{padding:2.2rem 1.8rem;text-align:center}
.cmp-platform{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1)}
.cmp-direct{background:rgba(196,163,90,.1);border:2px solid var(--gold)}
.cmp-label{font-size:.58rem;letter-spacing:.25em;text-transform:uppercase;margin-bottom:.9rem;color:rgba(255,255,255,.4)}
.cmp-label.g{color:var(--gold)}
.cmp-price{font-family:var(--serif);font-size:2.8rem;color:#fff;font-weight:300;line-height:1}
.cmp-price.strike{text-decoration:line-through;color:rgba(255,255,255,.26)}
.cmp-saving{background:var(--gold);color:var(--ink);font-size:.66rem;font-weight:700;padding:.26rem .85rem;display:inline-block;margin-top:.9rem;letter-spacing:.1em}
.cmp-note{font-size:.68rem;color:rgba(255,255,255,.28);margin-top:.45rem}

@media(max-width:960px){
  .two-col,.two-col.start{grid-template-columns:1fr;gap:3rem}
  .badge{right:0}
  .nav-links{display:none}
  .burger{display:flex}
  section{padding:4.5rem 5vw}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-grid .wide,.gallery-grid .tall{grid-column:span 1;grid-row:span 1;aspect-ratio:4/3}
  .compare{grid-template-columns:1fr;max-width:320px}
  .ical-box{padding:2rem}
  .feats-box{padding:2rem}
}
@media(max-width:520px){
  .gallery-grid{grid-template-columns:1fr}
  .stats-bar{grid-template-columns:1fr 1fr}
}
