*{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#12163a;--navy2:#1a1e45;--gold:#b8913a;--gold2:#d4a843;
  --gold-light:#f5e9cc;--gold-pale:#fdf8ef;
  --white:#ffffff;--off-white:#f9f8f6;--light-grey:#f2f0ed;
  --border:#e8e4dc;--border-light:#f0ece4;
  --text:#0f1225;--text2:#3d3d4a;--muted:#8a8790;--muted2:#b8b5bf;
  --green:#1a6b3c;
  --font:'Jost',sans-serif;--serif:'Cormorant Garamond',serif;
}
html{scroll-behavior:smooth}
body{background:var(--white);color:var(--text);font-family:var(--font);font-size:16px;line-height:1.65;overflow-x:hidden}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--light-grey)}
::-webkit-scrollbar-thumb{background:var(--gold2);border-radius:3px}

/* NAV */
nav{position:sticky;top:0;z-index:200;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 64px;background:rgba(255,255,255,.97);border-bottom:1px solid var(--border-light);backdrop-filter:blur(12px);box-shadow:0 1px 12px rgba(15,18,37,.05)}
.nav-brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-name{font-family:var(--serif);font-size:22px;color:var(--navy);letter-spacing:.06em;line-height:1}
.nav-tagline-sm{font-size:8px;color:var(--gold);letter-spacing:.22em;text-transform:uppercase;margin-top:2px;font-weight:600}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:11px;color:var(--text2);text-decoration:none;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:color .2s;padding-bottom:3px;border-bottom:2px solid transparent}
.nav-links a:hover,.nav-links a.nav-active{color:var(--gold);border-bottom-color:var(--gold)}
.nav-cta{padding:10px 24px;background:var(--navy);color:#fff;font-size:11px;font-weight:600;letter-spacing:.1em;text-decoration:none;text-transform:uppercase;transition:all .2s}
.nav-cta:hover{background:var(--gold)}

/* BUTTONS */
.btn-primary{padding:16px 40px;background:var(--navy);color:#fff;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border:none;cursor:pointer;transition:all .25s;text-decoration:none;display:inline-block}
.btn-primary:hover{background:var(--gold);transform:translateY(-1px)}
.btn-secondary{padding:15px 36px;background:transparent;color:var(--navy);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border:1.5px solid var(--navy);cursor:pointer;transition:all .25s;text-decoration:none;display:inline-block}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}
.btn-gold{padding:16px 44px;background:var(--gold);color:#fff;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;border:none;cursor:pointer;transition:all .25s;text-decoration:none;display:inline-block}
.btn-gold:hover{background:var(--gold2);transform:translateY(-1px)}

/* SECTION TYPOGRAPHY */
.section-eyebrow{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-weight:600}
.section-title{font-family:var(--serif);font-size:52px;font-weight:300;line-height:1.12;margin-bottom:16px;color:var(--navy)}
.section-title em{font-style:italic;color:var(--gold)}
.section-sub{font-size:15px;color:var(--text2);max-width:500px;line-height:1.9;font-weight:300}

/* FOOTER */
footer{background:var(--off-white);border-top:1px solid var(--border);padding:64px 64px 40px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;margin-bottom:48px}
.footer-wordmark{font-family:var(--serif);font-size:22px;color:var(--navy);letter-spacing:.06em;margin-bottom:4px}
.footer-tagline-full{font-size:8.5px;color:var(--gold);letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px;font-weight:600}
.footer-desc{font-size:13px;color:var(--muted);line-height:1.85;font-weight:300;max-width:240px;margin-bottom:16px}
.footer-social{display:flex;gap:10px;margin-top:4px}
.footer-social a{width:32px;height:32px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);text-decoration:none;font-size:13px;transition:all .2s}
.footer-social a:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-pale)}
.footer-col-title{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--navy);margin-bottom:14px}
.footer-col a,.footer-col p{display:block;font-size:13px;color:var(--muted);text-decoration:none;margin-bottom:9px;transition:color .2s;line-height:1.5}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid var(--border);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-copy{font-size:11px;color:var(--muted2)}

