/* =========================================================
   GOLDEN AVENUE · RIVERSIDE CITY · HARIDWAR
   aesthetic: Editorial Hush — paper · river · brass · ink
   ========================================================= */

:root{
  /* ---- palette: warm bone paper · deep NAVY river · aged brass/gold accents */
  --ink:#14110d;
  --ink-2:#1d1a14;
  --paper:#efe7d8;
  --paper-soft:#f7f0df;
  --paper-2:#e6dcc6;
  --river:#0a1f3d;        /* deep navy (was teal-green) */
  --river-2:#142d54;
  --river-3:#1d3e6c;
  --brass:#a87f44;
  --brass-2:#8d6932;
  --brass-glow:#c89e5e;
  --brass-soft:#d8b87a;
  --clay:#c79670;
  --sindoor:#b73f2f;
  --mist:#d6cdb8;
  --line: rgba(168,127,68,.28);
  --line-strong: rgba(168,127,68,.55);
  --line-light: rgba(245,237,221,.22);

  --serif:'Fraunces', 'Cormorant Garamond', Georgia, serif;
  --sans:'Manrope', system-ui, -apple-system, sans-serif;
  --caps:'Tenor Sans', 'Manrope', sans-serif;
  --mono:'DM Mono', ui-monospace, Menlo, monospace;
  --hindi:'Tiro Devanagari Hindi', 'Fraunces', serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html, body{cursor:auto}
@media (hover:hover){
  body.cursor-on, body.cursor-on a, body.cursor-on button, body.cursor-on input, body.cursor-on select, body.cursor-on textarea, body.cursor-on label{cursor:none}
}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.wrap{width:min(1240px, 92vw); margin-inline:auto; position:relative}

/* =========================================================
   ATMOSPHERE — grain, cursor, watermarks
   ========================================================= */
.grain{
  position:fixed; inset:-50%;
  pointer-events:none; z-index:1000;
  opacity:.06;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size:240px 240px;
}
.cursor-dot, .cursor-ring{
  position:fixed; top:0; left:0;
  pointer-events:none; z-index:1100;
  border-radius:50%;
  transform:translate(-50%,-50%);
  transition: transform .12s ease-out, opacity .3s;
  mix-blend-mode:difference;
}
.cursor-dot{ width:6px; height:6px; background:var(--brass-glow); }
.cursor-ring{ width:36px; height:36px; border:1px solid rgba(200,158,94,.5); transition: transform .35s cubic-bezier(.2,.7,.2,1), width .25s, height .25s, opacity .3s; }
body.over-link .cursor-ring{ width:72px; height:72px; border-color:rgba(200,158,94,.85); }
@media (hover:none){ .cursor-dot, .cursor-ring{display:none} }

.watermark{
  position:absolute;
  font-family:var(--hindi);
  font-weight:400;
  color:var(--brass);
  opacity:.05;
  letter-spacing:-.04em;
  line-height:.85;
  pointer-events:none;
  user-select:none;
  white-space:nowrap;
  z-index:0;
}
.watermark-hero{ top:18vh; left:-3vw; font-size:clamp(180px, 30vw, 460px); }
.watermark-brief{ top:6%; right:-4vw; font-size:clamp(120px, 18vw, 280px); opacity:.06; color:var(--brass-glow); }
.watermark-plans{ bottom:-2%; left:-2vw; font-size:clamp(120px, 20vw, 320px); }
.watermark-reserve{ top:8%; left:-2vw; font-size:clamp(100px, 16vw, 260px); opacity:.07; color:var(--brass-glow); }
.watermark-visit{ bottom:-5%; right:-3vw; font-size:clamp(140px, 22vw, 360px); }

/* =========================================================
   TOP MARQUEE
   ========================================================= */
.topmq{
  background:var(--river);
  color:var(--paper-soft);
  border-bottom:1px solid var(--line-light);
  overflow:hidden;
  position:relative;
}
.topmq-track{
  display:inline-flex; gap:32px; align-items:center;
  white-space:nowrap; padding:11px 0;
  font-family:var(--caps); font-size:11.5px; letter-spacing:.32em; text-transform:uppercase;
  animation: ticker 38s linear infinite;
}
.topmq-track span:not([aria-hidden]){ color:var(--paper-soft) }
.topmq-track span[aria-hidden]{ color:var(--brass-glow); font-family:var(--serif); font-size:13px }
@keyframes ticker{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:sticky; top:0; z-index:60;
  background:rgba(10,31,61,.82);
  backdrop-filter:saturate(160%) blur(16px);
  -webkit-backdrop-filter:saturate(160%) blur(16px);
  border-bottom:1px solid rgba(168,127,68,.22);
  transition:background .3s, border-color .3s;
}
.nav.scrolled{ background:rgba(10,31,61,.96) }
.nav-inner{display:flex; align-items:center; justify-content:space-between; height:108px}
.brand{ display:inline-flex; align-items:center }
.brand-logo{ height:80px; width:auto; display:block; transition:transform .4s }
.brand:hover .brand-logo{ transform:scale(1.02) }
.links{display:flex; gap:34px; align-items:center}
.links a:not(.cta){
  font-family:var(--caps); font-size:12px; letter-spacing:.24em; text-transform:uppercase;
  color:#e5dcc4; position:relative; padding:6px 0;
  transition:color .25s;
}
.links a:not(.cta):hover{ color:var(--brass-glow) }
.links a:not(.cta):after{
  content:''; position:absolute; left:0; right:100%; bottom:-2px; height:1px;
  background:var(--brass-glow); transition:right .35s cubic-bezier(.2,.7,.2,1);
}
.links a:not(.cta):hover:after{ right:0 }

.cta{
  display:inline-flex; align-items:center; gap:10px;
  padding:13px 22px;
  border:1px solid var(--brass-glow);
  background:transparent;
  color:var(--brass-glow);
  font-family:var(--caps); font-size:11.5px; letter-spacing:.22em; text-transform:uppercase;
  transition:.3s;
}
.cta:hover{ background:var(--brass-glow); color:var(--river) }
.cta .arr{ font-family:var(--serif); font-size:14px; transition:transform .3s }
.cta:hover .arr{ transform:translateX(4px) }

.burger{display:none; background:none; border:0; width:38px; height:30px; padding:0}
.burger span{display:block; height:1.4px; background:var(--brass-glow); margin:8px 0; transition:.3s}

/* =========================================================
   SIDE PROGRESS RAIL
   ========================================================= */
.rail{
  position:fixed; right:28px; top:50%; transform:translateY(-50%);
  z-index:40;
  display:flex; align-items:center; gap:18px;
  font-family:var(--caps); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--ink);
}
.rail-track{
  width:1px; height:240px;
  background:var(--line);
  position:relative;
}
.rail-fill{
  position:absolute; left:0; top:0; width:1px;
  background:var(--brass); height:0;
  transition:height .25s;
}
.rail-list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px }
.rail-list li{
  display:flex; align-items:center; gap:10px;
  opacity:.4; transition:opacity .3s, color .3s;
  cursor:pointer;
}
.rail-list li i{
  width:8px; height:1px; background:var(--ink); display:block;
  transition: width .35s, background .3s;
}
.rail-list li.on{ opacity:1; color:var(--brass-2) }
.rail-list li.on i{ width:22px; background:var(--brass) }
.rail-list li:hover{ opacity:.85 }
.rail-list li span{ font-size:10px }
@media (max-width: 1180px){ .rail{display:none} }

