/* ============================================================
   HORIZON — dark-luxury editorial system
   Display: Cormorant Garamond · Body: Be Vietnam Pro
   Palette (restrained): warm ink + ivory + gold, sunset ember accent
   ============================================================ */
:root{
  --ink:#0d0b09;
  --ink-2:#15110d;
  --ink-3:#1d1813;
  --card:#171210;
  --card-2:#1f1813;
  --cream:#f4ede1;
  --paper:#cdbfa8;
  --muted:#b3a48d;
  --muted-2:#8a7c66;
  --gold:#c9a25a;
  --gold-lt:#e6cd93;
  --ember:#e07a45;
  --line:rgba(201,162,90,.22);
  --line-soft:rgba(244,237,225,.09);
  --line-strong:rgba(244,237,225,.18);
  --gold-grad:linear-gradient(102deg,#ecd49b 0%,#c9a25a 52%,#a8803c 100%);
  --shadow:0 40px 90px -40px rgba(0,0,0,.85);
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  background:var(--ink);
  color:var(--cream);
  font-family:"Be Vietnam Pro",system-ui,sans-serif;
  font-weight:400;
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  background-image:
    radial-gradient(circle at top left, rgba(224,122,69,.08), transparent 28%),
    radial-gradient(circle at 86% 18%, rgba(201,162,90,.08), transparent 26%),
    linear-gradient(180deg, #0d0b09 0%, #130f0c 34%, #0d0b09 100%);
}
img{display:block;max-width:100%;height:auto}
[hidden]{display:none !important}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--gold);color:var(--ink)}
:focus-visible{outline:2px solid var(--gold-lt);outline-offset:3px;border-radius:2px}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,48px)}

/* ---- language switch ---- */
.lang-vi .en{display:none}
.lang-en .vi{display:none}

.skip-link{position:fixed;top:-60px;left:16px;z-index:200;background:var(--gold);color:var(--ink);padding:10px 16px;border-radius:8px;font-weight:600;transition:top .2s}
.skip-link:focus{top:12px}

/* ---- typography helpers ---- */
.h2{
  font-family:"Cormorant Garamond",serif;
  font-weight:500;
  font-size:clamp(2rem,4.6vw,3.5rem);
  line-height:1.02;
  letter-spacing:-.02em;
  color:var(--cream);
}
.h2--light{color:#fff}
.eyebrow{
  font-size:.74rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;
  color:var(--paper);margin-bottom:1.1rem;display:block;
}
.eyebrow--light{color:var(--gold-lt)}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:#e7ddcb;line-height:1.7}
.muted{color:var(--muted)}

.section{padding:clamp(72px,11vw,140px) 0;position:relative}
.section::before{
  content:"";
  position:absolute;
  top:0;
  left:clamp(20px,5vw,48px);
  width:72px;
  height:1px;
  background:linear-gradient(90deg,rgba(201,162,90,.85),rgba(201,162,90,0));
  opacity:.5;
}
.section__head{max-width:700px;margin-bottom:clamp(46px,6vw,74px)}
.section__head--center{margin-inline:auto;text-align:center}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:.92em 1.7em;border-radius:999px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s,border-color .25s;
  will-change:transform;
}
.btn--gold{background:var(--gold-grad);color:#2a1d0c;box-shadow:0 10px 30px -10px rgba(201,162,90,.6);min-height:48px}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(201,162,90,.7)}
.btn--ghost{border:1px solid var(--line);color:var(--cream);backdrop-filter:blur(4px);background:rgba(19,15,12,.42);min-height:48px}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-lt);transform:translateY(-2px);background:rgba(19,15,12,.72)}

/* ============ TOP BAR ============ */
.topbar{background:rgba(14,11,9,.92);border-bottom:1px solid var(--line-soft);font-size:.8rem;color:var(--muted)}
.topbar__inner{display:flex;align-items:center;gap:14px;height:38px}
.topbar__item{display:inline-flex;align-items:center;gap:7px}
.topbar__sep{color:var(--muted-2)}
.topbar__phone{margin-left:auto;display:inline-flex;align-items:center;gap:7px;color:var(--gold-lt);font-weight:600;letter-spacing:.02em}
.ic{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex:none}
@media(max-width:760px){.topbar__item:nth-child(3),.topbar__sep{display:none}}
@media(max-width:620px){
  .topbar{font-size:.72rem}
  .topbar__inner{height:34px;gap:10px}
  .topbar__phone{font-size:.78rem;letter-spacing:0}
}

/* ============ NAV ============ */
.nav{position:sticky;top:0;z-index:90;transition:background .35s,backdrop-filter .35s,border-color .35s,padding .35s;border-bottom:1px solid transparent}
.nav{position:sticky;top:0;z-index:90;transition:background .35s,backdrop-filter .35s,border-color .35s,padding .35s;border-bottom:1px solid transparent}
.nav::before{content:"";position:absolute;left:18px;right:18px;top:10px;bottom:10px;border-radius:999px;
  background:linear-gradient(180deg,rgba(20,16,13,.8),rgba(12,10,8,.74));border:1px solid rgba(214,181,119,.1);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 24px 44px -36px rgba(0,0,0,.92);pointer-events:none;opacity:.94}
