/* =========================================================================
   VIVIDUS — vividus.css
   Component and layout styles specific to the Vividus micro-site.
   Depends on base.css (tokens + primitives).
   ========================================================================= */


/* ---------- 1. Fixed chrome (top bar) ---------- */

.chrome {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 40;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 22px var(--container-pad);
  background: linear-gradient(180deg, rgba(248, 243, 230, .82) 0%, rgba(248, 243, 230, .0) 100%);
  backdrop-filter: blur(0);
  pointer-events: none;
  transition: background var(--m-base) var(--ease);
}
body.menu-open .chrome { background: transparent; }
body.menu-open .chrome .c-left,
body.menu-open .chrome .c-center,
body.menu-open .chrome .c-right > a.btn-link {
  opacity: 0;
  pointer-events: none;
  transition: opacity 240ms var(--ease);
}
.chrome > * { pointer-events: auto; }
.chrome .c-left  { justify-self: start; display: inline-flex; align-items: center; gap: 10px; }
.chrome .c-center { justify-self: center; }
.chrome .c-right { justify-self: end; display: inline-flex; align-items: center; gap: var(--s5); }

.chrome .c-wm {
  font-family: var(--fb);
  font-size: 11px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--vv-ink);
}
.chrome .c-wm em {
  font-family: var(--fd);
  font-style: italic;
  letter-spacing: .02em;
  text-transform: none;
  color: var(--vv-gold-deep);
  margin: 0 .18em;
}

/* Menu trigger — lives in the chrome, becomes the Close × when open */
.menu-trigger {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-ink);
  padding: 6px 2px;
  position: relative;
  transition: color var(--m-fast) var(--ease);
}
.menu-trigger:hover { color: var(--vv-gold-deep); }
.menu-trigger .t-word { position: relative; }
.menu-trigger .t-close { display: none; }
.menu-trigger .t-mark {
  display: inline-grid; gap: 4px;
  width: 22px;
}
.menu-trigger .t-mark .ln {
  display: block; height: 1px; width: 100%;
  background: currentColor;
  transition: transform var(--m-base) var(--ease), opacity var(--m-base) var(--ease);
  transform-origin: center;
}
body.menu-open .menu-trigger .t-open  { display: none; }
body.menu-open .menu-trigger .t-close { display: inline; }
body.menu-open .menu-trigger .t-mark .ln:nth-child(1) { transform: translateY(5px) rotate(45deg); }
body.menu-open .menu-trigger .t-mark .ln:nth-child(2) { opacity: 0; }
body.menu-open .menu-trigger .t-mark .ln:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }


/* ---------- 2. Cover (section 1) ---------- */

.cover {
  position: relative;
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr;
  padding-top: 120px;
  background: var(--vv-paper);
  overflow: hidden;
}

.cover-copy {
  text-align: center;
  padding: clamp(48px, 9vh, 120px) var(--container-pad) clamp(48px, 6vh, 72px);
  max-width: 1080px;
  margin: 0 auto;
}
.cover-copy .label { display: inline-block; margin-bottom: var(--s6); color: var(--vv-gold-deep); }
.cover-copy h1 {
  font-style: italic;
  font-weight: 500;
  letter-spacing: -0.012em;
}
.cover-copy h1 em { color: var(--vv-gold-deep); }
.cover-copy .sub {
  margin-top: var(--s5);
  font-family: var(--fd);
  font-size: var(--t-hero-sub);
  font-style: normal;
  color: var(--vv-ink-soft);
  line-height: 1.3;
  max-width: none;
}

/* Ken-burns plate — very slow, breathing zoom */
.cover-plate {
  position: relative;
  width: 100%;
  height: clamp(380px, 72vh, 720px);
  overflow: hidden;
  border-top: 1px solid var(--vv-line);
}
.cover-plate::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(180deg, rgba(46,40,24,0) 50%, rgba(46,40,24,.14) 100%),
    var(--cover-img, url('https://images.unsplash.com/photo-1566073771259-6a8506099945?w=2000&q=85&auto=format&fit=crop'));
  background-size: cover;
  background-position: center;
  transform: scale(1.0);
  transition: transform var(--m-breath) linear;
}
.cover-plate.is-breathing::before { transform: scale(1.04); }

.cover-plate .plate-caption {
  position: absolute;
  left: var(--container-pad);
  bottom: var(--s6);
  color: var(--vv-paper);
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  opacity: .86;
}


/* ---------- 3. Anchor (section 2) ---------- */

.anchor {
  background: var(--vv-paper-vellum);
  padding: var(--section-y) var(--container-pad);
  text-align: center;
}
.anchor .word {
  font-family: var(--fk);
  font-size: var(--t-kannada);
  line-height: 1;
  color: var(--vv-gold-deep);
  letter-spacing: 0;
  display: inline-block;
}
.anchor .english {
  margin-top: var(--s6);
  font-family: var(--fd);
  font-style: italic;
  font-size: clamp(20px, 1.6vw, 26px);
  color: var(--vv-ink);
  line-height: 1.45;
  max-width: 44ch;
  margin-left: auto; margin-right: auto;
}
.anchor .english em { color: var(--vv-gold-deep); }
.anchor .v-mark { margin-top: var(--s7); color: var(--vv-gold-deep); }
.anchor .gold-rule { margin-top: var(--s5); }