/* FORMS */
.fgroup{margin-bottom:18px}
.flabel{font-size:9px;font-weight:700;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;display:block;margin-bottom:7px}
.finput{width:100%;padding:12px 14px;border:1.5px solid var(--border);background:var(--white);font-family:var(--font);font-size:14px;color:var(--text);transition:border .2s;outline:none}
.finput:focus{border-color:var(--gold)}
.finput::placeholder{color:var(--muted2)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* BOOKING MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,18,37,.6);z-index:300;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto;backdrop-filter:blur(6px)}
.modal-overlay.open{display:flex}
.modal{background:#fff;width:100%;max-width:880px;display:grid;grid-template-columns:1fr 1fr;position:relative;border:1px solid var(--border)}
.modal-close{position:absolute;top:18px;right:20px;background:none;border:none;cursor:pointer;color:var(--muted);font-size:20px;z-index:10;transition:color .2s}
.modal-close:hover{color:var(--navy)}
.modal-left{padding:44px}
.modal-right{padding:44px;background:var(--off-white);border-left:1px solid var(--border)}
.modal-prop-name{font-family:var(--serif);font-size:24px;color:var(--navy);margin-bottom:4px;line-height:1.3}
.modal-prop-loc{font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:28px}
.mcal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.mcal-nav{background:transparent;border:1px solid var(--border);color:var(--muted);padding:5px 12px;cursor:pointer;font-size:13px;font-family:var(--font);transition:all .15s}
.mcal-nav:hover{border-color:var(--gold);color:var(--gold)}
.mcal-month{font-family:var(--serif);font-size:15px;color:var(--navy)}
.mcal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:20px}
.mc-dl{font-size:9px;color:var(--muted2);text-align:center;padding:4px;text-transform:uppercase;letter-spacing:.06em}
.mc-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:12px;cursor:pointer;transition:all .1s;color:var(--text)}
.mc-day:hover{background:var(--light-grey)}
.mc-day.empty,.mc-day.past{pointer-events:none;color:var(--muted2);opacity:.4}
.mc-day.today{font-weight:700;color:var(--gold)}
.mc-day.selected{background:var(--navy);color:#fff}
.mc-day.in-range{background:var(--gold-pale)}
.mc-day.booked{background:#fef2f2;color:#dc2626;pointer-events:none;opacity:.7}
.sum-title{font-family:var(--serif);font-size:22px;color:var(--navy);margin-bottom:6px}
.sum-prop{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px}
.sum-card{border:1px solid var(--border);padding:16px;margin-bottom:14px;background:var(--white)}
.sum-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:13.5px}
.sum-row:last-child{border:none}
.sum-total{font-family:var(--serif);font-size:16px;color:var(--navy)}
.pay-btn{width:100%;padding:15px;background:var(--navy);color:#fff;border:none;font-family:var(--font);font-size:11px;font-weight:700;cursor:pointer;letter-spacing:.12em;text-transform:uppercase;margin-top:14px;transition:background .2s}
.pay-btn:hover{background:var(--gold)}
.secure-note{font-size:11px;color:var(--muted);text-align:center;margin-top:10px}
.success-wrap{text-align:center;padding:48px 32px}
.success-icon{width:64px;height:64px;background:#d1fae5;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:28px}

/* PAGE HERO BANNER */
.page-banner{background:var(--navy);padding:72px 64px;position:relative;overflow:hidden}
.page-banner::before{content:"";position:absolute;top:-40%;right:-10%;width:480px;height:480px;border-radius:50%;background:rgba(184,145,58,.06);pointer-events:none}
.page-banner-eyebrow{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:rgba(184,145,58,.6);margin-bottom:14px;font-weight:600}
.page-banner-title{font-family:var(--serif);font-size:54px;font-weight:300;color:#fff;line-height:1.1;margin-bottom:12px}
.page-banner-title em{font-style:italic;color:var(--gold2)}
.page-banner-sub{font-size:15px;color:rgba(255,255,255,.45);font-weight:300;max-width:500px;line-height:1.8}

/* MISC */
.area-tag{display:inline-block;padding:4px 10px;background:var(--light-grey);font-size:11px;color:var(--text2);margin:3px 3px 3px 0}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .6s ease forwards;opacity:0}
.fade-up-1{animation-delay:.05s}.fade-up-2{animation-delay:.15s}.fade-up-3{animation-delay:.25s}.fade-up-4{animation-delay:.35s}

@media(max-width:900px){
  nav{padding:0 20px}
  .nav-links{display:none}
  .page-banner{padding:60px 24px}
  .page-banner-title{font-size:38px}
  footer{padding:48px 24px 32px}
  .footer-top{grid-template-columns:1fr}
  .modal{grid-template-columns:1fr}
  .modal-right{display:none}
  .frow{grid-template-columns:1fr}
}