.nav__inner{position:relative;display:flex;align-items:center;gap:20px;height:94px;padding:0 18px}
.nav.scrolled{background:rgba(13,11,9,.42);backdrop-filter:blur(18px) saturate(1.2);border-bottom-color:transparent}
.brand{display:inline-flex;align-items:center;gap:13px;flex:none;min-width:max-content}
.brand__mark{
  width:48px;height:48px;border-radius:50%;object-fit:contain;display:block;flex:none;
}
.brand__text{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:1.5rem;line-height:1;letter-spacing:.01em;color:var(--cream)}
.brand__text small{display:block;font-family:"Be Vietnam Pro",sans-serif;font-weight:600;font-size:.56rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-top:5px}
.nav__links{display:flex;align-items:center;justify-content:center;gap:14px;margin-left:14px;flex:1;min-width:0}
.navlink{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;flex:none;min-height:44px;
  padding:0 10px;border-radius:999px;font-size:.82rem;font-weight:600;letter-spacing:.04em;color:#d8cdba;position:relative;transition:color .25s,background .25s}
.navlink .vi,.navlink .en{white-space:nowrap;line-height:1}
.navlink::after{content:"";position:absolute;left:12px;right:12px;bottom:5px;height:1.5px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transition:transform .28s var(--ease)}
.navlink:hover{color:var(--gold-lt);background:rgba(255,255,255,.03)}
.navlink:hover::after,.navlink.active::after{transform:scaleX(1)}
.navlink.active{color:var(--gold-lt);background:rgba(201,162,90,.08)}
.nav__right{margin-left:auto;display:flex;align-items:center;gap:12px;flex:none}
.lang{display:inline-flex;align-items:center;gap:6px;padding:5px 8px 5px 5px;border-radius:999px;border:1px solid rgba(214,181,119,.14);
  background:rgba(255,255,255,.025);color:var(--muted-2);font-size:.76rem;font-weight:700;letter-spacing:.12em}
.lang-btn{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;border-radius:999px;color:var(--muted-2);transition:color .2s,background .25s;padding:0 8px;line-height:1}
.lang-btn.on{color:#1b1208;background:var(--gold)}
.lang-btn:hover{color:var(--cream)}
.nav__cta{display:inline-flex;align-items:center;gap:10px;padding:10px 12px 10px 20px;border-radius:999px;min-height:52px;box-shadow:0 18px 36px -24px rgba(201,162,90,.6)}
.nav__cta .vi,.nav__cta .en{white-space:nowrap;line-height:1}
.lang-vi .navlink .vi,.lang-en .navlink .en,
.lang-vi .nav__cta .vi,.lang-en .nav__cta .en{
  display:inline-flex;
  align-items:center;
}
.nav__cta-icon{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;
  background:rgba(53,31,13,.14);border:1px solid rgba(53,31,13,.12);font-size:1rem;line-height:1;color:#251608}
.burger{display:none;flex-direction:column;gap:5px;padding:8px;margin:-8px}
.burger span{width:24px;height:2px;background:var(--cream);border-radius:2px;transition:transform .3s var(--ease),opacity .3s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile menu */
.mobile{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);z-index:95;background:var(--ink-2);
  display:flex;flex-direction:column;gap:6px;padding:108px 32px 40px;
  border-left:1px solid var(--line-soft);box-shadow:var(--shadow);
  transform:translateX(0);transition:transform .4s var(--ease);overflow-y:auto}
.mobile.hidden-menu{transform:translateX(105%)}
.mobile__link{font-family:"Cormorant Garamond",serif;font-size:1.5rem;font-weight:500;padding:12px 0;border-bottom:1px solid var(--line-soft);color:var(--cream)}
.mobile__link:hover{color:var(--gold-lt)}
.mobile__cta{margin-top:22px}

/* ============ HERO — smooth-scroll reveal ============ */
/* Section is tall (scrollHeight + 100vh); height set inline by JS as a fallback too */
.hero{position:relative;width:100%;height:calc(1500px + 100vh);z-index:1}
.hero__sticky{position:sticky;top:0;height:100vh;width:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;isolation:isolate}
.hero__frame{position:absolute;inset:0;background:#0d0b09;
  /* scroll-scrubbed frame-sequence canvas; JS advances frames on scroll */
  transform:translateZ(0);will-change:transform}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;display:block;transform:translateZ(0);will-change:contents}
/* Loader overlay shown until all frames are preloaded */
.hero__loader{position:absolute;inset:0;z-index:3;display:flex;align-items:flex-end;justify-content:center;padding-bottom:64px;background:#0d0b09;transition:opacity .6s var(--ease)}
.hero__loader.is-done{opacity:0;pointer-events:none}
.hero__loader-bar{width:140px;height:2px;border-radius:2px;background:rgba(244,237,225,.18);overflow:hidden}
.hero__loader-bar span{display:block;height:100%;width:0;background:var(--gold-lt);transition:width .2s linear}
.hero__scrim{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(13,11,9,.68) 0%,rgba(13,11,9,.14) 34%,rgba(13,11,9,.68) 78%,rgba(13,11,9,.94) 100%),
  radial-gradient(120% 80% at 18% 92%,rgba(13,11,9,.76),transparent 60%),
  radial-gradient(84% 60% at 76% 12%,rgba(224,122,69,.12),transparent 54%)}
.hero__content{position:relative;z-index:2;text-align:center;max-width:980px;padding-top:60px;
  animation:heroIn 1s var(--ease)}
/* end-of-scroll CTA: hidden until the frame sequence reaches its final frames */
.hero__content--end{animation:none;opacity:0;transform:translateY(26px);pointer-events:none;
  transition:opacity .55s var(--ease),transform .55s var(--ease)}
.hero__content--end.is-visible{opacity:1;transform:none;pointer-events:auto}
@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.hero__title{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:clamp(3.2rem,8vw,6.5rem);line-height:1.01;letter-spacing:-.03em;color:#fff;margin:.6rem 0 1.4rem;text-shadow:0 2px 40px rgba(0,0,0,.55)}
.hero__title em{font-style:italic;color:var(--gold-lt)}
.hero__lead{max-width:720px;margin-inline:auto;font-size:clamp(1.06rem,1.7vw,1.24rem);color:#f3ebdd;line-height:1.7;text-shadow:0 1px 18px rgba(0,0,0,.55)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:2.2rem;justify-content:center}
.hero__meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:10px 18px;
  margin-top:1.4rem;
  color:var(--paper);
  font-size:.76rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.hero__meta span{display:inline-flex;align-items:center;gap:.55rem}
.hero__meta span::before{
  content:"";
  width:28px;
  height:1px;
  background:linear-gradient(90deg,var(--gold),rgba(201,162,90,0));
}
.hero__cue{position:absolute;z-index:2;bottom:28px;left:50%;transform:translateX(-50%);width:72px;height:78px;border-radius:999px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:14px 12px 12px;border:1px solid rgba(214,177,96,.32);background:linear-gradient(180deg,rgba(25,20,16,.26),rgba(14,11,9,.42));box-shadow:0 14px 36px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.06);backdrop-filter:blur(10px) saturate(1.08);-webkit-backdrop-filter:blur(10px) saturate(1.08);transition:opacity .45s ease,transform .45s ease,border-color .35s ease,box-shadow .35s ease}
.hero__cue:hover{border-color:rgba(214,177,96,.56);box-shadow:0 18px 42px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.08)}
.hero__cue-label{font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:rgba(244,237,225,.78)}
.hero__cue-dot{width:4px;height:12px;border-radius:999px;background:linear-gradient(180deg,rgba(247,221,154,.98),rgba(214,177,96,.62));box-shadow:0 0 16px rgba(214,177,96,.36);animation:cueDrift 2.4s var(--ease) infinite}
@keyframes cueDrift{0%,100%{opacity:.32;transform:translateY(-1px) scaleY(.9)}50%{opacity:1;transform:translateY(9px) scaleY(1)}}

/* ============ ABOUT ============ */
.about__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,84px);align-items:center}
.about__copy .lead{margin-bottom:1.1rem}
.about__feats{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:2.4rem}
.feat{display:flex;gap:14px;align-items:center}
.feat img{width:64px;height:64px;border-radius:14px;object-fit:cover;flex:none;box-shadow:0 8px 22px -10px rgba(0,0,0,.7)}
.feat__title{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:1.06rem;color:var(--cream)}
.feat__sub{font-size:.86rem;color:var(--muted);line-height:1.45}
.about__photo{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.about__photo img{width:100%;aspect-ratio:1/1;object-fit:cover;transition:transform 1.2s var(--ease)}
.about__photo:hover img{transform:scale(1.04)}
.about__photo figcaption{position:absolute;left:0;right:0;bottom:0;padding:20px;font-size:.84rem;color:#f0e6d6;
  background:linear-gradient(transparent,rgba(13,11,9,.82));letter-spacing:.02em}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:clamp(54px,8vw,96px);
  padding-top:clamp(40px,6vw,60px);border-top:1px solid var(--line-soft)}
.stat{text-align:center;position:relative;padding:18px 12px 12px;border:1px solid rgba(244,237,225,.06);border-radius:18px;background:linear-gradient(180deg,rgba(244,237,225,.04),rgba(244,237,225,.01))}
.stat+.stat::before{content:"";position:absolute;left:-10px;top:8px;bottom:8px;width:1px;background:var(--line-soft)}
.stat__num{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:clamp(2.1rem,4.4vw,3rem);color:var(--gold-lt);display:block;line-height:1}
.stat__num small{font-size:.5em;color:var(--gold)}
.stat__label{font-size:.82rem;color:var(--muted);letter-spacing:.03em;margin-top:.5rem;display:block}

/* ============ SIGNATURE ============ */
.taste{background:linear-gradient(180deg,var(--ink-2) 0%,#110d0b 100%)}
.taste__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px)}
.taste__card{position:relative;border-radius:18px;overflow:hidden;background:var(--card);box-shadow:var(--shadow)}
.taste__img{overflow:hidden;aspect-ratio:3/4}
.taste__img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.taste__card:hover .taste__img img{transform:scale(1.06)}
.taste__card figcaption{position:absolute;left:0;right:0;bottom:0;padding:22px 22px 24px;
  background:linear-gradient(transparent,rgba(13,11,9,.5) 30%,rgba(13,11,9,.94));}
.taste__name{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:1.28rem;color:#fff;margin-bottom:.3rem}
.taste__desc{font-size:.9rem;color:#ddd1bd;line-height:1.45}

/* ============ MENU ============ */
.tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:clamp(34px,5vw,52px)}
.tab{font-family:"Cormorant Garamond",serif;font-size:1.02rem;font-weight:500;color:var(--muted);
  padding:.55em 1.3em;border-radius:999px;border:1px solid transparent;transition:all .25s var(--ease)}
.tab:hover{color:var(--cream)}
.tab.active{color:var(--ink);background:var(--gold-grad);box-shadow:0 8px 22px -10px rgba(201,162,90,.6)}
.menu-panel{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(28px,5vw,64px);align-items:center;animation:fadein .5s var(--ease);padding:clamp(18px,2vw,24px)}
.menu-panel[hidden]{display:none}
@keyframes fadein{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.menu-panel__photo{border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.menu-panel__photo img{width:100%;aspect-ratio:4/5;object-fit:cover}
.menu-list{list-style:none;display:flex;flex-direction:column}
.menu-item{padding:18px 0;border-bottom:1px solid var(--line-soft)}
.menu-item:first-child{padding-top:0}
.menu-item:last-child{border-bottom:none}
.menu-item__head{display:flex;align-items:baseline;gap:10px}
.menu-item__head h3{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:1.16rem;color:var(--cream);white-space:nowrap}
.menu-item .dots{flex:1;border-bottom:1.5px dotted var(--line);transform:translateY(-4px);min-width:24px}
.menu-item .price{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:1.1rem;color:var(--gold-lt);white-space:nowrap}
.menu-item p{font-size:.9rem;color:var(--muted);margin-top:.3rem;line-height:1.5}
.menu__note{text-align:center;margin-top:clamp(32px,5vw,48px);font-size:.82rem;color:var(--muted-2);letter-spacing:.02em}

/* ============ GALLERY ============ */
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;
  width:100%;max-width:1480px;margin-inline:auto;padding-inline:clamp(14px,4vw,40px)}
.gal{position:relative;overflow:hidden;border-radius:14px;background:var(--ink-2);grid-row:span 1}
.gal--tall{grid-row:span 2}
.gal--wide{grid-column:span 2}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .4s}
.gal::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(13,11,9,.35));opacity:0;transition:opacity .35s}
.gal:hover img{transform:scale(1.07)}
.gal:hover::after{opacity:1}