/* ---------- 4. Pillars (section 3) ---------- */

.pillars {
  padding: var(--section-y) 0;
  background: var(--vv-paper);
}
.pillars .p-head {
  text-align: center;
  margin-bottom: var(--s9);
  padding: 0 var(--container-pad);
}
.pillars .p-head h2 {
  font-style: italic;
  font-weight: 500;
  max-width: 18ch;
  margin: var(--s4) auto 0;
}
.pillars .p-head h2 em { color: var(--vv-gold-deep); }

.pillar-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px;
  padding: 0 var(--container-pad);
  max-width: 1480px;
  margin: 0 auto;
}
.pillar-card {
  display: block;
  color: inherit;
}
.pillar-card .p-img {
  aspect-ratio: 3 / 4;
  background-color: var(--vv-paper-vellum);
  overflow: hidden;
  position: relative;
}
.pillar-card .p-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--m-slow) var(--ease-out);
}
.pillar-card .p-img::after {
  content: "";
  position: absolute; inset: 0;
  background: rgba(46, 40, 24, 0);
  transition: background var(--m-slow) var(--ease-out);
  pointer-events: none;
}
.pillar-card:hover .p-img img { transform: scale(1.02); }
.pillar-card:hover .p-img::after { background: rgba(46, 40, 24, .12); }

.pillar-card .p-word {
  margin-top: var(--s5);
  font-family: var(--fd);
  font-style: italic;
  font-size: var(--t-pillar);
  line-height: 1;
  color: var(--vv-ink);
  letter-spacing: -0.015em;
}
.pillar-card .p-tag {
  margin-top: var(--s3);
  font-family: var(--fd);
  font-style: normal;
  font-size: clamp(15px, 1.1vw, 18px);
  color: var(--vv-ink-soft);
  line-height: 1.4;
  max-width: 22ch;
}

@media (max-width: 1180px) {
  .pillar-grid { grid-template-columns: repeat(3, 1fr); }
  .pillar-card:nth-child(n+4) .p-img { aspect-ratio: 4 / 3; }
}
@media (max-width: 860px) {
  .pillar-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .pillar-grid { grid-template-columns: 1fr; }
  .pillar-card .p-img { aspect-ratio: 4 / 3; }
}


/* ---------- 5. Rooms (section 4) ---------- */

.rooms {
  background: var(--vv-paper-ivory);
  padding: var(--section-y) 0;
}
.rooms .r-head {
  text-align: left;
  padding: 0 var(--container-pad);
  max-width: var(--container);
  margin: 0 auto var(--s9);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s7);
  align-items: end;
}
.rooms .r-head .label { align-self: start; }
.rooms .r-head h2 em { color: var(--vv-gold-deep); font-style: italic; }
.rooms .r-head .lede { color: var(--vv-ink-soft); }

.room-row {
  display: grid;
  grid-template-columns: 0.42fr 0.58fr;
  gap: clamp(32px, 4vw, 80px);
  align-items: center;
  padding: clamp(48px, 5vh, 80px) var(--container-pad);
  max-width: var(--container);
  margin: 0 auto;
  border-top: 1px solid var(--vv-line);
}
.room-row:first-of-type { border-top: 0; }
.room-row:nth-child(even) { grid-template-columns: 0.58fr 0.42fr; }
.room-row:nth-child(even) .r-img { order: 2; }
.room-row:nth-child(even) .r-copy { order: 1; }

.room-row .r-img {
  aspect-ratio: 4 / 5;
  background-color: var(--vv-paper-vellum);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  position: relative;
}
.room-row .r-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--m-slow) var(--ease-out);
}
.room-row:hover .r-img img { transform: scale(1.02); }
.room-row .r-copy h3 {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(28px, 3vw, 44px);
  letter-spacing: -0.01em;
  color: var(--vv-ink);
}
.room-row .r-copy h3 em { color: var(--vv-gold-deep); font-style: normal; }
.room-row .r-copy p {
  margin-top: var(--s4);
  color: var(--vv-ink-soft);
  max-width: 48ch;
}
.room-row .r-facts {
  margin-top: var(--s5);
  list-style: none; padding: 0;
  display: flex; flex-wrap: wrap; gap: var(--s5);
  font-family: var(--fb);
  font-size: var(--t-sm);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--vv-ink-mute);
}
.room-row .r-facts li { position: relative; padding-left: 14px; }
.room-row .r-facts li::before {
  content: ""; position: absolute; left: 0; top: 50%;
  width: 4px; height: 4px;
  background: var(--vv-gold);
  border-radius: 50%;
  transform: translateY(-50%);
}

@media (max-width: 860px) {
  .rooms .r-head { grid-template-columns: 1fr; gap: var(--s5); }
  .room-row,
  .room-row:nth-child(even) { grid-template-columns: 1fr; }
  .room-row:nth-child(even) .r-img { order: 0; }
  .room-row:nth-child(even) .r-copy { order: 0; }
}


/* ---------- 6. Plates (section 5 — signature spaces) ---------- */

