:root {
  --rdc-navy: #071827;
  --rdc-blue: #0d2d42;
  --rdc-cream: #f8f1e5;
  --rdc-paper: #fffaf2;
  --rdc-gold: #c4934f;
  --rdc-gold-2: #efd08a;
  --rdc-ink: #17212a;
  --rdc-muted: #64717a;
  --rdc-line: rgba(23, 33, 42, 0.12);
  --rdc-shadow: 0 18px 44px rgba(7, 24, 39, 0.14);
  --rdc-display: "Cormorant Garamond", Georgia, serif;
  --rdc-body: "Montserrat", "Segoe UI", Arial, sans-serif;
}

html,
body {
  overflow-x: hidden;
}

body {
  background: var(--rdc-cream);
  color: var(--rdc-ink);
  font-family: var(--rdc-body);
  letter-spacing: 0;
}

body p,
body li,
body input,
body select,
body textarea,
body button,
body a {
  font-family: var(--rdc-body);
}

body h1,
body h2,
body h3 {
  font-family: var(--rdc-display);
  letter-spacing: 0;
}

body .container {
  width: min(1120px, calc(100% - 56px));
}

body .site-header {
  min-height: 76px;
  grid-template-columns: 210px 1fr auto;
  gap: 24px;
  padding: 12px clamp(28px, 5vw, 72px);
  background: rgba(7, 24, 39, 0.78);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

body .site-header.is-scrolled {
  min-height: 68px;
  background: rgba(7, 24, 39, 0.96);
}

body .brand {
  min-width: 0;
}

body .brand-logo-img {
  width: 178px;
  height: 56px;
  max-height: none;
  object-fit: contain;
  object-position: left center;
  filter: none;
}

body .site-nav {
  justify-content: center;
  gap: 24px;
  font-size: 11px;
  line-height: 1;
}

body .site-nav a {
  color: rgba(255, 255, 255, 0.88);
}

body .header-cta {
  min-width: 144px;
}

body .btn {
  min-height: 42px;
  border-radius: 5px;
  padding: 0 20px;
  font-size: 11px;
}

body .btn-gold {
  background: linear-gradient(135deg, #f2d792, #bd8844);
  box-shadow: 0 12px 24px rgba(196, 147, 79, 0.22);
}

body .hero {
  min-height: 680px;
  padding: 112px 0 30px;
  align-content: center;
}

body .hero-bg {
  object-fit: cover;
  object-position: center center;
}

body .hero-shade {
  background:
    linear-gradient(90deg, rgba(7, 24, 39, 0.9) 0%, rgba(7, 24, 39, 0.74) 39%, rgba(7, 24, 39, 0.3) 72%, rgba(7, 24, 39, 0.14) 100%),
    linear-gradient(0deg, rgba(7, 24, 39, 0.48), rgba(7, 24, 39, 0.04) 52%);
}

body .hero-layout {
  grid-template-columns: minmax(0, 1fr) 370px;
  gap: 58px;
  align-items: center;
}

body .hero .eyebrow {
  margin: 0 0 12px;
  color: var(--rdc-gold-2);
  font-size: 11px;
}

body .hero h1 {
  max-width: 660px;
  color: #f2d78f;
  font-size: clamp(46px, 5vw, 66px);
  font-weight: 700;
  line-height: 0.98;
  text-shadow: 0 14px 34px rgba(0, 0, 0, 0.28);
}

body .hero-copy p {
  max-width: 560px;
  margin: 18px 0 24px;
  color: rgba(255, 255, 255, 0.86);
  font-size: 16px;
  line-height: 1.65;
}

body .hero-actions {
  gap: 12px;
}

body .lead-card {
  width: 370px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.55);
  border-radius: 8px;
  background: rgba(255, 250, 242, 0.98);
  box-shadow: 0 20px 46px rgba(0, 0, 0, 0.22);
}

body .lead-form {
  padding: 20px;
  gap: 10px;
  border-radius: 7px;
  background: var(--rdc-paper);
}

body .lead-form h2 {
  color: var(--rdc-ink);
  font-size: 28px;
  font-weight: 700;
  line-height: 1.04;
}

body .lead-form label {
  gap: 6px;
  color: #4d5960;
  font-size: 11px;
}

body input,
body select,
body textarea {
  min-height: 42px;
  border: 1px solid rgba(23, 33, 42, 0.15);
  border-radius: 4px;
  padding: 10px 12px;
  background: #fff;
  font-size: 14px;
}

body .live-badge {
  margin: 4px 4px 0;
  padding: 7px 11px;
  font-size: 11px;
}

body .hero-stats {
  width: min(1120px, calc(100% - 56px));
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 24px;
}

body .stat-card {
  min-height: 84px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 7px;
  padding: 15px 16px;
  background: rgba(7, 24, 39, 0.58);
}

body .stat-card strong {
  color: #fff;
  font-size: 25px;
}

body .stat-card small {
  margin-top: 6px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 10px;
}

body .section {
  padding: 62px 0;
}

body .section-soft {
  background: #fffaf2;
}

body .grid-2 {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 48px;
  align-items: center;
}

body .align-start {
  align-items: start;
}

body .section-copy h2,
body .section-head h2 {
  max-width: 660px;
  color: #142434;
  font-size: clamp(34px, 3.4vw, 46px);
  font-weight: 700;
  line-height: 1.05;
}

body .section-copy p,
body .section-head p {
  max-width: 640px;
  margin-top: 14px;
  color: var(--rdc-muted);
  font-size: 15px;
  line-height: 1.62;
}

body .eyebrow {
  margin-bottom: 10px;
  color: var(--rdc-gold);
  font-size: 11px;
}

body .image-frame,
body .media-card,
body .floorplan-card,
body .video-card {
  border: 1px solid var(--rdc-line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--rdc-shadow);
}

body .image-frame {
  overflow: hidden;
}

body .image-frame img {
  width: 100%;
  min-height: 310px;
  object-fit: cover;
  object-position: center;
}

body .overview .image-frame img,
body [data-overview-image] {
  min-height: 330px;
  object-fit: cover;
  object-position: 58% center;
}

body .check-list {
  gap: 9px;
  margin-top: 20px;
}

body .check-list li {
  font-size: 14px;
  line-height: 1.42;
}

body .highlight-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

body .highlight-card {
  min-height: 150px;
  padding: 20px;
}

body .highlight-card strong {
  font-size: 31px;
}

body .highlight-card p {
  font-size: 14px;
}

body .amenity-floor-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 22px;
}

