/* ============================================================
   FIVE SEASONS — interior page styles
   ============================================================ */

/* page hero (interior pages, below fixed header) */
.page-hero{
  padding:clamp(8rem,16vh,11rem) 0 clamp(3rem,7vw,5rem);
  text-align:center;
  background:radial-gradient(ellipse 70% 80% at 50% 0%,#16120a,var(--ink));
}
.page-hero--video{position:relative;overflow:hidden;background:#000}
.page-hero__video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:0;opacity:.5;
}
.page-hero--video::after{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(10,10,10,.7),rgba(10,10,10,.4) 50%,rgba(10,10,10,.85));
}

/* full-width video divider */
.video-divider{
  position:relative;min-height:60vh;display:grid;place-items:center;
  overflow:hidden;background:#000;text-align:center;
}
.video-divider video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.8;
}
.video-divider::after{
  content:'';position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse 80% 70% at 50% 50%,transparent,rgba(10,10,10,.7));
}
.video-divider__text{
  position:relative;z-index:2;
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(1.5rem,3.5vw,2.8rem);line-height:1.4;
  color:var(--bone);max-width:20ch;margin-inline:auto;padding:2rem;
  text-shadow:0 2px 30px rgba(0,0,0,.8);
}
.page-hero h1{
  font-size:clamp(2.4rem,6vw,4.6rem);
  font-weight:300;letter-spacing:.04em;margin:.8rem 0 1.4rem;
}
.page-hero h1 .em{font-style:italic;color:var(--gold-bright)}
.page-hero__lead{
  max-width:60ch;margin:0 auto;color:var(--ash);
  font-size:clamp(1.05rem,1.6vw,1.25rem);line-height:1.7;
}

/* ============================================================
   ROOMS
   ============================================================ */
.rooms{display:flex;flex-direction:column;gap:clamp(2.5rem,5vw,4.5rem)}
.room{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center;
}
.room--rev .room__media{order:2}
@media (max-width:820px){
  .room,.room--rev{grid-template-columns:1fr}
  .room--rev .room__media{order:0}
}
.room__media{
  aspect-ratio:4/3;background:var(--ink) center/cover;position:relative;
  border:1px solid var(--line);min-height:280px;
}
.room__price{
  position:absolute;bottom:1rem;left:1rem;
  background:rgba(10,10,10,.78);backdrop-filter:blur(6px);
  border:1px solid var(--gold);color:var(--gold-bright);
  font-family:var(--display);font-style:italic;font-size:1.05rem;
  padding:.35rem 1rem;letter-spacing:.04em;
}
.room__it{font-family:var(--display);font-style:italic;color:var(--gold);font-size:1.15rem;margin-bottom:.3rem;letter-spacing:.02em}
.room__body h3{font-size:clamp(1.6rem,3vw,2.3rem);color:var(--bone);font-weight:400;margin-bottom:.7rem}
.room__spec{
  font-family:var(--display);text-transform:uppercase;letter-spacing:.14em;
  font-size:.78rem;color:var(--ash);margin-bottom:1.3rem;line-height:1.9;
}
.room__body p{color:var(--ash);line-height:1.75}

/* ============================================================
   GOOD TO KNOW
   ============================================================ */
.know{border:1px solid var(--line);padding:clamp(2rem,5vw,3.5rem);background:linear-gradient(180deg,var(--ink-soft),var(--ink))}
.know__head{text-align:center;margin-bottom:2.5rem}
.know__head h2{font-size:clamp(1.8rem,3.5vw,2.6rem);font-style:italic;color:var(--gold-bright);margin-top:.6rem;font-weight:400}
.know__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem 2.5rem}
@media (max-width:680px){.know__grid{grid-template-columns:1fr}}
.know__item h4{font-family:var(--display);text-transform:uppercase;letter-spacing:.18em;font-size:.82rem;color:var(--gold);margin-bottom:.7rem;font-weight:500}
.know__item p{color:var(--ash);font-size:.96rem;line-height:1.7}
.know__buyout{text-align:center;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--line);font-size:.98rem}
.know__buyout a{color:var(--gold);border-bottom:1px solid var(--gold-dim)}
.know__buyout a:hover{color:var(--gold-bright)}

/* ============================================================
   DINING upgrades
   ============================================================ */
.dining{max-width:860px;margin:0 auto;border-top:1px solid var(--line)}
.dining__row{
  display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem;align-items:baseline;
  padding:1.6rem 0;border-bottom:1px solid var(--line);
}
@media (max-width:640px){.dining__row{grid-template-columns:1fr;gap:.4rem}}
.dining__day{font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--gold);white-space:nowrap;min-width:9ch}
.dining__main b{font-family:var(--display);font-size:1.3rem;color:var(--bone);font-weight:500;display:block;margin-bottom:.25rem}
.dining__main span{color:var(--ash);font-size:.95rem;line-height:1.6}
.dining__price{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--gold-bright);white-space:nowrap}

/* ============================================================
   OPTIONAL experiences
   ============================================================ */
.opt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media (max-width:720px){.opt-grid{grid-template-columns:1fr}}
.opt{
  background:var(--ink);padding:1.5rem 1.8rem;
  display:flex;flex-direction:column;gap:.3rem;
  transition:background .35s var(--ease);
}
.opt:hover{background:var(--ink-soft)}
.opt__name{font-family:var(--display);font-size:1.15rem;color:var(--bone)}
.opt__note{color:var(--ash);font-size:.9rem;line-height:1.5;flex-grow:1}
.opt__price{font-family:var(--display);font-style:italic;color:var(--gold-bright);font-size:1.05rem;margin-top:.3rem}