.plates {
  padding: var(--section-y) 0;
  background: var(--vv-paper);
}
.plates .p-head {
  text-align: center;
  padding: 0 var(--container-pad);
  margin-bottom: var(--s9);
}
.plates .p-head h2 {
  font-style: italic;
  font-weight: 500;
  max-width: 20ch;
  margin: var(--s4) auto 0;
}
.plates-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--s6);
  padding: 0 var(--container-pad);
  max-width: 1440px;
  margin: 0 auto;
}
.plate {
  display: block;
  color: inherit;
}
.plate-img {
  aspect-ratio: 4 / 3;
  background-color: var(--vv-paper-vellum);
  overflow: hidden;
  position: relative;
}
.plate-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--m-slow) var(--ease-out);
}
.plate-img::after {
  content: "";
  position: absolute; inset: 0;
  background: rgba(46, 40, 24, 0);
  transition: background var(--m-slow) var(--ease-out);
  pointer-events: none;
}
.plate:hover .plate-img img { transform: scale(1.02); }
.plate:hover .plate-img::after { background: rgba(46, 40, 24, .12); }

.plate .plate-cap {
  margin-top: var(--s4);
  display: flex; align-items: baseline; justify-content: space-between;
  gap: var(--s4);
}
.plate .plate-cap .name {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(20px, 1.6vw, 26px);
  color: var(--vv-ink);
}
.plate .plate-cap .role {
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-ink-mute);
}

.plate.span-7 { grid-column: span 7; }
.plate.span-5 { grid-column: span 5; }
.plate.span-6 { grid-column: span 6; }
.plate.span-4 { grid-column: span 4; }
.plate.span-8 { grid-column: span 8; }
.plate.span-12 { grid-column: span 12; }

@media (max-width: 860px) {
  .plates-grid { grid-template-columns: 1fr; gap: var(--s7); }
  .plate.span-7, .plate.span-5, .plate.span-6, .plate.span-4, .plate.span-8, .plate.span-12 {
    grid-column: span 1;
  }
}


/* ---------- 7. Place (section 6) ---------- */

.place {
  padding: var(--section-y) 0;
  background: var(--vv-paper-ivory);
}
.place .p-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 6vw, 120px);
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--container-pad);
  align-items: center;
}
.place .p-copy h2 {
  font-style: italic;
  font-weight: 500;
  margin-top: var(--s4);
}
.place .p-copy h2 em { color: var(--vv-gold-deep); }
.place .p-copy p {
  margin-top: var(--s5);
  color: var(--vv-ink-soft);
  font-size: var(--t-body-lg);
  line-height: 1.7;
  max-width: 48ch;
}
.place .neighbours {
  margin-top: var(--s6);
  list-style: none; padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: var(--s3) var(--s6);
  font-family: var(--fd);
  font-style: italic;
  font-size: clamp(18px, 1.25vw, 22px);
  color: var(--vv-ink);
}
.place .neighbours li::before {
  content: "· ";
  color: var(--vv-gold-deep);
  font-style: normal;
}

.map-plate {
  position: relative;
  display: block;
  background: var(--vv-paper-vellum);
  border: 1px solid var(--vv-line);
  padding: var(--s7);
  aspect-ratio: 4 / 5;
  box-shadow: var(--shadow-soft);
  color: inherit;
  text-decoration: none;
  transition:
    border-color var(--m-base) var(--ease),
    box-shadow var(--m-base) var(--ease),
    transform var(--m-base) var(--ease-out);
}
.map-plate svg {
  width: 100%; height: auto;
  color: var(--vv-gold-deep);
  display: block;
  margin: auto;
  max-height: calc(100% - 44px);
}
.map-plate:hover {
  border-color: var(--vv-gold);
  box-shadow: var(--shadow-plate);
  transform: translateY(-2px);
}

.map-cta {
  position: absolute;
  left: var(--s7); right: var(--s7); bottom: var(--s6);
  display: inline-flex; align-items: baseline; justify-content: space-between;
  gap: var(--s3);
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-ink-mute);
  padding-top: var(--s3);
  border-top: 1px solid var(--vv-line);
  transition: color var(--m-fast) var(--ease);
}
.map-cta-arrow {
  font-family: var(--fd);
  font-style: italic;
  font-size: 16px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--vv-gold-deep);
  transition: transform var(--m-base) var(--ease-out);
  display: inline-block;
}
.map-plate:hover .map-cta { color: var(--vv-ink); }
.map-plate:hover .map-cta-arrow {
  color: var(--vv-gold-deep);
  transform: translate(3px, -3px);
}

@media (max-width: 860px) {
  .place .p-inner { grid-template-columns: 1fr; }
}


/* ---------- 8. Accolades (section 7) ---------- */