body .floor-card {
  min-height: 132px;
  padding: 17px;
}

body .floor-card h3 {
  font-size: 22px;
}

body .floor-card li {
  font-size: 14px;
}

body .media-grid {
  gap: 14px;
  margin-top: 18px;
}

body .media-card {
  overflow: hidden;
}

body .media-card img {
  width: 100%;
  aspect-ratio: 1.55 / 1;
  object-fit: cover;
}

body .media-card-body {
  min-height: 88px;
  padding: 15px;
}

body .media-card h3,
body .floorplan-card h3,
body .video-card h3 {
  font-size: 21px;
}

body .floorplan-card img {
  width: 100%;
  height: 260px;
  object-fit: contain;
  background: #fffaf2;
}

body .policy-grid {
  gap: 9px;
  margin-top: 20px;
}

body .policy-card {
  min-height: 96px;
  padding: 15px;
}

body .policy-images {
  gap: 12px;
}

body .policy-images img {
  width: 100%;
  min-height: 490px;
  max-height: 580px;
  object-fit: cover;
  object-position: top center;
  border-radius: 8px;
  box-shadow: var(--rdc-shadow);
}

body .final-cta {
  min-height: 500px;
}

body .site-footer {
  padding: 0;
}

body .footer-grid {
  grid-template-columns: minmax(280px, 1.3fr) repeat(3, minmax(145px, 0.7fr));
  gap: 28px;
  padding: 42px 0 28px;
}

body .footer-logo-img {
  width: 176px;
  height: auto;
}

body .footer-bottom {
  padding: 16px 0 28px;
}

body .policies {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 250, 242, 0.97), rgba(244, 233, 215, 0.97)),
    #fffaf2;
}

body .policy-shell {
  display: grid;
  gap: 26px;
}

body .policy-head {
  display: grid;
  max-width: 760px;
}

body .policy-head h2 {
  max-width: 720px;
  color: #142434;
  font-family: var(--rdc-display);
  font-size: clamp(36px, 3.8vw, 52px);
  font-weight: 700;
  line-height: 1.02;
}

body .policy-head p {
  max-width: 650px;
  margin-top: 13px;
  color: var(--rdc-muted);
  font-size: 15px;
  line-height: 1.65;
}

body .policy-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 18px;
  align-items: start;
}

body .policy-board {
  padding: 18px;
  border: 1px solid rgba(196, 147, 79, 0.28);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(7, 24, 39, 0.98), rgba(12, 42, 61, 0.96)),
    var(--rdc-navy);
  box-shadow: 0 24px 54px rgba(7, 24, 39, 0.2);
}

body .policy-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 0;
}

body .policy-card {
  display: grid;
  align-content: start;
  min-height: 138px;
  padding: 17px 16px 16px;
  border: 1px solid rgba(239, 208, 138, 0.22);
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.06);
  box-shadow: none;
}

body .policy-card-featured {
  min-height: 158px;
  background: linear-gradient(145deg, rgba(239, 208, 138, 0.2), rgba(255, 255, 255, 0.08));
}

body .policy-card small {
  min-height: 18px;
  color: rgba(239, 208, 138, 0.92);
  font-family: var(--rdc-body);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

body .policy-card strong {
  margin-top: 12px;
  color: #f5d88e;
  font-family: var(--rdc-display);
  font-size: clamp(30px, 3.2vw, 43px);
  font-weight: 700;
  line-height: 0.95;
}

body .policy-card span {
  margin-top: 11px;
  color: rgba(255, 255, 255, 0.82);
  font-size: 13px;
  line-height: 1.45;
}

body .policy-aside {
  display: grid;
  grid-template-rows: auto auto auto;
  gap: 12px;
  min-width: 0;
}

body .policy-doc-card {
  position: relative;
  overflow: hidden;
  height: 214px;
  min-height: 214px;
  border: 1px solid rgba(23, 33, 42, 0.12);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--rdc-shadow);
}

body .policy-doc-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(7, 24, 39, 0), rgba(7, 24, 39, 0.44));
}

