/* Cormorant Garamond 600, self-hosted (display serif, distinct from Vikas/Nivasa Marcellus) */
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/fonts/cormorant-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/fonts/cormorant-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ============================================================
   Nivasa Green City - Stylesheet
   Theme: Luxury gold + biophilic green
   ============================================================ */

:root {
  --green-900: #07302a;
  --green-800: #0b3f37;
  --green-700: #105043;
  --green-600: #1a6a57;
  --green-500: #2c8670;
  --cream: #f7f1e5;
  --cream-2: #efe3cd;
  --ink: #1e2622;
  --muted: #5d685f;
  --line: #e6dcc4;

  --gold-1: #c2933f;
  --gold-2: #edca84;
  --gold-3: #8c6826;
  --gold-grad: linear-gradient(135deg, #856120 0%, #c5983e 40%, #f1d488 55%, #b1822e 78%, #856120 100%);

  --radius: 13px;
  --radius-sm: 8px;
  --shadow: 0 22px 55px -22px rgba(6, 30, 26, 0.5);
  --shadow-soft: 0 12px 34px -18px rgba(6, 30, 26, 0.32);
  --container: 1200px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);

  --font-head: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --font-body: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; scroll-padding-top: 90px; font-size: 106.25%; }

body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

html, body { max-width: 100%; overflow-x: hidden; }

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.container {
  width: min(100% - 40px, var(--container));
  margin-inline: auto;
}

/* ---------- Typography helpers ---------- */
.eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--gold-3);
  margin-bottom: 14px;
}
.eyebrow--light { color: var(--gold-2); }

.section { padding: 92px 0; }

.section__title {
  font-family: var(--font-head);
  font-weight: 600;
  font-size: clamp(1.9rem, 4vw, 3rem);
  line-height: 1.12;
  letter-spacing: 0.2px;
  color: var(--green-800);
}
.section__title--light { color: #fff; }

.section__head { max-width: 720px; margin-bottom: 54px; }
.section__head.center { margin-inline: auto; text-align: center; }
.section__sub { color: var(--muted); font-size: 1.18rem; margin-top: 16px; line-height: 1.65; }

.center { text-align: center; }

/* ---------- Buttons ---------- */
.btn {
  --pad-y: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: var(--pad-y) 26px;
  border: 0;
  border-radius: 4px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.92rem;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease), background 0.3s, color 0.3s;
  white-space: nowrap;
}
.btn--lg { --pad-y: 16px; padding-inline: 34px; font-size: 1rem; }
.btn--block { width: 100%; }

.btn--gold {
  background: var(--gold-grad);
  color: #3a2b06;
  box-shadow: 0 12px 26px -12px rgba(176, 126, 42, 0.7);
  background-size: 200% 200%;
}
.btn--gold:hover { transform: translateY(-2px); background-position: right center; box-shadow: 0 16px 34px -12px rgba(176, 126, 42, 0.85); }

.btn--outline {
  background: transparent;
  color: var(--green-700);
  border: 1.5px solid var(--gold-1);
}
.btn--outline:hover { background: var(--green-700); color: #fff; border-color: var(--green-700); }

.btn--outline-light {
  background: rgba(255,255,255,0.08);
  color: #fff;
  border: 1.5px solid rgba(255,255,255,0.6);
  backdrop-filter: blur(4px);
}
.btn--outline-light:hover { background: #fff; color: var(--green-800); }

.btn--ghost { background: transparent; color: var(--cream); padding-inline: 14px; }

/* ---------- Honeypot (spam trap) + form-note error state ---------- */
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.form-note--err { color: #b00020; }

/* ---------- Topbar ---------- */
.topbar {
  background: var(--green-900);
  color: #cdbf9a;
  font-size: 0.8rem;
  letter-spacing: 0.04em;
}
.topbar__inner { display: flex; justify-content: space-between; align-items: center; height: 38px; }
.topbar__rera { color: var(--gold-2); font-weight: 500; }
.topbar__contact a:hover { color: #fff; }
.topbar__sep { margin: 0 10px; opacity: 0.4; }

/* ---------- Header ---------- */
.header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(247, 244, 236, 0.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid transparent;
  transition: background 0.3s, box-shadow 0.3s, border-color 0.3s;
}
.header.scrolled {
  background: rgba(247, 243, 236, 0.97);
  box-shadow: var(--shadow-soft);
  border-bottom: 2px solid var(--gold-1);
}
.header__inner { display: flex; align-items: center; justify-content: space-between; height: 76px; gap: 20px; }

.brand { display: flex; align-items: center; gap: 8px; }
.brand__logo { height: 46px; width: auto; max-width: 180px; object-fit: contain; border-radius: 0; }
.footer__brand img, .modal__head img { object-fit: contain; border-radius: 0; }
.brand__sub {
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 600;
  color: var(--green-600);
  letter-spacing: 0.06em;
}

.nav { display: flex; align-items: center; gap: 22px; }
.nav__link {
  position: relative;
  font-weight: 500;
  font-size: 0.92rem;
  color: var(--green-800);
  padding: 6px 0;
}
.nav__link::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 0; height: 2px;
  background: var(--gold-grad);
  transition: width 0.3s var(--ease);
}
.nav__link:hover::after, .nav__link.active::after { width: 100%; }
.nav__link--mobile-cta { display: none; }
.nav__close { display: none; }
.nav-backdrop { display: none; }

.header__actions { display: flex; align-items: center; gap: 12px; }
.btn--phone { color: var(--green-800); border: 1.5px solid var(--line); border-radius: 4px; }
.btn--phone:hover { border-color: var(--gold-1); color: var(--gold-3); }

/* ---------- Hamburger ---------- */
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 6px;
}
.nav-toggle span {
  width: 26px; height: 2px;
  background: var(--green-800);
  border-radius: 2px;
  transition: transform 0.3s var(--ease), opacity 0.3s;
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  min-height: calc(100svh - 114px);
  display: flex;
  align-items: center;
  background: var(--green-900);
  color: #fff;
  overflow: hidden;
}
.hero__slides { position: absolute; inset: 0; z-index: 0; }
.hero__slide {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; background-size: cover; background-position: center;
  opacity: 0; will-change: opacity, transform;
  animation: heroKen 32s infinite;
}
.hero__slide--first { animation-name: heroKenFirst; }
@keyframes heroKenFirst {
  0% { opacity: 1; transform: scale(1.04); }
  22% { opacity: 1; }
  25% { opacity: 0; transform: scale(1.12); }
  97% { opacity: 0; }
  100% { opacity: 1; transform: scale(1.04); }
}
.hero__slide:nth-child(1) { animation-delay: 0s; }
.hero__slide:nth-child(2) { animation-delay: 8s; }
.hero__slide:nth-child(3) { animation-delay: 16s; }
.hero__slide:nth-child(4) { animation-delay: 24s; }
@keyframes heroKen {
  0%   { opacity: 0; transform: scale(1.04); }
  3%   { opacity: 1; }
  22%  { opacity: 1; }
  25%  { opacity: 0; transform: scale(1.12); }
  100% { opacity: 0; transform: scale(1.04); }
}
.hero__scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(100deg, rgba(7,12,22,0.93) 0%, rgba(7,12,22,0.8) 34%, rgba(7,12,22,0.42) 60%, rgba(7,12,22,0) 84%),
    linear-gradient(to top, rgba(7,12,22,0.55) 0%, rgba(7,12,22,0) 42%);
}
.hero__overlay { display: none; }
.hero__content { position: relative; z-index: 2; padding: 28px 0; max-width: 580px; }
@media (prefers-reduced-motion: reduce) {
  .hero__slide:nth-child(1) { opacity: 1; }
}
.hero__eyebrow {
  display: inline-block;
  font-size: 0.82rem; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--gold-2); font-weight: 600;
  padding: 8px 18px;
  border: 1px solid rgba(243, 226, 168, 0.4);
  border-radius: 999px;
  margin-bottom: 26px;
}
.hero__title {
  font-family: var(--font-head);
  font-weight: 600;
  font-size: clamp(2rem, 4.1vw, 3.35rem);
  line-height: 1.08;
  letter-spacing: 0.3px;
  text-shadow: 0 2px 16px rgba(0,0,0,0.55);
}
.hero__lead { margin-top: 20px; font-size: 1.08rem; max-width: 440px; color: rgba(255,255,255,0.92); text-shadow: 0 1px 10px rgba(0,0,0,0.5); }
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 36px; }

