:root {
  --ink: #102b35;
  --ink-soft: #26454f;
  --gold: #c8a34b;
  --gold-light: #ead7a0;
  --cream: #f5f0e5;
  --paper: #fbfaf6;
  --white: #fff;
  --muted: #68787d;
  --line: rgba(16, 43, 53, .14);
  --serif: "Playfair Display", Georgia, serif;
  --sans: "DM Sans", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--sans); line-height: 1.6; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
.sr-only, .hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }

.site-header {
  position: fixed; inset: 0 0 auto; z-index: 20; height: 82px; padding: 0 5vw;
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(251, 250, 246, .95); border-bottom: 1px solid rgba(16, 43, 53, .08);
  backdrop-filter: blur(14px);
}
.brand { display: flex; align-items: center; gap: 14px; }
.brand img { width: 142px; height: 42px; object-fit: contain; }
.brand .sarovar-logo { width: 110px; background: #ffffff; }
.brand span { width: 1px; height: 32px; background: var(--line); }
nav { display: flex; align-items: center; gap: 30px; font-size: .86rem; font-weight: 600; }
nav a:not(.nav-cta):hover { color: #8a6b22; }
.nav-cta { padding: 11px 20px; color: var(--white); background: var(--ink); }
.menu-button { display: none; padding: 8px; border: 0; background: none; }
.menu-button > span:not(.sr-only) { display: block; width: 25px; height: 2px; margin: 5px; background: var(--ink); }

.hero {
  position: relative; min-height: 840px; padding: 180px 8vw 110px;
  display: grid; grid-template-columns: minmax(0, 1fr) 330px; align-items: end; gap: 8vw;
  color: var(--white); background: url("brochure-assets/p05-02-Im13.jpg") center 28%/cover no-repeat;
}
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(6,25,31,.92) 0%, rgba(6,25,31,.64) 48%, rgba(6,25,31,.16) 100%), linear-gradient(0deg, rgba(6,25,31,.72), transparent 55%); }
.hero-content, .offer-card { position: relative; z-index: 1; }
.hero-content { max-width: 760px; }
.eyebrow { margin: 0 0 18px; color: var(--gold-light); font-size: .72rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; }
.eyebrow.dark { color: #92752e; }
h1, h2 { margin: 0; font-family: var(--serif); font-weight: 500; line-height: 1.05; }
h1 { max-width: 650px; font-size: clamp(4.2rem, 8.5vw, 8rem); letter-spacing: -.055em; }
h2 { font-size: clamp(2.6rem, 5vw, 4.8rem); letter-spacing: -.035em; }
.hero-copy { max-width: 660px; margin: 26px 0 32px; font-size: clamp(1.05rem, 1.5vw, 1.3rem); color: rgba(255,255,255,.84); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 52px; padding: 0 25px; border: 1px solid transparent; font-weight: 700; cursor: pointer; }
.button-gold { color: #152b2f; background: var(--gold-light); }
.button-gold:hover { background: #f4e2aa; }
.button-ghost { color: var(--white); border-color: rgba(255,255,255,.55); }
.button-ghost:hover { background: rgba(255,255,255,.1); }
.launch-note { margin: 30px 0 0; font-size: .83rem; letter-spacing: .03em; }
.launch-note span { display: inline-block; width: 7px; height: 7px; margin-right: 9px; border-radius: 50%; background: var(--gold-light); }
.offer-card { align-self: end; padding: 30px; color: var(--ink); background: rgba(251,250,246,.96); box-shadow: 0 24px 60px rgba(0,0,0,.22); }
.offer-card > p { margin: 0 0 8px; color: #8a6b22; font-size: .72rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.offer { padding: 20px 0; border-bottom: 1px solid var(--line); }
.offer span, .offer small { display: block; color: var(--muted); }
.offer strong { display: block; margin: 2px 0; font-family: var(--serif); font-size: 2.3rem; line-height: 1.1; }
.offer-card > a { display: inline-block; margin-top: 22px; font-weight: 700; }

.trust-strip { display: grid; grid-template-columns: repeat(4, 1fr); background: var(--ink); color: var(--white); }
.trust-strip div { padding: 30px 5vw; border-right: 1px solid rgba(255,255,255,.12); }
.trust-strip strong { display: block; color: var(--gold-light); font-family: var(--serif); font-size: 2rem; font-weight: 500; }
.trust-strip span { color: rgba(255,255,255,.68); font-size: .8rem; }
.section { padding: 130px 8vw; }
.split-section { display: grid; grid-template-columns: .9fr 1.1fr; align-items: center; gap: 9vw; }
.section-copy > p:not(.eyebrow, .fine-print) { margin: 28px 0; color: var(--ink-soft); font-size: 1.05rem; }
.feature-list { margin: 35px 0 25px; padding: 0; list-style: none; }
.feature-list li { padding: 16px 0; border-bottom: 1px solid var(--line); font-weight: 600; }
.feature-list span { display: inline-block; width: 45px; color: #9c7a27; font-size: .72rem; letter-spacing: .1em; }
.fine-print { color: var(--muted); font-size: .72rem; line-height: 1.6; }
.image-composition { position: relative; padding: 0 0 55px 45px; }
.main-image { width: 100%; min-height: 540px; object-fit: cover; }
.image-note { position: absolute; left: 0; bottom: 0; width: 280px; padding: 25px; color: var(--white); background: var(--ink); }
.image-note strong, .image-note span { display: block; }
.image-note strong { margin-bottom: 5px; font: 500 1.7rem var(--serif); color: var(--gold-light); }
.image-note span { font-size: .8rem; color: rgba(255,255,255,.72); }

.income-section { color: var(--white); background: var(--ink); }
.income-intro { display: flex; align-items: end; justify-content: space-between; }
.income-grid { margin-top: 70px; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(255,255,255,.16); }
.income-grid article { min-height: 260px; padding: 28px 28px 20px 0; border-right: 1px solid rgba(255,255,255,.16); }
.income-grid article:not(:first-child) { padding-left: 28px; }
.income-grid span { color: var(--gold-light); font-size: .72rem; }
.income-grid h3 { margin: 60px 0 12px; font: 500 1.55rem var(--serif); }
.income-grid p { margin: 0; color: rgba(255,255,255,.62); font-size: .86rem; }

.section-heading { margin-bottom: 65px; }
.amenity-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.amenity-card { position: relative; min-height: 330px; overflow: hidden; color: var(--white); background: var(--ink); }
.amenity-card.large { grid-column: span 2; }
.amenity-card img { width: 100%; height: 100%; min-height: 330px; object-fit: cover; transition: transform .7s ease; }
.amenity-card::after { content: ""; position: absolute; inset: 30% 0 0; background: linear-gradient(transparent, rgba(4,18,23,.88)); }
.amenity-card div { position: absolute; z-index: 1; inset: auto 25px 24px; }
.amenity-card span { color: var(--gold-light); font-size: .65rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.amenity-card h3 { margin: 5px 0 0; font: 500 1.7rem var(--serif); }
.amenity-card p { max-width: 430px; margin: 6px 0 0; color: rgba(255,255,255,.7); font-size: .83rem; }
.amenity-card:hover img { transform: scale(1.035); }

.perks-section { padding-top: 0; display: grid; grid-template-columns: 1fr 1fr; }
.perks-image img { width: 100%; height: 100%; min-height: 650px; object-fit: cover; }
.perks-copy { padding: 80px; color: var(--white); background: #173944; }
.perks-copy h2 { margin-bottom: 45px; }
.perk { display: grid; grid-template-columns: 150px 1fr; gap: 25px; padding: 23px 0; border-top: 1px solid rgba(255,255,255,.16); }
.perk strong { color: var(--gold-light); font-family: var(--serif); font-size: 1.25rem; font-weight: 500; }
.perk span { color: rgba(255,255,255,.72); font-size: .88rem; }
.fine-print.light { margin-top: 25px; color: rgba(255,255,255,.5); }

.location-section { display: grid; grid-template-columns: .8fr 1.2fr; align-items: center; gap: 8vw; }
.location-copy > p:not(.eyebrow) { margin: 25px 0; color: var(--ink-soft); }
address { margin: 25px 0; font-style: normal; font-weight: 600; }
.text-link { color: #84661f; font-weight: 700; border-bottom: 1px solid #b99743; }
.location-visual { padding: 25px; background: #dcecef; }
.location-visual img { width: 100%; }

.enquiry-section { padding: 120px 8vw; display: grid; grid-template-columns: .85fr 1.15fr; gap: 10vw; color: var(--white); background: #0d262f; }
.enquiry-copy > p:not(.eyebrow) { max-width: 520px; margin: 25px 0; color: rgba(255,255,255,.68); }
.contact-lines { margin-top: 45px; }
.contact-lines a { display: block; margin: 8px 0; font-weight: 600; }
.lead-form { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; padding: 40px; color: var(--ink); background: var(--paper); }
.lead-form label { color: var(--ink-soft); font-size: .76rem; font-weight: 700; }
.lead-form input:not([type="checkbox"]), .lead-form select, .lead-form textarea {
  width: 100%; margin-top: 7px; padding: 12px 0; border: 0; border-bottom: 1px solid #aab4b4; border-radius: 0; outline: 0; color: var(--ink); background: transparent;
}
.lead-form input:focus, .lead-form select:focus, .lead-form textarea:focus { border-color: var(--gold); }
.lead-form label:nth-of-type(5), .consent, .lead-form button, .form-note { grid-column: 1 / -1; }
.consent { display: flex; align-items: center; gap: 9px; }
.consent input { accent-color: var(--ink); }
.lead-form button { border: 0; }
.form-note { margin: -8px 0 0; text-align: center; color: var(--muted); font-size: .68rem; }

footer { padding: 70px 8vw 35px; display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 7vw; background: var(--cream); }
footer img { width: 175px; }
footer h3 { margin: 0 0 14px; font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; }
footer a { display: block; margin: 8px 0; font-size: .86rem; }
.footer-brand p { max-width: 400px; color: var(--muted); font-size: .82rem; }
.footer-legal { grid-column: 1 / -1; margin: 35px 0 0; padding-top: 25px; border-top: 1px solid var(--line); color: var(--muted); font-size: .68rem; }
.mobile-actions { display: none; }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 980px) {
  .site-header { height: 72px; padding: 0 24px; }
  .brand img { width: 112px; height: 36px; }
  .brand .sarovar-logo { width: 88px; }
  .menu-button { display: block; }
  nav { position: absolute; top: 72px; left: 0; right: 0; padding: 20px 24px 28px; display: none; align-items: stretch; flex-direction: column; gap: 18px; background: var(--paper); box-shadow: 0 14px 25px rgba(0,0,0,.1); }
  nav.open { display: flex; }
  .nav-cta { text-align: center; }
  .hero { min-height: auto; padding: 160px 7vw 80px; grid-template-columns: 1fr; }
  .offer-card { max-width: 380px; }
  .section { padding: 90px 7vw; }
  .split-section, .location-section { grid-template-columns: 1fr; }
  .image-composition { max-width: 740px; }
  .income-grid { grid-template-columns: 1fr 1fr; }
  .income-grid article:nth-child(2) { border-right: 0; }
  .amenity-grid { grid-template-columns: 1fr 1fr; }
  .perks-section { grid-template-columns: 1fr; padding: 0; }
  .perks-image img { min-height: 480px; }
  .enquiry-section { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  body { padding-bottom: 58px; }
  .site-header { padding: 0 16px; }
  .brand { gap: 7px; }
  .brand img { width: 94px; }
  .brand .sarovar-logo { width: 72px; }
  .brand span { height: 25px; }
  .hero { padding: 140px 22px 55px; background-position: 57% center; }
  .hero-shade { background: linear-gradient(90deg, rgba(6,25,31,.93), rgba(6,25,31,.52)), linear-gradient(0deg, rgba(6,25,31,.82), transparent); }
  h1 { font-size: 4rem; }
  h2 { font-size: 2.7rem; }
  .hero-actions { flex-direction: column; }
  .hero-actions .button { width: 100%; }
  .offer-card { margin-top: 15px; padding: 24px; }
  .trust-strip { grid-template-columns: 1fr 1fr; }
  .trust-strip div { padding: 22px; }
  .section { padding: 75px 22px; }
  .main-image { min-height: 340px; }
  .image-composition { padding: 0 0 60px 18px; }
  .income-grid { grid-template-columns: 1fr; margin-top: 45px; }
  .income-grid article, .income-grid article:not(:first-child) { min-height: 0; padding: 25px 0; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.16); }
  .income-grid h3 { margin: 25px 0 8px; }
  .amenity-grid { grid-template-columns: 1fr; }
  .amenity-card.large { grid-column: auto; }
  .amenity-card, .amenity-card img { min-height: 290px; }
  .perks-image img { min-height: 360px; }
  .perks-copy { padding: 65px 22px; }
  .perk { grid-template-columns: 1fr; gap: 5px; }
  .location-section { gap: 45px; }
  .enquiry-section { padding: 75px 22px; }
  .lead-form { grid-template-columns: 1fr; padding: 28px 22px; }
  .lead-form label { grid-column: 1 / -1; }
  footer { padding: 55px 22px 30px; grid-template-columns: 1fr; gap: 28px; }
  .mobile-actions { position: fixed; z-index: 30; inset: auto 0 0; height: 58px; display: grid; grid-template-columns: 1fr 1fr; box-shadow: 0 -4px 18px rgba(0,0,0,.18); }
  .mobile-actions a { display: flex; align-items: center; justify-content: center; color: var(--white); background: var(--ink); font-weight: 700; }
  .mobile-actions a:last-child { color: var(--ink); background: var(--gold-light); }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
}