body .policy-doc-card span {
  position: absolute;
  z-index: 1;
  left: 14px;
  bottom: 12px;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

body .policy-doc-card img {
  width: 100%;
  height: 100%;
  min-height: 214px;
  object-fit: cover;
  object-position: top center;
  transition: transform 0.35s ease, filter 0.35s ease;
}

body .policy-doc-card:hover img {
  filter: brightness(1.05);
  transform: scale(1.04);
}

body .proof-toast {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  opacity: 0;
  pointer-events: none;
}

body .proof-toast.show {
  opacity: 0.98;
}

body .floating-actions {
  opacity: 0;
  pointer-events: none;
}

body .floating-actions a,
body .floating-actions button {
  min-width: 132px;
  padding-inline: 16px;
  white-space: nowrap;
}

body.show-floating .floating-actions {
  opacity: 1;
  pointer-events: auto;
}

body .proof-toast {
  position: fixed;
  top: auto;
  right: auto;
  bottom: 22px;
  left: 22px;
  z-index: 70;
  width: min(318px, calc(100vw - 44px));
  transform: translate3d(-18px, 14px, 0);
  border: 1px solid rgba(239, 208, 138, 0.24);
  background: rgba(7, 24, 39, 0.94);
  box-shadow: 0 20px 44px rgba(7, 24, 39, 0.26);
  backdrop-filter: blur(14px);
}

body .proof-toast.show {
  transform: translate3d(0, 0, 0);
}

@media (max-width: 1080px) {
  body .site-header {
    grid-template-columns: 1fr auto;
  }

  body .brand-logo-img {
    width: 150px;
  }

  body .hero-layout,
  body .grid-2,
  body .final-layout {
    grid-template-columns: 1fr;
  }

  body .lead-card {
    width: min(100%, 460px);
  }

  body .highlight-grid,
  body .amenity-floor-grid,
  body .media-grid.three,
  body .media-grid.four,
  body .video-grid,
  body .policy-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  body .container {
    width: min(100% - 32px, 1120px);
  }

  body .site-header {
    min-height: 72px;
    padding: 10px 16px;
  }

  body .brand-logo-img {
    width: 132px;
    height: 48px;
  }

  body .hero {
    min-height: 650px;
    padding-top: 92px;
  }

  body .hero h1 {
    font-size: 36px;
  }

  body .hero-copy p {
    font-size: 15px;
  }

  body .lead-card {
    display: none;
  }

  body .hero-stats,
  body .highlight-grid,
  body .amenity-floor-grid,
  body .media-grid.three,
  body .media-grid.four,
  body .video-grid,
  body .policy-grid,
  body .policy-images,
  body .footer-grid {
    grid-template-columns: 1fr;
  }

  body .hero-stats {
    width: min(100% - 32px, 1120px);
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body .section {
    padding: 48px 0;
  }

  body .section-copy h2,
  body .section-head h2 {
    font-size: 32px;
  }

  body .image-frame img,
  body .overview .image-frame img {
    min-height: 240px;
  }
}

@media (max-width: 1080px) {
  body .policy-layout {
    grid-template-columns: 1fr;
  }

  body .policy-aside {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto auto;
  }

  body .policy-aside .btn {
    grid-column: 1 / -1;
  }
}

@media (max-width: 720px) {
  body .policy-head h2 {
    font-size: 34px;
  }

  body .policy-board {
    padding: 12px;
  }

  body .policy-card,
  body .policy-card-featured {
    min-height: 128px;
  }

  body .policy-card strong {
    font-size: 32px;
  }

  body .policy-aside {
    grid-template-columns: 1fr;
  }
}

/* Brochure layout pass: closer to the supplied Radisson reference. */
body {
  background: #f5efe4;
}

body .container {
  width: min(1280px, calc(100% - 64px));
}

body .site-header {
  min-height: 72px;
  grid-template-columns: 190px minmax(0, 1fr) 148px;
  padding: 10px clamp(40px, 5vw, 78px);
  background: linear-gradient(180deg, rgba(3, 25, 40, 0.92), rgba(3, 25, 40, 0.62));
}

body .brand span {
  display: none;
}

body .brand-logo-img {
  width: 142px;
  height: 58px;
}

body .site-nav {
  gap: clamp(18px, 2.6vw, 42px);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

body .btn {
  border-radius: 2px;
  min-height: 44px;
  letter-spacing: 0;
}

body .btn-gold {
  background: linear-gradient(90deg, #d8a24f, #f0c77c);
  color: #082033;
}

body .hero {
  min-height: 610px;
  padding: 94px 0 34px;
}

body .hero-layout {
  grid-template-columns: minmax(0, 670px);
  gap: 0;
  align-items: center;
}

body .lead-card {
  display: none;
}

body .hero-shade {
  background:
    linear-gradient(90deg, rgba(3, 22, 35, 0.97) 0%, rgba(3, 22, 35, 0.8) 34%, rgba(3, 22, 35, 0.34) 68%, rgba(3, 22, 35, 0.08) 100%),
    linear-gradient(0deg, rgba(3, 22, 35, 0.34), rgba(3, 22, 35, 0.06) 56%);
}

body .hero-bg {
  object-position: 58% center;
}

body .hero h1 {
  max-width: 620px;
  color: #e7bd70;
  font-size: clamp(52px, 5.6vw, 82px);
  line-height: 0.9;
  text-transform: uppercase;
}

body .hero-copy p {
  max-width: 430px;
  margin-top: 20px;
  color: #fff5e5;
  font-size: 17px;
}

body .hero-stats {
  width: min(1280px, calc(100% - 64px));
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin-top: 42px;
  border-top: 1px solid rgba(232, 191, 111, 0.22);
  border-bottom: 1px solid rgba(232, 191, 111, 0.16);
  background: rgba(4, 28, 44, 0.58);
}

body .stat-card {
  min-height: 86px;
  border: 0;
  border-right: 1px solid rgba(232, 191, 111, 0.22);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

body .stat-card:last-child {
  border-right: 0;
}

body .section {
  padding: 0;
  border-bottom: 1px solid rgba(7, 24, 39, 0.1);
}

body .overview,
body .amenities,
body .floorplans {
  background: #f7f1e7;
}

body .section-soft {
  background: #fbf6ec;
}

body .overview .grid-2,
body .amenities > .grid-2,
body .floorplans .grid-2,
body .progress .grid-2 {
  width: min(100%, 1440px);
  grid-template-columns: minmax(320px, 0.42fr) minmax(0, 0.58fr);
  gap: 0;
}

body .overview .section-copy,
body .amenities .section-copy,
body .floorplans .section-copy,
body .progress .section-copy {
  padding: clamp(42px, 5vw, 72px) clamp(34px, 6vw, 78px);
}

body .section-copy h2,
body .section-head h2,
body .policy-head h2 {
  font-size: clamp(34px, 3.7vw, 54px);
  line-height: 1;
}

body .eyebrow {
  color: #b7833d;
  font-size: 10px;
  font-weight: 800;
}

body .image-frame,
body .media-card,
body .floorplan-card,
body .video-card {
  margin: 0;
  border-radius: 0;
  border-color: rgba(7, 24, 39, 0.1);
  box-shadow: none;
}

body .overview .image-frame,
body .amenities .image-frame,
body .progress .image-frame {
  height: 100%;
  min-height: 430px;
}

body .overview .image-frame img,
body .amenities .image-frame img,
body .progress .image-frame img {
  height: 100%;
  min-height: 430px;
  object-fit: cover;
}

body .highlights {
  background: #fbf6ec;
}

body .highlight-grid {
  width: min(100%, 1440px);
  margin: 0 auto;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
}

body .highlight-card {
  min-height: 178px;
  border-radius: 0;
  border: 0;
  border-right: 1px solid rgba(7, 24, 39, 0.1);
  padding: 34px clamp(26px, 4vw, 58px);
  box-shadow: none;
}

body .highlight-card strong {
  color: #17212a;
  font-family: var(--rdc-display);
  font-size: 42px;
}

body .location {
  position: relative;
  min-height: 300px;
  padding: 0;
  background: #061b2d;
  color: #fff;
}

body .location .section-head {
  position: absolute;
  z-index: 2;
  left: max(32px, calc((100vw - 1280px) / 2));
  top: 50%;
  width: min(420px, calc(100% - 64px));
  transform: translateY(-50%);
}

body .location .section-head h2 {
  color: #fff3df;
  font-size: clamp(38px, 4.5vw, 62px);
}

body .location .section-head p {
  display: none;
}

body .location-layout {
  width: 100%;
  max-width: none;
  margin: 0;
}

body .location .image-frame {
  width: 100%;
  max-width: none;
  border: 0;
}

body .location .image-frame img {
  width: 100%;
  height: 300px;
  min-height: 300px;
  object-fit: cover;
  object-position: center 58%;
  filter: brightness(0.78) saturate(1.08);
}

body .location-points {
  display: none;
}

body .amenity-floor-grid,
body .media-grid.three,
body .media-grid.four,
body .floorplan-grid,
body .video-grid {
  width: min(1280px, calc(100% - 64px));
}

body .amenity-floor-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 0;
  padding: 22px 0;
}

body .floor-card {
  border-radius: 0;
  box-shadow: none;
}

body .media-grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding-bottom: 34px;
}

body .media-grid.four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  padding-bottom: 34px;
}

body .media-card {
  overflow: hidden;
  background: #fff;
}

body .media-card img {
  aspect-ratio: 1.7 / 1;
}

body .media-card-body {
  min-height: 72px;
  padding: 11px 12px;
  text-align: center;
}

body .media-card h3,
body .floorplan-card h3 {
  color: #071827;
  font-family: var(--rdc-body);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

body .media-card p {
  font-size: 11px;
}

body .residences .section-head {
  padding-top: 38px;
}

body .residences .media-card-body {
  background: #061b2d;
}

body .residences .media-card h3,
body .residences .media-card p {
  color: #fff;
}

body .floorplans .floorplan-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  align-self: center;
  padding: 42px 64px 42px 0;
}

body .floorplan-card img {
  height: 260px;
  background: #fff;
}

body .progress {
  background: #f7f1e7;
  color: var(--rdc-ink);
}

body .progress.section-deep .section-copy h2,
body .progress.section-deep .section-copy p {
  color: var(--rdc-ink);
}

body .progress .grid-2 {
  grid-template-columns: minmax(0, 0.56fr) minmax(320px, 0.44fr);
}

body .video-section {
  padding: 54px 0;
  background: #fbf6ec;
}

body .policies {
  padding: 48px 0;
}

body .sales-stock,
body .ownership,
body .faq-section {
  padding: 54px 0;
  background: #f7f1e7;
}

body .investment,
body .gallery-section {
  padding: 54px 0;
}

body .stock-grid,
body .investment-grid,
body .gallery-grid {
  display: grid;
  gap: 12px;
}

body .stock-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body .stock-card,
body .investment-card,
body .timeline-item,
body .faq-item {
  border: 1px solid rgba(7, 24, 39, 0.1);
  border-radius: 0;
  background: #fff;
  box-shadow: none;
}

body .stock-card {
  display: grid;
  gap: 12px;
  min-height: 240px;
  padding: 20px;
}

body .stock-status {
  width: fit-content;
  border: 1px solid rgba(196, 147, 79, 0.28);
  padding: 6px 9px;
  color: #9b6c2e;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

body .stock-card h3,
body .investment-card h3,
body .timeline-item h3 {
  color: #071827;
  font-family: var(--rdc-display);
  font-size: 28px;
  line-height: 1.05;
}

body .stock-card strong {
  color: #071827;
  font-family: var(--rdc-display);
  font-size: 38px;
  line-height: 1;
}

body .stock-card p,
body .investment-card p,
body .timeline-item p,
body .faq-item p {
  color: var(--rdc-muted);
  font-size: 14px;
  line-height: 1.55;
}

body .stock-card .btn {
  align-self: end;
}

body .investment-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body .investment-card {
  min-height: 190px;
  padding: 22px;
}

body .investment-card span,
body .timeline-item span {
  display: inline-block;
  margin-bottom: 18px;
  color: #c4934f;
  font-family: var(--rdc-display);
  font-size: 32px;
  font-weight: 700;
}

body .ownership .grid-2,
body .faq-section .grid-2 {
  grid-template-columns: minmax(300px, 0.42fr) minmax(0, 0.58fr);
}

body .timeline {
  display: grid;
  gap: 10px;
}

body .timeline-item {
  padding: 20px 22px;
}

body .gallery-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body .gallery-card {
  position: relative;
  overflow: hidden;
  margin: 0;
  min-height: 260px;
  background: #071827;
}

body .gallery-card img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
  transition: transform 0.35s ease, filter 0.35s ease;
}

body .gallery-card:hover img {
  filter: brightness(1.06);
  transform: scale(1.04);
}

body .gallery-card figcaption {
  position: absolute;
  left: 14px;
  bottom: 12px;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  text-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
}

body .faq-list {
  display: grid;
  gap: 10px;
}

body .faq-item {
  padding: 0;
}

body .faq-item summary {
  cursor: pointer;
  padding: 18px 20px;
  color: #071827;
  font-weight: 800;
}

body .faq-item p {
  margin: 0;
  border-top: 1px solid rgba(7, 24, 39, 0.08);
  padding: 0 20px 18px;
}

body .final-cta {
  min-height: 330px;
  padding: 52px 0;
}

body .final-layout {
  grid-template-columns: minmax(0, 1fr) 420px;
}

body .final-form {
  border: 1px solid rgba(232, 191, 111, 0.32);
  background: rgba(3, 22, 35, 0.76);
}

@media (max-width: 1080px) {
  body .site-header {
    grid-template-columns: 1fr auto;
  }

  body .overview .grid-2,
  body .amenities > .grid-2,
  body .floorplans .grid-2,
  body .progress .grid-2,
  body .ownership .grid-2,
  body .faq-section .grid-2,
  body .final-layout {
    grid-template-columns: 1fr;
  }

  body .stock-grid,
  body .investment-grid,
  body .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body .floorplans .floorplan-grid {
    padding: 0 32px 42px;
  }
}

@media (max-width: 720px) {
  body .container,
  body .hero-stats,
  body .amenity-floor-grid,
  body .media-grid.three,
  body .media-grid.four,
  body .floorplan-grid,
  body .video-grid {
    width: min(100% - 28px, 1280px);
  }

  body .hero {
    min-height: 620px;
  }

  body .hero h1 {
    font-size: 42px;
  }

  body .hero-stats,
  body .highlight-grid,
  body .amenity-floor-grid,
  body .media-grid.three,
  body .media-grid.four,
  body .floorplan-grid,
  body .stock-grid,
  body .investment-grid,
  body .gallery-grid {
    grid-template-columns: 1fr;
  }

  body .overview .section-copy,
  body .amenities .section-copy,
  body .floorplans .section-copy,
  body .progress .section-copy {
    padding: 36px 18px;
  }

  body .location .section-head {
    left: 18px;
  }

  body .location .image-frame img {
    height: 260px;
    min-height: 260px;
  }
}

body .proof-toast,
body .proof-toast.show {
  left: 22px !important;
  right: auto !important;
  bottom: 22px !important;
}

body .floating-actions {
  display: flex !important;
  align-items: stretch;
  width: max-content !important;
  max-width: calc(100vw - 32px);
  overflow: visible !important;
  border-radius: 8px !important;
}

body .floating-actions a,
body .floating-actions button {
  display: inline-flex !important;
  flex: 0 0 auto !important;
  align-items: center;
  justify-content: center;
  min-width: auto !important;
  min-height: 50px;
  padding: 0 18px !important;
  line-height: 1.1;
  white-space: nowrap !important;
}

body .floating-actions a {
  min-width: 176px !important;
}

body .floating-actions button {
  min-width: 104px !important;
}

body .location {
  min-height: auto;
  padding: 58px 0;
  background:
    linear-gradient(180deg, rgba(251, 246, 236, 0.96), rgba(247, 241, 231, 0.98)),
    #f7f1e7;
  color: var(--rdc-ink);
}

body .location .section-head {
  position: static;
  width: min(1280px, calc(100% - 64px));
  transform: none;
  margin: 0 auto 24px;
}

body .location .section-head h2 {
  color: #071827;
}

body .location .section-head p {
  display: block;
  max-width: 760px;
}

body .location-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.62fr) minmax(320px, 0.38fr);
  gap: 18px;
  width: min(1280px, calc(100% - 64px));
  max-width: 1280px;
  margin: 0 auto;
}