.accolades {
  padding: var(--section-y) 0;
  background: var(--vv-paper);
  text-align: center;
}
.accolades .a-head { margin-bottom: var(--s8); }
.accolades .a-head h2 {
  font-style: italic;
  font-weight: 500;
  max-width: 22ch;
  margin: var(--s4) auto 0;
}
.accolades ul {
  list-style: none; padding: 0;
  max-width: 820px;
  margin: 0 auto;
  padding-inline: var(--container-pad);
}
.accolades li {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(20px, 2vw, 30px);
  line-height: 1.4;
  color: var(--vv-ink);
  padding: var(--s6) 0 var(--s6) var(--s6);
  border-top: 1px solid var(--vv-line);
  display: flex; justify-content: space-between; align-items: baseline;
  gap: var(--s5);
  text-align: left;
  position: relative;
}
.accolades li::before {
  content: "";
  position: absolute;
  left: 0;
  top: calc(var(--s6) + 0.65em);
  width: 5px; height: 5px;
  background: var(--vv-gold);
  border-radius: 50%;
  transform: translateY(-50%);
}
.accolades li:first-child { border-top: 0; }
.accolades li .year {
  font-family: var(--fb);
  font-style: normal;
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-gold-deep);
  flex-shrink: 0;
  align-self: center;
}
.accolades li em { color: var(--vv-gold-deep); }


/* ---------- 9. Reserve (section 8) ---------- */

.reserve {
  background: var(--vv-paper-vellum);
  padding: var(--section-y) 0;
  text-align: center;
}
.reserve h2 {
  font-style: italic;
  font-weight: 500;
  max-width: 14ch;
  margin: var(--s4) auto 0;
}
.reserve h2 em { color: var(--vv-gold-deep); }
.reserve .r-meta {
  margin-top: var(--s7);
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--s5) var(--s8);
  font-family: var(--fd);
  font-style: italic;
  font-size: clamp(18px, 1.3vw, 24px);
  color: var(--vv-ink);
}
.reserve .r-meta span { color: var(--vv-ink-soft); }
.reserve .r-meta a { color: var(--vv-ink); }
.reserve .r-meta a:hover { color: var(--vv-gold-deep); }
.reserve .r-cta {
  margin-top: var(--s7);
}


/* =========================================================================
   RESERVE CARD — the business conversion engine
   A printed-reservation-slip CTA. Double-hairline engraved border +
   a small brass concierge bell SVG that rings on hover. The whole card
   is a tel: link.
   ========================================================================= */

.reserve-card {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(20px, 2.6vw, 40px);
  padding: clamp(28px, 3.4vw, 44px) clamp(32px, 3.6vw, 56px);
  margin: clamp(32px, 4vh, 56px) auto 0;
  max-width: 720px;
  background: var(--vv-paper-ivory);
  color: var(--vv-ink);
  text-decoration: none;
  border: 1px solid var(--vv-line);
  box-shadow:
    inset 0 0 0 8px var(--vv-paper-ivory),
    inset 0 0 0 9px var(--vv-gold-pale),
    0 1px 2px rgba(46,40,24,.04),
    0 8px 24px rgba(46,40,24,.08);
  transition:
    transform var(--m-base) var(--ease-out),
    box-shadow var(--m-base) var(--ease-out),
    border-color var(--m-base) var(--ease);
}

/* Faint V watermark on the card's right side — extra editorial stamp */
.reserve-card::after {
  content: "";
  position: absolute;
  top: 50%; right: 6%;
  transform: translateY(-50%);
  width: 96px; height: 96px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' fill='none' stroke='%239D8345' stroke-width='0.9' stroke-linecap='round' stroke-linejoin='round'><path d='M 5 7 L 16 26 L 27 7'/><path d='M 11 7 L 16 18 L 21 7' opacity='.55'/><circle cx='16' cy='5' r='.9' fill='%239D8345' stroke='none'/></svg>") center / contain no-repeat;
  opacity: 0.06;
  pointer-events: none;
  z-index: 0;
}
.reserve-card > * { position: relative; z-index: 1; }

.reserve-card:hover,
.reserve-card:focus-visible {
  transform: translateY(-4px);
  border-color: var(--vv-gold);
  box-shadow:
    inset 0 0 0 8px var(--vv-paper-ivory),
    inset 0 0 0 9px var(--vv-gold),
    0 2px 6px rgba(46,40,24,.06),
    0 18px 44px rgba(46,40,24,.14);
  outline: none;
}

.reserve-card .rc-stamp {
  width: clamp(56px, 5vw, 72px);
  color: var(--vv-gold-deep);
  flex-shrink: 0;
  align-self: center;
}
.reserve-card .rc-stamp svg {
  width: 100%;
  height: auto;
  display: block;
  overflow: visible;
}

.reserve-card .rc-body { display: grid; gap: 4px; }
.reserve-card .rc-label {
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--vv-gold-deep);
}
.reserve-card .rc-title {
  font-family: var(--fd);
  font-style: italic;
  font-size: clamp(22px, 2.2vw, 32px);
  font-weight: 500;
  line-height: 1.12;
  letter-spacing: -0.01em;
  color: var(--vv-ink);
  margin-top: 4px;
}
.reserve-card .rc-title em {
  color: var(--vv-gold-deep);
  font-style: italic;
}
.reserve-card .rc-sub {
  font-family: var(--fd);
  font-style: italic;
  font-size: clamp(14px, 1.05vw, 16px);
  color: var(--vv-ink-soft);
  margin-top: 2px;
  line-height: 1.4;
}