/* ============================================================
   EVENTS / generic content blocks (used by events, london, about, contact)
   ============================================================ */
.prose{max-width:62ch;margin:0 auto}
.prose p{color:var(--ash);margin-bottom:1.4rem;line-height:1.8}
.prose p.big{font-family:var(--display);font-size:clamp(1.3rem,2.4vw,1.9rem);color:var(--bone);font-weight:300;line-height:1.5}

.event-card{
  border:1px solid var(--line);padding:clamp(1.8rem,4vw,3rem);
  background:linear-gradient(180deg,var(--ink-soft),var(--ink));margin-bottom:1.5rem;
  display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:center;
}
@media (max-width:680px){.event-card{grid-template-columns:1fr}}
.event-card__date{font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.8rem;color:var(--gold);margin-bottom:.5rem}
.event-card h3{font-size:clamp(1.5rem,3vw,2.2rem);color:var(--bone);font-weight:400;margin-bottom:.6rem}
.event-card p{color:var(--ash);line-height:1.7}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
@media (max-width:760px){.contact-grid{grid-template-columns:1fr}}
.contact-block h4{font-family:var(--display);text-transform:uppercase;letter-spacing:.18em;font-size:.85rem;color:var(--gold);margin-bottom:1rem;font-weight:500}
.contact-block a,.contact-block p{color:var(--bone);display:block;margin-bottom:.5rem}
.contact-block a:hover{color:var(--gold-bright)}

/* ============================================================
   JOURNAL
   ============================================================ */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media (max-width:900px){.journal-grid{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}
.post-card{
  border:1px solid var(--line);background:var(--ink);overflow:hidden;
  display:flex;flex-direction:column;transition:border-color .4s var(--ease),transform .4s var(--ease);
}
.post-card:hover{border-color:var(--gold);transform:translateY(-4px)}
.post-card__media{aspect-ratio:3/2;background:var(--ink-soft) center/cover}
.post-card__body{padding:1.8rem;display:flex;flex-direction:column;gap:.6rem}
.post-card__date{font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--gold)}
.post-card__body h3{font-size:1.35rem;color:var(--bone);font-weight:400;line-height:1.25}
.post-card__body p{color:var(--ash);font-size:.95rem;line-height:1.6}

/* ============================================================
   SAMPLE MENUS
   ============================================================ */
.menu-list{max-width:720px;margin:0 auto;border-top:1px solid var(--line)}
.menu-course{display:flex;gap:1.5rem;padding:1.5rem 0;border-bottom:1px solid var(--line);align-items:baseline}
.menu-course__num{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--gold);min-width:2.5ch;text-align:right}
.menu-course b{font-family:var(--display);font-size:1.3rem;color:var(--bone);font-weight:500;display:block;margin-bottom:.2rem}
.menu-course span{color:var(--ash);font-size:.95rem;line-height:1.55}

/* room gallery strip */
.room-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:-1rem}
@media (max-width:820px){.room-gallery{grid-template-columns:1fr 1fr}}
.room-gallery__item{
  aspect-ratio:4/3;background:var(--ink-soft) center/cover;
  border:1px solid var(--line);transition:transform .5s var(--ease),border-color .4s;
}
.room-gallery__item:hover{transform:scale(1.02);border-color:var(--gold)}

/* taller media for portrait room photos */
.room__media--tall{aspect-ratio:3/4;min-height:420px}
@media (max-width:820px){.room__media--tall{aspect-ratio:4/5}}

/* tall band media for portrait showcase photos */
.band__media--tall{min-height:520px}
@media (max-width:860px){.band__media--tall{min-height:380px}}

/* whatsapp link accent */
.wa-link{color:var(--gold)!important;border-bottom:1px solid var(--gold-dim);display:inline-block;width:fit-content}
.wa-link:hover{color:var(--gold-bright)!important}

/* featured event card (Garden Festival) */
.event-card--feature{border-color:var(--gold-dim);background:linear-gradient(180deg,rgba(201,162,95,.05),transparent)}
.event-card__tease{
  font-family:var(--display);font-style:italic;font-size:1.25rem;
  color:var(--gold-bright);line-height:1.45;margin:.2rem 0 1rem;max-width:42ch;
}
.event-tiers{display:flex;gap:1rem;flex-wrap:wrap;margin:1.4rem 0 1rem}
.event-tier{
  flex:1;min-width:130px;border:1px solid var(--line);padding:1rem 1.1rem;
  background:var(--ink);transition:border-color .3s var(--ease)}
.event-tier:hover{border-color:var(--gold)}
.event-tier b{display:block;font-family:var(--display);letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;color:var(--ash)}
.event-tier span{display:block;font-family:var(--display);font-size:1.8rem;color:var(--gold-bright);margin:.2rem 0}
.event-tier small{display:block;font-size:.82rem;color:var(--ash);line-height:1.4}

/* three-column layout (Private page) */
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}
@media (max-width:860px){.three-col{grid-template-columns:1fr;max-width:520px;margin-inline:auto;gap:3rem}}
.three-col__item h3{font-size:1.5rem;font-weight:400;color:var(--bone);margin:.6rem 0 .8rem;line-height:1.25}
.three-col__item p{color:var(--ash);line-height:1.65}