.hero__stats {
  list-style: none;
  display: grid; grid-template-columns: repeat(2, max-content); gap: 18px 48px;
  margin-top: 38px;
  padding-top: 30px;
  border-top: 1px solid rgba(255,255,255,0.18);
}
.hero__stats li { display: flex; flex-direction: column; }
.hero__stats strong { font-family: var(--font-head); font-size: 1.7rem; color: var(--gold-2); line-height: 1; }
.hero__stats span { font-size: 0.82rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.75); margin-top: 6px; }

.hero__scroll {
  display: none;
  position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%);
  width: 26px; height: 42px; border: 2px solid rgba(255,255,255,0.6); border-radius: 16px; z-index: 2;
}
.hero__scroll span { position: absolute; top: 8px; left: 50%; transform: translateX(-50%); width: 4px; height: 8px; background: var(--gold-2); border-radius: 2px; animation: scrollDot 1.6s infinite; }
@keyframes scrollDot { 0% { opacity: 0; top: 8px; } 50% { opacity: 1; } 100% { opacity: 0; top: 24px; } }

/* ---------- About ---------- */
.about { background: var(--cream); }
.about__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.about__media { position: relative; }
.about__media img { border-radius: var(--radius); box-shadow: var(--shadow); aspect-ratio: 4/3.4; object-fit: cover; }
.about__media-badge {
  position: absolute; bottom: -22px; right: -10px;
  background: var(--gold-grad); color: #3a2b06;
  padding: 16px 26px; border-radius: var(--radius-sm);
  box-shadow: var(--shadow); text-align: center;
}
.about__media-badge strong { display: block; font-family: var(--font-head); font-size: 1.5rem; line-height: 1; }
.about__media-badge span { font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; }
.about__text p { color: var(--muted); margin-bottom: 16px; font-size: 1.12rem; line-height: 1.7; }
.about__list { list-style: none; margin: 22px 0 28px; }
.about__list li { position: relative; padding-left: 30px; margin-bottom: 12px; color: var(--green-800); font-weight: 500; }
.about__list li::before {
  content: ""; position: absolute; left: 0; top: 7px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--gold-grad);
  box-shadow: 0 0 0 4px rgba(199,154,69,0.18);
}

/* ---------- Configurations ---------- */
.configs { background: linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%); }
.configs__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; max-width: 940px; margin-inline: auto; }
.config-card {
  position: relative;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
  overflow: hidden;
}
.config-card:hover { transform: translateY(-8px); box-shadow: var(--shadow); }
.config-card--featured { background: var(--green-800); color: #fff; }

.config-card__media {
  position: relative; cursor: zoom-in; background: #f4f1e8;
  border-bottom: 4px solid transparent; border-image: var(--gold-grad) 1;
  aspect-ratio: 16 / 11; overflow: hidden;
}
.config-card__media img { width: 100%; height: 100%; object-fit: contain; padding: 14px; transition: transform 0.5s var(--ease); }
.config-card__media:hover img { transform: scale(1.04); }
.config-card__tag {
  position: absolute; top: 14px; left: 14px;
  font-size: 0.85rem; letter-spacing: 0.1em; text-transform: uppercase;
  font-weight: 700; color: #3a2b06; background: var(--gold-grad);
  padding: 6px 16px; border-radius: 999px; box-shadow: var(--shadow-soft);
}
.config-card__body { padding: 26px 30px 30px; }
.config-card h3 { font-family: var(--font-head); font-size: 2.1rem; color: var(--green-800); margin-bottom: 18px; }
.config-card--featured h3 { color: #fff; }
.config-card__specs {
  list-style: none; display: flex; gap: 10px; margin-bottom: 24px;
}
.config-card__specs li {
  flex: 1; text-align: center; padding: 12px 6px;
  background: var(--cream); border-radius: var(--radius-sm);
}
.config-card--featured .config-card__specs li { background: rgba(255,255,255,0.07); }
.config-card__specs strong { display: block; font-family: var(--font-head); font-size: 1.5rem; color: var(--gold-3); line-height: 1.1; }
.config-card--featured .config-card__specs strong { color: var(--gold-2); }
.config-card__specs span { font-size: 0.82rem; color: var(--muted); }
.config-card--featured .config-card__specs span { color: rgba(255,255,255,0.7); }
.configs__cta { margin-top: 46px; }
.amenities__cta { margin-top: 58px; }
.gallery__cta { margin-top: 48px; }
.faq__cta { margin-top: 42px; }

/* ---------- Amenities ---------- */
.amenities { background: var(--green-800); color: #fff; }
.amenities .section__title { color: #fff; }
.amenities .eyebrow { color: var(--gold-2); }
.amenities .section__sub { color: rgba(255,255,255,0.72); }

.amenity-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
  margin-bottom: 64px;
}
.amenity {
  display: flex; align-items: center; gap: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-sm);
  padding: 18px 22px;
  transition: transform 0.3s var(--ease), background 0.3s, border-color 0.3s;
}
.amenity:hover { transform: translateY(-4px); background: rgba(243,226,168,0.07); border-color: rgba(243,226,168,0.35); }
.amenity img { width: 46px; height: 46px; flex-shrink: 0; filter: drop-shadow(0 2px 6px rgba(0,0,0,0.3)); }
.amenity span { font-weight: 500; font-size: 1.08rem; }

.amenity-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; }
.amenity-block {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius);
  padding: 34px 32px;
}
.amenity-block h3 { font-family: var(--font-head); font-size: 1.7rem; color: var(--gold-2); margin-bottom: 22px; }
.amenity-block ul { list-style: none; columns: 2; column-gap: 26px; }
.amenity-block li { position: relative; padding-left: 22px; margin-bottom: 12px; color: rgba(255,255,255,0.85); break-inside: avoid; font-size: 1.04rem; }
.amenity-block li::before { content: "✦"; position: absolute; left: 0; color: var(--gold-1); font-size: 0.75rem; top: 3px; }
.clubfloor { padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,0.08); }
.clubfloor:last-child { border-bottom: 0; }
.clubfloor h4 { color: var(--gold-2); font-size: 0.82rem; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 6px; }
.clubfloor p { color: rgba(255,255,255,0.82); font-size: 1.04rem; }

/* ---------- Floor Plans ---------- */
.floorplans { background: var(--cream); }
.floorplan-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; margin-bottom: 44px; }
.floorplan {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 18px; box-shadow: var(--shadow-soft); cursor: zoom-in;
  transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
}
.floorplan:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.floorplan img { border-radius: var(--radius-sm); background: #fafafa; }
.floorplan figcaption { margin-top: 14px; text-align: center; font-weight: 600; color: var(--green-700); font-size: 1.08rem; }

/* ---------- Gallery ---------- */
.gallery { background: linear-gradient(180deg, var(--cream-2), var(--cream)); }
.gallery-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 200px; gap: 16px;
}
.g-item {
  overflow: hidden; border-radius: var(--radius-sm); cursor: zoom-in; position: relative;
  box-shadow: var(--shadow-soft);
}
.g-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--ease); }
.g-item::after {
  content: "⤢"; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  background: rgba(12,26,18,0.45); color: var(--gold-2); font-size: 1.6rem;
  opacity: 0; transition: opacity 0.3s;
}
.g-item:hover img { transform: scale(1.08); }
.g-item:hover::after { opacity: 1; }
.g-item:nth-child(1) { grid-column: span 2; grid-row: span 2; }
.g-item:nth-child(6) { grid-column: span 2; }

/* ---------- Location ---------- */
.location { background: var(--cream); }
.conn-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px; margin-bottom: 54px; }
.conn-card {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  background: linear-gradient(170deg, var(--green-700) 0%, var(--green-900) 100%);
  border: 1px solid rgba(243, 226, 168, 0.14);
  border-radius: var(--radius);
  padding: 30px 20px 26px;
  color: #fff;
  transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.35s var(--ease);
  box-shadow: var(--shadow-soft);
}
.conn-card:hover { transform: translateY(-6px); border-color: rgba(243, 226, 168, 0.45); box-shadow: var(--shadow); }
.conn-card img {
  width: 40px; height: 40px; object-fit: contain;
  padding: 17px; box-sizing: content-box;
  background: radial-gradient(circle at 50% 35%, rgba(243,226,168,0.18), rgba(243,226,168,0.05));
  border: 1px solid rgba(243, 226, 168, 0.3);
  border-radius: 50%; margin-bottom: 18px;
}
.conn-card h4 { font-size: 1.14rem; color: var(--gold-2); margin-bottom: 10px; font-family: var(--font-head); font-weight: 600; line-height: 1.2; }
.conn-card p { font-size: 0.98rem; color: rgba(255,255,255,0.72); line-height: 1.55; }