body .location .image-frame {
  overflow: hidden;
  border: 1px solid rgba(7, 24, 39, 0.1);
  background: #fffaf2;
}

body .location .image-frame img {
  height: 520px;
  min-height: 520px;
  object-fit: contain;
  object-position: center;
  filter: none;
  background: #f7f1e7;
}

body .location-points {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  align-self: stretch;
}

body .location-pill {
  display: flex;
  align-items: center;
  min-height: 40px;
  border: 1px solid rgba(196, 147, 79, 0.24);
  border-radius: 0;
  padding: 10px 14px;
  color: #071827;
  background: #fff;
  font-size: 13px;
  font-weight: 700;
}

body .location-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  margin-right: 10px;
  border-radius: 999px;
  background: #c4934f;
  flex: 0 0 auto;
}

@media (max-width: 420px) {
  body .floating-actions {
    right: 12px !important;
    bottom: 12px !important;
  }

  body .floating-actions a {
    min-width: 158px !important;
    padding-inline: 12px !important;
  }

body .floating-actions button {
  min-width: 92px !important;
  padding-inline: 12px !important;
  }
}

/* Lead capture bars and final typography tuning */
body .site-nav {
  font-size: 12px !important;
  gap: clamp(20px, 2.4vw, 36px) !important;
}