.reserve-card .rc-action {
  display: flex;
  align-items: center;
  gap: clamp(12px, 1.4vw, 20px);
  flex-shrink: 0;
}
.reserve-card .rc-phone {
  font-family: var(--fd);
  font-style: italic;
  font-size: clamp(15px, 1.15vw, 19px);
  color: var(--vv-ink);
  white-space: nowrap;
}
.reserve-card .rc-cta-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(40px, 3.6vw, 48px);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: var(--vv-ink);
  color: var(--vv-paper-ivory);
  font-family: var(--fb);
  font-size: 16px;
  transition:
    transform var(--m-base) var(--ease-out),
    background var(--m-base) var(--ease);
}
.reserve-card:hover .rc-cta-arrow,
.reserve-card:focus-visible .rc-cta-arrow {
  background: var(--vv-gold-deep);
  transform: translateX(4px);
}

/* Bell ring animation — tilts around the knob, fires on hover/focus */
.reserve-card .bell {
  transform-origin: 28px 7px;
  transition: transform var(--m-base) var(--ease);
}
.reserve-card .bell-wave {
  opacity: 0;
  transition: opacity var(--m-fast) var(--ease);
}
.reserve-card:hover .bell,
.reserve-card:focus-visible .bell {
  animation: vv-bell-ring 720ms ease-out;
}
.reserve-card:hover .bell-wave,
.reserve-card:focus-visible .bell-wave {
  animation: vv-bell-wave 720ms ease-out;
}

@keyframes vv-bell-ring {
  0%   { transform: rotate(0); }
  20%  { transform: rotate(7deg); }
  40%  { transform: rotate(-5deg); }
  60%  { transform: rotate(3deg); }
  80%  { transform: rotate(-2deg); }
  100% { transform: rotate(0); }
}
@keyframes vv-bell-wave {
  0%   { opacity: 0; }
  30%  { opacity: 1; }
  100% { opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .reserve-card,
  .reserve-card:hover,
  .reserve-card:focus-visible,
  .reserve-card .bell,
  .reserve-card .bell-wave,
  .reserve-card .rc-cta-arrow { animation: none; transform: none; transition: background var(--m-base) var(--ease), border-color var(--m-base) var(--ease); }
}

/* Stack vertically on narrow viewports */
@media (max-width: 760px) {
  .reserve-card {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
    padding: clamp(28px, 6vw, 40px) clamp(24px, 5vw, 36px);
    gap: 14px;
  }
  .reserve-card .rc-action {
    margin-top: 8px;
  }
  .reserve-card::after { display: none; }
}


/* ---------- 10. Footer (section 9) ---------- */

.v-footer {
  background: var(--vv-paper-sepia);
  padding: var(--s9) var(--container-pad) var(--s6);
  color: var(--vv-ink);
  border-top: 1px solid var(--vv-line);
}
.v-footer-inner {
  max-width: var(--container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--s7);
}
.v-footer h4 {
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-gold-deep);
  font-weight: 600;
  margin-bottom: var(--s4);
}
.v-footer .f-brand .wm {
  font-family: var(--fd);
  font-size: clamp(26px, 2vw, 34px);
  font-style: italic;
  letter-spacing: -0.01em;
  color: var(--vv-ink);
  line-height: 1;
}
.v-footer .f-brand .tag {
  margin-top: var(--s3);
  font-family: var(--fb);
  font-size: var(--t-sm);
  color: var(--vv-ink-soft);
  letter-spacing: .04em;
}
.v-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--s2); }
.v-footer a { color: var(--vv-ink-soft); transition: color var(--m-fast) var(--ease); }
.v-footer a:hover { color: var(--vv-gold-deep); }
.v-footer-bottom {
  max-width: var(--container);
  margin: var(--s8) auto 0;
  padding-top: var(--s5);
  border-top: 1px solid var(--vv-line);
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--s4);
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-ink-mute);
}
.v-footer-bottom .v-mark { color: var(--vv-gold-deep); }

@media (max-width: 860px) {
  .v-footer-inner { grid-template-columns: 1fr 1fr; }
  .v-footer-bottom { flex-direction: column; gap: var(--s3); text-align: center; }
}
@media (max-width: 560px) {
  .v-footer-inner { grid-template-columns: 1fr; }
}


/* ---------- 11. Right-rail editorial margin note (optional, used sparingly) ---------- */

.marginalia {
  position: absolute;
  right: clamp(16px, 2vw, 32px);
  top: var(--section-y);
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--vv-ink-mute);
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  pointer-events: none;
  z-index: 1;
}
.marginalia .num { color: var(--vv-gold-deep); margin-right: .7em; }

.rooms, .plates, .place, .pillars, .accolades, .reserve, .anchor { position: relative; }

@media (max-width: 1180px) {
  .marginalia { display: none; }
}


/* ---------- 12. Menu overlay (the site index) ---------- */

body.menu-open { overflow: hidden; }