.location__cta {
  display: flex; align-items: center; justify-content: space-between; gap: 30px; flex-wrap: wrap;
  background: var(--gold-grad);
  border-radius: var(--radius);
  padding: 40px 44px;
}
.location__cta h3 { font-family: var(--font-head); font-size: 1.9rem; color: #3a2b06; }
.location__cta p { color: #5b451a; max-width: 560px; margin-top: 8px; }
.location__cta .btn--gold { background: var(--green-800); color: #fff; box-shadow: none; }
.location__cta .btn--gold:hover { background: var(--green-900); }

/* ---------- Video bands (full-screen autoplay Shorts) ---------- */
.videoshow {
  background:
    radial-gradient(95% 55% at 50% -8%, rgba(199,154,69,0.20), transparent 55%),
    linear-gradient(180deg, var(--green-800) 0%, var(--green-900) 72%);
}
.vidbands { display: flex; gap: clamp(14px, 3vw, 40px); }
.vidband {
  position: relative;
  flex: 1 1 0; min-width: 0;
  min-height: 100svh;
  display: flex; align-items: center; justify-content: center;
  background: transparent;
}
.vidband__player {
  position: relative; z-index: 2;
  height: min(92svh, 46vw * 16 / 9);
  aspect-ratio: 9 / 16;
  border-radius: 18px; overflow: hidden; background: #000;
  box-shadow: 0 40px 90px -30px rgba(0,0,0,0.85), 0 0 0 1px rgba(255,255,255,0.08);
}
.vidband__video { width: 100%; height: 100%; object-fit: cover; display: block; }
.vidband__cap {
  position: absolute; top: 0; left: 0; right: 0; z-index: 3;
  padding: 22px 20px 44px; text-align: center; color: #fff; pointer-events: none;
  background: linear-gradient(to bottom, rgba(0,0,0,0.55), transparent);
}
.vidband__cap .eyebrow { margin-bottom: 4px; }
.vidband__title { font-family: var(--font-head); font-weight: 600; font-size: clamp(1.2rem, 2.4vw, 1.7rem); text-shadow: 0 2px 12px rgba(0,0,0,0.55); }

.vidband__bigplay {
  position: absolute; inset: 0; z-index: 4; margin: auto;
  width: 78px; height: 78px; border-radius: 50%;
  display: grid; place-items: center; cursor: pointer; padding-left: 4px;
  background: rgba(0,0,0,0.42); border: 2px solid rgba(255,255,255,0.85); color: #fff;
  transition: transform 0.25s var(--ease), background 0.25s;
}
.vidband__bigplay:hover { transform: scale(1.08); background: rgba(0,0,0,0.6); }
.vidband.is-playing .vidband__bigplay { display: none; }

.vidband__ui {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 5;
  display: flex; flex-direction: column; gap: 10px;
  padding: 46px 14px 14px;
  background: linear-gradient(to top, rgba(0,0,0,0.65), transparent);
  opacity: 0; transition: opacity 0.3s var(--ease);
}
.vidband:hover .vidband__ui, .vidband.show-ui .vidband__ui { opacity: 1; }
.vidband__mute { align-self: flex-end; }
.vidband__bottom { display: flex; align-items: center; gap: 10px; }
.vidband__btn {
  display: grid; place-items: center; flex-shrink: 0;
  width: 40px; height: 40px; border: 0; border-radius: 50%; cursor: pointer;
  background: rgba(255,255,255,0.16); color: #fff;
  transition: background 0.2s, transform 0.2s;
}
.vidband__btn:hover { background: rgba(255,255,255,0.32); transform: scale(1.06); }
.vidband__mute .ic-on, .vidband__play .ic-pause { display: none; }
.vidband__mute[aria-pressed="true"] .ic-on { display: block; }
.vidband__mute[aria-pressed="true"] .ic-off { display: none; }
.vidband.is-playing .vidband__play .ic-pause { display: block; }
.vidband.is-playing .vidband__play .ic-play { display: none; }
.vidband__progress { position: relative; flex: 1; height: 5px; border-radius: 3px; background: rgba(255,255,255,0.28); cursor: pointer; }
.vidband__played { position: absolute; left: 0; top: 0; bottom: 0; width: 0; border-radius: 3px; background: var(--gold-2); }

.vidband-cta { background: transparent; padding: 40px 0 56px; }
.btn--dark { background: var(--green-800); color: #fff; box-shadow: 0 12px 26px -14px rgba(0,0,0,0.6); }
.btn--dark:hover { background: var(--green-900); transform: translateY(-2px); }

/* ---------- Why Invest ---------- */
.invest {
  background:
    linear-gradient(rgba(10,20,14,0.93), rgba(10,20,14,0.95)),
    url("../images/swaminarayan-city-riverfront-bridge-night.webp") center/cover;
  color: #fff;
}
.invest .eyebrow { color: var(--gold-2); }
.invest__sub { color: rgba(255,255,255,0.78); }
.invest-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.invest-card {
  position: relative;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius);
  padding: 30px 28px 28px;
  transition: transform 0.35s var(--ease), border-color 0.35s, background 0.35s;
}
.invest-card:hover { transform: translateY(-6px); border-color: var(--gold-1); background: rgba(243,226,168,0.06); }
.invest-card__time {
  display: inline-block;
  font-family: var(--font-head); font-weight: 700; font-size: 1.5rem;
  color: #3a2b06; background: var(--gold-grad);
  padding: 4px 16px; border-radius: 999px; margin-bottom: 16px;
}
.invest-card h4 { font-size: 1.35rem; color: #fff; margin-bottom: 8px; font-weight: 600; font-family: var(--font-head); }
.invest-card p { color: rgba(255,255,255,0.75); font-size: 1.02rem; line-height: 1.6; }
.invest__cta { margin-top: 46px; }

/* ---------- FAQ ---------- */
.faq { background: var(--cream); }
.faq__inner { max-width: 860px; }
.faq-list { display: flex; flex-direction: column; gap: 12px; }
.faq-item {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius-sm);
  overflow: hidden; transition: box-shadow 0.3s, border-color 0.3s;
}
.faq-item[open] { box-shadow: var(--shadow-soft); border-color: var(--gold-1); }
.faq-item summary {
  list-style: none; cursor: pointer; padding: 22px 26px;
  font-weight: 600; color: var(--green-800); font-size: 1.18rem;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+"; font-size: 1.5rem; color: var(--gold-3); font-weight: 400;
  transition: transform 0.3s var(--ease); line-height: 1;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item p { padding: 0 26px 24px; color: var(--muted); font-size: 1.06rem; line-height: 1.65; }

/* ---------- Contact ---------- */
.contact {
  background:
    linear-gradient(rgba(10,20,14,0.92), rgba(10,20,14,0.94)),
    url("../images/swaminarayan-city-grand-entrance-arrival.webp") center/cover;
  color: #fff;
}
.contact__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
.contact__lead { color: rgba(255,255,255,0.8); margin-bottom: 30px; font-size: 1.08rem; }
.contact__details { list-style: none; display: flex; flex-direction: column; gap: 22px; }
.contact__details li { display: flex; gap: 16px; align-items: flex-start; }
.contact__icon {
  width: 44px; height: 44px; flex-shrink: 0; border-radius: 12px;
  background: rgba(243,226,168,0.12); border: 1px solid rgba(243,226,168,0.3);
  display: grid; place-items: center; font-size: 1.1rem;
}
.contact__details strong { display: block; color: var(--gold-2); font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 3px; }
.contact__details div { color: rgba(255,255,255,0.88); }
.contact__details a:hover { color: var(--gold-2); }

.contact__form {
  background: #fff; color: var(--ink);
  border-radius: var(--radius); padding: 40px 38px;
  box-shadow: var(--shadow);
}
.contact__form h3 { font-family: var(--font-head); font-size: 1.8rem; color: var(--green-800); margin-bottom: 22px; }
.field { margin-bottom: 16px; }
.contact__form input, .contact__form select, .contact__form textarea,
.modal__form input, .modal__form select {
  width: 100%; padding: 14px 18px;
  border: 1.5px solid var(--line); border-radius: var(--radius-sm);
  font-family: var(--font-body); font-size: 1rem; color: var(--ink);
  background: var(--cream); transition: border-color 0.25s, box-shadow 0.25s;
}
.contact__form input:focus, .contact__form select:focus, .contact__form textarea:focus,
.modal__form input:focus, .modal__form select:focus {
  outline: none; border-color: var(--gold-1); box-shadow: 0 0 0 3px rgba(199,154,69,0.18); background: #fff;
}
.form-note { color: var(--green-600); font-weight: 600; margin-top: 14px; text-align: center; }
.form-fineprint { font-size: 0.78rem; color: var(--muted); margin-top: 14px; text-align: center; }

/* ---------- Footer ---------- */
.footer { background: var(--green-900); color: rgba(255,255,255,0.7); padding-top: 70px; }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 50px; }
.footer__brand img { height: 40px; margin-bottom: 18px; }
.footer__brand p { font-size: 0.95rem; line-height: 1.7; }
.footer__rera { display: inline-block; margin-top: 16px; color: var(--gold-2); font-size: 0.82rem; letter-spacing: 0.08em; }
.footer__socials { margin-top: 22px; }
.footer__socials-label { display: block; font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.45); margin-bottom: 9px; }
.footer__social { display: inline-flex; align-items: center; gap: 9px; color: rgba(255,255,255,0.82); font-size: 0.92rem; transition: color 0.25s, transform 0.25s; }
.footer__social svg { flex-shrink: 0; }
.footer__social:hover { color: var(--gold-2); transform: translateY(-1px); }
.footer__col h4 { color: #fff; font-family: var(--font-head); font-size: 1.2rem; margin-bottom: 18px; }
.footer__col a { display: block; padding: 6px 0; font-size: 0.95rem; transition: color 0.25s, padding-left 0.25s; }
.footer__col a:hover { color: var(--gold-2); padding-left: 6px; }
.footer__addr { font-size: 0.92rem; margin-top: 10px; }
.footer__bar { border-top: 1px solid rgba(255,255,255,0.1); padding: 22px 0; font-size: 0.85rem; }
.footer__bar-inner { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.footer__legal a:hover { color: var(--gold-2); }
.footer__disclaimer { font-size: 0.76rem; color: rgba(255,255,255,0.4); padding-bottom: 30px; line-height: 1.6; }

/* ---------- Floating ---------- */
.float {
  position: fixed; z-index: 90; right: 22px; bottom: 22px;
  width: 56px; height: 56px; border-radius: 50%;
  display: grid; place-items: center; color: #fff;
  box-shadow: 0 10px 26px -8px rgba(0,0,0,0.5);
  transition: transform 0.3s var(--ease);
}
.float:hover { transform: scale(1.08); }
.float--wa { background: #25d366; animation: pulse 2.4s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(37,211,102,0.5); } 70% { box-shadow: 0 0 0 16px rgba(37,211,102,0); } 100% { box-shadow: 0 0 0 0 rgba(37,211,102,0); } }

/* ---------- Mobile sticky CTA bar (Call · WhatsApp · Enquire) ---------- */
.mobile-cta {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 95;
  display: none;                         /* shown only on mobile (see media query) */
  grid-template-columns: 1fr 1fr 1.2fr;
  gap: 1px;
  background: rgba(255,255,255,0.14);
  box-shadow: 0 -10px 26px -12px rgba(0,0,0,0.55);
  transform: translateY(110%);
  transition: transform 0.35s var(--ease);
  padding-bottom: env(safe-area-inset-bottom);
}
.mobile-cta.show { transform: translateY(0); }
.mcta {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px;
  padding: 11px 6px 12px; border: 0; cursor: pointer; text-decoration: none;
  font-family: var(--font-body); font-weight: 600; font-size: 0.72rem; letter-spacing: 0.02em;
  color: #fff;
}
.mcta svg { display: block; }
.mcta--call { background: var(--green-800); }
.mcta--wa { background: #25d366; }
.mcta--enquire { background: var(--gold-grad); color: #3a2b06; }
.mcta--enquire:active, .mcta--wa:active, .mcta--call:active { filter: brightness(0.94); }

/* ---------- Modal ---------- */
.modal { position: fixed; inset: 0; z-index: 200; display: none; align-items: center; justify-content: center; padding: 20px; }
.modal.open { display: flex; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(8,16,11,0.7); backdrop-filter: blur(4px); animation: fade 0.3s; }
.modal__dialog {
  position: relative; background: var(--cream); border-radius: var(--radius);
  width: min(440px, 100%); padding: 38px 36px; box-shadow: var(--shadow);
  animation: pop 0.35s var(--ease);
  border-top: 5px solid transparent; border-image: var(--gold-grad) 1;
}
@keyframes fade { from { opacity: 0; } }
@keyframes pop { from { opacity: 0; transform: translateY(20px) scale(0.97); } }
.modal__close {
  position: absolute; top: 14px; right: 16px; background: transparent; border: 0;
  font-size: 1.8rem; line-height: 1; color: var(--muted); cursor: pointer;
}
.modal__close:hover { color: var(--green-800); }
.modal__head { text-align: center; margin-bottom: 22px; }
.modal__head img { height: 38px; margin: 0 auto 14px; }
.modal__head h3 { font-family: var(--font-head); font-size: 1.7rem; color: var(--green-800); }
.modal__head p { color: var(--muted); font-size: 0.95rem; margin-top: 6px; }
.modal__form { display: flex; flex-direction: column; gap: 14px; }

/* ---------- Lightbox ---------- */
.lightbox { position: fixed; inset: 0; z-index: 300; display: none; align-items: center; justify-content: center; background: rgba(6,12,8,0.94); padding: 30px; }
.lightbox.open { display: flex; animation: fade 0.3s; }
.lightbox img { max-width: 92vw; max-height: 86vh; border-radius: 8px; box-shadow: 0 20px 60px rgba(0,0,0,0.6); }
.lightbox__close, .lightbox__nav {
  position: absolute; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.25);
  color: #fff; cursor: pointer; border-radius: 50%;
  width: 52px; height: 52px; font-size: 1.8rem; display: grid; place-items: center;
  transition: background 0.25s;
}
.lightbox__close:hover, .lightbox__nav:hover { background: rgba(243,226,168,0.3); }
.lightbox__close { top: 24px; right: 24px; }
.lightbox__nav--prev { left: 24px; top: 50%; transform: translateY(-50%); }
.lightbox__nav--next { right: 24px; top: 50%; transform: translateY(-50%); }

/* ---------- Reveal animation ---------- */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
/* Subtle column-wise stagger so grid items cascade in (capped, no perf cost). */
.amenity-grid .amenity:nth-child(3n+2), .invest-grid .invest-card:nth-child(3n+2) { transition-delay: 0.07s; }
.amenity-grid .amenity:nth-child(3n),   .invest-grid .invest-card:nth-child(3n)   { transition-delay: 0.14s; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1024px) {
  .amenity-grid { grid-template-columns: repeat(2, 1fr); }
  .conn-grid { grid-template-columns: repeat(3, 1fr); }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .gallery-grid { grid-template-columns: repeat(3, 1fr); }
  .invest-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 860px) {
  .section { padding: 68px 0; }
  .about__grid, .configs__grid, .amenity-detail, .contact__grid { grid-template-columns: 1fr; }
  .about__grid { gap: 50px; }
  .about__media-badge { right: 16px; }

  /* Video bands: stack full-screen on mobile (one per screen); player uses more width; pad bottom so the sticky CTA bar never covers the controls. */
  .vidbands { display: block; }
  .vidband { padding-bottom: 64px; }
  .vidband__player { height: min(82svh, 94vw * 16 / 9); }

  /* Mobile sticky CTA bar replaces the round WhatsApp bubble */
  .mobile-cta { display: grid; }
  .float--wa { display: none; }

  /* Disable backdrop-filter on mobile so the fixed nav drawer is positioned
     relative to the viewport (filters create a containing block otherwise). */
  .header, .header.scrolled { backdrop-filter: none; -webkit-backdrop-filter: none; }

  /* Mobile nav */
  .nav {
    position: fixed; top: 0; right: 0; bottom: 0; left: auto;
    width: min(82%, 340px); max-width: 100vw;
    flex-direction: column; align-items: flex-start; justify-content: flex-start;
    gap: 4px; background: var(--cream); padding: 100px 30px 40px;
    transform: translateX(100%); transition: transform 0.4s var(--ease), visibility 0.4s;
    box-shadow: var(--shadow); z-index: 99;
    visibility: hidden; overflow-y: auto;
  }
  .nav.open { transform: translateX(0); visibility: visible; }

  .nav__close {
    display: grid; place-items: center;
    position: absolute; top: 16px; right: 18px;
    width: 42px; height: 42px; border-radius: 50%;
    background: var(--green-800); color: #fff; border: 0;
    font-size: 1.8rem; line-height: 1; cursor: pointer;
    transition: background 0.25s, transform 0.25s;
  }
  .nav__close:hover { background: var(--green-900); transform: rotate(90deg); }

  .nav-backdrop {
    display: block; position: fixed; inset: 0; z-index: 98;
    background: rgba(8, 16, 11, 0.55); backdrop-filter: blur(2px);
    opacity: 0; visibility: hidden; transition: opacity 0.4s var(--ease), visibility 0.4s;
  }
  .nav-backdrop.open { opacity: 1; visibility: visible; }

  .nav__link { font-size: 1.1rem; padding: 12px 0; width: 100%; border-bottom: 1px solid var(--line); }
  .nav__link--mobile-cta { display: block; }
  .nav-toggle { display: flex; }
  .btn--phone span { display: none; }
  .header__inner { gap: 10px; }
  .header__actions { gap: 8px; }
  .brand__sub { display: none; }
}

@media (max-width: 480px) {
  .header__actions .btn--gold { display: none; }
  .brand__logo { height: 40px; }
}

@media (max-width: 600px) {
  .topbar__contact a:last-child { display: none; }
  .topbar__sep { display: none; }
  .hero__content { padding: 24px 0 48px; }
  .hero__title { font-size: clamp(1.8rem, 7vw, 2.4rem); }
  .hero__lead { font-size: 1.05rem; }
  .hero__stats { gap: 16px 26px; margin-top: 28px; padding-top: 22px; }
  .hero__stats strong { font-size: 1.4rem; }
  .amenity-grid { grid-template-columns: 1fr; }
  .amenity-block ul { columns: 1; }
  .conn-grid { grid-template-columns: 1fr 1fr; }
  .invest-grid { grid-template-columns: 1fr; }
  .invest, .contact { background-attachment: scroll; }
  .gallery-grid { grid-template-columns: 1fr; grid-auto-rows: clamp(200px, 56vw, 280px); }
  .g-item:nth-child(1), .g-item:nth-child(6) { grid-column: auto; grid-row: auto; }
  .floorplan-grid { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .location__cta { padding: 30px 24px; text-align: center; justify-content: center; }
  .location__cta .btn { width: 100%; }
  .conn-grid { gap: 14px; }
  .contact__form, .modal__dialog { padding: 28px 24px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
}


/* ============================================================
   Vikas Ritz, additions (brand wordmark, RERA block, market, galleria)
   ============================================================ */

/* Text wordmark brand (no logo image) */
.brand__wordmark { display:flex; flex-direction:column; line-height:1; }
.brand__name {
  font-family: var(--font-head); font-size: 1.5rem; letter-spacing:0.16em;
  color: var(--green-800); text-transform:uppercase;
}
.brand__name b { color: var(--gold-3); font-weight:inherit; }
.brand__loc {
  font-size: 0.62rem; letter-spacing:0.34em; text-transform:uppercase;
  color: var(--muted); margin-top:5px;
}
.header.scrolled .brand__name { color: var(--green-900); }

/* Soft "on request" pill used wherever a price/area is pending client confirmation */
.pill-soft {
  display:inline-block; font-size:0.78rem; letter-spacing:0.06em;
  color: var(--gold-3); background: rgba(198,160,82,0.12);
  border:1px solid rgba(198,160,82,0.35); border-radius:999px; padding:3px 12px;
}

/* RERA / legal block */
.rera { background: var(--green-900); color:#fff; }
.rera .section__title { color:#fff; }
.rera .eyebrow { color: var(--gold-2); }
.rera .section__sub { color: rgba(255,255,255,0.72); }
.rera-grid { display:grid; grid-template-columns: repeat(5,1fr); gap:16px; margin-bottom:30px; }
.rera-card {
  background: rgba(255,255,255,0.04); border:1px solid rgba(243,221,166,0.18);
  border-radius: var(--radius-sm); padding:22px 16px; text-align:center;
  transition: transform .3s var(--ease), border-color .3s;
}
.rera-card:hover { transform: translateY(-4px); border-color: rgba(243,221,166,0.45); }
.rera-card__tower {
  font-family: var(--font-head); font-size:1.12rem; color: var(--gold-2); margin-bottom:4px;
}
.rera-card__type { font-size:0.7rem; letter-spacing:0.14em; text-transform:uppercase; color: rgba(255,255,255,0.5); margin-bottom:14px; display:block; }
.rera-card__qr { width:96px; height:96px; margin:0 auto 14px; background:#fff; border-radius:8px; padding:7px; }
.rera-card__qr img { width:100%; height:100%; object-fit:contain; }
.rera-card__label { font-size:0.66rem; letter-spacing:0.12em; text-transform:uppercase; color: rgba(255,255,255,0.5); }
.rera-card__no { font-size:0.95rem; font-weight:600; color:#fff; letter-spacing:0.02em; word-break:break-all; }
.rera-foot {
  display:flex; gap:18px; align-items:center; justify-content:space-between; flex-wrap:wrap;
  background: rgba(255,255,255,0.04); border:1px solid rgba(243,221,166,0.18);
  border-radius: var(--radius-sm); padding:18px 24px;
}
.rera-foot p { font-size:0.92rem; color: rgba(255,255,255,0.7); margin:0; }
.rera-foot a.btn { flex-shrink:0; }

/* Market / why-Kalyan figures band */
.statband { display:grid; grid-template-columns: repeat(4,1fr); gap:18px; margin-top:8px; }
.stat {
  background: rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius); padding:26px 22px; text-align:center;
}
.stat strong { display:block; font-family: var(--font-head); font-size:1.9rem; color: var(--gold-2); line-height:1.1; }
.stat span { display:block; font-size:0.92rem; color: rgba(255,255,255,0.72); margin-top:8px; }

/* Galleria (commercial) light mention strip */
.galleria { background: var(--cream); }
.galleria__inner {
  display:grid; grid-template-columns: 1.1fr 1fr; gap:44px; align-items:center;
  background:#fff; border:1px solid var(--line); border-radius: var(--radius);
  overflow:hidden; box-shadow: var(--shadow-soft);
}
.galleria__media img { width:100%; height:100%; object-fit:cover; min-height:260px; }
.galleria__body { padding:40px 40px 40px 4px; }
.galleria__body h3 { font-family: var(--font-head); font-size:1.8rem; color: var(--green-800); margin-bottom:12px; }
.galleria__body p { color: var(--muted); margin-bottom:18px; font-size:1.06rem; }
@media (max-width:860px){
  .rera-grid { grid-template-columns: repeat(2,1fr); }
  .statband { grid-template-columns: repeat(2,1fr); }
  .galleria__inner { grid-template-columns:1fr; }
  .galleria__body { padding:30px 26px; }
}
@media (max-width:480px){ .rera-grid { grid-template-columns:1fr; } }


/* === SPOKE PAGES === */
.page-hero{position:relative;overflow:hidden;color:#fff;padding:74px 0 60px;background:var(--green-900)}
.page-hero::before{content:"";position:absolute;inset:0;z-index:0;background-image:var(--ph,linear-gradient(160deg,var(--green-700),var(--green-900)));background-size:cover;background-position:center;transform-origin:50% 50%;animation:pageKen 22s ease-in-out infinite alternate;will-change:transform}
.page-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(7,12,22,.9) 0%,rgba(7,12,22,.66) 42%,rgba(7,12,22,.4) 72%,rgba(7,12,22,.28) 100%)}
.page-hero .container{position:relative;z-index:2;max-width:900px}
.page-hero .breadcrumb{font-size:.85rem;color:rgba(255,255,255,.72);margin-bottom:16px;letter-spacing:.02em}
.page-hero .breadcrumb a:hover{color:var(--gold-2)}
.page-hero h1{font-family:var(--font-head);font-weight:600;font-size:clamp(1.95rem,4.4vw,3rem);line-height:1.12;color:#fff}
.page-hero p.sub{margin-top:16px;font-size:1.14rem;color:rgba(255,255,255,.86);max-width:680px}
.rich{max-width:880px}
.rich>p,.rich>ul,.rich>ol{color:var(--ink);font-size:1.08rem;line-height:1.75;margin-bottom:18px}
.rich h2{font-family:var(--font-head);font-size:1.7rem;color:var(--green-800);margin:36px 0 12px}
.rich h3{font-family:var(--font-head);font-size:1.25rem;color:var(--green-700);margin:24px 0 8px}
.rich ul,.rich ol{padding-left:22px}.rich li{margin-bottom:9px;line-height:1.7}
.rich strong{color:var(--green-800)}
.rich a{color:var(--gold-3);text-decoration:underline;text-underline-offset:3px}
.costsheet{width:100%;border-collapse:collapse;margin:6px 0 22px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.costsheet th,.costsheet td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--line);font-size:1rem;vertical-align:top}
.costsheet th{background:var(--cream-2);color:var(--green-800);font-weight:600;width:38%}
.costsheet tr:last-child td,.costsheet tr:last-child th{border-bottom:0}
.cta-band{background:var(--green-900);color:#fff;border-radius:var(--radius);padding:34px 36px;text-align:center;margin-top:30px;max-width:880px}
.cta-band h3{font-family:var(--font-head);font-size:1.55rem;color:var(--gold-2);margin-bottom:8px}
.cta-band p{color:rgba(255,255,255,.82);margin-bottom:20px}
.mapwrap{margin:8px 0 20px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--line);line-height:0}
.mapwrap iframe{width:100%;height:340px;border:0}
.explore{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.explore-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.explore-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:20px 22px;box-shadow:var(--shadow-soft);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.explore-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold-1)}
.explore-card h4{font-family:var(--font-head);color:var(--green-800);font-size:1.12rem;margin-bottom:4px}
.explore-card span{color:var(--muted);font-size:.9rem}
@media(max-width:760px){.explore-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.explore-grid{grid-template-columns:1fr}}


/* === MEDIA PAGES === */
.vr-gal{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.vr-gal h2{grid-column:1/-1;font-family:var(--font-head);color:var(--green-800);font-size:1.35rem;margin:18px 0 0}
.vr-gal figure{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-soft);cursor:zoom-in;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.vr-gal figure:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.vr-gal img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.vr-gal figcaption{padding:12px 14px;font-size:.92rem;color:var(--muted)}
.vt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px}
.vt{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-soft)}
.vt__media{position:relative;aspect-ratio:9/16;background:#000}
.vt__media img,.vt__media video{width:100%;height:100%;object-fit:cover;display:block}
.vt__play{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;border:2px solid #fff;background:rgba(0,0,0,.42);color:#fff;font-size:1.4rem;cursor:pointer;display:grid;place-items:center;padding-left:4px;transition:transform .2s,background .2s}
.vt__play:hover{transform:scale(1.08);background:rgba(0,0,0,.62)}
.vt figcaption{padding:16px 16px 18px}
.vt figcaption h3{font-family:var(--font-head);color:var(--green-800);font-size:1.12rem;margin-bottom:6px}
.vt figcaption p{color:var(--muted);font-size:.93rem;line-height:1.55}
@media(max-width:760px){.vr-gal{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.vr-gal{grid-template-columns:1fr}}

/* spoke hero animation + mobile topbar fix */
@keyframes pageKen{from{transform:scale(1)}to{transform:scale(1.08)}}
@media (prefers-reduced-motion: reduce){.page-hero::before{animation:none}}
@media (max-width:600px){.topbar{overflow:hidden}.topbar__inner{gap:8px}.topbar__rera{white-space:nowrap;font-size:0.64rem;letter-spacing:0}.topbar__contact a{white-space:nowrap;font-size:0.72rem}}

/* Full-screen hero: cover slideshow + overlaid text on every viewport */
.hero__banner{display:none}
@media (min-width:861px){
  .hero__content{max-width:600px; padding:24px 0}
  .hero__lead{max-width:480px}
  .hero__stats{display:flex; gap:18px 48px}
  .hero__scroll{display:block}
}


/* ============================================================
   Swaminarayan City, IDENTITY LAYER
   (distinct from Vikas/Nivasa: Cormorant display, riverside
   teal+sand-gold, softer shapes, river-wave motif)
   ============================================================ */

/* Cormorant runs smaller & lighter than Marcellus, scale display type up and tune */
.section__title { font-size: clamp(2.2rem, 4.6vw, 3.6rem); letter-spacing: 0; line-height: 1.05; }
.hero__title    { font-size: clamp(2.4rem, 5vw, 4.05rem); letter-spacing: 0; line-height: 1.03; }
.page-hero h1   { font-size: clamp(2.25rem, 4.9vw, 3.4rem); letter-spacing: 0; line-height: 1.05; }
.config-card h3 { font-size: 2.45rem; line-height: 1; }
.amenity-block h3, .galleria__body h3, .location__cta h3, .cta-band h3 { font-size: 1.95rem; }
.contact__form h3, .modal__head h3 { font-size: 2.05rem; }
.rich h2 { font-size: 2rem; } .rich h3 { font-size: 1.5rem; }
.footer__col h4 { font-size: 1.4rem; }
.faq-item summary { font-size: 1.2rem; }
.section__sub { font-size: 1.16rem; }

/* Softer, rounder buttons (Vikas used squared) */
.btn { border-radius: 9px; letter-spacing: 0.03em; }
.btn--phone { border-radius: 9px; }

/* Brand wordmark tuned for Cormorant */
.brand__name { font-size: 1.72rem; letter-spacing: 0.12em; font-weight: 600; }
.brand__loc  { letter-spacing: 0.3em; }

/* Hero eyebrow: calmer, less pill-heavy */
.hero__eyebrow { border-radius: 6px; letter-spacing: 0.26em; }

/* ---- River-wave divider (signature motif) ---- */
.riverline {
  height: 26px; width: 230px; margin: 0 auto;
  background: center/contain no-repeat
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='230' height='26' viewBox='0 0 230 26'%3E%3Cpath d='M5 13h70' stroke='%23c9a25e' stroke-width='1.4' stroke-linecap='round'/%3E%3Cpath d='M225 13h-70' stroke='%23c9a25e' stroke-width='1.4' stroke-linecap='round'/%3E%3Cpath d='M88 13c3-7 7-7 9 0s7 7 9 0 7-7 9 0 7 7 9 0 7-7 9 0 7 7 9 0' fill='none' stroke='%23c9a25e' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");
  opacity: 0.92;
}
.riverline--light {
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='230' height='26' viewBox='0 0 230 26'%3E%3Cpath d='M5 13h70' stroke='%23e7cd97' stroke-width='1.4' stroke-linecap='round'/%3E%3Cpath d='M225 13h-70' stroke='%23e7cd97' stroke-width='1.4' stroke-linecap='round'/%3E%3Cpath d='M88 13c3-7 7-7 9 0s7 7 9 0 7-7 9 0 7 7 9 0 7-7 9 0 7 7 9 0' fill='none' stroke='%23e7cd97' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");
}
.section__head.center .riverline { margin-top: 18px; }

/* ---- Township "at a glance" numbers band ---- */
.tband { background: linear-gradient(165deg, var(--green-700) 0%, var(--green-900) 100%); color:#fff; }
.tband__grid { display:grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.tnum {
  text-align:center; padding: 20px 14px;
  border:1px solid rgba(231,205,151,0.18); border-radius: var(--radius);
  background: rgba(255,255,255,0.03);
  transition: transform .35s var(--ease), border-color .35s, background .35s;
}
.tnum:hover { transform: translateY(-5px); border-color: rgba(231,205,151,0.45); background: rgba(231,205,151,0.06); }
.tnum strong { display:block; font-family: var(--font-head); font-size: 3rem; line-height:1; color: var(--gold-2); }
.tnum span { display:block; margin-top: 10px; font-size: 0.86rem; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.74); }

/* ---- Township USP pillars (riverside highlights) ---- */
.pillars { display:grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.pillar {
  background:#fff; border:1px solid var(--line); border-radius: var(--radius);
  padding: 30px 28px; box-shadow: var(--shadow-soft);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s;
}
.pillar:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: var(--gold-1); }
.pillar__ic {
  width: 52px; height: 52px; border-radius: 14px; display:grid; place-items:center; margin-bottom: 18px;
  background: radial-gradient(circle at 40% 30%, rgba(201,162,94,0.22), rgba(201,162,94,0.08));
  border: 1px solid rgba(201,162,94,0.4); font-size: 1.5rem;
}
.pillar h3 { font-family: var(--font-head); font-size: 1.6rem; color: var(--green-800); margin-bottom: 8px; line-height:1.1; }
.pillar p { color: var(--muted); font-size: 1.02rem; line-height: 1.6; }

/* ---- Split feature (image + copy) reused for "about township" ---- */
.about__media img { aspect-ratio: 4/3.2; }
.about__media-badge { background: var(--gold-grad); }

/* Section eyebrow gets a leading wave glyph */
.eyebrow::before {
  content:""; display:inline-block; width:18px; height:8px; margin-right:9px; vertical-align: middle;
  background: center/contain no-repeat
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='8' viewBox='0 0 18 8'%3E%3Cpath d='M1 4c2-4 4-4 5 0s4 4 5 0 4-4 5 0' fill='none' stroke='%239c7531' stroke-width='1.4' stroke-linecap='round'/%3E%3C/svg%3E");
}
.eyebrow--light::before, .amenities .eyebrow::before, .tband .eyebrow::before, .rera .eyebrow::before, .invest .eyebrow::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='8' viewBox='0 0 18 8'%3E%3Cpath d='M1 4c2-4 4-4 5 0s4 4 5 0 4-4 5 0' fill='none' stroke='%23e7cd97' stroke-width='1.4' stroke-linecap='round'/%3E%3C/svg%3E");
}

/* gallery first-tile bias tuned for riverside aerial */
.g-item:nth-child(1) { grid-column: span 2; grid-row: span 2; }

@media (max-width: 860px){
  .tband__grid { grid-template-columns: repeat(2,1fr); }
  .pillars { grid-template-columns: 1fr; }
  .config-card h3 { font-size: 2.2rem; }
}
@media (max-width: 480px){
  .tnum strong { font-size: 2.4rem; }
}

/* ---- Landscape video feature (sample-flat walkthroughs, native controls) ---- */
.vfeat { background: linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%); }
.vfeat-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.vcard { background:#fff; border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-soft); }
.vcard__media { position:relative; aspect-ratio:16/9; background:#06181c; }
.vcard__media video { width:100%; height:100%; object-fit:cover; display:block; }
.vcard__body { padding:20px 24px 24px; }
.vcard__body h3 { font-family:var(--font-head); font-size:1.6rem; color:var(--green-800); margin-bottom:4px; }
.vcard__body p { color:var(--muted); font-size:0.98rem; }
@media (max-width:760px){ .vfeat-grid { grid-template-columns:1fr; } }

/* ---- inline-SVG icons inside circular/rounded frames ---- */
.pillar__ic svg, .conn-card__ic svg, .amenity__ic svg { width:24px; height:24px; stroke:var(--gold-2); fill:none; }
.pillar__ic svg { stroke: var(--gold-3); }
.conn-card__ic {
  width:40px; height:40px; display:grid; place-items:center; padding:17px; box-sizing:content-box;
  background: radial-gradient(circle at 50% 35%, rgba(231,205,151,0.18), rgba(231,205,151,0.05));
  border:1px solid rgba(231,205,151,0.3); border-radius:50%; margin-bottom:18px;
}
.amenity__ic {
  width:46px; height:46px; flex-shrink:0; display:grid; place-items:center; border-radius:12px;
  background: rgba(231,205,151,0.1); border:1px solid rgba(231,205,151,0.28);
}
.amenity__ic svg { width:22px; height:22px; stroke: var(--gold-2); fill:none; }

/* ---- amenities featured image ---- */
.amenities__feature { margin-bottom: 54px; border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow); position:relative; }
.amenities__feature img { width:100%; aspect-ratio: 21/9; object-fit:cover; }

/* RERA grid for 4 phases */
.rera-grid { grid-template-columns: repeat(4,1fr); }
@media (max-width:860px){ .rera-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width:480px){ .rera-grid { grid-template-columns:1fr; } }

/* ---- Mobile display-type fix (identity layer defeated the base mobile sizes) ---- */
@media (max-width: 600px) {
  .hero__title { font-size: clamp(1.75rem, 6.6vw, 2.35rem); line-height: 1.08; }
  .section__title { font-size: clamp(1.7rem, 6.4vw, 2.3rem); }
  .page-hero h1 { font-size: clamp(1.7rem, 6.2vw, 2.3rem); }
  .tnum strong { font-size: 2.3rem; }
  .config-card h3 { font-size: 2rem; }
}
@media (max-width: 360px) {
  .hero__title { font-size: 1.6rem; }
}

/* ============================================================
   v2, warmth, logo lockup, contrast (home-buyer refinement)
   ============================================================ */

/* ---- Brand: real logo lockup (mark + wordmark) ---- */
.brand { gap: 12px; }
.brand__mark {
  width: 46px; height: 46px; flex-shrink: 0; display: block;
  border-radius: 11px; box-shadow: 0 6px 16px -8px rgba(6,30,26,0.5);
}
.brand__name { font-size: 1.5rem; letter-spacing: 0.1em; line-height: 1.05; color: var(--green-800); }
.header.scrolled .brand__name { color: var(--green-900); }
.brand__loc {
  font-size: 0.6rem; letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--gold-3); font-weight: 600; margin-top: 5px;
}
@media (max-width: 480px){ .brand__mark { width: 40px; height: 40px; } .brand__name { font-size: 1.32rem; } }

/* ---- Warm glow on the large light sections (kills the flat/dull feel) ---- */
.about, .faq, .location, .configs {
  background-image: radial-gradient(120% 70% at 50% -10%, rgba(194,147,63,0.07), transparent 58%);
  background-color: var(--cream);
}
.configs { background-image: radial-gradient(120% 70% at 50% -10%, rgba(194,147,63,0.08), transparent 58%), linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%); }
body { background: linear-gradient(180deg, #f7f1e5 0%, #f3ecdc 100%); }

/* ---- Stronger hero scrim (mobile slideshow): legible text, stats & buttons ---- */
.hero__scrim {
  background:
    linear-gradient(95deg, rgba(6,30,26,0.95) 0%, rgba(6,30,26,0.82) 36%, rgba(6,30,26,0.5) 64%, rgba(6,30,26,0.18) 100%),
    linear-gradient(to top, rgba(6,30,26,0.88) 0%, rgba(6,30,26,0.32) 36%, rgba(6,30,26,0) 62%);
}
.hero__lead { color: rgba(255,255,255,0.95); }

/* ---- Topbar: short label on mobile so the RERA list never overflows ---- */
.topbar__rera .t-short { display: none; }
@media (max-width: 720px){
  .topbar__rera .t-full { display: none; }
  .topbar__rera .t-short { display: inline; }
}

/* ---- Warmer header tint ---- */
.header { background: rgba(247, 241, 229, 0.86); }
.header.scrolled { background: rgba(247, 241, 229, 0.97); border-bottom: 2px solid var(--gold-1); }

/* ---- Mobile hero CTA + eyebrow fit ---- */
@media (max-width: 600px){
  .hero__cta { flex-direction: column; align-items: stretch; }
  .hero__cta .btn { width: 100%; }
  .hero__eyebrow { letter-spacing: 0.14em; font-size: 0.72rem; padding: 7px 14px; }
}

/* ============================================================
   Mobile-first audit fixes
   (responsive grids, tap targets, focus, contrast,
   sticky-bar clearance, call button). Source-last so these
   win over the base + identity + v2 layers above.
   ============================================================ */

/* 1. Residence config cards: intrinsically responsive, up to 3-up
   on desktop, 2-up on tablet, exactly 1-up on phones. Replaces the
   deleted inline grid-template-columns override (no fragile breakpoints). */
.configs__grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  max-width: 940px;
}

/* 2. Sample-flat video cards: up to 3-up on desktop, single full-width
   column on phones so native video controls and captions stay usable.
   Replaces the deleted inline override on /video-tour/. */
.vfeat-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
}
@media (max-width: 760px) {
  .vfeat-grid { grid-template-columns: 1fr; }
}

/* 3. Connectivity cards carry real copy (not stat pairs): comfortable
   2-up on small tablets, single column on phones. */
@media (max-width: 480px) {
  .conn-grid { grid-template-columns: 1fr; }
}

/* 4. Header call button: keep a phone icon visible after the number
   text is hidden on mobile, sized as a proper 44px tap target so it
   is never an empty pill. */
.btn--phone { gap: 8px; }
.btn--phone .btn__ic { width: 18px; height: 18px; flex-shrink: 0; }
@media (max-width: 860px) {
  .btn--phone {
    width: 44px; height: 44px; min-height: 44px;
    padding: 0; justify-content: center;
  }
  .btn--phone .btn__ic { width: 20px; height: 20px; }
}

/* 5. Footer links: 44px touch targets, plus a little legal-link spacing. */
.footer__col a { padding: 11px 0; }
.footer__legal a { display: inline-block; padding: 6px 8px; }

/* 6. Disclaimer contrast on the dark footer (was 0.40, now AA-friendlier). */
.footer__disclaimer { color: rgba(255, 255, 255, 0.62); }

/* 7. Clear the fixed mobile CTA bar so it never covers footer copy. */
@media (max-width: 860px) {
  .footer { padding-bottom: calc(76px + env(safe-area-inset-bottom)); }
}

/* 8. Enquiry-modal close control: explicit 44x44 hit box, centered glyph. */
.modal__close {
  top: 10px; right: 12px;
  width: 44px; height: 44px;
  display: grid; place-items: center;
}

/* 9. Consistent, high-contrast keyboard focus ring on interactive elements. */
.btn:focus-visible,
.nav__link:focus-visible,
.footer__col a:focus-visible,
.footer__legal a:focus-visible,
.footer__social:focus-visible,
.topbar__contact a:focus-visible,
.explore-card:focus-visible,
.rich a:focus-visible,
.faq-item summary:focus-visible {
  outline: 3px solid var(--gold-1);
  outline-offset: 2px;
  border-radius: 5px;
}

/* 10. Cost-sheet table: roomier on the narrowest phones. */
@media (max-width: 480px) {
  .costsheet th { width: 42%; }
  .costsheet th, .costsheet td { padding: 10px 12px; font-size: 0.95rem; }
}

/* ============================================================
   v3: editorial modernization (de-template the desktop layout)
   ============================================================ */

/* 1) Drop the centered "eyebrow + title + wavy divider" template pattern */
.riverline { display: none !important; }
.section { padding: 110px 0; }
.section__head, .section__head.center {
  text-align: left; margin-inline: 0; max-width: 880px; margin-bottom: 58px;
}
.section__head .section__sub, .section__sub { margin-left: 0; margin-right: 0; }
.section__title { font-size: clamp(2.45rem, 4.6vw, 4.05rem); line-height: 1.0; letter-spacing: -0.012em; }
.eyebrow { margin-bottom: 20px; }
.section__sub { max-width: 660px; margin-top: 18px; }

/* Editorial 2-column header on wide screens: big title left, supporting line right */
@media (min-width: 980px) {
  .section__head { display: grid; grid-template-columns: 1.5fr 1fr; column-gap: 56px; align-items: end; max-width: none; }
  .section__head .eyebrow { grid-column: 1; margin-bottom: 16px; }
  .section__head .section__title { grid-column: 1; }
  .section__head .section__sub { grid-column: 2; align-self: end; margin: 0 0 8px; }
}

/* 2) Township numbers: editorial ledger row, not 4 boxes */
.tband { padding: 92px 0; }
.tband__grid { grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(237,202,132,0.24); }
.tnum {
  border: 0; border-right: 1px solid rgba(237,202,132,0.16); border-radius: 0;
  background: transparent; text-align: left; padding: 36px 30px 6px;
}
.tnum:last-child { border-right: 0; }
.tnum:hover { transform: none; background: transparent; border-color: rgba(237,202,132,0.16); }
.tnum strong { font-size: clamp(2.7rem, 4vw, 3.9rem); }
.tnum span { margin-top: 14px; letter-spacing: 0.1em; }

/* 3) Pillars: de-boxed editorial columns with a gold top rule */
.pillars { gap: 44px 48px; }
.pillar {
  background: transparent; border: 0; border-top: 2px solid var(--gold-1);
  border-radius: 0; box-shadow: none; padding: 26px 0 0;
}
.pillar:hover { transform: translateY(-3px); box-shadow: none; border-top-color: var(--green-600); }
.pillar__ic { width: auto; height: auto; background: transparent; border: 0; margin-bottom: 16px; }
.pillar__ic svg { width: 32px; height: 32px; }
.pillar h3 { font-size: 1.55rem; margin-bottom: 10px; }

/* 4) Lighter, modern cards (less boxy) */
.config-card { box-shadow: 0 14px 38px -26px rgba(6,30,26,0.45); border-color: rgba(20,40,35,0.08); }
.config-card:hover { box-shadow: 0 26px 60px -30px rgba(6,30,26,0.5); }
.pillar, .conn-card, .invest-card { transition: transform .35s var(--ease), border-color .35s, box-shadow .35s; }

/* 5) RERA: 5 phases */
.rera-grid { grid-template-columns: repeat(5, 1fr); }
.rera-card__tower { font-family: var(--font-head); font-size: 1.15rem; color: var(--gold-2); margin-bottom: 12px; }
.rera-card__note { display:block; font-size:0.66rem; letter-spacing:0.1em; text-transform:uppercase; color: var(--gold-2); margin-top:8px; }
@media (max-width: 920px){ .rera-grid { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 600px){ .rera-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 380px){ .rera-grid { grid-template-columns: 1fr; } }

/* 6) Mobile: trim hero wordiness + editorial spacing */
@media (max-width: 600px) {
  .section { padding: 66px 0; }
  .section__head { margin-bottom: 36px; }
  .hero__lead { display: none; }
  .tband__grid { grid-template-columns: repeat(2, 1fr); }
  .tnum { padding: 24px 18px 4px; border-bottom: 1px solid rgba(237,202,132,0.14); }
  .tnum:nth-child(2n) { border-right: 0; }
  .pillars { gap: 30px; }
}



/* ============================================================
   v4: wordmark logo (two-line SWAMINARAYAN / CITY, no mark/tagline)
   ============================================================ */
.brand { gap: 0; }
.brand__mark { display: none; }
.brand__loc { display: none; }
.brand__wordmark { display: flex; flex-direction: column; line-height: 1; }
.brand__name {
  font-family: var(--font-head); font-weight: 600; text-transform: uppercase;
  color: var(--green-800); font-size: clamp(1.3rem, 2.1vw, 1.62rem);
  letter-spacing: 0.2em; line-height: 1;
}
.brand__city {
  font-family: var(--font-head); font-weight: 600; text-transform: uppercase;
  color: var(--gold-1); font-size: clamp(1.18rem, 1.9vw, 1.48rem);
  letter-spacing: 0.42em; line-height: 1; margin-top: 6px;
}
.header.scrolled .brand__name { color: var(--green-900); }
@media (max-width: 480px) {
  .brand__name { font-size: 1.16rem; letter-spacing: 0.16em; }
  .brand__city { font-size: 1.04rem; letter-spacing: 0.34em; }
}

/* v5: config card images fill (no letterbox), and floor-plan figure */
.config-card__media img { object-fit: cover; padding: 0; }
.fp-figure { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:16px; box-shadow:var(--shadow-soft); cursor:zoom-in; margin:6px 0 26px; max-width:880px; }
.fp-figure img { border-radius:var(--radius-sm); width:100%; }
.fp-figure figcaption { margin-top:12px; text-align:center; color:var(--muted); font-size:.95rem; }


/* ============================================================
   v6: header breathing room + responsive residences grid
   ============================================================ */
/* Space between the logo and the nav links (actions stay far right) */
.header__inner { justify-content: flex-start; }
.brand { margin-right: clamp(26px, 5vw, 76px); }
.header__actions { margin-left: auto; }

/* Residences: 3-up only on real desktop (was forced 3-up at all widths, clipping the spec boxes) */
.configs__grid { grid-template-columns: 1fr; max-width: 940px; }
@media (min-width: 720px) { .configs__grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 980px) { .configs__grid { grid-template-columns: repeat(3, 1fr); max-width: none; } }
.config-card__specs li { padding: 11px 5px; }
.config-card__specs strong { font-size: clamp(1.1rem, 1.4vw, 1.3rem); }
.config-card__specs span { font-size: 0.76rem; }




/* v7: hero brandline (keyword in H1, kept elegant) */
.hero__brandline { display:block; font-family:var(--font-body); font-weight:600; font-size:0.82rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold-2); margin-bottom:16px; }
@media (max-width:600px){ .hero__brandline{ font-size:0.72rem; letter-spacing:0.16em; margin-bottom:12px; } }