body .site-nav a {
  font-weight: 900 !important;
}

body .hero h1 {
  font-size: clamp(42px, 4.5vw, 66px) !important;
  line-height: 0.96 !important;
}

body .section-inline-form {
  position: relative;
  z-index: 2;
  padding: 18px clamp(18px, 4vw, 64px);
  background: #f7f1e7;
}

body .section-inline-form-dark {
  background: #071827;
}

body .inline-lead-form {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(170px, 230px) minmax(150px, 210px) auto;
  gap: 10px;
  align-items: center;
  width: min(1280px, 100%);
  margin: 0 auto;
  border: 1px solid rgba(196, 147, 79, 0.28);
  padding: 12px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 16px 42px rgba(7, 24, 39, 0.08);
}

body .section-inline-form-dark .inline-lead-form {
  border-color: rgba(232, 193, 120, 0.32);
  background: rgba(255, 250, 242, 0.08);
}

body .inline-lead-form strong {
  color: #071827;
  font-family: var(--rdc-display);
  font-size: clamp(22px, 2.2vw, 34px);
  line-height: 1.05;
}

body .section-inline-form-dark .inline-lead-form strong {
  color: #f4dfb5;
}

body .inline-lead-form input {
  width: 100%;
  min-height: 46px;
  border-radius: 0;
}

