/* ── Reset & base ────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:#FFFBF7;color:#2C2424;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;overflow-x:hidden;line-height:1.5;}
a{text-decoration:none;color:inherit;}
::selection{background:#E31E24;color:white;}

/* ── Scrollbar ───────────────────────────────────────── */
::-webkit-scrollbar{width:8px;}
::-webkit-scrollbar-track{background:#fffbf7;}
::-webkit-scrollbar-thumb{background:#E31E24;border-radius:4px;}

/* ── Keyframe animations ─────────────────────────────── */
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
@keyframes heroZoom{0%,100%{transform:scale(1.05);}50%{transform:scale(1.12);}}
@keyframes spinSlow{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
@keyframes bounceCue{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(6px);}}
@keyframes fadeIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes revealLeft{from{opacity:0;transform:translateX(-40px);}to{opacity:1;transform:translateX(0);}}
@keyframes revealRight{from{opacity:0;transform:translateX(40px);}to{opacity:1;transform:translateX(0);}}
@keyframes revealUp{from{opacity:0;transform:translateY(40px);}to{opacity:1;transform:translateY(0);}}

/* ── Utility classes ─────────────────────────────────── */
.animate-float{animation:float 6s ease-in-out infinite;}
.animate-spin-slow{animation:spinSlow 12s linear infinite;}
.hero-img{animation:heroZoom 28s ease-in-out infinite;}

/* ── Scroll reveal ───────────────────────────────────── */
.reveal{opacity:0;transition:opacity .9s ease,transform .9s ease;}
.reveal.from-up   {transform:translateY(44px);}
.reveal.from-left {transform:translateX(-44px);}
.reveal.from-right{transform:translateX(44px);}
.reveal.visible   {opacity:1;transform:translate(0,0);}

/* ── Nav scroll transition ───────────────────────────── */
#main-nav{transition:background .4s,padding .4s,box-shadow .4s;}

/* ── Nav link underline hover ────────────────────────── */
.nav-link{position:relative;padding-bottom:3px;transition:color .3s;color:#2C2424;}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:#E31E24;transition:width .3s ease;}
.nav-link:hover::after{width:100%;}
.nav-link:hover{color:#E31E24;}

/* ── Nav state: transparent (over hero) vs scrolled ─── */
#main-nav.over-hero .nav-link{color:rgba(255,255,255,.92);}
#main-nav.over-hero #book-btn{background:rgba(255,255,255,.15);color:white;border:1px solid rgba(255,255,255,.4);}
#main-nav.over-hero #book-btn:hover{background:white;color:#2C2424;}
#main-nav.over-hero #mobile-menu-btn span{background:white;}
#main-nav.over-hero #mobile-menu-btn{border-color:rgba(255,255,255,.3);}
#main-nav.over-hero .nav-link:hover{color:white;}

/* ── Book Now button hover ───────────────────────────── */
#book-btn{transition:background .25s,transform .2s,box-shadow .25s;}
#book-btn:hover{background:#E31E24;transform:translateY(-2px);box-shadow:0 8px 20px rgba(227,30,36,.35);}

/* ── Booking widget tabs ─────────────────────────────── */
.tab-btn{transition:color .2s,border-color .2s;}
.booking-field{transition:background .2s;}
.booking-field:hover{background:rgba(227,30,36,.04);}
.booking-field:hover .field-label{color:#E31E24;}
#cta-btn{transition:background .2s;}
#cta-btn:hover{background:#c4151b;}

/* ── Booking icon (hidden on desktop, shown on mobile) ── */
.bk-icon{display:none;flex-shrink:0;color:rgba(44,36,36,.45);}
.bk-text{display:flex;flex-direction:column;}
.field-label{display:block;}
.field-value{display:block;}

/* ── Booking field wrappers & dropdowns ─────────────── */
.bk-field-wrap{position:relative;flex:1;min-width:0;display:flex;}
.bk-field-wrap>.booking-field{flex:1;transition:background .2s;}
.bk-field-wrap.active>.booking-field{background:rgba(227,30,36,.05);}
.bk-dropdown{
  position:absolute;top:calc(100% + 8px);left:0;z-index:200;
  background:white;border-radius:16px;
  box-shadow:0 10px 40px rgba(44,36,36,.16);
  border:1px solid rgba(44,36,36,.08);
  padding:20px;min-width:260px;
  display:none;animation:fadeIn .18s ease;
}
.bk-dropdown.open{display:block;}
.bk-drop-label{font-size:11px;font-weight:800;color:rgba(44,36,36,.4);text-transform:uppercase;letter-spacing:.13em;margin-bottom:10px;}
.bk-date-input{
  width:100%;padding:10px 12px;
  border:1.5px solid rgba(44,36,36,.12);border-radius:8px;
  font-size:15px;font-weight:600;color:#2C2424;
  outline:none;cursor:pointer;box-sizing:border-box;
}
.bk-date-input:focus{border-color:#E31E24;}
/* ── Calendar picker ─────────────────────────────────── */
.cal-dropdown{min-width:664px;padding:20px 22px 16px;}
.cal-top{display:flex;align-items:flex-start;gap:8px;}
.cal-nav-side{display:flex;flex-direction:column;justify-content:flex-start;padding-top:28px;flex-shrink:0;}
.cal-nav-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid rgba(44,36,36,.15);background:white;cursor:pointer;font-size:20px;line-height:1;color:#2C2424;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s;flex-shrink:0;}
.cal-nav-btn:hover{border-color:#E31E24;color:#E31E24;}
.cal-months{display:grid;grid-template-columns:1fr 1fr;gap:0 28px;flex:1;min-width:0;}
.cal-month-title{font-size:13px;font-weight:800;color:#2C2424;text-align:center;margin-bottom:10px;letter-spacing:.04em;text-transform:uppercase;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px 0;}
.cal-dow{font-size:9px;font-weight:800;color:rgba(44,36,36,.3);text-transform:uppercase;letter-spacing:.07em;text-align:center;padding:0 0 8px;}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#2C2424;border-radius:50%;cursor:pointer;transition:background .12s,color .12s;position:relative;user-select:none;}
.cal-day:hover:not(.cal-past):not(.cal-empty){background:rgba(227,30,36,.13);color:#E31E24;}
.cal-day.cal-past{color:rgba(44,36,36,.2);cursor:default;pointer-events:none;}
.cal-day.cal-empty{pointer-events:none;}
.cal-day.cal-today{font-weight:800;}
.cal-day.cal-today::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:3px;height:3px;background:#E31E24;border-radius:50%;}
.cal-day.cal-sel{background:#E31E24 !important;color:#fff !important;border-radius:50% !important;}
.cal-day.cal-inrange{background:rgba(227,30,36,.09);border-radius:0;color:#c41a20;}
.cal-day.cal-range-start{background:#E31E24;color:#fff;border-radius:50% 0 0 50%;}
.cal-day.cal-range-end{background:#E31E24;color:#fff;border-radius:0 50% 50% 0;}
.cal-day.cal-range-start.cal-range-end{border-radius:50%;}
.cal-footer{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:12px;border-top:1px solid rgba(44,36,36,.07);}
.cal-hint{font-size:11px;font-weight:700;color:rgba(44,36,36,.4);letter-spacing:.03em;}
.cal-clear-btn{background:none;border:1.5px solid rgba(44,36,36,.15);cursor:pointer;font-size:12px;font-weight:700;color:rgba(44,36,36,.4);padding:7px 14px;border-radius:8px;transition:all .15s;}
.cal-clear-btn:hover{border-color:#E31E24;color:#E31E24;}
.cal-done-btn{background:#2C2424;color:white;border:none;cursor:pointer;font-size:13px;font-weight:700;padding:9px 22px;border-radius:8px;transition:background .15s;}
.cal-done-btn:hover{background:#E31E24;}
/* ── Merged dates field ──────────────────────────────── */
.dates-wrap{display:flex;align-items:stretch;}
.dates-half{flex:1;min-width:0;transition:background .2s;}
.dates-half:hover{background:rgba(227,30,36,.04);}
.dates-arrow{display:flex;align-items:center;color:rgba(44,36,36,.2);flex-shrink:0;padding:0 2px;}
.cal-single{min-width:280px;padding:16px 18px 14px;}
.cal-single .cal-months{grid-template-columns:1fr;}
@media(max-width:700px){
  .cal-dropdown{min-width:unset;width:calc(100vw - 32px);}
  .cal-months{grid-template-columns:1fr;}
}
.cnt-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;}
.cnt-row+.cnt-row{border-top:1px solid rgba(44,36,36,.06);}
.cnt-info{font-weight:700;color:#2C2424;font-size:14px;}
.cnt-sub{font-size:11px;color:rgba(44,36,36,.4);margin-top:2px;}
.cnt-controls{display:flex;align-items:center;gap:14px;}
.cnt-btn{
  width:32px;height:32px;border-radius:50%;
  border:1.5px solid rgba(44,36,36,.2);background:white;
  cursor:pointer;font-size:18px;line-height:1;color:#2C2424;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s;
}
.cnt-btn:hover{border-color:#E31E24;color:#E31E24;}
.cnt-num{font-weight:700;font-size:16px;min-width:22px;text-align:center;color:#2C2424;}
.bk-done-btn{
  width:100%;margin-top:14px;background:#2C2424;color:white;
  padding:10px;border:none;border-radius:8px;font-weight:700;
  font-size:13px;cursor:pointer;transition:background .2s;
}
.bk-done-btn:hover{background:#E31E24;}
.promo-row{display:flex;gap:8px;margin-top:10px;}
.promo-input{
  flex:1;padding:10px 12px;
  border:1.5px solid rgba(44,36,36,.12);border-radius:8px;
  font-size:14px;color:#2C2424;outline:none;
}
.promo-input:focus{border-color:#E31E24;}
.promo-apply{
  background:#E31E24;color:white;padding:10px 16px;
  border:none;border-radius:8px;font-weight:700;font-size:13px;cursor:pointer;
  transition:background .2s;white-space:nowrap;
}
.promo-apply:hover{background:#c4151b;}

/* ── Booking row responsive (≤640px) ────────────────── */
@media(max-width:640px){
  #booking-tabs{display:none !important;}
  .booking-row{flex-direction:column;background:transparent;border:none !important;border-radius:0;gap:6px;}
  .booking-row #room-fields{flex-direction:column;gap:6px;width:100%;}
  .booking-row #event-fields{flex-direction:column;gap:6px;width:100%;}
  .bk-field-wrap{width:100%;flex:none;}
  .booking-field{background:white;border:1.5px solid rgba(44,36,36,.1) !important;border-radius:10px !important;padding:14px 16px !important;display:flex !important;align-items:center;gap:14px;flex-direction:row !important;width:100% !important;box-sizing:border-box;}
  .bk-dropdown{position:fixed;left:16px;right:16px;min-width:0;top:50%;transform:translateY(-50%);}
  .bk-icon{display:block;}
  .field-label{display:none !important;}
  .field-value{font-size:16px !important;color:#2C2424 !important;white-space:normal !important;}
  #cta-btn{width:100%;border-radius:10px !important;padding:15px 24px !important;justify-content:center;margin-top:2px;}
}

/* ── Feature icon hover ──────────────────────────────── */
.feature-icon{transition:background .3s,color .3s,transform .3s;}
.feature-item:hover .feature-icon{background:#E31E24;color:white;transform:scale(1.1);}

/* ── Room cards ──────────────────────────────────────── */
.room-card{transition:transform .45s cubic-bezier(.2,.8,.2,1),box-shadow .45s ease;}
.room-card:hover{transform:translateY(-10px);box-shadow:0 28px 60px rgba(44,36,36,.14);}
.room-card-img img{transition:transform .7s ease;}
.room-card:hover .room-card-img img{transform:scale(1.1);}
.room-card-inner{transition:background .3s;}
.room-card:hover .room-card-inner{background:white;}
.room-btn{transition:background .3s,color .3s,border-color .3s;}
.room-card:hover .room-btn{background:#2C2424;color:white;border-color:#2C2424;}
/* subtle red overlay on hover */
.room-overlay{position:absolute;inset:0;background:rgba(227,30,36,0);transition:background .4s;}
.room-card:hover .room-overlay{background:rgba(227,30,36,.07);}

/* ── Dining image hover ──────────────────────────────── */
.dining-img{transition:opacity .5s,transform .7s;}
.dining-img-wrap:hover .dining-img{opacity:1;transform:scale(1.03);}

/* ── Dining item hover ───────────────────────────────── */
.dining-item{transition:background .25s;}
.dining-item:hover{background:rgba(255,255,255,.06);}
.dining-icon{transition:background .3s,color .3s,transform .3s;}
.dining-item:hover .dining-icon{background:#E31E24;color:white;transform:scale(1.08);}

/* ── Dining outlet cards ─────────────────────────────── */
.outlet-cards{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(255,255,255,.06);}
.outlet-card{padding:40px 32px;background:#141010;transition:background .3s;}
.outlet-card:hover{background:rgba(255,255,255,.025);}
@media(max-width:900px){
  .outlet-cards{grid-template-columns:1fr;}
  .outlet-card{border-bottom:1px solid rgba(255,255,255,.06);}
  .outlet-card:last-child{border-bottom:none;}
}

/* ── Menu Modal ──────────────────────────────────────── */
#menu-modal{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.82);backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;padding:32px 16px;overflow-y:auto;}
#menu-modal.open{display:flex;}
.modal-box{background:#FFFBF7;border-radius:20px;width:100%;max-width:840px;box-shadow:0 40px 80px rgba(0,0,0,.5);flex-shrink:0;animation:fadeIn .22s ease;}
.ev-opt{display:block;width:100%;text-align:left;padding:9px 12px;font-size:13px;font-weight:600;color:#2C2424;background:none;border:none;border-radius:8px;cursor:pointer;transition:background .15s;}
.ev-opt:hover{background:rgba(227,30,36,.06);color:#E31E24;}
.modal-head{position:sticky;top:0;background:#FFFBF7;border-radius:20px 20px 0 0;border-bottom:1px solid rgba(44,36,36,.08);padding:20px 28px 0;z-index:10;}
.modal-head-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.modal-close{width:32px;height:32px;border-radius:50%;background:rgba(44,36,36,.07);border:none;cursor:pointer;font-size:20px;color:#2C2424;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;line-height:1;}
.modal-close:hover{background:#E31E24;color:white;}
.modal-tabs-bar{display:flex;gap:0;overflow-x:auto;}
.modal-tab-btn{padding:8px 20px 12px;font-size:13px;font-weight:700;background:none;border:none;cursor:pointer;color:rgba(44,36,36,.4);border-bottom:2px solid transparent;transition:color .2s,border-color .2s;white-space:nowrap;flex-shrink:0;}
.modal-tab-btn.active{color:#E31E24;border-bottom-color:#E31E24;}
.modal-body{padding:24px 28px 32px;}
.msec-title{font-size:10px;font-weight:800;color:rgba(44,36,36,.35);text-transform:uppercase;letter-spacing:.16em;padding:20px 0 10px;border-top:1px solid rgba(44,36,36,.06);margin-bottom:4px;}
.msec:first-child .msec-title,.msec-title:first-child{border-top:none;padding-top:0;}
.msec{margin-bottom:8px;}
.mdish{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;gap:16px;border-bottom:1px solid rgba(44,36,36,.04);}
.mdish:last-child{border-bottom:none;}
.mdish-left{flex:1;min-width:0;}
.mdish-name{font-size:13px;font-weight:700;color:#2C2424;margin-bottom:2px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.mdish-desc{font-size:11px;color:rgba(44,36,36,.45);font-weight:500;line-height:1.4;}
.mdish-price{font-size:13px;font-weight:800;color:#E31E24;flex-shrink:0;white-space:nowrap;margin-top:1px;}
.mdot-v,.mdot-nv{display:inline-flex;width:11px;height:11px;flex-shrink:0;border-radius:2px;align-items:center;justify-content:center;}
.mdot-v{border:1.5px solid #27ae60;}
.mdot-v::after,.mdot-nv::after{content:'';width:4px;height:4px;border-radius:50%;}
.mdot-v::after{background:#27ae60;}
.mdot-nv{border:1.5px solid #c0392b;}
.mdot-nv::after{background:#c0392b;}
.mcat-note{font-size:11px;color:rgba(44,36,36,.4);font-weight:600;margin-bottom:12px;margin-top:-4px;font-style:italic;}
@media(max-width:600px){.modal-head{padding:16px 18px 0;}.modal-body{padding:18px;}.modal-tab-btn{padding:6px 14px 10px;font-size:12px;}}

/* ── Events: grid cells ──────────────────────────────── */
.events-img img{transition:transform .6s ease;}
.events-img:hover img{transform:scale(1.06);}
.events-cell{transition:background .25s,transform .25s;}
.events-cell:hover{transform:scale(1.03);}

/* ── Events: CTA button ──────────────────────────────── */
.events-btn{transition:background .25s,transform .2s;}
.events-btn:hover{background:#E31E24;transform:translateY(-1px);}

/* ── Social icons ────────────────────────────────────── */
.social-icon{transition:background .25s,transform .2s;}
.social-icon:hover{background:#E31E24;transform:scale(1.12);}

/* ── Footer links ────────────────────────────────────── */
.footer-link{transition:color .2s;}
.footer-link:hover{color:#E31E24;}

/* ── Scroll cue ──────────────────────────────────────── */
#scroll-cue{animation:bounceCue 2s ease-in-out infinite;}

/* ════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════ */

/* ── Layout grid classes (no inline style overrides needed) ── */
.philosophy-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.dining-cols    {display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.events-layout  {display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.features-grid  {display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.three-col      {display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.four-col       {display:grid;grid-template-columns:1.5fr 1fr 1fr 1.5fr;gap:40px;margin-bottom:52px;}
.section-inner  {max-width:1100px;margin:0 auto;padding:0 24px;}

/* ── Tablet  ≤ 900px ─────────────────────────────────── */
@media(max-width:900px){
  #nav-links{display:none;}
  #mobile-menu-btn{display:flex !important;}
  .hero-headline{font-size:52px;}
  .hero-sub{font-size:15px;}
  .philosophy-grid{grid-template-columns:1fr;gap:40px;}
  .dining-cols{grid-template-columns:1fr;gap:40px;}
  .order-swap{order:-1;}
  .three-col{grid-template-columns:repeat(2,1fr);}
  .four-col{grid-template-columns:1fr 1fr;gap:32px;}
  .events-layout{grid-template-columns:1fr;}
  .events-grid{height:auto;}
}
/* ── Dining feature grid responsive ─────────────────── */
@media(max-width:900px){
  #dining [style*="grid-template-columns:420px"]{grid-template-columns:1fr !important;}
  #dining [style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr !important;}
  #dining [style*="padding:40px 36px 40px 0"]{padding:32px 0 !important;border-right:none !important;border-bottom:1px solid rgba(255,255,255,.06) !important;}
  #dining [style*="padding:40px 36px;"]{padding:32px 0 !important;border-right:none !important;border-bottom:1px solid rgba(255,255,255,.06) !important;}
  #dining [style*="padding:40px 0 40px 36px"]{padding:32px 0 !important;}
}

/* ── Mobile  ≤ 600px ─────────────────────────────────── */
@media(max-width:600px){
  #main-nav{padding-top:14px;padding-bottom:14px;}
  .hero-headline{font-size:38px;letter-spacing:-1px;}
  .hero-sub{font-size:14px;max-width:100%;}
  .hero-inner{padding-top:80px;padding-bottom:60px;}
  .hero-cta{font-size:13px;padding:12px 24px;}
  section{padding:56px 0;}
  .section-inner{padding:0 16px;}
  .philosophy-grid{grid-template-columns:1fr;gap:32px;}
  .philosophy-img{height:320px;}
  .features-grid{grid-template-columns:1fr;}
  .three-col{grid-template-columns:1fr;}
  .dining-cols{grid-template-columns:1fr;gap:32px;}
  #beverages [style*="grid-template-columns:2fr 1fr"]{grid-template-columns:1fr !important;}
  #beverages [style*="min-height:560px"]{min-height:280px !important;}
  .events-layout{grid-template-columns:1fr;}
  .events-grid{height:340px;}
  .section-h2{font-size:34px;}
  .section-header-row{flex-direction:column;gap:12px;}
  .section-header-row p{text-align:left;max-width:100%;}
  .four-col{grid-template-columns:1fr;gap:28px;}
  .spin-ring{display:none;}
}
