/* ==========================================================
   SUNRISE POOL VILLA — shared brand stylesheet
   Quiet luxury · Navy #122448 · Gold #BA9C6A
   ========================================================== */

:root{
  --navy:#122448;
  --navy-85:rgba(18,36,72,.85);
  --navy-70:rgba(18,36,72,.70);
  --navy-50:rgba(18,36,72,.50);
  --navy-20:rgba(18,36,72,.20);
  --navy-08:rgba(18,36,72,.08);
  --gold:#BA9C6A;
  --gold-50:rgba(186,156,106,.50);
  --gold-25:rgba(186,156,106,.25);
  --cream:#F8F8F8;
  --white:#FFFFFF;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Montserrat", Arial, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--navy);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.8;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--navy-08);
}
.nav-inner{
  max-width:1440px;margin:0 auto;
  padding:22px 48px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-mark{display:flex;align-items:center;gap:14px}
.nav-mark .n-serif{font-family:var(--serif);font-weight:400;font-size:22px;letter-spacing:.28em;color:var(--navy)}
.nav-mark .n-rule{width:22px;height:1px;background:var(--gold)}
.nav-mark .n-sans{font-family:var(--sans);font-weight:300;font-size:9px;letter-spacing:.5em;color:var(--navy-70);text-transform:uppercase}
.nav-links{display:flex;gap:40px;align-items:center}
.nav-links a{font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--navy);font-weight:300;transition:color .25s ease}
.nav-links a:hover{color:var(--gold)}
.nav-links .nav-dd{position:relative}
.nav-links .nav-dd > a::after{content:" ▾";color:var(--gold);margin-left:4px}
.nav-links .nav-dd:hover .dd-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dd-menu{
  position:absolute;top:100%;left:-18px;margin-top:14px;
  background:var(--white);border:1px solid var(--navy-08);
  min-width:220px;padding:12px 0;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:all .25s ease;
}
.dd-menu a{display:block;padding:12px 22px;letter-spacing:.25em;font-size:10px}
.dd-menu a:hover{background:var(--cream);color:var(--gold)}
.nav-cta{
  font-size:10px;letter-spacing:.35em;text-transform:uppercase;
  color:var(--navy);border:1px solid var(--gold);padding:12px 22px;
  transition:all .25s ease;
}
.nav-cta:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}

/* ---------- MOBILE MENU (shared) ---------- */
.nav-toggle{
  display:none;background:none;border:0;padding:8px;cursor:pointer;
  width:40px;height:40px;align-items:center;justify-content:center;
}
.nav-toggle span{
  display:block;width:22px;height:1px;background:var(--navy);position:relative;
  transition:background .2s ease;
}
.nav-toggle span::before,.nav-toggle span::after{
  content:"";position:absolute;left:0;width:22px;height:1px;background:var(--navy);
  transition:transform .25s ease, top .25s ease;
}
.nav-toggle span::before{top:-7px}
.nav-toggle span::after{top:7px}
.nav-toggle[aria-expanded="true"] span{background:transparent}
.nav-toggle[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

/* ---------- PAGE HERO (tall) ---------- */
.hero{
  position:relative;min-height:100vh;color:var(--white);overflow:hidden;
  display:flex;align-items:center;justify-content:center;text-align:center;
}
.hero-img{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.02);
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(18,36,72,.35) 0%, rgba(18,36,72,.55) 100%);
}
.hero-inner{position:relative;z-index:2;padding:0 32px;max-width:980px}
.hero-label{font-size:10px;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);font-weight:300;margin-bottom:36px}
.hero-wordmark{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(56px, 10vw, 120px);letter-spacing:.22em;line-height:1;color:var(--white);
  margin-left:.22em;
}
.hero-rule{width:160px;height:1px;background:var(--gold);margin:32px auto}
.hero-sub1{font-size:12px;letter-spacing:.55em;text-transform:uppercase;color:rgba(255,255,255,.82);font-weight:300}
.hero-sub2{font-size:10px;letter-spacing:.45em;text-transform:uppercase;color:var(--gold);font-weight:300;margin-top:12px}
.hero-tagline{
  font-family:var(--serif);font-weight:400;font-style:italic;
  font-size:clamp(20px, 2.6vw, 30px);color:var(--white);margin-top:60px;letter-spacing:.02em;
}

/* ---------- PAGE HERO (short / inner pages) ---------- */
.page-hero{
  position:relative;min-height:62vh;color:var(--white);overflow:hidden;
  display:flex;align-items:flex-end;padding:0 48px 80px;
}
.page-hero .hero-img{transform:none}
.page-hero .hero-overlay{background:linear-gradient(180deg, rgba(18,36,72,.20) 0%, rgba(18,36,72,.65) 100%)}
.page-hero-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto;width:100%}
.page-hero .label{font-size:10px;letter-spacing:.55em;text-transform:uppercase;color:var(--gold);font-weight:300}
.page-hero h1{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(44px, 6.2vw, 82px);letter-spacing:.10em;line-height:1.05;
  color:var(--white);margin:22px 0 18px;max-width:900px;
}
.page-hero .sub{font-family:var(--serif);font-style:italic;font-size:clamp(18px, 2vw, 22px);color:rgba(255,255,255,.85);max-width:620px;line-height:1.6}
.page-hero .hr-gold{width:80px;height:1px;background:var(--gold);margin:26px 0}

/* breadcrumb sits on page hero */
.crumb{font-size:10px;letter-spacing:.45em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:30px}
.crumb a:hover{color:var(--gold)}
.crumb .sep{color:var(--gold);margin:0 12px}

/* ---------- SECTION BASELINE ---------- */
section{padding:140px 48px}
.wrap{max-width:1200px;margin:0 auto}
.wrap-narrow{max-width:820px;margin:0 auto;text-align:center}
.wrap-wide{max-width:1440px;margin:0 auto}