body .inline-lead-form .btn {
  min-height: 46px;
  white-space: nowrap;
}

body .media-grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body .media-grid.four {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body .media-card img,
body .gallery-card img {
  filter: saturate(1.04) contrast(1.02);
}

@media (max-width: 1080px) {
  body .inline-lead-form {
    grid-template-columns: 1fr 1fr;
  }

  body .inline-lead-form strong,
  body .inline-lead-form .btn {
    grid-column: 1 / -1;
  }

  body .site-nav {
    font-size: 13px !important;
  }
}

@media (max-width: 720px) {
  body .inline-lead-form {
    grid-template-columns: 1fr;
  }

  body .hero h1 {
    font-size: 36px !important;
  }

  body .media-grid.three,
  body .media-grid.four {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1080px) {
  body .location-layout {
    grid-template-columns: 1fr;
  }

  body .location .image-frame img {
    height: 420px;
    min-height: 420px;
  }

  body .location-points {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  body .location .section-head,
  body .location-layout {
    width: min(100% - 28px, 1280px);
  }

  body .location .image-frame img {
    height: 310px;
    min-height: 310px;
  }

  body .location-points {
    grid-template-columns: 1fr;
  }
}

/* An Viet inspired location section */
body .location {
  position: relative !important;
  overflow: hidden;
  padding: clamp(64px, 7vw, 96px) 0 !important;
  background: #081d2b !important;
  color: #fff;
}

body .location-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(8, 29, 43, 0.97), rgba(8, 29, 43, 0.84) 42%, rgba(8, 29, 43, 0.62)),
    url("assets/anviet/ani-back-main.png") center/cover no-repeat;
  opacity: 1;
}

body .location-intro,
body .location-layout {
  position: relative;
  z-index: 1;
}

body .location-intro {
  width: min(1280px, calc(100% - 64px)) !important;
  margin: 0 auto 28px !important;
}

body .location-intro .eyebrow {
  color: #e8c178;
}

body .location-intro h2 {
  max-width: 780px;
  color: #f4dfb5;
  font-family: var(--rdc-display);
  font-size: clamp(42px, 5.4vw, 76px);
  line-height: 0.96;
}

body .location-intro p {
  max-width: 760px;
  margin-top: 16px;
  color: rgba(255, 250, 242, 0.86);
  font-size: 17px;
  line-height: 1.8;
}

body .location-layout {
  display: grid !important;
  grid-template-columns: minmax(360px, 0.42fr) minmax(0, 0.58fr) !important;
  gap: 24px !important;
  width: min(1280px, calc(100% - 64px)) !important;
  max-width: 1280px !important;
  margin: 0 auto !important;
  align-items: stretch;
}

body .location-copy {
  display: grid;
  align-content: start;
  gap: 18px;
  border: 1px solid rgba(232, 193, 120, 0.28);
  padding: clamp(24px, 3vw, 38px);
  background: rgba(3, 20, 31, 0.7);
  backdrop-filter: blur(10px);
}

body .location-copy h3 {
  margin: 0;
  color: #fff;
  font-family: var(--rdc-display);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1;
}

body .location-copy p {
  margin: 0;
  color: rgba(255, 250, 242, 0.78);
  font-size: 14px;
  line-height: 1.7;
}

body .location-map {
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(232, 193, 120, 0.28);
  background: #f7f1e7;
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.28);
}

body .location-map img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 620px;
  object-fit: contain;
  object-position: center;
}