.menu-overlay {
  position: fixed;
  inset: 0;
  z-index: 30;
  background: var(--vv-paper-ivory);
  opacity: 0;
  pointer-events: none;
  clip-path: inset(0 0 100% 0);
  transition: opacity 420ms var(--ease-out), clip-path 560ms var(--ease);
  display: grid;
  grid-template-rows: auto 1fr auto;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
}
body.menu-open .menu-overlay {
  opacity: 1;
  pointer-events: auto;
  clip-path: inset(0 0 0 0);
}

/* A barely-there champagne wash */
.menu-overlay::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(200,169,104,.06), transparent 42%),
    radial-gradient(circle at 80% 80%, rgba(200,169,104,.05), transparent 48%);
  pointer-events: none;
}

.menu-topbar {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 22px var(--container-pad);
  border-bottom: 1px solid var(--vv-line);
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-ink-mute);
  position: sticky; top: 0;
  background: var(--vv-paper-ivory);
  z-index: 3;
}
.menu-topbar .mt-center {
  font-family: var(--fd);
  font-style: italic;
  font-size: clamp(18px, 1.4vw, 22px);
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--vv-ink);
}
.menu-topbar .mt-center em { color: var(--vv-gold-deep); }
/* Right cell is hidden because the chrome's CLOSE trigger (z-40) sits in that corner. */
.menu-topbar .mt-right { visibility: hidden; }

.menu-body {
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: clamp(32px, 6vw, 96px);
  padding: clamp(24px, 4vh, 56px) var(--container-pad);
  max-width: 1440px;
  margin: 0 auto;
  width: 100%;
  position: relative;
  z-index: 1;
}

/* ----- menu list ----- */
.menu-list {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  align-content: start;
  gap: clamp(2px, 0.4vh, 8px);
}

.menu-item {
  display: grid;
  grid-template-columns: 40px 1fr auto auto;
  gap: clamp(16px, 2vw, 28px);
  align-items: baseline;
  padding: clamp(12px, 1.6vh, 22px) 0;
  color: var(--vv-ink);
  text-decoration: none;
  position: relative;
  opacity: 0;
  transform: translateX(-12px);
  transition:
    opacity 520ms var(--ease-out),
    transform 520ms var(--ease-out),
    color var(--m-base) var(--ease);
}
body.menu-open .menu-item { opacity: 1; transform: translateX(0); }
body.menu-open .menu-item:nth-child(1) { transition-delay: 160ms; }
body.menu-open .menu-item:nth-child(2) { transition-delay: 220ms; }
body.menu-open .menu-item:nth-child(3) { transition-delay: 280ms; }
body.menu-open .menu-item:nth-child(4) { transition-delay: 340ms; }
body.menu-open .menu-item:nth-child(5) { transition-delay: 400ms; }
body.menu-open .menu-item:nth-child(6) { transition-delay: 460ms; }
body.menu-open .menu-item:nth-child(7) { transition-delay: 520ms; }

/* Signature hairline with midpoint bullet beneath each item */
.menu-item::after {
  content: "";
  position: absolute;
  left: 40px; right: 0; bottom: 0;
  height: 1px;
  background: var(--vv-line);
  transition: background var(--m-base) var(--ease);
}
.menu-item::before {
  content: "";
  position: absolute;
  left: calc(40px + 50%);
  bottom: 0;
  width: 3px; height: 3px;
  background: var(--vv-gold);
  border-radius: 50%;
  transform: translate(-50%, 50%);
  transition: background var(--m-base) var(--ease);
}
.menu-item:last-child::after,
.menu-item:last-child::before { background: transparent; }

.menu-item .m-num {
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--vv-gold-deep);
  padding-top: 10px;
  opacity: .9;
  align-self: start;
}

.menu-item .m-main {
  display: grid;
  grid-template-columns: minmax(180px, auto) 1fr;
  gap: clamp(12px, 2vw, 24px);
  align-items: baseline;
}

.menu-item .m-title {
  font-family: var(--fd);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(34px, 4.6vw, 64px);
  line-height: 1;
  letter-spacing: -0.018em;
  color: var(--vv-ink);
  transition:
    color var(--m-base) var(--ease),
    transform var(--m-base) var(--ease);
}
.menu-item .m-tag {
  font-family: var(--fd);
  font-style: normal;
  font-size: clamp(14px, 1.05vw, 17px);
  color: var(--vv-ink-soft);
  opacity: .82;
  line-height: 1.4;
  max-width: 36ch;
  transition: opacity var(--m-base) var(--ease), color var(--m-base) var(--ease);
}

.menu-item .m-kn {
  font-family: var(--fk);
  font-size: clamp(16px, 1.2vw, 20px);
  color: var(--vv-gold-deep);
  letter-spacing: .01em;
  line-height: 1;
  transition: color var(--m-base) var(--ease);
  align-self: center;
}

.menu-item .m-arrow {
  font-family: var(--fb);
  font-size: clamp(18px, 1.4vw, 22px);
  color: var(--vv-ink-mute);
  transition:
    transform var(--m-base) var(--ease),
    color var(--m-base) var(--ease),
    opacity var(--m-base) var(--ease);
  opacity: .45;
}