.eyebrow{font-size:10px;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);font-weight:300;display:inline-block}
.eyebrow::after{content:"";display:block;width:40px;height:1px;background:var(--gold);margin:18px auto 0}
.eyebrow.left{display:inline-block}
.eyebrow.left::after{margin:14px 0 0}

.heading{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(32px, 4.2vw, 48px);color:var(--navy);
  letter-spacing:.06em;line-height:1.2;margin:24px 0 28px;
}
.lede{font-family:var(--serif);font-weight:400;font-size:clamp(18px, 2vw, 22px);color:var(--navy-85);line-height:1.7;font-style:italic}
.prose{font-size:13px;letter-spacing:.06em;color:var(--navy-70);line-height:2;margin-top:24px}

.cream{background:var(--cream)}
.navy{background:var(--navy);color:var(--white)}
.navy .heading,.navy h2,.navy h3{color:var(--white)}
.navy .prose{color:rgba(255,255,255,.75)}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-block;background:var(--navy);color:var(--white);
  padding:18px 36px;font-size:10px;letter-spacing:.5em;text-transform:uppercase;
  border:1px solid var(--navy);transition:all .25s ease;
}
.btn:hover{background:transparent;color:var(--navy)}
.btn-outline{background:transparent;color:var(--navy);border:1px solid var(--gold)}
.btn-outline:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn-light{background:transparent;color:var(--white);border:1px solid var(--gold)}
.btn-light:hover{background:var(--white);color:var(--navy);border-color:var(--white)}

/* ---------- RATE TABLE ---------- */
.rate-table{
  width:100%;border-collapse:collapse;margin-top:32px;
  font-size:12px;letter-spacing:.04em;
}
.rate-table thead th{
  background:var(--navy);color:var(--white);
  font-family:var(--sans);font-weight:300;
  font-size:10px;letter-spacing:.35em;text-transform:uppercase;
  padding:16px 18px;text-align:left;
}
.rate-table tbody td{
  padding:16px 18px;border-bottom:1px solid var(--navy-08);
  font-family:var(--serif);font-size:15px;color:var(--navy);
  background:var(--white);
}
.rate-table tbody tr:nth-child(even) td{background:var(--cream)}
.rate-table tbody td:first-child{font-family:var(--sans);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--navy-70);font-weight:300}

/* ---------- INCLUSION LIST ---------- */
.inclusions{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px 40px;margin-top:40px;
}
.inclusions div{
  display:flex;align-items:flex-start;gap:14px;
  font-size:12px;letter-spacing:.05em;color:var(--navy);line-height:1.6;
}
.inclusions div::before{
  content:"";flex:none;width:10px;height:1px;background:var(--gold);
  margin-top:10px;
}

/* ---------- FOOTER ---------- */
footer{background:var(--navy);color:var(--white);padding:110px 48px 50px}
.footer-inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:60px;
}
.footer-mark{display:flex;flex-direction:column;gap:14px}
.footer-mark .fm-serif{font-family:var(--serif);font-weight:400;font-size:34px;letter-spacing:.22em;color:var(--white)}
.footer-mark .fm-rule{width:90px;height:1px;background:var(--gold)}
.footer-mark .fm-sans1{font-size:11px;letter-spacing:.55em;text-transform:uppercase;color:rgba(255,255,255,.65)}
.footer-mark .fm-sans2{font-size:10px;letter-spacing:.45em;text-transform:uppercase;color:var(--gold)}
.footer-mark .fm-tag{margin-top:24px;font-family:var(--serif);font-style:italic;font-size:18px;color:rgba(255,255,255,.75);line-height:1.6}
footer h5{font-size:10px;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);margin-bottom:22px;font-weight:300}
footer p, footer a{font-size:12px;letter-spacing:.06em;color:rgba(255,255,255,.7);line-height:2;display:block}
footer a:hover{color:var(--gold)}
.footer-bottom{
  max-width:1200px;margin:80px auto 0;padding-top:30px;
  border-top:1px solid rgba(186,156,106,.25);
  display:flex;justify-content:space-between;
  font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.45);
}

/* ---------- RESPONSIVE ---------- */
@media (max-width:960px){
  section{padding:100px 28px}
  .nav-inner{padding:14px 18px;flex-wrap:wrap;gap:10px}
  .nav-mark{gap:8px;flex:1;min-width:0}
  .nav-mark .n-serif{font-size:16px;letter-spacing:.22em}
  .nav-mark .n-rule{width:14px}
  .nav-mark .n-sans{font-size:8px;letter-spacing:.35em;line-height:1.4}
  .nav-cta{padding:10px 14px;font-size:9px;letter-spacing:.25em;white-space:nowrap}
  .nav-toggle{display:inline-flex;order:-1;margin-right:4px}
  .nav-links{
    display:none;flex-direction:column;gap:0;
    width:100%;order:3;margin-top:14px;
    border-top:1px solid var(--navy-08);padding-top:10px;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 0;width:100%}
  .nav-links .nav-dd{width:100%}
  .nav-links .dd-menu{
    position:static;opacity:1;visibility:visible;transform:none;
    border:0;padding:0 0 6px 14px;min-width:0;margin-top:0;
  }
  .nav-links .nav-dd > a::after{content:""}
  .inclusions{grid-template-columns:1fr 1fr;gap:18px 24px}
  .footer-inner{grid-template-columns:1fr 1fr;gap:40px}
  .footer-bottom{flex-direction:column;gap:14px;text-align:center}
  .page-hero{padding:0 28px 60px;min-height:56vh}
}
@media (max-width:560px){
  .inclusions{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
}