body .location-points {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

body .location-pill {
  display: flex !important;
  align-items: center;
  min-height: 42px;
  border: 1px solid rgba(232, 193, 120, 0.22);
  padding: 10px 12px;
  color: #fff7e8;
  background: rgba(255, 255, 255, 0.06);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.3;
}

body .location-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  margin-right: 9px;
  border-radius: 999px;
  background: #e8c178;
  flex: 0 0 auto;
}

body .location-copy .btn {
  width: fit-content;
  margin-top: 4px;
}

@media (max-width: 1080px) {
  body .location-layout {
    grid-template-columns: 1fr !important;
  }

  body .location-map img {
    min-height: 430px;
  }
}

@media (max-width: 720px) {
  body .location-intro,
  body .location-layout {
    width: min(100% - 28px, 1280px) !important;
  }

  body .location-points {
    grid-template-columns: 1fr !important;
  }

  body .location-map img {
    min-height: 320px;
  }
}

/* Location section, map-left layout like the An Viet reference */
body .location {
  min-height: clamp(620px, 58vw, 860px) !important;
  padding: 0 !important;
  background: #f9ead7 !important;
  color: #402619;
}

body .location-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 35% 52%, rgba(154, 218, 245, 0.72) 0 23%, rgba(154, 218, 245, 0.48) 38%, rgba(249, 234, 215, 0.2) 58%, rgba(249, 234, 215, 0) 72%),
    linear-gradient(115deg, #f7ddc3 0%, #faead7 48%, #f8eddd 100%);
}

body .location::after {
  content: "";
  position: absolute;
  right: -4vw;
  bottom: -8vw;
  width: 58vw;
  height: 22vw;
  pointer-events: none;
  opacity: 0.3;
  background:
    repeating-radial-gradient(ellipse at bottom right, transparent 0 16px, rgba(156, 118, 82, 0.32) 17px 19px, transparent 20px 34px);
}

body .location-layout {
  position: relative;
  z-index: 1;
  display: grid !important;
  grid-template-columns: minmax(0, 0.58fr) minmax(420px, 0.42fr) !important;
  gap: clamp(22px, 4vw, 58px) !important;
  align-items: center;
  width: min(1500px, calc(100% - 72px)) !important;
  max-width: 1500px !important;
  min-height: clamp(620px, 58vw, 860px);
  margin: 0 auto !important;
}

body .location-map {
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

body .location-map img {
  width: min(820px, 100%);
  height: auto;
  min-height: 0;
  object-fit: contain;
  filter: drop-shadow(0 24px 45px rgba(124, 83, 46, 0.08));
}

body .location-copy {
  display: grid;
  gap: 18px;
  padding: 0;
  border: 0;
  background: transparent;
  backdrop-filter: none;
}

body .location-copy .eyebrow {
  color: #af7a30;
}

body .location-copy h2 {
  margin: 0;
  color: #3d2418;
  font-family: var(--rdc-display);
  font-size: clamp(46px, 5.4vw, 76px);
  font-weight: 700;
  line-height: 1.02;
  white-space: pre-line;
}

body .location-copy h2::first-line {
  color: #3d2418;
}

body .location-copy p {
  max-width: 560px;
  margin: 0;
  color: rgba(61, 36, 24, 0.76);
  font-size: 15px;
  line-height: 1.7;
}

body .location-points {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px 30px !important;
  margin-top: 6px;
}

body .location-pill {
  position: relative;
  display: block !important;
  min-height: auto;
  border: 0;
  padding: 0 0 0 18px;
  color: #3d2418;
  background: transparent;
  font-family: var(--rdc-display);
  font-size: clamp(16px, 1.35vw, 21px);
  font-weight: 600;
  line-height: 1.35;
}

body .location-pill::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 4px;
  height: 4px;
  margin: 0;
  border-radius: 999px;
  background: #3d2418;
}

body .location-copy .btn {
  width: fit-content;
  margin-top: 10px;
}

@media (max-width: 1080px) {
  body .location {
    padding: 54px 0 !important;
  }

  body .location-layout {
    grid-template-columns: 1fr !important;
    min-height: auto;
  }

  body .location-map img {
    width: min(760px, 100%);
  }
}

@media (max-width: 720px) {
  body .location-layout {
    width: min(100% - 28px, 1500px) !important;
  }

  body .location-copy h2 {
    font-size: 40px;
  }

  body .location-points {
    grid-template-columns: 1fr !important;
  }
}