.menu-item:hover,
.menu-item:focus-visible {
  outline: none;
  color: var(--vv-gold-deep);
}
.menu-item:hover .m-title,
.menu-item:focus-visible .m-title {
  color: var(--vv-gold-deep);
  transform: translateX(8px);
}
.menu-item:hover .m-tag,
.menu-item:focus-visible .m-tag { opacity: 1; color: var(--vv-ink); }
.menu-item:hover .m-arrow,
.menu-item:focus-visible .m-arrow {
  transform: translateX(10px);
  opacity: 1;
  color: var(--vv-gold-deep);
}
.menu-item:hover::after,
.menu-item:focus-visible::after { background: var(--vv-gold); }
.menu-item:hover::before,
.menu-item:focus-visible::before { background: var(--vv-gold-deep); }

@media (max-width: 860px) {
  .menu-body { grid-template-columns: 1fr; }
  .menu-item { grid-template-columns: 34px 1fr auto; }
  .menu-item .m-arrow { display: none; }
  .menu-item .m-main { grid-template-columns: 1fr; gap: 4px; }
}

/* ----- menu preview aside ----- */
.menu-preview {
  position: relative;
  align-self: stretch;
  min-height: 420px;
  overflow: hidden;
  background: var(--vv-paper-vellum);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 720ms var(--ease-out) 200ms, transform 720ms var(--ease-out) 200ms;
}
body.menu-open .menu-preview { opacity: 1; transform: translateY(0); }

.menu-preview .preview-head {
  position: absolute;
  top: var(--s5); left: var(--s5); right: var(--s5);
  display: flex; justify-content: space-between;
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-paper);
  z-index: 2;
  mix-blend-mode: difference;
}
.menu-preview .preview-stack {
  position: absolute; inset: 0; overflow: hidden;
}
.menu-preview .preview-frame {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity var(--m-slow) var(--ease);
}
.menu-preview .preview-frame.is-active { opacity: 1; }
.menu-preview .preview-frame::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(46,40,24,0) 55%, rgba(46,40,24,.45) 100%);
}

.menu-preview .preview-caption {
  position: absolute;
  left: var(--s5); right: var(--s5); bottom: var(--s5);
  color: var(--vv-paper);
  z-index: 2;
}
.menu-preview .preview-caption .kn {
  display: block;
  font-family: var(--fk);
  font-size: clamp(24px, 2vw, 32px);
  color: var(--vv-gold-leaf);
  line-height: 1;
  margin-bottom: 8px;
}
.menu-preview .preview-caption .quote {
  font-family: var(--fd);
  font-style: italic;
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.3;
  margin: 0 0 6px 0;
  max-width: 28ch;
}
.menu-preview .preview-caption .meta {
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  opacity: .85;
}

@media (max-width: 860px) {
  .menu-preview { min-height: 220px; }
}

/* ----- menu bottombar ----- */
.menu-bottombar {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--s5);
  padding: 20px var(--container-pad);
  border-top: 1px solid var(--vv-line);
  background: var(--vv-paper-ivory);
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-ink);
}
.menu-bottombar .mb-left a,
.menu-bottombar .mb-right a {
  font-family: var(--fd);
  font-style: italic;
  font-size: 17px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--vv-ink);
  transition: color var(--m-fast) var(--ease);
}
.menu-bottombar .mb-left a:hover,
.menu-bottombar .mb-right a:hover { color: var(--vv-gold-deep); }
.menu-bottombar .mb-center em {
  font-family: var(--fd);
  font-style: italic;
  color: var(--vv-gold-deep);
}
.menu-bottombar .mb-right { text-align: right; }

@media (max-width: 640px) {
  .menu-bottombar { grid-template-columns: 1fr; justify-items: center; gap: var(--s3); text-align: center; }
}


/* =========================================================================
   PHASE C · Chapter numerals + art-deco corner flourishes
   ========================================================================= */

/* A large faded Roman numeral anchored at the top of each section,
   setting up a book-chapter rhythm. One numeral per section. */
.chapter-num {
  position: absolute;
  top: clamp(28px, 5vh, 72px);
  left: clamp(16px, 3vw, 48px);
  font-family: var(--fd);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(68px, 8.4vw, 136px);
  line-height: 1;
  color: var(--vv-gold-deep);
  opacity: .22;
  letter-spacing: -0.02em;
  user-select: none;
  pointer-events: none;
  z-index: 1;
}
/* On the cover, shift down to live in the left margin next to the centered
   hero copy without colliding with the chrome. */
.cover .chapter-num {
  top: clamp(140px, 20vh, 220px);
}

/* Art-deco corner flourish — an L-bracket + inner accent + corner dot.
   Rotated via transform to serve all four corners from one SVG. */
.corner-flourish {
  position: absolute;
  width: clamp(36px, 3.8vw, 54px);
  height: clamp(36px, 3.8vw, 54px);
  color: var(--vv-gold-deep);
  pointer-events: none;
  opacity: .78;
  z-index: 1;
}
.corner-flourish--tl { top: clamp(24px, 3.2vh, 48px); left:  clamp(24px, 3vw, 56px); }
.corner-flourish--tr { top: clamp(24px, 3.2vh, 48px); right: clamp(24px, 3vw, 56px); transform: scaleX(-1); }
.corner-flourish--bl { bottom: clamp(24px, 3.2vh, 48px); left:  clamp(24px, 3vw, 56px); transform: scaleY(-1); }
.corner-flourish--br { bottom: clamp(24px, 3.2vh, 48px); right: clamp(24px, 3vw, 56px); transform: scale(-1, -1); }


