/* ============================================================
   Novotel Residences JVT — Pass 1
   Palette: cream #F3EFE4 · navy #0F1155 · blue #1E22AA · white
   Type: Fraunces (display serif) + Inter (UI/body)
   ============================================================ */

:root{
  --cream:#F3EFE4;
  --cream-2:#EAE4D5;
  --navy:#0F1155;
  --blue:#1E22AA;
  --white:#FFFFFF;
  --ink:#15173A;
  --muted:#6B6E86;
  --line:rgba(15,17,85,.14);

  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, sans-serif;

  --pad:clamp(1.25rem, 4vw, 3.75rem);
  --maxw:1600px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
em{ font-style:italic; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--blue); color:#fff; }

/* Lenis */
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-stopped{ overflow:hidden; }

.serif{ font-family:var(--serif); }
.kicker{
  font-size:.72rem; letter-spacing:.22em; text-transform:uppercase;
  font-weight:500; color:var(--muted);
}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed; inset:0 0 auto 0; z-index:120;
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center;
  padding:1.6rem var(--pad);
  color:#fff;
  transition:background .5s var(--ease), color .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.header.scrolled{
  background:var(--cream);
  color:var(--navy);
  padding:.95rem var(--pad);
  box-shadow:0 1px 0 var(--line);
}
.header__zone{ display:flex; align-items:center; gap:1.5rem; }
.header__right{ justify-content:flex-end; }

/* logo */
.header__logo{
  justify-self:center; display:flex; flex-direction:column; align-items:center; gap:.28rem;
  color:inherit;
}
.logo-svg{ width:clamp(118px,9vw,150px); height:auto; display:block; transition:width .5s var(--ease); }
.header:not(.scrolled) .logo-svg{ width:clamp(170px,14vw,230px); }
.header__logo-sub{
  font-size:.58rem; letter-spacing:.42em; font-weight:500;
  padding-left:.42em; opacity:.85; transition:font-size .5s var(--ease), letter-spacing .5s var(--ease);
}
.header:not(.scrolled) .header__logo-sub{ font-size:.7rem; letter-spacing:.5em; }

/* menu toggle */
.menu-toggle{ display:flex; align-items:center; gap:.7rem; }
.menu-toggle__lines{ position:relative; width:26px; height:12px; display:inline-block; }
.menu-toggle__lines i{
  position:absolute; left:0; width:100%; height:1.5px; background:currentColor;
  transition:transform .45s var(--ease), top .3s var(--ease), opacity .3s var(--ease);
}
.menu-toggle__lines i:nth-child(1){ top:2px; }
.menu-toggle__lines i:nth-child(2){ top:9px; }
.menu-toggle__label{
  font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; font-weight:500;
}
body.menu-open .menu-toggle__lines i:nth-child(1){ top:9px; transform:rotate(45deg); }
body.menu-open .menu-toggle__lines i:nth-child(2){ top:9px; transform:rotate(-45deg); }

/* lang */
.lang{ position:relative; }
.lang__btn{ font-size:.72rem; letter-spacing:.16em; font-weight:500; text-transform:uppercase; }
.lang__menu{
  position:absolute; top:130%; left:50%; transform:translateX(-50%) translateY(6px);
  background:#fff; color:var(--navy); border-radius:8px; padding:.35rem 0;
  display:flex; flex-direction:column; min-width:62px; box-shadow:0 14px 40px rgba(0,0,0,.16);
  opacity:0; visibility:hidden; transition:.25s var(--ease);
}
.lang:hover .lang__menu{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.lang__menu a{ padding:.4rem 1rem; font-size:.78rem; }
.lang__menu a:hover{ color:var(--blue); }

/* book button */
.btn-book{
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid currentColor; border-radius:4px;
  padding:.7rem 1.5rem; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; font-weight:500;
  transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
}
.btn-book:hover{ background:var(--blue); border-color:var(--blue); color:#fff; }
.header.scrolled .btn-book:hover{ color:#fff; }

/* hide header chrome when menu open (keep toggle + logo) */
body.menu-open .header{ color:#fff !important; background:transparent !important; box-shadow:none !important; }
body.menu-open .btn-book{ opacity:0; pointer-events:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; height:100svh; min-height:600px; width:100%; overflow:hidden; }
.hero__media{ position:absolute; inset:0; }
.hero__video{ width:100%; height:100%; object-fit:cover; }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(rgba(0,0,0,.10), rgba(0,0,0,.10)),
    linear-gradient(to bottom, rgba(15,17,85,.42) 0%, rgba(15,17,85,0) 28%),
    linear-gradient(to top, rgba(15,17,85,.55) 0%, rgba(15,17,85,0) 42%);
}
.hero__content{
  position:absolute; left:0; right:0; bottom:clamp(220px,36vh,440px);
  text-align:center; color:#fff; padding:0 var(--pad);
}
.hero__kicker{
  font-size:clamp(.74rem,1vw,.9rem); letter-spacing:.26em; text-transform:uppercase; font-weight:500;
  opacity:.92; margin-bottom:1.4rem;
}
.hero__title{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(3rem, 8.4vw, 7.6rem); line-height:1.02;
  letter-spacing:-.015em;
  font-optical-sizing:auto;
}
.hero__title em{ font-weight:300; }

.hero__scroll{
  position:absolute; left:50%; bottom:34px; transform:translateX(-50%);
  display:none; flex-direction:column; align-items:center; gap:.6rem; color:#fff;
  font-size:.64rem; letter-spacing:.22em; text-transform:uppercase;
}
.hero__scroll i{ width:1px; height:34px; background:rgba(255,255,255,.6); position:relative; overflow:hidden; }
.hero__scroll i::after{ content:""; position:absolute; inset:0; background:#fff; transform:translateY(-100%); animation:scrollcue 2.2s var(--ease) infinite; }
@keyframes scrollcue{ 0%{transform:translateY(-100%)} 50%{transform:translateY(0)} 100%{transform:translateY(100%)} }

/* reveal */
.reveal-up{ opacity:0; transform:translateY(28px); }

/* ============================================================
   BOOKING BAR — fixed bottom, big -> compact, hides at footer
   ============================================================ */
.booking{
  position:fixed; left:0; right:0; bottom:clamp(20px,3.4vh,34px);
  z-index:110; display:flex; justify-content:center; padding:0 var(--pad);
  transition:transform .55s var(--ease), opacity .45s var(--ease);
}
.booking.hidden{ transform:translateY(180%); opacity:0; pointer-events:none; }

.booking__bar{
  position:relative;
  width:min(1060px, 100%);
  display:flex; align-items:stretch; gap:.4rem;
  background:#fff; border-radius:12px;
  padding:.5rem .5rem .5rem 1rem;
  box-shadow:0 24px 70px rgba(15,17,85,.28);
  transition:width .55s var(--ease), padding .5s var(--ease), border-radius .5s var(--ease), box-shadow .5s var(--ease);
}
.booking__field{
  display:flex; align-items:center; gap:.85rem; flex:1; text-align:left;
  padding:1.05rem 1.2rem; border-radius:9px; transition:background .25s var(--ease), padding .5s var(--ease);
}
.booking__field:hover{ background:rgba(15,17,85,.045); }
.booking__icon{ width:24px; height:24px; flex:none; fill:none; stroke:var(--blue); stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; transition:width .5s var(--ease), height .5s var(--ease); }
.booking__text{ display:flex; flex-direction:column; gap:.18rem; min-width:0; }
.booking__label{ font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:500; }
.booking__value{ font-size:1.02rem; color:var(--navy); font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; transition:font-size .5s var(--ease); }
.booking__sep{ width:1px; background:var(--line); margin:.9rem 0; flex:none; }
.booking__search{
  flex:none; background:var(--blue); color:#fff; border-radius:9px;
  padding:0 2.2rem; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; font-weight:500;
  transition:background .3s var(--ease), padding .5s var(--ease), font-size .5s var(--ease);
}
.booking__search:hover{ background:var(--navy); }

/* compact (after scrolling past hero) */
.booking.compact .booking__bar{ width:min(900px, 100%); padding:.45rem .45rem .45rem .85rem; box-shadow:0 18px 48px rgba(15,17,85,.22); }
.booking.compact .booking__field{ padding:.8rem 1.05rem; gap:.7rem; }
.booking.compact .booking__icon{ width:22px; height:22px; }
.booking.compact .booking__value{ font-size:.95rem; }
.booking.compact .booking__label{ display:none; }
.booking.compact .booking__sep{ margin:.7rem 0; }
.booking.compact .booking__search{ padding:0 1.8rem; font-size:.78rem; }

/* popovers */
.pop{
  position:absolute; bottom:calc(100% + 12px); left:0;
  background:#fff; border-radius:14px; box-shadow:0 30px 80px rgba(15,17,85,.26);
  padding:1.2rem; z-index:5; animation:popin .3s var(--ease);
}
.pop--dates{ left:0; }
.pop--guests{ left:34%; width:320px; }
.pop--promo{ right:120px; left:auto; width:300px; }
@keyframes popin{ from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:translateY(0)} }
.pop__foot{ display:flex; justify-content:flex-end; gap:.6rem; margin-top:1rem; padding-top:.9rem; border-top:1px solid var(--line); }
.pop__done{ background:var(--navy); color:#fff; border-radius:7px; padding:.6rem 1.4rem; font-size:.78rem; letter-spacing:.06em; }
.pop__done:hover{ background:var(--blue); }
.pop__clear{ color:var(--muted); font-size:.78rem; padding:.6rem .8rem; }
.pop__clear:hover{ color:var(--navy); }
.pop__promolabel{ display:block; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:.6rem; }
.pop__input{ width:100%; border:1px solid var(--line); border-radius:8px; padding:.8rem 1rem; font-size:1rem; font-family:inherit; }
.pop__input:focus{ outline:none; border-color:var(--blue); }

/* calendar */
.cal{ display:flex; gap:1.6rem; }
.cal__month{ width:248px; }
.cal__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:.7rem; }
.cal__title{ font-family:var(--serif); font-size:1.05rem; color:var(--navy); }
.cal__nav{ width:30px; height:30px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--navy); }
.cal__nav:hover{ background:rgba(15,17,85,.07); }
.cal__nav[disabled]{ opacity:.25; pointer-events:none; }
.cal__grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.cal__dow{ font-size:.6rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); text-align:center; padding:.3rem 0; }
.cal__day{ aspect-ratio:1; display:flex; align-items:center; justify-content:center; font-size:.82rem; border-radius:50%; color:var(--ink); position:relative; }
.cal__day:hover:not(.is-empty):not([disabled]){ background:rgba(30,34,170,.12); }
.cal__day[disabled]{ color:#c9c6ba; pointer-events:none; }
.cal__day.is-empty{ pointer-events:none; }
.cal__day.in-range{ background:rgba(30,34,170,.10); border-radius:0; }
.cal__day.is-start,.cal__day.is-end{ background:var(--blue); color:#fff; }
.cal__day.is-start{ border-radius:50% 0 0 50%; }
.cal__day.is-end{ border-radius:0 50% 50% 0; }
.cal__day.is-start.is-end{ border-radius:50%; }

/* steppers */
.stepper{ display:flex; align-items:center; justify-content:space-between; padding:.7rem 0; border-bottom:1px solid var(--line); }
.stepper:last-of-type{ border-bottom:none; }
.stepper strong{ font-weight:500; color:var(--navy); font-size:.95rem; display:block; }
.stepper small{ color:var(--muted); font-size:.72rem; }
.stepper__ctl{ display:flex; align-items:center; gap:1rem; }
.stepper__ctl button{ width:32px; height:32px; border:1px solid var(--line); border-radius:50%; color:var(--navy); font-size:1.1rem; display:flex; align-items:center; justify-content:center; transition:.2s var(--ease); }
.stepper__ctl button:hover{ border-color:var(--blue); color:var(--blue); }
.stepper__ctl span{ min-width:18px; text-align:center; font-weight:500; }

/* ============================================================
   PLACEHOLDER SECTIONS (replaced in Pass 2)
   ============================================================ */
.section{ position:relative; }
.ph{
  min-height:70vh; display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:1.4rem; color:var(--muted);
  border-top:1px solid var(--line);
}
.living .ph{ background:#1a1c44; color:rgba(255,255,255,.5); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--navy); color:#fff; padding:clamp(4rem,8vw,7rem) var(--pad) 2.5rem; }
.footer__news{ text-align:center; max-width:620px; margin:0 auto clamp(3rem,6vw,5rem); }
.footer__newsTitle{ font-family:var(--serif); font-weight:300; font-size:clamp(1.8rem,4vw,3rem); line-height:1.1; }
.footer__newsSub{ color:rgba(255,255,255,.6); margin-top:.9rem; }
.footer__form{ display:flex; max-width:420px; margin:2rem auto 0; gap:0; }
.footer__form input{ flex:1; background:transparent; border:1px solid rgba(255,255,255,.3); border-right:none; border-radius:6px 0 0 6px; padding:.9rem 1.1rem; color:#fff; font-family:inherit; font-size:.95rem; }
.footer__form input::placeholder{ color:rgba(255,255,255,.45); }
.footer__form input:focus{ outline:none; border-color:#fff; }
.footer__form button{ background:#fff; color:var(--navy); padding:0 1.5rem; border-radius:0 6px 6px 0; font-weight:600; letter-spacing:.05em; }
.footer__form button:hover{ background:var(--blue); color:#fff; }

.footer__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; max-width:var(--maxw); margin:0 auto; padding:clamp(2.5rem,5vw,4rem) 0; border-top:1px solid rgba(255,255,255,.14); }
.footer__col h4{ font-family:var(--serif); font-weight:400; font-size:1.1rem; margin-bottom:1.1rem; }
.footer__col a{ display:block; color:rgba(255,255,255,.6); font-size:.9rem; padding:.32rem 0; transition:color .2s var(--ease); }
.footer__col a:hover{ color:#fff; }
.footer__bar{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; max-width:var(--maxw); margin:0 auto; padding-top:2rem; border-top:1px solid rgba(255,255,255,.14); color:rgba(255,255,255,.5); font-size:.78rem; }

/* ============================================================
   MEGAMENU
   ============================================================ */
.mega{
  position:fixed; inset:0; z-index:115; background:var(--navy); color:#fff;
  display:flex; align-items:center;
  padding:7rem var(--pad) 3rem;
  clip-path:inset(0 0 100% 0);
  visibility:hidden;
  transition:clip-path .7s var(--ease), visibility 0s linear .7s;
}
body.menu-open .mega{ clip-path:inset(0 0 0% 0); visibility:visible; transition:clip-path .8s var(--ease); }
.mega__inner{ display:grid; grid-template-columns:1.5fr 1fr .9fr; gap:clamp(2rem,4vw,5rem); width:100%; max-width:var(--maxw); margin:0 auto; align-items:center; }

.mega__cards{ display:grid; grid-template-columns:1.3fr 1fr; grid-template-rows:1fr 1fr; gap:1rem; height:min(64vh,560px); }
.mcard{ position:relative; border-radius:10px; overflow:hidden; }
.mcard--big{ grid-row:1 / span 2; }
.mcard::before{ content:""; position:absolute; inset:0; background:var(--img) center/cover no-repeat; transform:scale(1.02); transition:transform .8s var(--ease); }
.mcard::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(8,9,40,.7), rgba(8,9,40,0) 60%); }
.mcard:hover::before{ transform:scale(1.08); }
.mcard__cap{ position:absolute; left:1.1rem; bottom:1rem; z-index:2; display:flex; flex-direction:column; gap:.15rem; }
.mcard__cap strong{ font-family:var(--serif); font-weight:400; font-size:1.3rem; }
.mcard__cap small{ font-size:.78rem; color:rgba(255,255,255,.7); }

.mega__nav{ list-style:none; }
.mega__nav li{ overflow:hidden; }
.mega__nav a{ font-family:var(--serif); font-weight:300; font-size:clamp(1.3rem,2vw,1.9rem); line-height:1.7; color:rgba(255,255,255,.86); display:inline-block; transition:color .25s var(--ease), transform .35s var(--ease); }
.mega__nav a:hover{ color:#fff; transform:translateX(10px); }

.mega__contact{ align-self:end; }
.mega__label{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.5); display:block; margin-bottom:1.1rem; }
.mega__contact p{ color:rgba(255,255,255,.75); font-size:.92rem; line-height:1.7; margin-bottom:1rem; }
.mega__contact > a{ font-size:1.05rem; color:#fff; }
.mega__social{ display:flex; gap:1.2rem; margin-top:1.6rem; }
.mega__social a{ font-size:.82rem; color:rgba(255,255,255,.7); }
.mega__social a:hover{ color:#fff; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .mega__inner{ grid-template-columns:1fr 1fr; }
  .mega__contact{ grid-column:1 / -1; align-self:start; margin-top:1rem; }
}
@media (max-width:860px){
  .header__logo-sub{ display:none; }
  .menu-toggle__label{ display:none; }
  .booking__bar{ flex-wrap:wrap; }
  .booking__sep{ display:none; }
  .booking__field{ flex:1 1 40%; }
  .booking__search{ flex:1 1 100%; padding:1rem; }
  .booking.compact .booking__bar{ width:100%; }
  .cal{ flex-direction:column; }
  .pop--guests,.pop--promo{ left:0; right:auto; width:min(320px,86vw); }
  .mega{ padding:6rem var(--pad) 2rem; overflow-y:auto; align-items:flex-start; }
  .mega__inner{ grid-template-columns:1fr; gap:2rem; }
  .mega__cards{ height:auto; grid-template-rows:200px 200px; }
  .footer__grid{ grid-template-columns:repeat(2,1fr); }
  .footer__bar{ flex-direction:column; }
}
@media (max-width:520px){
  .footer__grid{ grid-template-columns:1fr; }
  .mega__cards{ grid-template-columns:1fr; grid-template-rows:repeat(3,160px); }
  .mcard--big{ grid-row:auto; }
}