/* Residence gallery and footer contrast fix */
body .residences .media-grid.four {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

body .residences .media-card img {
  height: clamp(245px, 21vw, 320px) !important;
  object-fit: cover !important;
}

body .residences .media-card-body {
  display: grid;
  min-height: 108px;
  align-content: center;
}

body .site-footer,
body .site-footer p,
body .site-footer a,
body .site-footer button,
body .site-footer span,
body .footer-bottom span {
  color: #ffffff !important;
}

body .site-footer h3,
body .site-footer a:hover,
body .site-footer button:hover {
  color: #f1c878 !important;
}

body .footer-brand strong {
  color: #ffffff !important;
}

@media (max-width: 900px) {
  body .residences .media-grid.four {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  body .residences .media-grid.four {
    grid-template-columns: 1fr !important;
  }
}

/* Final lead section contrast fix */
body .final-cta .hero-shade {
  background:
    linear-gradient(90deg, rgba(3, 16, 27, 0.96), rgba(3, 16, 27, 0.76) 50%, rgba(3, 16, 27, 0.6)),
    linear-gradient(0deg, rgba(3, 16, 27, 0.5), rgba(3, 16, 27, 0.5)) !important;
}

body .final-cta .section-copy .eyebrow {
  color: #f1c878 !important;
}

body .final-cta .section-copy h2,
body .final-cta .section-copy p,
body .final-cta .final-form h2,
body .final-cta .final-form label {
  color: #ffffff !important;
}

body .final-cta .section-copy h2 {
  text-shadow: 0 18px 42px rgba(0, 0, 0, 0.45);
}

body .final-cta .section-copy p,
body .final-cta .final-form label {
  opacity: 1 !important;
}

body .final-cta .final-form {
  border-color: rgba(241, 200, 120, 0.5) !important;
  background: rgba(3, 16, 27, 0.78) !important;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.35) !important;
}

/* Layout pass: larger floorplans, restored video, footer, desktop menu, mobile balance */
@media (min-width: 1081px) {
  body .site-nav {
    font-size: 15px !important;
    gap: clamp(16px, 1.8vw, 30px) !important;
  }
}

body .floorplans {
  padding: clamp(54px, 6vw, 82px) 0 !important;
}

body .floorplan-layout {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 28px !important;
}

body .floorplans .section-copy {
  width: min(980px, 100%) !important;
  padding: 0 !important;
}

body .floorplans .section-copy h2 {
  max-width: 940px !important;
  font-size: clamp(42px, 5vw, 74px) !important;
}

body .floorplans .section-copy p {
  max-width: 760px !important;
}

body .floorplans .floorplan-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
  width: 100% !important;
  padding: 0 !important;
}

body .floorplan-card {
  display: grid;
  align-content: start;
  min-height: 0;
  border: 1px solid rgba(7, 24, 39, 0.12);
  background: #fff;
}

body .floorplan-card img {
  width: 100% !important;
  height: clamp(420px, 34vw, 620px) !important;
  min-height: 0 !important;
  object-fit: contain !important;
  padding: 18px !important;
  background: #fff !important;
}

body .floorplan-card h3 {
  padding: 18px 22px 24px !important;
  font-size: 18px !important;
}

body .video-section .section-head h2[hidden],
body .video-section .section-head p[hidden] {
  display: block !important;
}

body .video-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

body .video-card {
  border: 1px solid rgba(7, 24, 39, 0.1);
  background: #fff;
}

body .video-frame {
  aspect-ratio: 16 / 9;
}

body .site-footer .footer-grid {
  grid-template-columns: minmax(300px, 1.3fr) minmax(180px, 0.8fr) minmax(220px, 0.9fr) !important;
}

body .footer-credit {
  color: rgba(255, 255, 255, 0.62) !important;
  font-size: 12px !important;
}

@media (max-width: 720px) {
  body .section,
  body .visual-wall,
  body .video-section,
  body .sales-stock,
  body .ownership,
  body .faq-section {
    padding-top: 42px !important;
    padding-bottom: 42px !important;
  }

  body .section-head,
  body .section-copy {
    text-align: left !important;
  }

  body .section-head h2,
  body .section-copy h2 {
    font-size: clamp(32px, 10vw, 42px) !important;
    line-height: 1.04 !important;
  }

  body .section-head p,
  body .section-copy p {
    font-size: 15px !important;
    line-height: 1.65 !important;
  }

  body .floorplans .floorplan-grid,
  body .video-grid {
    grid-template-columns: 1fr !important;
  }

  body .floorplan-card img {
    height: auto !important;
    max-height: none !important;
    padding: 10px !important;
  }

  body .media-card img,
  body .gallery-card img {
    min-height: 220px !important;
  }

  body .inline-lead-form strong {
    font-size: 24px !important;
  }

  body .site-footer .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
}

/* Richer image density */
body .visual-wall {
  padding: 54px 0 64px !important;
  background: #f7f1e7 !important;
}

body .visual-wall .section-head {
  margin-bottom: 20px !important;
}

body .visual-wall .section-head h2 {
  max-width: 760px;
  font-size: clamp(34px, 4vw, 54px) !important;
}

body .visual-wall-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  grid-auto-flow: dense;
  gap: 12px !important;
}

body .visual-wall-grid .gallery-card {
  min-height: 250px;
}

body .visual-wall-grid .gallery-card:nth-child(1),
body .visual-wall-grid .gallery-card:nth-child(2) {
  grid-column: span 2;
  min-height: 340px;
}

body .amenities .media-grid.three,
body .residences .media-grid.four {
  margin-top: 18px !important;
}

body .amenities .media-card img {
  height: clamp(210px, 18vw, 280px) !important;
}

body .gallery-section .gallery-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

body .gallery-section .gallery-card {
  min-height: 240px;
}

body .gallery-section .gallery-card:nth-child(1),
body .gallery-section .gallery-card:nth-child(2),
body .gallery-section .gallery-card:nth-child(6),
body .gallery-section .gallery-card:nth-child(11) {
  grid-column: span 2;
  min-height: 330px;
}

@media (max-width: 1080px) {
  body .visual-wall-grid,
  body .gallery-section .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  body .visual-wall-grid,
  body .gallery-section .gallery-grid {
    grid-template-columns: 1fr !important;
  }

  body .visual-wall-grid .gallery-card,
  body .visual-wall-grid .gallery-card:nth-child(1),
  body .visual-wall-grid .gallery-card:nth-child(2),
  body .gallery-section .gallery-card,
  body .gallery-section .gallery-card:nth-child(1),
  body .gallery-section .gallery-card:nth-child(2),
  body .gallery-section .gallery-card:nth-child(6),
  body .gallery-section .gallery-card:nth-child(11) {
    grid-column: auto;
    min-height: 260px;
  }
}