/* ============ RESERVATION ============ */
.reservation{isolation:isolate;overflow:hidden}
.reservation__bg{position:absolute;inset:0;z-index:-2}
.reservation__bg img{width:100%;height:100%;object-fit:cover}
.reservation::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(110deg,rgba(13,11,9,.95) 0%,rgba(13,11,9,.86) 40%,rgba(13,11,9,.6) 100%)}
.reservation__inner{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(36px,6vw,76px);align-items:center}
.reservation__lead{color:#e7ddcb;max-width:420px;margin-top:.4rem}
.reservation__points{list-style:none;margin-top:1.8rem;display:flex;flex-direction:column;gap:12px}
.reservation__points li{position:relative;padding-left:26px;color:#ddd1bd;font-size:.95rem}
.reservation__points li::before{content:"";position:absolute;left:0;top:9px;width:9px;height:9px;border-radius:50%;background:var(--gold-grad)}
.resform{background:rgba(23,18,16,.72);backdrop-filter:blur(10px);border:1px solid var(--line);
  border-radius:22px;padding:clamp(24px,3.4vw,38px);display:grid;grid-template-columns:1fr 1fr;gap:16px;box-shadow:var(--shadow)}
.field{display:flex;flex-direction:column;gap:7px}
.field--full{grid-column:1/-1}
.field label{font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.field .opt{text-transform:none;font-weight:400;color:var(--muted-2)}
.field input,.field select,.field textarea{
  background:rgba(13,11,9,.6);border:1px solid var(--line-soft);border-radius:11px;
  padding:.78em .9em;color:var(--cream);font-family:inherit;font-size:.96rem;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,90,.18)}
.field textarea{resize:vertical}
.field input::-webkit-calendar-picker-indicator{filter:invert(.7) sepia(1) saturate(2) hue-rotate(5deg)}
.resform__submit{grid-column:1/-1;margin-top:6px;width:100%}
.resform__note{grid-column:1/-1;display:none;background:rgba(201,162,90,.12);border:1px solid var(--line);
  border-radius:12px;padding:14px 16px;color:var(--gold-lt);font-size:.92rem;line-height:1.5}
.resform__note.show{display:block;animation:fadein .4s var(--ease)}
.resform__actions{grid-column:1/-1;display:flex;gap:12px;flex-wrap:wrap}
.resform__actions[hidden]{display:none}
.booking-studio{grid-column:1/-1;margin-bottom:clamp(20px,3vw,32px);display:flex;flex-direction:column;
  gap:clamp(20px,2.6vw,28px);padding:clamp(20px,3vw,30px);border-radius:calc(var(--bezel-r) + 4px);
  background:linear-gradient(180deg,rgba(18,14,12,.8),rgba(12,10,9,.92));
  border:1px solid rgba(201,162,90,.2);box-shadow:0 28px 60px -38px rgba(0,0,0,.85)}
.booking-studio__header{max-width:760px}
.booking-studio__lead{margin-top:.8rem;color:#ddd1bd;line-height:1.7}
.booking-studio__grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:clamp(18px,2vw,24px)}
.studio-panel{border-radius:calc(var(--bezel-r) - 4px);border:1px solid var(--line);
  background:rgba(244,237,225,.035);padding:clamp(18px,2vw,24px)}
.studio-guest{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.studio-note{margin-top:14px}
.studio-toolbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.studio-legend{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.studio-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.03);font-size:.84rem;color:#e7ddcb}
.studio-chip i{width:10px;height:10px;border-radius:50%;display:block}
.studio-chip .is-free{background:#d8c08d}
.studio-chip .is-held{background:#d88b4a}
.studio-chip .is-cover{background:#9f7754}
.studio-chip .is-sunset{background:#ffb55f}
.studio-chip .is-busy{background:#6d5a4d}
.table-map{margin-top:18px}
.table-map{display:grid;gap:12px}
.table-hero-map{position:relative;border-radius:34px;overflow:hidden;border:1px solid rgba(201,162,90,.24);
  background:linear-gradient(180deg,rgba(24,17,13,.92),rgba(12,10,8,.98));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 36px 80px -46px rgba(0,0,0,.9)}
.table-hero-map__bg{display:block;width:100%;height:auto}
.table-hero-map__veil{position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(10,8,7,.1),rgba(10,8,7,.3)),
    radial-gradient(circle at 50% 10%, rgba(255,199,116,.12), transparent 24%);
  pointer-events:none}
.table-hero-map__tables{position:absolute;inset:0 0 110px 0}
.table-hero-map__focus{position:absolute;left:18px;right:18px;bottom:18px;display:flex;justify-content:center;pointer-events:none}
.table-focus-card{width:min(100%,760px);padding:16px 18px;border-radius:22px;border:1px solid rgba(255,224,177,.14);
  background:linear-gradient(180deg,rgba(17,13,10,.86),rgba(17,13,10,.72));backdrop-filter:blur(14px);
  box-shadow:0 24px 44px -30px rgba(0,0,0,.92);pointer-events:auto}
.table-focus-card.is-idle{width:auto;max-width:420px;padding:10px 14px 11px;text-align:center}
.table-focus-card__head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.table-focus-card__head strong{font-family:"Cormorant Garamond",serif;font-size:2rem;line-height:.9;font-weight:600;color:#fff8ef}
.table-focus-card__head span{padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:#fff0d9}
.table-focus-card p{margin-top:8px;color:#dacbb6;line-height:1.55}
.table-focus-card.is-idle strong{font-size:1rem;letter-spacing:.08em;text-transform:uppercase;color:#f2d7a4}
.table-focus-card.is-idle p{margin-top:4px;font-size:.84rem;line-height:1.45}
.table-focus-card__meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.table-focus-card__meta em{font-style:normal;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#f4d7a6;
  background:rgba(210,147,61,.12);padding:5px 9px;border-radius:999px;border:1px solid rgba(255,223,169,.08)}
.table-focus-card__actions{display:flex;justify-content:flex-end;margin-top:12px}
.table-focus-card__clear{padding:10px 14px;border-radius:999px;border:1px solid rgba(255,220,170,.18);
  background:rgba(255,255,255,.04);color:#f6e4c0;font-size:.82rem;letter-spacing:.06em}
.table-focus-card__clear:hover{background:rgba(255,220,170,.08);transform:translateY(-1px)}
.table-focus-card__clear:active{transform:translateY(0) scale(.98)}
.table-helper-card{padding:10px 14px;border-radius:16px;border:1px solid rgba(255,224,177,.12);
  background:linear-gradient(180deg,rgba(17,13,10,.72),rgba(17,13,10,.56));text-align:center}
.table-helper-card strong{font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;color:#f2d7a4}
.table-helper-card p{margin-top:4px;color:#d7c8b4;font-size:.84rem;line-height:1.45}
.table-card{position:relative;text-align:left;padding:16px 16px 14px;border-radius:24px;border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(44,34,27,.88),rgba(24,20,17,.95));color:#fff;
  transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease),opacity .25s}
.table-card--hotspot{position:absolute;left:var(--table-x);top:var(--table-y);transform:translate(-50%,-50%);
  display:grid;place-items:center;width:28px;height:28px;padding:0;border:none;background:none;overflow:visible}
.table-card--long{width:42px}
.table-card[data-state="available"]{cursor:pointer}
.table-card__pin{position:absolute;left:50%;top:50%;width:10px;height:10px;border-radius:50%;
  transform:translate(-50%,-50%);background:radial-gradient(circle at 35% 35%, #fff5cb, #d59c4f 58%, #8c5425 100%);
  box-shadow:0 0 0 3px rgba(18,13,10,.48),0 0 0 1px rgba(255,232,177,.64),0 0 16px rgba(255,180,80,.42)}
.table-card__pin::after{content:"";position:absolute;left:50%;top:50%;width:22px;height:22px;border-radius:50%;
  transform:translate(-50%,-50%);border:1px solid rgba(255,220,152,.22)}
.table-card__label{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;margin-top:-26px;
  min-width:36px;padding:5px 6px 5px;border-radius:999px;border:1px solid rgba(255,231,189,.12);
  background:linear-gradient(180deg,rgba(17,13,10,.82),rgba(17,13,10,.58));
  backdrop-filter:blur(10px);box-shadow:0 18px 24px -24px rgba(0,0,0,.95)}
.table-card--long .table-card__label{min-width:56px}
.table-card strong{display:block;font-family:"Cormorant Garamond",serif;font-size:.82rem;line-height:1;font-weight:700;color:#fff9ef;
  text-shadow:0 4px 14px rgba(0,0,0,.45)}
.table-card__label small{font-size:.44rem;letter-spacing:.18em;text-transform:uppercase;color:#f4d7a6}
.table-card__meta{display:none}
.table-card__status{display:none}
.table-card--hotspot[data-state="available"]:hover{transform:translate(-50%,-52%)}
.table-card--hotspot[data-state="available"]:hover .table-card__pin{box-shadow:0 0 0 3px rgba(18,13,10,.58),0 0 0 1px rgba(255,232,177,.7),0 0 22px rgba(255,186,91,.74)}
.table-card--hotspot[data-state="selected"] .table-card__label{border-color:rgba(255,219,146,.55);background:linear-gradient(180deg,rgba(49,33,16,.88),rgba(29,21,16,.7))}
.table-card--hotspot[data-state="selected"] .table-card__pin{box-shadow:0 0 0 3px rgba(18,13,10,.58),0 0 0 1px rgba(255,232,177,.84),0 0 28px rgba(255,201,118,.92)}
.table-card--hotspot[data-combo="true"] .table-card__label{border-color:rgba(155,222,255,.5);background:linear-gradient(180deg,rgba(16,42,56,.88),rgba(11,24,36,.72))}
.table-card--hotspot[data-combo="true"] .table-card__pin{background:radial-gradient(circle at 35% 35%, #edfbff, #89c8db 58%, #2d5d73 100%);box-shadow:0 0 0 3px rgba(10,20,28,.62),0 0 0 1px rgba(192,239,255,.82),0 0 24px rgba(104,208,255,.42)}
.table-card--hotspot[data-state="held"] .table-card__label{background:linear-gradient(180deg,rgba(82,55,26,.88),rgba(44,30,14,.72))}
.table-card--hotspot[data-state="held"] .table-card__pin{background:radial-gradient(circle at 35% 35%, #ffe0ae, #bb8140 58%, #6f4520 100%)}
.table-card--hotspot[data-state="booked"]{opacity:.45}
.table-card--hotspot[data-state="booked"] .table-card__pin{background:radial-gradient(circle at 35% 35%, #d7c9b4, #8d7962 60%, #514338 100%);box-shadow:0 0 0 6px rgba(18,13,10,.38),0 0 0 1px rgba(255,255,255,.12)}
.table-card--hotspot[data-state="booked"] .table-card__label{background:linear-gradient(180deg,rgba(27,22,18,.82),rgba(17,13,10,.52))}
.table-card--hotspot[data-featured="true"] .table-card__label{border-color:rgba(255,216,150,.24)}
.table-card--hotspot[data-featured="true"]:not([data-state="selected"]) .table-card__label{background:linear-gradient(180deg,rgba(56,34,16,.72),rgba(24,17,11,.5))}
.table-card--hotspot[data-covered="true"] .table-card__label::after{content:"";position:absolute;inset:4px 10px auto 10px;height:2px;border-radius:999px;background:rgba(245,211,156,.42)}
.studio-status{margin-top:16px;padding:12px 14px;border-radius:14px;border:1px solid rgba(201,162,90,.18);
  background:rgba(201,162,90,.08);color:#eadfcf;line-height:1.55}
.studio-footnote{margin-top:10px;color:#cdbda7;font-size:.88rem;line-height:1.6;text-align:center}
.studio-kicker{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-lt)}
.studio-summary h3{margin-top:10px;font-family:"Cormorant Garamond",serif;font-size:2rem;font-weight:500;color:#fff}
.studio-summary__list{list-style:none;margin-top:14px;display:grid;gap:12px}
.studio-summary__list li{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-bottom:12px;border-bottom:1px solid var(--line-soft);color:#ddd1bd}
.studio-summary__list strong{color:#fff;font-weight:600;text-align:right}
.payment-box{margin-top:20px;padding-top:18px;border-top:1px solid var(--line-soft)}
.payment-methods{display:grid;gap:10px;margin-top:14px}
.payment-method{text-align:left;padding:14px 14px 13px;border-radius:18px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);color:#f4ede1;transition:border-color .25s var(--ease),background .25s var(--ease),transform .25s var(--ease)}
.payment-method strong{display:block;font-size:.98rem}
.payment-method span{display:block;margin-top:4px;font-size:.84rem;color:#d2c5b1}
.payment-method.is-on{border-color:rgba(201,162,90,.55);background:rgba(201,162,90,.12)}
.payment-method:hover{transform:translateY(-2px)}
.banking-card{display:grid;grid-template-columns:1fr;gap:16px;margin-top:16px;padding:16px;
  border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.03)}
.banking-card__meta{display:grid;gap:10px;align-content:start}
.banking-card__row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-bottom:10px;border-bottom:1px solid var(--line-soft)}
.banking-card__row span{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:#cdbfa8}
.banking-card__row strong{font-size:1rem;color:#fff;text-align:right}
.banking-card__row--stack{display:grid;justify-content:stretch}
.banking-card__row--stack strong{text-align:left;font-size:1.08rem;line-height:1.4}
.banking-card__row--stack img{width:min(280px,100%);margin-top:14px;border-radius:18px;background:#fff;padding:10px;justify-self:center}
.banking-copy{justify-self:start;margin-top:10px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.04);color:var(--gold-lt);font-size:.84rem}
#vietQrWrap .banking-copy{justify-self:center}
.banking-card__note{color:#d7cab8;font-size:.9rem;line-height:1.6}
.payment-actions{display:flex;justify-content:center;gap:12px;margin-top:20px}
.payment-actions .btn{min-width:min(100%,320px)}
.payment-result{margin-top:14px;padding:14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid var(--line);color:#efe4d5;line-height:1.6}
.payment-result.is-success{border-color:rgba(160,209,167,.35);background:rgba(118,169,125,.12)}
.payment-result.is-warning{border-color:rgba(220,155,82,.35);background:rgba(220,155,82,.12)}
.payment-result.is-error{border-color:rgba(203,104,96,.35);background:rgba(203,104,96,.12)}

/* ============ TESTIMONIALS ============ */
.testi__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,28px)}
.testi__card{background:var(--card);border:1px solid var(--line-soft);border-radius:18px;padding:30px 28px;
  display:flex;flex-direction:column;gap:14px;transition:transform .35s var(--ease),border-color .35s}
.testi__card:hover{transform:translateY(-4px);border-color:var(--line)}
.testi__media{border-radius:14px;overflow:hidden;aspect-ratio:4/3;border:1px solid rgba(222,193,138,.14)}
.testi__media img{width:100%;height:100%;display:block;object-fit:cover}
.stars{color:var(--gold);letter-spacing:.18em;font-size:.92rem}
.testi__card blockquote{font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:400;font-size:1.16rem;line-height:1.5;color:#ece2d2}
.testi__card figcaption{margin-top:auto;display:flex;flex-direction:column;gap:2px}
.testi__card figcaption strong{font-weight:600;color:var(--gold-lt)}
.testi__card figcaption span{font-size:.84rem;color:var(--muted)}

/* ============ CONTACT ============ */
.contact{background:var(--ink-2)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center}
.contact__list{list-style:none;margin-top:2rem;display:flex;flex-direction:column;gap:22px}
.contact__list li{display:grid;grid-template-columns:130px 1fr;gap:18px;align-items:start}
.contact__k{font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);padding-top:3px}
.contact__v{color:#e3d8c6;line-height:1.55}
.contact__v a:hover{color:var(--gold-lt)}
.contact__actions{margin-top:2.4rem;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.social{display:flex;gap:10px}
.social a{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--cream);transition:all .25s var(--ease)}
.social a:hover{background:var(--gold-grad);color:var(--ink);border-color:transparent;transform:translateY(-2px)}
.social .ic{width:18px;height:18px}
.contact__photo{border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.contact__photo img{width:100%;aspect-ratio:1/1;object-fit:cover;transition:transform 1.2s var(--ease)}
.contact__photo:hover img{transform:scale(1.04)}
.contact__map{margin-top:clamp(34px,5vw,58px)}
.contact__map iframe{width:100%;height:clamp(300px,40vw,440px);display:block;border:1px solid var(--line);
  border-radius:20px;box-shadow:var(--shadow);filter:grayscale(.4) contrast(1.04) brightness(.92);
  transition:filter .45s var(--ease)}
.contact__map iframe:hover{filter:none}

/* ============ FOOTER ============ */
.footer{background:linear-gradient(180deg,#0f0c0a 0%, var(--ink) 100%);border-top:1px solid var(--line-soft);padding:clamp(48px,7vw,72px) 0 28px}
.footer__inner{display:flex;flex-wrap:wrap;align-items:center;gap:18px 32px}
.footer__brand{display:inline-flex;align-items:center;gap:11px}
.footer__tag{color:var(--muted);font-size:.92rem;max-width:340px;flex:1;min-width:200px}
.footer__lang{margin-left:auto}
.footer__social{display:flex;align-items:center;gap:10px}
.footer__links{display:flex;gap:18px;flex-wrap:wrap;align-items:center;justify-content:flex-end;max-width:520px}
.footer__links a{font-size:.9rem;color:#cebfa8;transition:color .2s}
.footer__links a:hover{color:var(--gold-lt)}
.footer__base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  margin-top:clamp(34px,5vw,52px);padding-top:24px;border-top:1px solid var(--line-soft);
  font-size:.82rem;color:var(--muted-2)}

/* ============ FAB ============ */
.fab{position:fixed;right:18px;bottom:18px;z-index:80;width:56px;height:56px;border-radius:50%;
  background:var(--gold-grad);color:#23170a;display:none;place-items:center;
  box-shadow:0 14px 34px -10px rgba(201,162,90,.7);animation:pulse 2.6s infinite}
.fab svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
@keyframes pulse{0%,100%{box-shadow:0 14px 34px -10px rgba(201,162,90,.7),0 0 0 0 rgba(201,162,90,.4)}50%{box-shadow:0 14px 34px -10px rgba(201,162,90,.7),0 0 0 12px rgba(201,162,90,0)}}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(8,7,6,.95);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:5vw}
.lightbox.open{display:flex;animation:fadein .3s ease}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.8)}
.lb-close{position:absolute;top:22px;right:26px;font-size:1.6rem;color:#fff;opacity:.8;width:44px;height:44px;border-radius:50%}
.lb-close:hover{opacity:1;background:rgba(255,255,255,.08)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:2.6rem;color:#fff;opacity:.7;
  width:56px;height:56px;border-radius:50%;transition:all .2s}
.lb-nav:hover{opacity:1;background:rgba(255,255,255,.08)}
.lb-prev{left:14px}.lb-next{right:14px}

/* ============ REVEAL ANIMATION ============ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__media img{animation:none}
  .hero__cue-dot{animation:none}
  .fab{animation:none}
  *{scroll-behavior:auto}
}

/* ============================================================
   RESPONSIVE — mobile is DESIGNED, not shrunk
   ============================================================ */
@media(max-width:1024px){
  .gallery__grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:180px}
}
@media(max-width:880px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .burger{display:flex}
  .fab{display:grid}
  .about__grid{grid-template-columns:1fr;gap:34px}
  .about__photo{order:-1}
  .menu-panel{grid-template-columns:1fr;gap:26px}
  .menu-panel__photo{max-width:440px;margin-inline:auto}
  .menu-panel__photo img{aspect-ratio:16/10}
  .reservation__inner{grid-template-columns:1fr;gap:34px}
  .booking-studio__grid{grid-template-columns:1fr}
  .studio-guest{grid-template-columns:1fr 1fr}
  .studio-toolbar{grid-template-columns:1fr 1fr}
  .table-focus-card{padding:14px 16px}
  .table-focus-card__head strong{font-size:1.7rem}
  .contact__grid{grid-template-columns:1fr;gap:32px}
  .contact__photo{order:-1}
  .testi__grid{grid-template-columns:1fr}
  .taste__grid{grid-template-columns:1fr;gap:16px}
  .taste__card figcaption{position:static;background:none;padding:18px 4px 4px}
  .taste__name{color:var(--cream)}
  .taste__img{aspect-ratio:16/10;border-radius:16px}
}
@media(max-width:620px){
  body{font-size:16px}
  .wrap{padding-inline:16px}
  .hero__cue{bottom:18px;width:54px;height:58px;gap:7px;padding:11px 10px 9px;box-shadow:0 10px 26px rgba(0,0,0,.24),inset 0 1px 0 rgba(255,255,255,.05)}
  .hero__cue-label{font-size:.47rem;letter-spacing:.22em}
  .hero__cue-dot{height:10px}
  .stats{grid-template-columns:1fr 1fr;gap:28px 14px;text-align:center}
  .stat+.stat::before{display:none}
  .stat:nth-child(3),.stat:nth-child(4){padding-top:24px;border-top:1px solid var(--line-soft)}
  .nav::before{left:8px;right:8px;top:6px;bottom:6px;border-radius:26px}
  .nav__inner{height:74px;padding:0 12px;gap:10px}
  .brand{gap:10px;min-width:0}
  .brand__mark{width:40px;height:40px}
  .brand__text{font-size:1.18rem}
  .brand__text small{font-size:.47rem;letter-spacing:.22em}
  .lang{padding:4px 6px 4px 4px;gap:4px}
  .lang-btn{min-width:30px;height:30px;font-size:.76rem}
  .burger{padding:6px;margin:-6px}
  .burger span{width:22px}
  .mobile{width:min(88vw,320px);padding:92px 22px 30px}
  .mobile__link{font-size:1.3rem;padding:10px 0}
  .mobile__cta{margin-top:18px;width:100%}
  .page-hero{padding:98px 0 40px}
  .page-hero__inner{max-width:100%}
  .page-hero .h1{font-size:clamp(2.2rem,12vw,3.2rem);line-height:.98;margin-top:.3rem}
  .page-hero .lead{font-size:1rem;line-height:1.6;max-width:22ch}
  .page-hero__crumb{font-size:.66rem;letter-spacing:.16em;gap:6px;flex-wrap:wrap}
  .reservation__inner{gap:20px}
  .reservation__intro{padding-top:2px;max-width:none}
  .reservation__intro .h2{font-size:clamp(2rem,10vw,2.6rem);line-height:1.02}
  .reservation__lead{display:block;font-size:.98rem;line-height:1.6;max-width:100%}
  .reservation__points{gap:10px}
  .reservation__points li{padding:0 0 0 18px;font-size:.98rem;line-height:1.55}
  .resform{
    grid-template-columns:1fr;
    gap:14px;
    padding:18px 14px 22px;
    border-radius:24px;
  }
  .resform .seg,
  .resform .field,
  .resform .field--full,
  .resform__submit,
  .resform__note,
  .resform__actions{
    grid-column:1 / -1;
  }
  .resform .seg{
    margin-bottom:2px;
  }
  .resform .field{
    min-width:0;
  }
  .resform .field input,
  .resform .field select,
  .resform .field textarea{
    width:100%;
  }
  .booking-studio{padding:18px 14px;border-radius:24px}
  .booking-studio__header{max-width:100%}
  .booking-studio__lead{font-size:.98rem;line-height:1.6}
  .studio-panel{padding:18px 16px;border-radius:20px}
  .field label{font-size:.78rem}
  .field input,.field select,.field textarea{min-height:52px;font-size:16px}
  .field textarea{min-height:92px}
  .studio-note textarea{min-height:82px}
  .hero__meta{gap:8px 12px;font-size:.7rem;letter-spacing:.12em}
  .about__feats{grid-template-columns:1fr;gap:14px}
  .gallery__grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px;gap:10px}
  .gal--wide{grid-column:span 2}
  .gal--tall{grid-row:span 2}
  .studio-guest{grid-template-columns:1fr}
  .banking-card__row{display:grid;justify-content:stretch}
  .banking-card__row strong{text-align:left}
  .studio-toolbar{grid-template-columns:1fr}
  .studio-legend{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .studio-chip{justify-content:flex-start;padding:10px 12px;font-size:.82rem}
  .table-hero-map{border-radius:24px}
  .table-map{gap:10px}
  .table-hero-map__tables{inset:0 0 78px 0}
  .table-hero-map__focus{left:8px;right:8px;bottom:8px}
  .table-card--hotspot{width:24px;height:24px}
  .table-card--long{width:34px}
  .table-card__pin{width:9px;height:9px}
  .table-card__pin::after{width:18px;height:18px}
  .table-card__label{min-width:30px;margin-top:-22px;padding:4px 5px 4px;border-radius:999px}
  .table-card--long .table-card__label{min-width:48px}
  .table-card strong{font-size:.62rem}
  .table-focus-card{padding:10px 11px;border-radius:16px}
  .table-focus-card__head{align-items:flex-start;flex-direction:column}
  .table-focus-card__head strong{font-size:1.12rem}
  .table-focus-card__head span{font-size:.5rem;padding:6px 9px}
  .table-focus-card p{font-size:.8rem;line-height:1.45}
  .table-focus-card__meta{gap:6px;margin-top:10px}
  .table-focus-card__meta em{font-size:.62rem;padding:4px 7px}
  .table-focus-card__clear{width:100%;justify-content:center;padding:9px 12px;font-size:.76rem}
  .table-helper-card{padding:8px 10px}
  .table-helper-card strong{font-size:.76rem}
  .table-helper-card p{font-size:.72rem}
  .studio-status{font-size:.88rem;line-height:1.5}
  .studio-footnote{font-size:.8rem;line-height:1.55}
  .studio-summary h3{font-size:1.85rem}
  .studio-summary__list li{align-items:flex-start;gap:8px;padding-bottom:10px}
  .studio-summary__list strong{font-size:.96rem;max-width:48%;line-height:1.4}
  .banking-card{padding:14px;border-radius:18px}
  .banking-card__row span{font-size:.74rem}
  .banking-card__row strong{font-size:.95rem;line-height:1.45}
  .banking-card__row--stack img{width:min(240px,100%);padding:8px}
  .banking-copy{width:100%;justify-content:center}
  .banking-card__note{font-size:.84rem;line-height:1.55}
  .payment-result{font-size:.88rem;line-height:1.55}
  .table-focus-card__actions{justify-content:center}
  .hero__cta .btn{flex:1}
  .resform__actions{flex-direction:column}
  .resform__actions .btn{width:100%}
  .payment-actions{flex-direction:column;align-items:center}
  .payment-actions .btn{width:100%}
  .footer{padding:40px 0 22px}
  .footer__inner{gap:14px}
  .footer__tag{min-width:0;font-size:.86rem}
  .footer__lang{margin-left:0}
  .contact__list li{grid-template-columns:1fr;gap:4px}
  .contact__k{padding-top:0}
  .footer__lang,.footer__social{width:100%;justify-content:flex-start}
  .footer__links{margin-left:0;width:100%;justify-content:flex-start;max-width:none}
  .fab{
    width:60px;
    height:60px;
    right:14px;
    bottom:calc(env(safe-area-inset-bottom, 0px) + 88px);
  }
}


/* ============================================================
   PREMIUM POLISH PASS (redesign skill) — additive, non-breaking
   ============================================================ */

/* Anchor offset so the sticky nav never covers section headings on click */
section[id]{scroll-margin-top:92px}

/* Typography refinement: kill orphan words, tighten rhythm */
.h2,.hero__title,.taste__name,.testi__card blockquote,.menu-item__head h3{text-wrap:balance}
.lead,.hero__lead,.feat__sub,.taste__desc,.reservation__lead,.menu-item p,.about__copy p{text-wrap:pretty}

/* Tabular figures so numerals (stats, prices, phone) align cleanly */
.stat__num,.menu-item .price,.topbar__phone{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* Pressed / active feedback — interfaces should feel physical */
.btn:active{transform:translateY(0) scale(.975)}
.btn--ghost:active{transform:translateY(0) scale(.975)}
.tab:active{transform:scale(.97)}

/* Signature cards: lift + warm border + deeper shadow on hover */
.taste__card{border:1px solid transparent;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease)}
.taste__card:hover{transform:translateY(-5px);border-color:var(--line);
  box-shadow:0 52px 104px -46px rgba(0,0,0,.92)}

/* About feature tiles: subtle interactive depth */
.feat{padding:6px;margin:-6px;border-radius:14px;transition:background .3s var(--ease)}
.feat:hover{background:rgba(201,162,90,.06)}

/* Crafted glow on the big stat numbers instead of flat text */
.stat__num{text-shadow:0 0 28px rgba(230,205,147,.18)}

/* Film-grain texture overlay — adds depth and defeats the flat "AI" look.
   Fixed, ultra-low opacity, never blocks interaction. */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

@media (prefers-reduced-motion:reduce){
  .taste__card:hover{transform:none}
  .btn:active,.btn--ghost:active,.tab:active{transform:none}
}

/* ============ RETREAT / LƯU TRÚ ============ */
.retreat{background:var(--ink-2);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.lede{max-width:64ch;margin:18px auto 0;color:var(--muted);font-size:clamp(15px,1.5vw,18px);line-height:1.7;text-align:center}

.retreat__hero{position:relative;margin:clamp(28px,4vw,48px) 0;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.retreat__hero img{display:block;width:100%;height:auto;aspect-ratio:16/9;object-fit:cover}
.retreat__rating{position:absolute;left:18px;bottom:18px;display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:999px;background:rgba(13,11,9,.62);backdrop-filter:blur(8px);border:1px solid var(--line);color:var(--cream);font-size:13px;letter-spacing:.02em}
.retreat__rating strong{font-family:"Cormorant Garamond",serif;font-size:20px;color:var(--gold-lt)}

.retreat__rooms{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.4vw,28px)}
.room-card{position:relative;display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .5s var(--ease),border-color .5s var(--ease)}
.room-card:hover{transform:translateY(-4px);border-color:rgba(201,162,90,.45)}
.room-card__img{aspect-ratio:16/10;overflow:hidden}
.room-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.room-card:hover .room-card__img img{transform:scale(1.05)}
.room-card__body{padding:clamp(20px,2.4vw,30px);display:flex;flex-direction:column;gap:10px}
.room-card__badge{align-self:flex-start;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);background:var(--gold-grad);padding:4px 12px;border-radius:999px;font-weight:600}
.room-card__name{font-family:"Cormorant Garamond",serif;font-size:clamp(22px,2.6vw,30px);color:var(--cream);line-height:1.15}
.room-card__meta{color:var(--gold-lt);font-size:13px;letter-spacing:.04em}
.room-card__desc{color:var(--muted);line-height:1.7;font-size:15px}
.room-card__tags{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.room-card__tags li{font-size:12.5px;color:var(--cream);border:1px solid var(--line);border-radius:999px;padding:6px 12px;background:rgba(244,237,225,.03)}

.retreat__features{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:10px 14px;margin:clamp(28px,4vw,44px) auto 0;max-width:880px}
.retreat__features li{position:relative;color:var(--cream);font-size:14px;padding-left:20px}
.retreat__features li::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--gold-grad)}

.retreat__gallery{margin-top:clamp(28px,4vw,44px);margin-bottom:clamp(8px,1.4vw,16px)}
.retreat__gallery .gal{cursor:pointer;border:0;padding:0}
.retreat__gallery-head{display:flex;align-items:end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:clamp(24px,3vw,36px)}
.retreat__gallery-kicker{font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:10px}
.retreat__gallery-title{max-width:760px;font-family:"Cormorant Garamond",serif;font-size:clamp(1.5rem,2.7vw,2.2rem);line-height:1.12;color:var(--cream)}
.retreat__viewall{border:1px solid rgba(201,162,90,.34);background:rgba(255,255,255,.04);color:var(--cream);border-radius:999px;padding:12px 18px;font:inherit;font-weight:600;letter-spacing:.03em;cursor:pointer;transition:transform .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease)}
.retreat__viewall:hover{transform:translateY(-2px);background:rgba(201,162,90,.12);border-color:rgba(201,162,90,.6);color:var(--gold-lt)}

.retreat__cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px;margin-top:clamp(30px,4vw,46px);padding-top:clamp(24px,3vw,34px);border-top:1px solid var(--line-soft)}
.retreat__addr{color:var(--cream);font-size:15px}
.retreat__near{color:var(--muted-2);font-size:13px;margin-top:4px}
.retreat__actions{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.retreat__social{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.retreat__social a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--cream);transition:transform .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease)}
.retreat__social a:hover{color:var(--ink);background:var(--gold-grad);border-color:transparent;transform:translateY(-2px)}
.retreat__social .ic{width:18px;height:18px}

@media(max-width:880px){
  .retreat__rooms{grid-template-columns:1fr}
  .retreat__cta{flex-direction:column;align-items:flex-start}
  .retreat__actions{align-items:flex-start;width:100%}
  .retreat__gallery-head{align-items:flex-start}
}
@media(max-width:620px){
  .retreat__rating{left:12px;bottom:12px;padding:8px 13px}
  .retreat__viewall{width:100%}
  .retreat__gallery-title{max-width:100%}
}
@media (prefers-reduced-motion:reduce){
  .room-card:hover{transform:none}
  .room-card:hover .room-card__img img{transform:none}
  .retreat__gallery img:hover{transform:none}
}

/* ====================================================================== */
/* ============  $10K LUXE LAYER — Awwwards-tier execution  ============== */
/* ====================================================================== */

:root{
  --amb: 0 30px 60px -28px rgba(0,0,0,.7), 0 8px 20px -12px rgba(0,0,0,.55);
  --amb-gold: 0 40px 80px -36px rgba(201,162,90,.28);
  --bezel-r: 22px;
}

/* ---- Gold scroll-progress rail ---- */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:120;
  background:var(--gold-grad);transform:scaleX(0);transform-origin:0 50%;
  will-change:transform;box-shadow:0 0 18px rgba(201,162,90,.5)}

/* ---- Cinematic reveal: fade-up + soft de-blur ---- */
.reveal{filter:blur(8px);transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease)}
.reveal.in{filter:blur(0)}

/* ---- Editorial section numbering (01 — / 02 — ...) ---- */
body{counter-reset:sec}
.section .section__head .eyebrow::before{
  counter-increment:sec;
  content:counter(sec,decimal-leading-zero) " / ";
  color:var(--gold-lt);opacity:.85;font-variant-numeric:tabular-nums}

/* ---- Double-bezel + ambient elevation on major cards ---- */
.room-card,.taste__card,.testi__card,.menu-panel{
  border-radius:var(--bezel-r);
  box-shadow:var(--amb);
  background:
    linear-gradient(180deg,rgba(244,237,225,.04),rgba(244,237,225,0) 40%),
    var(--card);
  position:relative;
  transition:transform .7s cubic-bezier(.22,.61,.36,1),box-shadow .7s cubic-bezier(.22,.61,.36,1),border-color .7s var(--ease)}
/* inner top highlight (machined-glass edge) */
.room-card::before,.taste__card::before,.testi__card::before,.menu-panel::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  box-shadow:inset 0 1px 0 rgba(244,237,225,.14), inset 0 0 0 1px rgba(201,162,90,.10);
  z-index:3}
.room-card:hover,.taste__card:hover,.testi__card:hover,.menu-panel:hover{
  transform:translateY(-8px);
  box-shadow:var(--amb), var(--amb-gold);
  border-color:rgba(201,162,90,.4)}

/* slightly rounder, deeper media corners inside cards */
.room-card__img,.taste__img{border-radius:calc(var(--bezel-r) - 8px);overflow:hidden}

/* ---- Button-in-button: nested arrow on gold CTAs ---- */
.btn--gold{position:relative;padding-right:.55em}
.btn__ico{display:inline-flex;align-items:center;justify-content:center;
  width:1.65em;height:1.65em;margin-left:.1em;border-radius:999px;
  background:rgba(42,29,12,.16);color:#2a1d0c;font-size:.9em;line-height:1;
  transition:transform .5s cubic-bezier(.32,.72,0,1),background .5s var(--ease)}
.btn--gold:hover .btn__ico{transform:translate(2px,-2px) scale(1.06);background:rgba(42,29,12,.26)}
.btn--gold:active{transform:translateY(0) scale(.975)}

/* magnetic helper (JS sets --mx/--my) */
.btn--gold{transition:transform .35s cubic-bezier(.22,.61,.36,1),box-shadow .35s var(--ease)}
.btn--gold.is-magnetic{transform:translate(var(--mx,0),var(--my,0))}

/* ---- Keyboard accessibility: visible focus ring (checklist #8) ---- */
a:focus-visible,button:focus-visible,.btn:focus-visible,.tab:focus-visible,
.navlink:focus-visible,.lang-btn:focus-visible,.gal:focus-visible{
  outline:2px solid var(--gold-lt);outline-offset:3px;border-radius:6px}
:focus:not(:focus-visible){outline:none}

/* ---- Refined heading shimmer accent (key H2s) ---- */
.h2 .accent,.h2 em{
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  color:transparent;font-style:normal}

/* ---- Section breathing: a touch more air on large screens ---- */
@media(min-width:1024px){ .section{padding:clamp(96px,12vw,168px) 0} }

/* ---- Respect reduced motion: undo blur/magnetic/lift ---- */
@media (prefers-reduced-motion:reduce){
  .reveal{filter:none;transition:none}
  .room-card:hover,.taste__card:hover,.testi__card:hover,.menu-panel:hover{transform:none}
  .btn--gold.is-magnetic{transform:none}
  .scroll-progress{display:none}
}

/* ====================================================================== */
/* ============  HERO HEADLINE + LIGHTBOX CAPTION (upgrade)  ============= */
/* ====================================================================== */

/* Editorial hero title overlays the scroll-scrubbed canvas and fades out
   as the frame sequence advances (JS sets opacity/transform on scroll). */
.hero__intro{
  position:absolute;z-index:2;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:min(900px,92vw);text-align:center;padding:0 20px;
  will-change:opacity,transform;pointer-events:none}
.hero__eyebrow{
  font-size:.74rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-lt);margin-bottom:1.1rem;display:block;
  text-shadow:0 1px 16px rgba(0,0,0,.6)}
/* tighten the pre-defined hero type a touch on small screens */
.hero__intro .hero__title{margin:.4rem 0 1.3rem}

/* Reduced motion: no scrub, so stack the title above the CTA cleanly */
@media (prefers-reduced-motion:reduce){
  .hero__sticky{flex-direction:column;gap:26px;justify-content:center}
  .hero__intro{position:static;left:auto;top:auto;transform:none;opacity:1}
}

/* Lightbox caption + counter */
.lb-figure{margin:0;display:flex;flex-direction:column;align-items:center;gap:14px;max-width:92vw}
.lightbox .lb-figure img{max-height:78vh}
.lb-cap{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
  color:#e7ddcb;font-size:.9rem;letter-spacing:.02em;max-width:680px;text-align:center}
.lb-cap:empty{display:none}
.lb-count{font-variant-numeric:tabular-nums;color:var(--gold-lt);font-weight:600;
  border:1px solid var(--line);border-radius:999px;padding:3px 12px;font-size:.8rem;white-space:nowrap}
.lb-strip{display:none;grid-template-columns:repeat(auto-fit,minmax(58px,1fr));gap:10px;width:min(92vw,760px);max-height:132px;overflow:auto;padding:2px 2px 4px}
.lb-strip.show{display:grid}
.lb-strip button{border:1px solid rgba(255,255,255,.14);border-radius:12px;overflow:hidden;background:rgba(255,255,255,.04);padding:0;aspect-ratio:1/1;cursor:pointer;opacity:.58;transition:opacity .2s ease,border-color .2s ease,transform .2s ease}
.lb-strip button.is-active{opacity:1;border-color:var(--gold-lt);transform:translateY(-1px)}
.lb-strip img{width:100%;height:100%;object-fit:cover;display:block}

/* ====================================================================== */
/* ============  MULTI-PAGE: nav active · page banner · explore  ========= */
/* ====================================================================== */
.navlink[aria-current="page"]{color:var(--gold-lt);background:rgba(201,162,90,.08)}
.navlink[aria-current="page"]::after{transform:scaleX(1)}
.mobile__link[aria-current="page"]{color:var(--gold-lt)}

/* Slim editorial banner that opens every content page */
.page-hero{position:relative;isolation:isolate;overflow:hidden;
  padding:clamp(116px,17vh,196px) 0 clamp(52px,7vw,92px);
  border-bottom:1px solid var(--line-soft)}
.page-hero__bg{position:absolute;inset:0;z-index:-2}
.page-hero__bg img{width:100%;height:100%;object-fit:cover}
.page-hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(13,11,9,.66),rgba(13,11,9,.8) 58%,var(--ink) 100%),
    radial-gradient(130% 90% at 28% 0%,rgba(13,11,9,.45),transparent 62%)}
.page-hero__inner{max-width:780px}
.page-hero .h1{font-family:"Cormorant Garamond",serif;font-weight:500;line-height:1.04;
  letter-spacing:-.01em;color:#fff;font-size:clamp(2.5rem,6.4vw,4.6rem);margin-top:.45rem}
.page-hero .h1 em{font-style:italic;color:var(--gold-lt)}
.page-hero .lead{margin-top:1.15rem;max-width:600px}
.page-hero__crumb{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);display:flex;gap:8px;align-items:center}
.page-hero__crumb a{color:var(--muted-2);transition:color .2s}
.page-hero__crumb a:hover{color:var(--gold-lt)}
.page-hero__crumb span{color:var(--gold)}
/* a content page's first section can sit tighter under the banner */
.page-body > .section:first-of-type{padding-top:clamp(48px,7vw,96px)}

/* Explore gateway grid on the home page */
.explore{padding:clamp(64px,9vw,128px) 0}
.explore__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.xcard{position:relative;display:block;border-radius:var(--bezel-r);overflow:hidden;
  aspect-ratio:4/5;background:var(--card);box-shadow:var(--amb);
  transition:transform .6s var(--ease),box-shadow .6s var(--ease)}
.xcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 1s var(--ease);filter:brightness(.82)}
.xcard::after{content:"";position:absolute;inset:0;
  background:linear-gradient(transparent 32%,rgba(13,11,9,.55) 64%,rgba(13,11,9,.95))}
.xcard__body{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:24px}
.xcard__n{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-lt);font-weight:600}
.xcard__t{font-family:"Cormorant Garamond",serif;font-size:1.5rem;color:#fff;margin:.3rem 0 .35rem;line-height:1.1}
.xcard__d{font-size:.9rem;color:#ddd1bd;line-height:1.5}
.xcard__go{display:inline-flex;align-items:center;gap:.45em;margin-top:.8rem;color:var(--gold-lt);font-size:.84rem;font-weight:600;letter-spacing:.02em}
.xcard__go svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.8;transition:transform .4s var(--ease)}
.xcard:hover{transform:translateY(-6px);box-shadow:var(--amb),var(--amb-gold)}
.xcard:hover img{transform:scale(1.06)}
.xcard:hover .xcard__go svg{transform:translateX(4px)}
@media(max-width:880px){.explore__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.explore__grid{grid-template-columns:1fr}}

@media (prefers-reduced-motion:reduce){
  .xcard:hover{transform:none}
  .xcard:hover img{transform:none}
}

/* Full 8-item nav needs a little more room before collapsing to the burger */
@media(max-width:1180px){
  .nav__inner{gap:14px;padding:0 14px}
  .nav__links{gap:4px;margin-left:0}
  .navlink{font-size:.72rem;padding:0 7px;letter-spacing:.02em}
  .nav__right{gap:8px}
  .lang{padding:4px 7px 4px 4px}
  .lang-btn{min-width:32px;height:32px}
  .nav__cta{padding:8px 10px 8px 14px;min-height:46px;font-size:.86rem}
  .nav__cta-icon{width:26px;height:26px;font-size:.9rem}
}
@media(max-width:1280px){
  .reservation__inner{gap:30px}
  .reservation__intro{max-width:420px}
}
@media(max-width:1420px){
  .nav::before{left:10px;right:10px;top:8px;bottom:8px}
  .nav__inner{height:86px}
  .nav__links{display:none}
  .nav__cta{display:none}
  .burger{display:flex}
  .fab{display:grid}
}
/* lone explore label shouldn't carry a section number */
.explore .section__head .eyebrow::before{content:none}

/* ====================================================================== */
/* ============  STAY: clickable room cards + detail modal  ============= */
/* ====================================================================== */
.room-card[data-room]{cursor:pointer}
.room-card[data-room]:focus-visible{outline:2px solid var(--gold-lt);outline-offset:3px}
.room-card__more{display:inline-flex;align-items:center;gap:.4em;margin-top:6px;
  color:var(--gold-lt);font-size:.84rem;font-weight:600;letter-spacing:.02em}
.room-card[data-room] .room-card__more span[aria-hidden]{transition:transform .35s var(--ease)}
.room-card[data-room]:hover .room-card__more span[aria-hidden]{transform:translateX(4px)}

.room-modal{position:fixed;inset:0;z-index:130;display:none;align-items:center;justify-content:center;padding:clamp(14px,3vw,40px)}
.room-modal.open{display:flex;animation:fadein .3s ease}
.room-modal__backdrop{position:absolute;inset:0;background:rgba(8,7,6,.86);backdrop-filter:blur(8px)}
.room-modal__panel{position:relative;z-index:2;width:min(1080px,100%);max-height:92vh;overflow:auto;
  background:var(--ink-2);border:1px solid var(--line);border-radius:var(--bezel-r);
  box-shadow:var(--shadow);padding:clamp(16px,2.4vw,26px)}
.room-modal__close{position:absolute;top:12px;right:14px;z-index:5;width:42px;height:42px;border-radius:50%;
  font-size:1.2rem;color:var(--cream);background:rgba(13,11,9,.5);border:1px solid var(--line-soft);transition:all .2s}
.room-modal__close:hover{background:rgba(201,162,90,.18);color:var(--gold-lt)}

.room-detail{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(20px,2.6vw,34px);align-items:start}
.room-detail[hidden]{display:none}
.rd__main{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:calc(var(--bezel-r) - 8px);
  box-shadow:0 30px 60px -34px rgba(0,0,0,.8)}
.rd__thumbs{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:10px}
.rd__thumb{border-radius:9px;overflow:hidden;border:1px solid var(--line-soft);aspect-ratio:1/1;opacity:.62;
  transition:opacity .25s var(--ease),border-color .25s,transform .25s var(--ease)}
.rd__thumb img{width:100%;height:100%;object-fit:cover}
.rd__thumb:hover{opacity:.92;transform:translateY(-2px)}
.rd__thumb.is-active{opacity:1;border-color:var(--gold)}
.rd__info{display:flex;flex-direction:column;gap:12px;padding-top:6px}
.rd__info .room-card__badge{align-self:flex-start}
.rd__name{font-family:"Cormorant Garamond",serif;font-size:clamp(24px,3vw,34px);color:var(--cream);line-height:1.12}
.rd__meta{color:var(--gold-lt);font-size:13.5px;letter-spacing:.04em}
.rd__desc{color:var(--muted);line-height:1.7;font-size:15px}
.rd__amen{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:2px 0 6px}
.rd__amen li{font-size:12.5px;color:var(--cream);border:1px solid var(--line);border-radius:999px;
  padding:6px 12px;background:rgba(244,237,225,.03)}
.rd__info .btn--gold{align-self:flex-start;margin-top:6px}

@media(max-width:760px){
  .room-detail{grid-template-columns:1fr;gap:18px}
  .rd__thumbs{grid-template-columns:repeat(6,1fr)}
}
@media (prefers-reduced-motion:reduce){
  .rd__thumb:hover{transform:none}
  .room-card[data-room]:hover .room-card__more span[aria-hidden]{transform:none}
}


/* ====================================================================== */
/* ===========  HORIZON — chỉnh sửa giao diện bổ sung  ================== */
/* ====================================================================== */

/* Lấp đầy lưới ảnh, không còn ô trống */
.gallery__grid{grid-auto-flow:dense}

/* Thẻ/ảnh click được để xem thông tin */
.infozoom{cursor:pointer}
.taste__card.infozoom{border:0;padding:0;margin:0}
.menu-panel__photo.infozoom{cursor:pointer}
.infozoom:focus-visible{outline:2px solid var(--gold,#c9a25a);outline-offset:3px}

/* Dải ảnh bổ sung (taste + menu) */
.strip__head{font-family:"Cormorant Garamond",serif;font-size:clamp(1.15rem,2vw,1.5rem);
  margin:clamp(30px,4vw,44px) 0 0;color:var(--ink,#2a221c)}
.photo-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:14px;margin-top:clamp(14px,2vw,20px)}
.photo-strip figure{position:relative;margin:0;border-radius:14px;overflow:hidden;
  aspect-ratio:4/5;background:var(--ink-2);cursor:pointer;border:1px solid var(--line-soft)}
.photo-strip img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.photo-strip figure:hover img{transform:scale(1.06)}
.photo-strip figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 14px 12px;
  color:#fff;font-size:.92rem;line-height:1.3;
  background:linear-gradient(transparent,rgba(13,11,9,.88))}

/* Info lightbox (ảnh + tiêu đề + mô tả) */
.infolb .infolb__fig{display:flex;flex-direction:column;align-items:center;max-width:min(92vw,1000px)}
.infolb__cap{display:flex;flex-direction:column;gap:6px;text-align:center;color:#fff;margin-top:14px;max-width:680px}
.infolb__cap strong{font-family:"Cormorant Garamond",serif;font-size:1.2rem}
.infolb__cap span{opacity:.85;font-size:.95rem;line-height:1.5}

/* Đặt bàn / Đặt phòng — nút chuyển */
.seg{grid-column:1/-1;display:flex;gap:6px;background:rgba(255,255,255,.06);
  border:1px solid var(--line);border-radius:999px;padding:5px;margin-bottom:4px}
.seg__btn{flex:1;border:0;background:transparent;color:inherit;padding:11px 14px;
  border-radius:999px;cursor:pointer;font:inherit;transition:background .25s,color .25s}
.seg__btn.is-on{background:var(--gold,#c9a25a);color:#1a1410;font-weight:600}
.resform[data-mode="table"] .js-room-only{display:none}
.resform[data-mode="room"] .js-table-only{display:none}


/* ====================================================================== */
/* ===  STAY HERO: ảnh ở desktop, video ở mobile  ====================== */
/* ====================================================================== */
.retreat__hero-vid{display:none}
@media(max-width:768px){
  .retreat__hero .retreat__hero-img{display:none}
  .retreat__hero .retreat__hero-vid{display:block;width:100%;height:auto;background:#000}
}