/* =========================================================================
   PHASE D · Line illustrations (arch, façade, frangipani)
   ========================================================================= */

/* Arched doorway silhouette behind the anchor copy — an architectural echo
   of the V mark's upward thrust. Non-interactive, low-opacity, centered. */
.arch-bg {
  position: absolute;
  left: 50%;
  top: clamp(60px, 8vh, 120px);
  transform: translateX(-50%);
  width: clamp(280px, 42vw, 520px);
  height: auto;
  color: var(--vv-gold-deep);
  opacity: 0.07;
  pointer-events: none;
  z-index: 0;
}
.anchor { overflow: hidden; }
/* Raise the anchor content above the background arch */
.anchor > *:not(.arch-bg) { position: relative; z-index: 1; }

/* A schematic hotel façade SVG, placed in the bottom-left of the Place
   section as a small editorial mark. */
.facade {
  position: absolute;
  bottom: clamp(40px, 6vh, 80px);
  left: clamp(24px, 4vw, 64px);
  width: clamp(180px, 18vw, 240px);
  height: auto;
  color: var(--vv-gold-deep);
  opacity: 0.4;
  pointer-events: none;
  z-index: 0;
}

/* Stylized frangipani / jasmine branch — Bengaluru flora, bottom-right of
   the Reserve band. Hairline only, gold-deep. */
.botanical {
  position: absolute;
  bottom: clamp(-16px, 0vh, 24px);
  right: clamp(-24px, -1vw, 24px);
  width: clamp(120px, 16vw, 220px);
  height: auto;
  color: var(--vv-gold-deep);
  opacity: 0.32;
  pointer-events: none;
  z-index: 0;
}

@media (max-width: 860px) {
  .facade, .botanical { display: none; }
}


/* =========================================================================
   PHASE E · Cinematic photography bands (rhythm dividers)
   ========================================================================= */

.photo-band {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: var(--vv-paper-vellum);
  border-top: 1px solid var(--vv-line);
  border-bottom: 1px solid var(--vv-line);
}
.photo-band img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.photo-band--triptych {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--vv-line);
  height: clamp(220px, 28vh, 340px);
}
.photo-band--single {
  height: clamp(280px, 36vh, 440px);
}

/* A small editorial caption anchored bottom-left inside the cinematic band */
.photo-band .band-caption {
  position: absolute;
  left: var(--container-pad);
  bottom: clamp(16px, 2vh, 28px);
  font-family: var(--fb);
  font-size: var(--t-label);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--vv-paper);
  opacity: .9;
  text-shadow: 0 1px 2px rgba(0,0,0,.3);
  z-index: 2;
}

@media (max-width: 640px) {
  .photo-band--triptych { grid-template-columns: 1fr; height: auto; }
  .photo-band--triptych img { height: clamp(180px, 32vh, 260px); }
}


/* ---------- 13. Body-stack & reveal footer ---------- */

/* The body-stack wraps all scrolling content and sits above the fixed footer.
   Its bottom margin is set in JS to the footer's measured height. */
.body-stack {
  position: relative;
  z-index: 2;
  background: var(--vv-paper);
  margin-bottom: var(--footer-height, 0px);
}

/* When the footer is revealed as a peel, it is fixed at viewport bottom,
   and the body-stack scrolls off above it. */
.v-footer.is-reveal {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 1;
  /* Make sure the footer doesn't trigger its own scroll */
  max-height: 100vh;
  overflow: hidden;
}

/* Prime footer children — they fade up once revealed */
.v-footer.is-reveal > .v-footer-inner,
.v-footer.is-reveal > .v-footer-bottom,
.v-footer.is-reveal > .v-footer-inner > * {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 680ms var(--ease-out), transform 680ms var(--ease-out);
}

/* Staggered delays on footer children */
.v-footer.is-reveal > .v-footer-inner > *:nth-child(1) { transition-delay: 0ms; }
.v-footer.is-reveal > .v-footer-inner > *:nth-child(2) { transition-delay: 120ms; }
.v-footer.is-reveal > .v-footer-inner > *:nth-child(3) { transition-delay: 200ms; }
.v-footer.is-reveal > .v-footer-inner > *:nth-child(4) { transition-delay: 280ms; }
.v-footer.is-reveal > .v-footer-bottom { transition-delay: 360ms; }

/* Reveal state — set by IntersectionObserver in main.js when the body-stack end enters view */
.v-footer.is-reveal.is-revealing > .v-footer-inner,
.v-footer.is-reveal.is-revealing > .v-footer-bottom,
.v-footer.is-reveal.is-revealing > .v-footer-inner > * {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .v-footer.is-reveal > .v-footer-inner,
  .v-footer.is-reveal > .v-footer-bottom,
  .v-footer.is-reveal > .v-footer-inner > * {
    transform: none;
    transition: opacity var(--m-fast) var(--ease-out);
  }
}