/* =========================================================
   COMMON SECTION
   ========================================================= */
.section{ padding:140px 0; position:relative }
.section.dark{ background:var(--river); color:#e5dcc4 }

.numlabel{
  display:flex; align-items:center; gap:14px; margin:0 0 38px;
  font-family:var(--caps); font-size:11.5px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--brass-2);
}
.numlabel span:first-child{ font-family:var(--mono); letter-spacing:.06em; font-size:12.5px; color:var(--ink) }
.numlabel i{ width:48px; height:1px; background:var(--brass) }
.numlabel.light span:first-child{ color:var(--paper-soft) }
.numlabel.light{ color:var(--brass-glow) }
.numlabel.light i{ background:var(--brass-glow) }

.display{
  font-family:var(--serif);
  font-weight:380;
  font-size:clamp(40px, 5.6vw, 92px);
  line-height:1.0;
  letter-spacing:-.022em;
  margin:0 0 28px;
  color:var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 30;
}
.display.light{ color:#f0e8d5 }
.display em{
  font-style:italic; font-weight:340;
  color:var(--brass-2);
  font-variation-settings: "opsz" 144, "SOFT" 80;
}
.dark .display em{ color:var(--brass-glow) }
.display .line-thin{ display:block; font-weight:280; font-variation-settings: "opsz" 144, "SOFT" 100 }

.lede{ max-width:620px; font-size:17.5px; line-height:1.55; color:#5b5446; margin:0 0 8px }
.lede.light{ color:#cdc4ac }
.sec-head{ max-width:820px; margin-bottom:80px }

.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 24px;
  font-family:var(--caps); font-size:11.5px; letter-spacing:.22em; text-transform:uppercase;
  transition:.3s; border:1px solid transparent;
}
.btn .arr{ font-family:var(--serif); font-size:16px; transition:transform .3s }
.btn:hover .arr{ transform:translateX(4px) }
.btn-solid{ background:var(--brass); color:var(--paper-soft); border-color:var(--brass) }
.btn-solid:hover{ background:var(--ink); border-color:var(--ink) }
.btn-thin{ background:transparent; color:var(--ink); border-color:var(--ink); border-width:1px }
.btn-thin:hover{ background:var(--ink); color:var(--paper-soft) }
.dark .btn-thin{ color:#e5dcc4; border-color:rgba(229,220,196,.5) }
.dark .btn-thin:hover{ background:var(--brass); color:var(--river); border-color:var(--brass) }
.btn.block{ width:100%; justify-content:center }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; padding:80px 0 100px;
  min-height:calc(100vh - 36px);
  display:flex; flex-direction:column; justify-content:center;
  overflow:hidden;
}
.hero-grid{
  display:grid; grid-template-columns: 1.18fr .82fr;
  gap:80px; align-items:center;
  z-index:2;
}
.hero h1.display{
  font-size:clamp(54px, 9vw, 142px);
  margin:30px 0 32px;
  font-weight:400;
  font-variation-settings: "opsz" 144, "SOFT" 20;
}
.hero h1 em{ display:block }
.hero .lede{ max-width:520px; font-size:18.5px; color:#46402f }
.hero-cta{ display:flex; gap:14px; margin-top:38px; flex-wrap:wrap }
.hero-meta{
  list-style:none; padding:48px 0 0; margin:54px 0 0;
  display:grid; grid-template-columns:repeat(4,1fr); gap:32px;
  border-top:1px solid var(--line);
}
.hero-meta li{ display:flex; flex-direction:column; gap:8px }
.hero-meta b{
  font-family:var(--serif); font-size:42px; font-weight:380; line-height:1; color:var(--ink);
  font-variation-settings: "opsz" 144;
}
.hero-meta b small{ font-family:var(--mono); font-size:13px; color:var(--brass-2); margin-left:4px; letter-spacing:0; font-weight:400 }
.hero-meta span{ font-family:var(--caps); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase; color:#7a7160 }

.hero-right{ position:relative }
.hero-frame{
  margin:0; position:relative;
  aspect-ratio: 3/4;
  overflow:hidden;
  border:1px solid var(--line-strong);
  padding:14px;
  background:var(--paper-soft);
}
.hero-frame:before{
  content:''; position:absolute; inset:14px;
  border:1px solid rgba(168,127,68,.18);
  pointer-events:none; z-index:2;
}
.hero-frame img{
  width:100%; height:100%; object-fit:cover;
  filter: contrast(1.04) saturate(.95);
  transition: transform 8s ease-out;
}
.hero-frame:hover img{ transform:scale(1.04) }
.hero-frame figcaption{
  position:absolute; bottom:14px; left:14px; right:14px;
  background:rgba(20,17,13,.78);
  color:var(--paper-soft);
  padding:12px 16px;
  display:flex; align-items:center; gap:14px;
  font-family:var(--caps); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase;
  z-index:3;
}
.hero-frame figcaption i{ flex:1; height:1px; background:var(--brass-glow); opacity:.6 }
.hero-frame figcaption b{ font-family:var(--mono); letter-spacing:.06em; color:var(--brass-glow); font-weight:400 }
.hero-stat{
  position:absolute; left:-110px; bottom:-30px;
  background:var(--paper-soft);
  border:1px solid var(--line);
  padding:18px 22px;
  display:flex; flex-direction:column; gap:6px;
  box-shadow:0 30px 60px -30px rgba(20,17,13,.3);
  z-index:3;
}
.hero-stat b{ font-family:var(--serif); font-size:44px; line-height:1; color:var(--ink); font-variation-settings:"opsz" 144 }
.hero-stat span{ font-family:var(--caps); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--brass-2) }

.scrollhint{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
  font-family:var(--caps); font-size:10.5px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--ink); display:flex; flex-direction:column; align-items:center; gap:12px;
  opacity:.7; z-index:5;
}
.scrollhint i{ width:1px; height:42px; background:var(--brass); display:block; transform-origin:top; animation:drop 2s infinite }
@keyframes drop{ 0%{transform:scaleY(.1)} 50%{transform:scaleY(1); transform-origin:top} 51%{transform-origin:bottom} 100%{transform:scaleY(.1); transform-origin:bottom} }

/* =========================================================
   ESSENCE
   ========================================================= */
.essence{ background:var(--paper) }
.essence-grid{
  display:grid; grid-template-columns: 1.35fr 1fr;
  gap:100px; align-items:start;
}
.essence-text p{ max-width:560px; color:#5b5446; font-size:17px; margin:0 0 20px }
.pullquote{
  margin:54px 0 0; padding:42px 36px 38px;
  border:1px solid var(--line);
  border-top:none; border-bottom:none;
  font-family:var(--serif); font-style:italic; font-size:26px; line-height:1.32;
  color:var(--ink-2); position:relative;
  font-variation-settings:"opsz" 144, "SOFT" 60;
}
.pullquote .qmark{
  position:absolute; top:-12px; left:30px;
  font-size:90px; color:var(--brass); font-style:normal;
  line-height:.5; font-family:var(--serif);
}
.pullquote cite{
  display:block; margin-top:18px;
  font-family:var(--caps); font-style:normal; font-size:11px;
  letter-spacing:.28em; text-transform:uppercase; color:var(--brass-2);
}
.essence-side{
  display:grid; grid-template-columns:1fr; gap:26px;
  padding:34px 32px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, var(--paper-soft), var(--paper));
  position:sticky; top:140px;
}
.side-stat{ display:flex; flex-direction:column; gap:6px; padding-bottom:24px; border-bottom:1px solid var(--line) }
.side-stat:last-of-type{ border-bottom:none; padding-bottom:0 }
.numbig{
  font-family:var(--serif); font-size:64px; font-weight:380; line-height:1;
  color:var(--ink); font-variation-settings:"opsz" 144;
  display:flex; align-items:baseline; gap:6px;
}
.numbig sup{ font-size:30px; color:var(--brass); top:-.4em; position:relative }
.numbig em{ font-style:italic; color:var(--brass-2); font-size:36px; margin-left:6px }
.side-stat small{ font-family:var(--caps); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase; color:#7a7160; line-height:1.5 }
.side-chip{
  margin-top:8px; padding:14px 18px;
  background:var(--ink); color:var(--paper-soft);
  display:flex; align-items:center; gap:18px;
}
.side-chip b{ font-family:var(--mono); font-size:18px; letter-spacing:.12em; color:var(--brass-glow) }
.side-chip small{ font-family:var(--caps); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; color:#cdc4ac }

/* =========================================================
   BRIEF (dark, numbered list)
   ========================================================= */
.brief-list{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(3, 1fr); column-gap:1px; row-gap:0;
  background:rgba(168,127,68,.15);
  border-top:1px solid var(--line-light);
  border-bottom:1px solid var(--line-light);
}
.brief-list li{
  background:var(--river);
  padding:48px 38px 56px;
  position:relative;
  transition:background .35s;
}
.brief-list li:hover{ background:var(--river-2) }
.brief-list li .dig{
  display:block;
  font-family:var(--mono); font-size:12.5px; letter-spacing:.06em;
  color:var(--brass-glow); margin-bottom:36px;
}
.brief-list li h3{
  font-family:var(--serif); font-weight:380; font-variation-settings:"opsz" 60;
  font-size:30px; line-height:1.08;
  margin:0 0 14px; color:#f0e8d5;
}
.brief-list li p{ margin:0; color:#cdc4ac; font-size:14.5px; line-height:1.6 }

/* =========================================================
   PAVILIONS
   ========================================================= */
.pavilions{ background:var(--paper-soft) }
.pav-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:0;
  border-top:1px solid var(--line); border-left:1px solid var(--line);
}
.pav{
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:38px 28px 42px; min-height:230px;
  display:flex; flex-direction:column; gap:14px;
  position:relative; overflow:hidden;
  transition:background .35s;
}
.pav:hover{ background:#fff }
.pav:before{
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:var(--brass); transform:scaleX(0); transform-origin:left;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.pav:hover:before{ transform:scaleX(1) }
.pav-no{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.08em;
  color:var(--brass-2); margin-bottom:auto;
}
.pav h4{
  font-family:var(--serif); font-weight:380; font-size:24px; line-height:1.12;
  margin:0; color:var(--ink);
  font-variation-settings:"opsz" 60;
}
.pav p{ margin:0; font-size:14px; color:#5b5446; line-height:1.6 }

/* =========================================================
   PLANS
   ========================================================= */
.plans{ background:var(--paper) }
.plans-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:38px;
}
.plan{ margin:0; display:flex; flex-direction:column }
.plan-img{
  position:relative; aspect-ratio:4/3;
  background:var(--paper-soft);
  border:1px solid var(--line);
  overflow:hidden;
  padding:14px;
}
.plan-img img{ width:100%; height:100%; object-fit:contain; transition:transform .8s }
.plan:hover .plan-img img{ transform:scale(1.03) }
.plan-img .cap{
  position:absolute; top:18px; right:18px;
  font-family:var(--mono); font-size:11px; letter-spacing:.08em;
  background:var(--ink); color:var(--brass-glow);
  padding:4px 10px;
}
.plan figcaption{ padding:26px 4px 0 }
.plan .tag{
  font-family:var(--caps); font-size:10.5px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--brass-2); display:block; margin-bottom:12px;
}
.plan h4{
  font-family:var(--serif); font-weight:380; font-size:26px; margin:0 0 10px;
  font-variation-settings:"opsz" 60;
}
.plan p{ margin:0; color:#5b5446; font-size:14.5px; line-height:1.6 }

/* =========================================================
   GALLERY
   ========================================================= */
.gallery{ background:var(--paper) }
.gal{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:230px;
  gap:10px;
}
.g{
  position:relative; overflow:hidden;
  background:var(--ink);
}
.g img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.4s cubic-bezier(.2,.7,.2,1);
  filter:saturate(.92) contrast(1.03);
}
.g:hover img{ transform:scale(1.06); filter:saturate(1) contrast(1.05) }
.g:after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(14,17,13,.7));
  opacity:0; transition:.45s;
  pointer-events:none;
}
.g:hover:after{ opacity:1 }
.g-cap{
  position:absolute; left:18px; bottom:16px; z-index:2;
  font-family:var(--caps); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--paper-soft);
  opacity:0; transform:translateY(8px); transition:.45s;
}
.g:hover .g-cap{ opacity:1; transform:translateY(0) }
.g-tall{ grid-row:span 2 }
.g-wide{ grid-column:span 2 }
.g-arch{
  grid-row:span 2;
  border-radius: 50% 50% 4px 4px / 38% 38% 4px 4px;
}
.g-arch:after{ border-radius:inherit }

/* =========================================================
   RESERVE / PRICING (dark)
   ========================================================= */
.reserve{ background:var(--river) }
.price-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:28px;
}
.price{
  background:var(--river-2);
  border:1px solid rgba(168,127,68,.22);
  padding:44px 34px 38px;
  position:relative;
  transition:.4s;
  display:flex; flex-direction:column;
}
.price:hover{ transform:translateY(-6px); border-color:var(--brass) }
.price.feat{
  background:var(--paper-soft); color:var(--ink);
  border:none; transform:translateY(-12px);
  box-shadow: 0 50px 80px -40px rgba(0,0,0,.5);
}
.price.feat:hover{ transform:translateY(-16px) }
.price .ribbon{
  position:absolute; top:-12px; left:34px;
  background:var(--brass); color:var(--river);
  font-family:var(--caps); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase;
  padding:6px 14px;
}
.price header{
  display:flex; justify-content:space-between; align-items:baseline;
  padding-bottom:18px; border-bottom:1px solid rgba(255,255,255,.08);
}
.price.feat header{ border-color:var(--line) }
.price .t{ font-family:var(--mono); font-size:14px; letter-spacing:.08em; color:var(--brass-glow) }
.price.feat .t{ color:var(--brass-2) }
.price .t2{ font-family:var(--serif); font-size:24px; color:#f0e8d5; font-variation-settings:"opsz" 60 }
.price.feat .t2{ color:var(--ink) }
.price .size{ margin:20px 0 4px; font-family:var(--caps); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; color:#cdc4ac }
.price.feat .size{ color:var(--brass-2) }
.price .amt{
  font-family:var(--serif); font-weight:380; font-size:80px; line-height:1;
  margin:8px 0 26px; color:#f0e8d5;
  font-variation-settings:"opsz" 144;
}
.price.feat .amt{ color:var(--ink) }
.price .amt sup{ font-size:30px; color:var(--brass-glow); margin-right:4px; top:-.55em; position:relative }
.price.feat .amt sup{ color:var(--brass-2) }
.price .amt small{ font-size:20px; font-family:var(--mono); color:#cdc4ac; margin-left:6px; letter-spacing:.06em; font-weight:400 }
.price.feat .amt small{ color:#5b5446 }
.price ul{ list-style:none; padding:0; margin:0 0 28px; flex:1 }
.price li{
  padding:11px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
  font-size:14px; color:#cdc4ac;
  display:flex; gap:10px;
}
.price li:before{ content:'+'; color:var(--brass-glow); font-family:var(--mono) }
.price.feat li{ color:#5b5446; border-color:var(--line) }
.price.feat li:before{ color:var(--brass-2) }
.fineprint{ text-align:center; margin-top:38px; font-family:var(--caps); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; color:#a39a82 }

/* =========================================================
   LOCALITY
   ========================================================= */
.locality{ background:var(--paper-soft) }
.loc-grid{
  display:grid; grid-template-columns: 1fr 1.1fr; gap:80px;
  align-items:center;
}
.loc-map{
  margin:0; position:relative;
  border:1px solid var(--line);
  padding:14px; background:var(--paper);
}
.loc-map img{ width:100%; height:auto; display:block }
.loc-map figcaption{
  position:absolute; bottom:14px; left:14px; right:14px;
  background:rgba(20,17,13,.78); color:var(--paper-soft);
  padding:11px 16px; display:flex; align-items:center; gap:12px;
  font-family:var(--caps); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase;
}
.loc-map figcaption i{ flex:1; height:1px; background:var(--brass-glow); opacity:.5 }
.loc-map figcaption b{ font-family:var(--mono); color:var(--brass-glow); letter-spacing:.08em; font-weight:400 }
.loc-text p{ max-width:540px; color:#5b5446; font-size:17px; margin:0 0 18px }
.loc-list{
  list-style:none; padding:36px 0 0; margin:30px 0 0;
  display:grid; grid-template-columns:1fr 1fr; gap:22px 36px;
  border-top:1px solid var(--line);
}
.loc-list li{ display:flex; flex-direction:column; gap:4px }
.loc-list b{
  font-family:var(--serif); font-size:32px; font-weight:380; color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.loc-list b small{ font-family:var(--mono); font-size:11px; color:var(--brass-2); margin-left:5px; letter-spacing:.04em; font-weight:400 }
.loc-list span{ font-family:var(--caps); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase; color:#7a7160 }

/* =========================================================
   VISIT (contact)
   ========================================================= */
.visit{ background:var(--paper) }
.visit-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap:80px;
  align-items:start;
}
.visit-text p{ max-width:520px; color:#5b5446; font-size:17px; margin:0 0 30px }
.visit-info{
  list-style:none; padding:24px 0 0; margin:0 0 38px;
  border-top:1px solid var(--line);
}
.visit-info li{
  display:flex; justify-content:space-between; align-items:center; gap:18px;
  padding:18px 0; border-bottom:1px solid var(--line);
}
.visit-info span{ font-family:var(--caps); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase; color:#7a7160 }
.visit-info a{ font-family:var(--serif); font-size:21px; color:var(--ink); font-variation-settings:"opsz" 60 }
.visit-info a:hover{ color:var(--brass-2) }
.visit-qr{ display:flex; align-items:center; gap:20px; margin-top:8px }
.visit-qr img{ width:108px; height:108px; padding:6px; background:#fff; border:1px solid var(--line) }
.visit-qr p{ margin:0; font-family:var(--caps); font-size:11.5px; letter-spacing:.18em; text-transform:uppercase; color:#7a7160; line-height:1.7 }

.visit-form{
  background:var(--river); color:#e5dcc4;
  padding:48px 44px;
  display:flex; flex-direction:column; gap:18px;
  position:relative;
}
.visit-form:before{
  content:''; position:absolute; inset:8px;
  border:1px solid rgba(200,158,94,.2);
  pointer-events:none;
}
.visit-form h3{
  font-family:var(--serif); font-weight:380; font-size:34px; margin:0;
  color:#f0e8d5; font-variation-settings:"opsz" 60;
}
.visit-form .sub{ font-family:var(--caps); font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--brass-glow); margin:0 0 10px }
.visit-form label{ display:flex; flex-direction:column; gap:6px }
.visit-form label span{ font-family:var(--caps); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; color:#a39a82 }
.visit-form input, .visit-form select{
  font:inherit; font-family:var(--sans); font-size:15px;
  color:#f0e8d5;
  padding:13px 0;
  background:transparent;
  border:0; border-bottom:1px solid rgba(200,158,94,.32);
  border-radius:0;
}
.visit-form input::placeholder{ color:#7a7160 }
.visit-form input:focus, .visit-form select:focus{ outline:none; border-bottom-color:var(--brass-glow) }
.visit-form select{ color:#f0e8d5; appearance:none; background-image:linear-gradient(45deg, transparent 50%, var(--brass-glow) 50%), linear-gradient(135deg, var(--brass-glow) 50%, transparent 50%); background-position: calc(100% - 16px) 50%, calc(100% - 11px) 50%; background-size:5px 5px, 5px 5px; background-repeat:no-repeat }
.visit-form select option{ background:var(--river); color:var(--paper-soft) }
.visit-form .check{ flex-direction:row; align-items:center; gap:10px }
.visit-form .check input{ width:16px; height:16px; border:1px solid var(--brass-glow); accent-color:var(--brass-glow) }
.visit-form .check span{ font-family:var(--sans); text-transform:none; letter-spacing:.02em; color:#cdc4ac; font-size:13px }
.visit-form .ok{ display:none; color:var(--brass-glow); font-size:13px; font-family:var(--caps); letter-spacing:.18em; text-transform:uppercase; margin:0 }
.visit-form .ok.show{ display:block }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--ink); color:#a39a82; padding:90px 0 36px; margin-top:0 }
.foot-top{ display:grid; grid-template-columns: 1.2fr 2fr; gap:80px; align-items:start }
.foot-brand .brand-logo-dark{ height:96px }
.foot-brand p{ font-size:14.5px; line-height:1.7; max-width:340px; margin:20px 0 0; color:#7a7160 }
.foot-cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:48px }
.foot-cols h5{ font-family:var(--caps); font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--brass-glow); margin:0 0 22px }
.foot-cols a, .foot-cols span{ display:block; font-family:var(--sans); font-size:14px; color:#a39a82; padding:6px 0; transition:color .25s }
.foot-cols a:hover{ color:var(--brass-glow) }

.foot-rule{
  display:flex; justify-content:center; align-items:center;
  padding:40px 0; margin-top:48px;
  border-top:1px solid rgba(168,127,68,.18); border-bottom:1px solid rgba(168,127,68,.18);
}
.foot-mono{
  font-family:var(--hindi); font-size:15px; letter-spacing:.18em;
  color:var(--brass-glow);
}
.foot-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:28px;
  font-family:var(--caps); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase;
  color:#5b5446;
}

/* =========================================================
   REVEAL ANIMATION HOOK
   ========================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition: opacity .9s ease, transform .9s ease }
.reveal.in{ opacity:1; transform:translateY(0) }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1100px){
  .hero-grid{ grid-template-columns:1fr; gap:56px }
  .hero-stat{ left:auto; right:0; bottom:-20px; position:absolute }
  .essence-grid{ grid-template-columns:1fr; gap:60px }
  .essence-side{ position:static }
  .brief-list, .pav-grid{ grid-template-columns:1fr 1fr }
  .plans-grid, .price-grid{ grid-template-columns:1fr 1fr }
  .gal{ grid-template-columns:repeat(3,1fr); grid-auto-rows:200px }
  .loc-grid{ grid-template-columns:1fr; gap:56px }
  .visit-grid{ grid-template-columns:1fr; gap:56px }
  .foot-top{ grid-template-columns:1fr; gap:48px }
}
@media (max-width: 720px){
  .section{ padding:96px 0 }
  .nav-inner{ height:88px }
  .brand-logo{ height:62px }
  .topmq-track{ font-size:10.5px; letter-spacing:.22em; gap:22px }
  .links{
    position:fixed; top:88px; right:0; width:82%; max-width:360px;
    /* height (not bottom:0) — .nav's backdrop-filter makes it the containing
       block for this fixed child, so bottom:0 would collapse it to zero height */
    height:calc(100vh - 88px); height:calc(100dvh - 88px);
    background:var(--river); flex-direction:column; align-items:stretch;
    padding:40px 36px; gap:0;
    transform:translateX(100%); transition:transform .4s cubic-bezier(.2,.7,.2,1);
    box-shadow: -40px 0 100px rgba(0,0,0,.4);
  }
  .links.open{ transform:translateX(0) }
  .links a{ padding:18px 0; border-bottom:1px solid var(--line-light) }
  .links .cta{ margin-top:20px; justify-content:center }
  .burger{ display:block }
  .hero-meta{ grid-template-columns:1fr 1fr; gap:24px }
  .hero h1.display{ font-size:clamp(46px, 12vw, 80px) }
  .brief-list, .pav-grid, .plans-grid, .price-grid{ grid-template-columns:1fr }
  .price.feat{ transform:none }
  .price.feat:hover{ transform:translateY(-6px) }
  .gal{ grid-template-columns:1fr 1fr; grid-auto-rows:160px }
  .g-wide, .g-tall, .g-arch{ grid-column:auto; grid-row:auto; border-radius:0 }
  .loc-list{ grid-template-columns:1fr 1fr }
  .visit-form{ padding:32px 24px }
  .foot-cols{ grid-template-columns:1fr; gap:32px }
  .foot-bottom{ flex-direction:column; gap:10px; text-align:center }
  .watermark{ font-size:clamp(120px, 30vw, 220px) !important; opacity:.04 }
}

/* ============ ADDITIONS · NH-24 build ============ */
/* Payment-plan amount (text instead of currency) */
.amt-plan{ font-family:var(--serif); font-variation-settings:"opsz" 144; letter-spacing:.01em }
.amt-plan small{ font-family:var(--serif); color:var(--brass-glow); margin:0 2px; font-size:.7em }
.price.feat .amt-plan{ color:var(--brass-glow) }
.price ul b{ color:var(--brass-glow); font-family:var(--mono); font-weight:500 }

/* Footer disclaimer block */
.foot-disclaimer{ padding:6px 0 24px }
.foot-disclaimer p{
  font-family:var(--sans); font-size:12.5px; line-height:1.7;
  color:#9a937f; max-width:none; margin:0;
}
.foot-disclaimer b{ color:#c7bfa6; font-weight:600 }

/* Floating WhatsApp / Call actions */
.floaters{ position:fixed; right:18px; bottom:18px; z-index:120; display:flex; flex-direction:column; gap:12px }
.floater{
  width:54px; height:54px; border-radius:50%; display:grid; place-items:center;
  font-size:22px; text-decoration:none; box-shadow:0 10px 30px rgba(10,31,61,.35);
  transition:transform .25s ease, box-shadow .25s ease;
}
.floater:hover{ transform:translateY(-3px) scale(1.05) }
.floater-wa{ background:#25d366 }
.floater-call{ background:var(--brass); }
@media (max-width:560px){ .floater{ width:48px; height:48px; font-size:19px } }

/* =========================================================
   MOBILE REFINEMENTS · responsive polish layer
   ========================================================= */
html{ -webkit-text-size-adjust:100% }
body{ -webkit-tap-highlight-color: rgba(168,127,68,.18) }

/* Dynamic viewport height (accounts for mobile browser chrome) */
@supports (height:100dvh){ .hero{ min-height:calc(100dvh - 36px) } }

/* Lock background scroll while the mobile menu is open */
body.menu-open{ overflow:hidden }

/* Animated burger → X */
.burger{ position:relative; z-index:70 }
.burger span{ transform-origin:center; transition:transform .35s cubic-bezier(.2,.7,.2,1), opacity .2s }
.burger.open span:first-child{ transform:translateY(5px) rotate(45deg) }
.burger.open span:last-child{ transform:translateY(-5px) rotate(-45deg) }

/* Hide floating actions behind the open menu */
body.menu-open .floaters{ opacity:0; pointer-events:none; transition:opacity .25s }

/* Touch devices: reveal gallery captions (no hover to trigger them) */
@media (hover:none){
  .g-cap{ opacity:1; transform:none }
  .g:after{ opacity:.55 }
}

/* ---- Tablet / large phone ---- */
@media (max-width: 900px){
  .section{ padding:104px 0 }
  .sec-head{ margin-bottom:56px }
  .hero-stat b{ font-size:36px }
}

/* ---- Phones (≤600) ---- */
@media (max-width: 600px){
  .wrap{ width:88vw }
  .section{ padding:80px 0 }
  .numlabel{ margin-bottom:26px; font-size:10.5px; letter-spacing:.22em }
  .numlabel i{ width:30px }
  .sec-head{ margin-bottom:42px }

  /* hero */
  .hero{ padding:52px 0 70px }
  .hero h1.display{ font-size:clamp(40px,11.5vw,60px); margin:22px 0 24px }
  .hero .lede{ font-size:16.5px }
  .hero-cta .btn{ flex:1 1 auto; justify-content:center }
  .hero-meta{ padding-top:32px; margin-top:34px; gap:22px 18px }
  .hero-meta b{ font-size:29px }
  .hero-meta b small{ font-size:11px }
  .hero-frame{ aspect-ratio:4/5 }
  .hero-stat{ position:static; margin:14px 0 0; width:max-content; max-width:100%;
              box-shadow:0 18px 34px -22px rgba(20,17,13,.4) }
  .hero-stat b{ font-size:30px }
  .scrollhint{ display:none }

  /* tame oversized type so nothing clips */
  .pullquote{ font-size:21px; padding:32px 22px 28px }
  .pullquote .qmark{ font-size:70px; left:22px }
  .numbig{ font-size:44px }
  .numbig sup{ font-size:21px }
  .numbig em{ font-size:25px }
  .brief-list li{ padding:36px 26px 40px }
  .brief-list li h3, .plan h4{ font-size:24px }
  .pav{ min-height:0; padding:30px 24px 34px }
  .pav h4{ font-size:21px }

  /* pricing */
  .price{ padding:34px 24px 30px }
  .price .amt{ font-size:60px; margin-bottom:22px }
  .price .amt sup{ font-size:23px }
  .amt-plan{ font-size:46px }
  .price .ribbon{ left:24px }

  /* gallery */
  .gal{ grid-template-columns:1fr 1fr; grid-auto-rows:148px; gap:8px }
  .g-cap{ font-size:9.5px; left:12px; bottom:12px }

  /* location */
  .loc-list{ gap:18px 24px }
  .loc-list b{ font-size:26px }

  /* contact */
  .visit-info li{ flex-direction:column; align-items:flex-start; gap:5px; padding:15px 0 }
  .visit-info a{ font-size:18px; word-break:break-word }
  .visit-qr{ gap:16px }
  .visit-qr img{ width:92px; height:92px }
  .visit-form{ padding:30px 22px }
  .visit-form h3{ font-size:28px }
  .visit-form input, .visit-form select{ font-size:16px } /* ≥16px stops iOS focus-zoom */

  /* footer */
  .footer{ padding:64px 0 30px }
  .foot-brand .brand-logo-dark{ height:72px }
  .foot-rule{ padding:28px 0; margin-top:32px }
  .foot-mono{ font-size:12px; letter-spacing:.12em; text-align:center }
  .foot-disclaimer p{ font-size:12px }
}

/* ---- Small phones (≤400) ---- */
@media (max-width: 400px){
  .hero h1.display{ font-size:clamp(33px,12.5vw,46px) }
  .hero-cta .btn{ width:100%; flex:1 1 100% }
  .btn{ padding:15px 20px }
  .price .amt{ font-size:52px }
  .amt-plan{ font-size:42px }
  .visit-info a{ font-size:16px }
}

/* ---- Landscape, short viewport ---- */
@media (max-height: 560px) and (orientation: landscape){
  .hero{ min-height:auto; padding:84px 0 56px }
  .scrollhint{ display:none }
}

/* ---- Respect reduced-motion ---- */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:.01ms !important; animation-iteration-count:1 !important;
    transition-duration:.01ms !important; scroll-behavior:auto !important;
  }
  .topmq-track{ animation:none }
}

/* Mobile menu panel: scroll if taller than viewport */
@media (max-width: 720px){
  .links{ overflow-y:auto; -webkit-overflow-scrolling:touch; padding-bottom:48px }
}

/* New wider wordmark: keep it clear of the burger on small screens */
@media (max-width: 600px){ .brand-logo{ height:46px } }
@media (max-width: 400px){ .brand-logo{ height:40px } }

/* =========================================================
   BUILDER HUB · project cards
   ========================================================= */
.projects{ background:var(--paper) }
.proj-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:38px }
.proj{
  background:var(--paper-soft); border:1px solid var(--line);
  display:flex; flex-direction:column; transition:.4s;
}
.proj:hover{ transform:translateY(-6px); border-color:var(--brass); box-shadow:0 50px 80px -50px rgba(20,17,13,.45) }
.proj-media{ position:relative; display:block; aspect-ratio:16/10; overflow:hidden }
.proj-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s cubic-bezier(.2,.7,.2,1); filter:saturate(.96) contrast(1.03) }
.proj:hover .proj-media img{ transform:scale(1.05) }
.proj-tag{
  position:absolute; top:16px; left:16px; z-index:2;
  background:var(--brass); color:var(--river);
  font-family:var(--caps); font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  padding:7px 13px;
}
.proj-body{ padding:32px 32px 34px; display:flex; flex-direction:column; flex:1 }
.proj-loc{ font-family:var(--caps); font-size:10.5px; letter-spacing:.26em; text-transform:uppercase; color:var(--brass-2); display:block; margin-bottom:10px }
.proj-body h3{ font-family:var(--serif); font-weight:380; font-size:32px; line-height:1.08; margin:0 0 14px; color:var(--ink); font-variation-settings:"opsz" 80 }
.proj-body > p{ margin:0 0 22px; color:#5b5446; font-size:15px; line-height:1.6 }
.proj-facts{ list-style:none; padding:20px 0; margin:0 0 24px; display:flex; gap:28px; border-top:1px solid var(--line); border-bottom:1px solid var(--line) }
.proj-facts li{ display:flex; flex-direction:column; gap:3px }
.proj-facts b{ font-family:var(--serif); font-size:24px; color:var(--ink); font-variation-settings:"opsz" 60; line-height:1 }
.proj-facts span{ font-family:var(--caps); font-size:9.5px; letter-spacing:.2em; text-transform:uppercase; color:#7a7160 }
.proj-body .btn{ align-self:flex-start; margin-top:auto }
@media (max-width: 880px){ .proj-grid{ grid-template-columns:1fr; gap:28px } }
@media (max-width: 600px){
  .proj-body{ padding:26px 22px 28px }
  .proj-body h3{ font-size:27px }
  .proj-facts{ gap:18px }
  .proj-facts b{ font-size:21px }
}

/* =========================================================
   UNIT SCHEDULE (Riverside City floor plan)
   ========================================================= */
.dim-block{ margin-top:54px; border-top:1px solid var(--line); padding-top:40px }
.dim-title{ font-family:var(--serif); font-weight:380; font-size:26px; color:var(--ink); margin:0 0 24px; font-variation-settings:"opsz" 60 }
.dim-title span{ color:var(--brass-2); font-style:italic; font-size:18px }
.dim-list{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(2,1fr); gap:0 48px }
.dim-list li{ display:flex; justify-content:space-between; align-items:baseline; gap:16px; padding:13px 0; border-bottom:1px solid var(--line) }
.dim-list span{ font-size:14.5px; color:#5b5446 }
.dim-list b{ font-family:var(--mono); font-size:13.5px; letter-spacing:.02em; color:var(--brass-2); white-space:nowrap }
@media (max-width: 760px){ .dim-list{ grid-template-columns:1fr; gap:0 } }

/* =========================================================
   LIVE MAP EMBED (location section)
   ========================================================= */
.loc-map--map{ padding:0; overflow:hidden }
.loc-map--map iframe{ width:100%; height:440px; border:0; display:block; filter:grayscale(.15) contrast(1.02) }
.loc-cap-top{ top:14px; bottom:auto !important }
@media (max-width:600px){ .loc-map--map iframe{ height:340px } }

/* =========================================================
   OTHER-PROJECT CROSS-LINK BANNER
   ========================================================= */
.otherproj{ background:var(--river); padding:84px 0 }
.op-card{
  display:grid; grid-template-columns:1.05fr 1fr; align-items:stretch;
  border:1px solid rgba(168,127,68,.24); overflow:hidden; transition:.4s;
}
.op-card:hover{ border-color:var(--brass); box-shadow:0 50px 90px -50px rgba(0,0,0,.6) }
.op-media{ overflow:hidden; min-height:320px }
.op-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s cubic-bezier(.2,.7,.2,1); filter:saturate(.96) contrast(1.03) }
.op-card:hover .op-media img{ transform:scale(1.05) }
.op-body{ padding:48px 46px; display:flex; flex-direction:column; justify-content:center; color:#e5dcc4; background:var(--river-2) }
.op-ey{ font-family:var(--caps); font-size:10.5px; letter-spacing:.26em; text-transform:uppercase; color:var(--brass-glow); margin-bottom:14px }
.op-body h3{ font-family:var(--serif); font-weight:380; font-size:34px; line-height:1.1; color:#f0e8d5; margin:0 0 14px; font-variation-settings:"opsz" 80 }
.op-body p{ color:#cdc4ac; font-size:15px; line-height:1.6; margin:0 0 26px; max-width:440px }
.op-body .btn{ align-self:flex-start; color:#e5dcc4; border-color:rgba(229,220,196,.5) }
.op-card:hover .op-body .btn{ background:var(--brass); color:var(--river); border-color:var(--brass) }
@media (max-width:760px){
  .otherproj{ padding:60px 0 }
  .op-card{ grid-template-columns:1fr }
  .op-media{ min-height:210px }
  .op-body{ padding:32px 24px }
  .op-body h3{ font-size:27px }
}

/* Active nav link (PHP-driven) */
.links a.active{ color:var(--brass-glow) }
.links a.active:after{ right:0 }
