:root{
  --ocean:#1c6d95;
  --ocean-2:#2d93bd;
  --deep:#04131c;
  --navy:#08283b;
  --navy-2:#0d3d56;
  --sand:#c6a36a;
  --sand-2:#ead7b0;
  --paper:#f7f1e6;
  --cream:#fffaf0;
  --white:#ffffff;
  --muted:#6b7c86;
  --line:rgba(8,40,59,.12);
  --shadow:0 28px 80px rgba(4,19,28,.16);
  --soft-shadow:0 14px 36px rgba(4,19,28,.10);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--cream);color:var(--deep);overflow-x:hidden}
body.no-scroll{overflow:hidden}
a{text-decoration:none;color:inherit}button,input,select,textarea{font:inherit}button{cursor:pointer}img{max-width:100%;display:block}.full{width:100%}
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--sand),var(--ocean-2));z-index:5000;box-shadow:0 0 24px rgba(198,163,106,.5)}
.luxury-noise{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.06;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E")}
.ambient{position:fixed;border-radius:999px;filter:blur(70px);pointer-events:none;z-index:0;opacity:.42}.ambient-one{width:380px;height:380px;right:-160px;top:140px;background:rgba(45,147,189,.32)}.ambient-two{width:380px;height:380px;left:-130px;bottom:120px;background:rgba(198,163,106,.24)}
.site-header{position:fixed;top:18px;left:50%;transform:translateX(-50%);width:min(1180px,calc(100% - 32px));min-height:76px;border:1px solid rgba(255,255,255,.22);border-radius:28px;background:rgba(4,19,28,.68);backdrop-filter:blur(22px);display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 16px;z-index:1000;box-shadow:0 18px 50px rgba(0,0,0,.22)}
.brand{display:flex;align-items:center;min-width:175px}.brand img{width:164px;filter:brightness(0) invert(1)}
.main-nav{display:flex;align-items:center;justify-content:center;gap:6px;background:rgba(255,255,255,.06);padding:6px;border-radius:999px}.main-nav a{color:rgba(255,255,255,.78);font-size:14px;font-weight:800;padding:11px 17px;border-radius:999px;transition:.25s}.main-nav a:hover,.main-nav a.active{background:rgba(255,255,255,.14);color:#fff}
.header-actions{display:flex;align-items:center;gap:10px}.header-call,.cart-pill{height:44px;border:1px solid rgba(255,255,255,.16);border-radius:999px;background:rgba(255,255,255,.1);color:#fff;font-weight:900;padding:0 18px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.cart-pill span{min-width:24px;height:24px;display:inline-grid;place-items:center;border-radius:999px;background:var(--sand);color:#fff;font-size:12px}
.hero{position:relative;min-height:720px;background:#062132;color:#fff;overflow:hidden;padding:140px 24px 92px}.compact-hero{min-height:680px}.hero-media,.hero-gradient{position:absolute;inset:0}.hero-media img{width:100%;height:100%;object-fit:cover;animation:slowZoom 18s ease-in-out infinite alternate}.hero-gradient{background:linear-gradient(90deg,rgba(4,19,28,.92),rgba(4,19,28,.64),rgba(4,19,28,.42)),linear-gradient(0deg,rgba(4,19,28,.68),transparent 50%)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(330px,.55fr);align-items:end;gap:28px;width:min(1180px,100%);margin:0 auto}.hero-content{max-width:730px}.eyebrow{margin:0 0 12px;color:var(--sand);font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:12px}.hero h1{font-family:'Playfair Display',serif;font-size:clamp(48px,7vw,92px);line-height:.95;margin:0 0 22px;letter-spacing:-.045em}.hero-text{font-size:clamp(17px,2vw,22px);line-height:1.72;color:rgba(255,255,255,.78);font-weight:600;max-width:680px;margin:0 0 28px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}.btn{border:0;border-radius:999px;padding:14px 22px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.25s;min-height:48px}.btn-primary{background:linear-gradient(135deg,var(--sand),#ddbd83);color:#132838;box-shadow:0 18px 38px rgba(198,163,106,.28)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 22px 44px rgba(198,163,106,.34)}.btn-secondary{background:#fff;color:var(--navy);box-shadow:0 18px 34px rgba(255,255,255,.16)}.btn-secondary:hover{transform:translateY(-2px)}.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--navy)}.hero .btn-ghost{border-color:rgba(255,255,255,.20);color:#fff}.hero-meta{display:flex;gap:10px;flex-wrap:wrap}.hero-meta span{padding:10px 14px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.07);border-radius:999px;color:rgba(255,255,255,.76);font-weight:800;font-size:13px}.hero-offer-card{align-self:stretch;display:flex;flex-direction:column;justify-content:flex-end;min-height:390px;border:1px solid rgba(255,255,255,.18);border-radius:34px;background:linear-gradient(160deg,rgba(255,255,255,.18),rgba(255,255,255,.07));backdrop-filter:blur(22px);padding:28px;box-shadow:0 24px 70px rgba(0,0,0,.28);transform-style:preserve-3d}.offer-tag{display:inline-flex;width:max-content;border-radius:999px;background:rgba(198,163,106,.18);border:1px solid rgba(198,163,106,.36);color:var(--sand-2);padding:8px 12px;font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.09em}.hero-offer-card h2{font-size:36px;line-height:1.08;margin:18px 0 10px;color:#fff}.hero-offer-card p{color:rgba(255,255,255,.72);line-height:1.8;font-weight:700}.hero-price{display:flex;align-items:baseline;gap:12px;margin:10px 0 20px}.hero-price del{color:rgba(255,255,255,.46);font-weight:900}.hero-price strong{color:#fff;font-size:30px}
.section-pad{padding:90px 24px}.section-head{width:min(1180px,100%);margin:0 auto 34px;text-align:left}.section-head h2{font-family:'Playfair Display',serif;font-size:clamp(38px,5vw,62px);line-height:1;margin:0 0 14px;letter-spacing:-.04em;color:var(--deep)}.section-head p:not(.eyebrow){margin:0;color:var(--muted);font-size:18px;line-height:1.7;font-weight:600;max-width:720px}.setup-alert{width:min(1180px,calc(100% - 48px));margin:-50px auto 0;background:#fff4f4;color:#932b2b;border:1px solid rgba(147,43,43,.15);border-radius:28px;padding:24px;position:relative;z-index:3}.setup-alert h2{margin:0 0 8px}.offers-section{background:linear-gradient(180deg,#fffaf0,#f6efe4)}.offers-grid{width:min(1180px,100%);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.offer-card{background:rgba(255,255,255,.88);border:1px solid rgba(8,40,59,.08);border-radius:34px;overflow:hidden;box-shadow:var(--soft-shadow);transition:.25s;transform-style:preserve-3d}.offer-card:hover{box-shadow:var(--shadow)}.offer-img{position:relative;height:250px;overflow:hidden}.offer-img img{width:100%;height:100%;object-fit:cover;transition:.55s}.offer-card:hover .offer-img img{transform:scale(1.06)}.offer-img span{position:absolute;top:16px;left:16px;background:rgba(4,19,28,.72);color:#fff;border:1px solid rgba(255,255,255,.24);backdrop-filter:blur(12px);padding:8px 12px;border-radius:999px;font-weight:900;font-size:12px}.offer-body{padding:24px}.offer-body p{margin:0 0 8px;color:var(--sand);font-weight:900}.offer-body h3{font-size:26px;line-height:1.14;margin:0 0 10px;color:var(--deep)}.offer-body small{color:var(--muted);line-height:1.7;font-weight:700;display:block;min-height:50px}.price-row{display:flex;align-items:baseline;gap:12px;margin:18px 0}.price-row del{color:#9a9a9a;font-weight:800}.price-row strong{color:var(--ocean);font-size:28px}.mini-btn{width:100%;border:0;border-radius:18px;padding:14px;background:var(--navy);color:#fff;font-weight:900;transition:.25s}.mini-btn:hover{background:var(--ocean);transform:translateY(-2px)}
.menu-section{background:linear-gradient(180deg,#08283b,#04131c);color:#fff}.menu-section .section-head h2{color:#fff}.menu-section .section-head p:not(.eyebrow){color:rgba(255,255,255,.68)}.menu-shell{width:min(1180px,100%);margin:0 auto;background:linear-gradient(145deg,rgba(255,255,255,.12),rgba(255,255,255,.055));border:1px solid rgba(255,255,255,.12);border-radius:36px;padding:22px;box-shadow:0 34px 90px rgba(0,0,0,.24)}.menu-toolbar{display:grid;grid-template-columns:1fr auto;gap:12px;margin-bottom:16px}.search-wrap input,.menu-toolbar select{width:100%;height:54px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);color:#fff;border-radius:18px;padding:0 18px;outline:none;font-weight:800}.search-wrap input::placeholder{color:rgba(255,255,255,.5)}.menu-toolbar select option{color:#111}.cart-toggle{height:54px;color:#132838}.filters{display:flex;gap:10px;overflow:auto;padding:4px 0 12px;scrollbar-width:none}.filters::-webkit-scrollbar{display:none}.filter-btn{border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);color:rgba(255,255,255,.78);border-radius:999px;padding:12px 18px;white-space:nowrap;font-weight:900;transition:.22s}.filter-btn.active,.filter-btn:hover{background:#fff;color:var(--navy)}.menu-status{display:flex;align-items:center;justify-content:space-between;border-radius:18px;background:rgba(198,163,106,.12);border:1px solid rgba(198,163,106,.18);padding:12px 16px;margin-bottom:18px;color:var(--sand-2);font-weight:900}.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.menu-card{padding:22px;border-radius:28px;background:linear-gradient(160deg,rgba(255,255,255,.12),rgba(255,255,255,.055));border:1px solid rgba(255,255,255,.12);min-height:280px;display:flex;flex-direction:column;justify-content:space-between;transition:box-shadow .25s,border-color .25s,background .25s;position:relative;overflow:hidden;transform-style:preserve-3d}.menu-card:before{content:"";position:absolute;inset:auto -35px -35px auto;width:130px;height:130px;border-radius:50%;background:rgba(198,163,106,.13);pointer-events:none}.menu-card:hover{border-color:rgba(255,255,255,.27);background:linear-gradient(160deg,rgba(255,255,255,.17),rgba(255,255,255,.07));box-shadow:0 22px 46px rgba(0,0,0,.18)}.card-topline{display:flex;justify-content:space-between;gap:12px;align-items:center}.card-topline span{color:var(--sand-2);font-weight:900;font-size:13px}.card-topline em{font-style:normal;background:rgba(198,163,106,.18);color:#fff;border:1px solid rgba(198,163,106,.34);padding:6px 10px;border-radius:999px;font-weight:900;font-size:11px}.menu-card h3{font-size:23px;margin:16px 0 8px;line-height:1.24;color:#fff}.menu-card p{margin:0;color:rgba(255,255,255,.68);line-height:1.75;font-weight:650}.size-selector{display:flex;gap:8px;margin-top:16px}.size-btn{border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.09);color:#fff;border-radius:999px;padding:8px 12px;font-weight:900}.size-btn.active{background:#fff;color:var(--navy)}.menu-card-footer{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:22px}.menu-card-footer strong{font-size:21px;color:#fff}.menu-card-footer div{display:flex;gap:8px}.icon-btn{width:44px;height:44px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.09);color:#fff;border-radius:14px;font-size:20px}.icon-btn.active{background:var(--sand);color:#fff}.add-btn{height:44px;border:0;border-radius:14px;padding:0 18px;background:#fff;color:var(--navy);font-weight:900;transition:.18s}.add-btn.just-added{background:var(--sand);color:#fff}.menu-card.is-hidden{display:none}
.location-section{display:grid;grid-template-columns:1.05fr .95fr;gap:22px;background:linear-gradient(180deg,#04131c,#08283b);color:#fff}.location-card,.map-placeholder{border-radius:34px;padding:34px;background:linear-gradient(145deg,rgba(255,255,255,.12),rgba(255,255,255,.055));border:1px solid rgba(255,255,255,.12);box-shadow:0 28px 90px rgba(0,0,0,.24)}.location-card h2{font-family:'Playfair Display',serif;font-size:clamp(36px,4vw,56px);line-height:1;margin:0 0 16px;color:#fff}.location-card p{color:rgba(255,255,255,.72);line-height:1.8;font-weight:700}.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:22px 0}.contact-card{display:block;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:18px;transition:.25s}.contact-card:hover{background:rgba(255,255,255,.14);transform:translateY(-2px)}.contact-card span{display:block;color:var(--sand-2);font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.contact-card strong{display:block;margin-top:8px;color:#fff}.social-link{display:inline-block;color:var(--sand-2);font-weight:900}.map-placeholder{min-height:390px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}.map-placeholder:before{content:"";position:absolute;inset:22px;border-radius:28px;border:1px solid rgba(255,255,255,.12);background:radial-gradient(circle at 22% 18%,rgba(45,147,189,.42),transparent 32%),radial-gradient(circle at 70% 62%,rgba(198,163,106,.22),transparent 30%)}.map-placeholder>*{position:relative;z-index:2}.map-placeholder span{color:var(--sand-2);font-weight:900}.map-placeholder strong{font-family:'Playfair Display',serif;font-size:46px;line-height:1;margin:10px 0;color:#fff}.map-placeholder p{color:rgba(255,255,255,.72);line-height:1.8;font-weight:700}.map-lines{display:grid;gap:9px;margin-top:18px}.map-lines i{display:block;height:8px;border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,.34),rgba(255,255,255,.05))}.map-lines i:nth-child(2){width:70%}.map-lines i:nth-child(3){width:48%}
.site-footer{padding:48px 24px;text-align:center;background:#04131c;color:rgba(255,255,255,.72)}.site-footer img{width:190px;margin:0 auto 12px;filter:brightness(0) invert(1)}.site-footer p{font-weight:900;color:var(--sand-2);margin:0 0 8px}.mini-cart{position:fixed;left:50%;bottom:20px;transform:translate(-50%,120px);z-index:1200;display:flex;align-items:center;gap:12px;background:rgba(4,19,28,.88);color:#fff;border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(16px);border-radius:999px;padding:10px 12px 10px 18px;box-shadow:0 20px 50px rgba(0,0,0,.24);transition:.28s}.mini-cart.show{transform:translate(-50%,0)}.mini-cart span{font-weight:900}.mini-cart button{border:0;border-radius:999px;padding:10px 15px;background:var(--sand);color:#132838;font-weight:900}.toast{position:fixed;top:110px;right:22px;z-index:3000;min-width:240px;max-width:360px;background:#fff;color:var(--deep);border:1px solid rgba(8,40,59,.08);box-shadow:var(--shadow);padding:14px 16px;border-radius:18px;font-weight:900;opacity:0;transform:translateY(-10px);pointer-events:none;transition:.25s}.toast.show{opacity:1;transform:translateY(0)}
.cart-drawer,.checkout-modal{position:fixed;inset:0;z-index:1500;opacity:0;visibility:hidden;transition:.25s}.cart-drawer.open,.checkout-modal.open{opacity:1;visibility:visible}.cart-backdrop,.modal-backdrop{position:absolute;inset:0;background:rgba(2,10,15,.66);backdrop-filter:blur(8px)}.cart-panel{position:absolute;top:0;bottom:0;right:0;width:min(460px,100%);background:#fffaf0;color:var(--navy);padding:26px;box-shadow:-28px 0 80px rgba(0,0,0,.24);transform:translateX(100%);transition:.3s;overflow:auto}.cart-drawer.open .cart-panel{transform:translateX(0)}.cart-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.cart-head span{color:var(--sand);font-weight:900}.cart-head h3{font-size:30px;margin:0;color:var(--deep)}.close-btn{width:44px;height:44px;border:0;border-radius:14px;background:#fff;color:var(--navy);font-size:26px;box-shadow:0 10px 24px rgba(0,0,0,.08)}.cart-items{display:grid;gap:12px}.empty-state{background:#fff;border-radius:20px;padding:18px;color:var(--muted);font-weight:800}.cart-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:#fff;border-radius:22px;padding:14px;border:1px solid rgba(6,25,35,.06)}.cart-row strong{display:block}.cart-row small{color:var(--muted);font-weight:800}.qty{display:flex;align-items:center;gap:8px}.qty button{width:34px;height:34px;border-radius:50%;border:0;background:#eef5f7;color:var(--navy);font-weight:900}.cart-note{display:block;margin:18px 0;color:var(--navy);font-weight:900}.cart-note textarea,.modal-card textarea,.modal-card input,.modal-card select{width:100%;border:1px solid rgba(6,25,35,.1);background:#fff;border-radius:18px;padding:14px;outline:none;margin-top:8px}.cart-note textarea{min-height:88px;resize:vertical}.cart-total{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:22px;padding:18px;margin:16px 0;font-weight:900}.cart-total strong{font-size:26px;color:var(--ocean)}.checkout-modal{display:grid;place-items:center;padding:20px}.modal-card{position:relative;width:min(720px,100%);max-height:calc(100svh - 40px);overflow:auto;background:#fffaf0;border-radius:34px;padding:34px;box-shadow:0 30px 100px rgba(0,0,0,.3);transform:translateY(24px) scale(.98);transition:.25s}.checkout-modal.open .modal-card{transform:translateY(0) scale(1)}.modal-card .close-btn{position:absolute;top:18px;right:18px}.modal-card h3{font-size:34px;margin:0 0 8px;color:var(--deep)}.modal-card>p:not(.eyebrow){color:var(--muted);font-weight:800;line-height:1.8}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid label{font-weight:900;color:var(--navy)}.form-grid .full{grid-column:1/-1}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:none}.delay-1{transition-delay:.16s}@keyframes slowZoom{from{transform:scale(1.02)}to{transform:scale(1.08)}}
@media (max-width:980px){.site-header{top:10px;height:auto;border-radius:24px}.brand{min-width:auto}.brand img{width:126px}.main-nav{display:none}.header-call{display:none}.hero{padding-top:120px}.hero-grid{grid-template-columns:1fr}.hero-offer-card{min-height:auto}.offers-grid,.menu-grid,.location-section{grid-template-columns:1fr 1fr}.menu-toolbar{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr}}
@media (max-width:640px){.site-header{width:calc(100% - 18px);padding:10px 12px}.brand img{width:108px}.cart-pill{padding:10px 12px}.hero{min-height:92svh;padding:115px 18px 46px}.hero h1{font-size:42px}.hero-actions .btn{width:100%}.hero-meta span{width:100%;border-radius:18px}.section-pad{padding:64px 18px}.offers-grid,.menu-grid,.location-section,.form-grid{grid-template-columns:1fr}.offer-img{height:220px}.menu-shell{padding:14px;border-radius:24px}.menu-card{min-height:auto}.cart-panel{width:100%}.modal-card{padding:26px 18px}.section-head h2,.location-card h2{font-size:34px}.toast{top:96px;right:12px;left:12px;max-width:none}.mini-cart{width:calc(100% - 28px);justify-content:space-between}.menu-card-footer{align-items:flex-start;flex-direction:column}.menu-card-footer div{width:100%}.add-btn{flex:1}}

/* v3 refinements: tighter navbar, separate master offer card, cleaner menu, animated contact brand */
.site-header{
  top:14px;
  width:min(1080px,calc(100% - 44px));
  min-height:64px;
  padding:8px 12px;
  border-radius:24px;
  gap:14px;
}
.brand{display:flex;align-items:center;min-width:152px}
.brand img{width:104px;max-height:66px;object-fit:contain}
.main-nav{padding:6px;gap:4px}
.main-nav a{padding:10px 17px;font-size:14px}
.header-actions{gap:8px}
.header-call,.cart-pill{min-height:42px;padding:10px 16px;font-size:15px}
.cart-pill span{width:22px;height:22px;font-size:12px}
.hero{padding-top:112px}
.hero-grid.has-master-offer{grid-template-columns:minmax(0,1.06fr) minmax(310px,.48fr);align-items:center}
.hero-grid.no-master-offer{grid-template-columns:minmax(0,860px);justify-content:center;text-align:left}
.master-offer-card{min-height:420px;padding:0;overflow:hidden;justify-content:space-between;background:linear-gradient(160deg,rgba(255,255,255,.16),rgba(255,255,255,.06))}
.master-offer-media{height:155px;position:relative;overflow:hidden;border-radius:34px 34px 0 0;background:rgba(255,255,255,.08)}
.master-offer-media img{width:100%;height:100%;object-fit:cover;filter:saturate(1.08) contrast(1.05)}
.master-offer-media:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,19,28,.04),rgba(4,19,28,.72))}
.master-offer-media .offer-tag{position:absolute;left:20px;bottom:16px;z-index:2}
.master-offer-content{padding:24px 26px 26px}
.master-offer-content h2{font-size:31px;margin:0 0 8px}
.master-offer-content p{margin:0 0 10px}
.master-offer-content .master-subtitle{color:var(--sand-2);font-weight:900;line-height:1.5}
.master-offer-content .hero-price{margin-top:12px}
.menu-status{display:none!important}
.brand-motion-card{align-items:flex-start;justify-content:flex-end;isolation:isolate;--mx:0px;--my:0px}
.brand-motion-card:after{content:"";position:absolute;width:250px;height:250px;border-radius:50%;top:46px;right:60px;background:radial-gradient(circle,rgba(198,163,106,.18),rgba(45,147,189,.08) 45%,transparent 68%);filter:blur(8px);transform:translate(var(--mx),var(--my));transition:transform .12s ease-out;z-index:1}
.resort-logo-stage{position:absolute;top:32px;right:48px;width:230px;height:230px;display:grid;place-items:center;transform:translate(calc(var(--mx) * .55),calc(var(--my) * .55));transition:transform .12s ease-out;z-index:3;pointer-events:none}
.resort-logo-stage img{width:150px;filter:brightness(0) invert(1);opacity:.92;animation:logoFloat 5.8s ease-in-out infinite}
.orbit-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.16);inset:18px;animation:spinRing 13s linear infinite}
.ring-two{inset:44px;border-color:rgba(198,163,106,.26);animation-duration:18s;animation-direction:reverse}
.orbit-dot{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--sand);box-shadow:0 0 22px rgba(198,163,106,.75)}
.dot-one{top:22px;left:50%;animation:dotOrbit 7.5s ease-in-out infinite}
.dot-two{bottom:48px;right:34px;background:#fff;animation:dotOrbit 8.7s ease-in-out infinite reverse}
@keyframes spinRing{to{transform:rotate(360deg)}}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes dotOrbit{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(18px,12px) scale(1.25)}}
@media (max-width:980px){
  .site-header{width:calc(100% - 22px);padding:9px 12px;min-height:62px;border-radius:22px}
  .brand img{width:92px;max-height:58px}.brand{min-width:auto}
  .hero-grid.has-master-offer{grid-template-columns:1fr}.master-offer-card{max-width:520px;width:100%;justify-self:start}
  .resort-logo-stage{position:relative;top:auto;right:auto;margin:0 auto 22px}.brand-motion-card:after{top:22px;right:50%;transform:translate(50%,0)}
}
@media (max-width:640px){
  .site-header{top:8px;width:calc(100% - 16px);padding:8px 10px;min-height:58px}
  .brand img{width:76px;max-height:50px}.header-actions{gap:6px}.cart-pill{padding:8px 10px}.header-call{display:none}
  .hero{padding-top:92px}.master-offer-media{height:132px}.master-offer-content{padding:20px}.master-offer-content h2{font-size:26px}
}

/* v4 refinement: premium custom sort dropdown instead of the browser default menu */
.menu-toolbar{align-items:start;overflow:visible}
.custom-select{position:relative;height:54px;z-index:40}
.native-sort-select{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}
.custom-select-trigger{
  width:100%;height:54px;border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(145deg,rgba(255,255,255,.14),rgba(255,255,255,.07));
  color:#fff;border-radius:18px;padding:0 16px 0 18px;outline:none;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-weight:900;text-align:left;box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 16px 34px rgba(0,0,0,.12);
  transition:border-color .22s,box-shadow .22s,background .22s,transform .22s;
}
.custom-select-trigger:hover,.custom-select.open .custom-select-trigger{
  border-color:rgba(234,215,176,.42);
  background:linear-gradient(145deg,rgba(255,255,255,.18),rgba(255,255,255,.09));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 18px 42px rgba(0,0,0,.18),0 0 0 3px rgba(198,163,106,.08);
}
.custom-select-trigger svg{width:18px;height:18px;flex:0 0 auto;fill:none;stroke:#ead7b0;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;transition:transform .22s}
.custom-select.open .custom-select-trigger svg{transform:rotate(180deg)}
.custom-select-menu{
  position:absolute;left:0;right:0;top:calc(100% + 10px);z-index:300;
  padding:8px;border-radius:20px;border:1px solid rgba(234,215,176,.18);
  background:linear-gradient(155deg,rgba(6,31,45,.98),rgba(10,54,75,.96));
  box-shadow:0 26px 70px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.10);
  backdrop-filter:blur(18px);opacity:0;visibility:hidden;transform:translateY(-8px) scale(.98);
  transform-origin:top center;transition:opacity .18s ease,visibility .18s ease,transform .18s ease;
  overflow:hidden;
}
.custom-select.open .custom-select-menu{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.custom-select-menu button{
  width:100%;border:0;background:transparent;color:rgba(255,255,255,.82);border-radius:14px;
  padding:12px 13px;text-align:left;font-weight:850;line-height:1.2;display:flex;align-items:center;justify-content:space-between;gap:10px;
  transition:background .18s,color .18s,transform .18s;
}
.custom-select-menu button:hover{background:rgba(255,255,255,.10);color:#fff;transform:translateX(2px)}
.custom-select-menu button.active{background:linear-gradient(135deg,var(--sand),#ddbd83);color:#102638;box-shadow:0 12px 28px rgba(198,163,106,.22)}
.custom-select-menu button.active:after{content:"✓";font-weight:1000;color:#102638}
@media (max-width:720px){.custom-select{height:50px}.custom-select-trigger{height:50px}.custom-select-menu{top:calc(100% + 8px)}}

/* v5: removed sort control; toolbar now keeps only search and cart */
.menu-toolbar{grid-template-columns:1fr auto}
@media (max-width:720px){.menu-toolbar{grid-template-columns:1fr}.cart-toggle{width:100%}}

/* v8: visible sticky category navigation + timed item availability */
.menu-shell{overflow:visible}
.filters{
  position:sticky;
  top:92px;
  z-index:70;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  overflow:visible;
  padding:12px;
  margin:0 0 20px;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(145deg,rgba(8,40,59,.94),rgba(20,69,91,.82));
  box-shadow:0 18px 46px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.10);
  backdrop-filter:blur(18px);
}
.filter-btn{
  min-height:46px;
  padding:12px 20px;
  color:#fff;
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.20);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.filter-btn.active,.filter-btn:hover{
  background:linear-gradient(135deg,#ffffff,#fff7e8);
  color:var(--navy);
  box-shadow:0 12px 26px rgba(255,255,255,.12);
}
.availability-chip{
  align-self:flex-start;
  margin-top:14px;
  padding:8px 11px;
  border-radius:999px;
  border:1px solid rgba(234,215,176,.30);
  background:rgba(198,163,106,.13);
  color:var(--sand-2);
  font-size:12px;
  font-weight:900;
  letter-spacing:.01em;
}
.menu-card.is-time-closed{
  border-color:rgba(234,215,176,.20);
  background:linear-gradient(160deg,rgba(255,255,255,.09),rgba(255,255,255,.04));
}
.menu-card.is-time-closed:after{
  content:"Currently unavailable";
  position:absolute;
  top:18px;
  right:18px;
  z-index:4;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(4,19,28,.72);
  border:1px solid rgba(234,215,176,.28);
  color:#fff;
  font-size:11px;
  font-weight:900;
  backdrop-filter:blur(12px);
}
.menu-card.is-time-closed .add-btn,
.add-btn:disabled{
  cursor:not-allowed;
  background:rgba(255,255,255,.22);
  color:rgba(255,255,255,.72);
  box-shadow:none;
}
.menu-card.is-time-closed .availability-chip{
  color:#fff;
  border-color:rgba(255,255,255,.20);
  background:rgba(255,255,255,.10);
}
@media (max-width:980px){.filters{top:78px}}
@media (max-width:720px){
  .filters{
    flex-wrap:nowrap;
    overflow-x:auto;
    overflow-y:hidden;
    padding:10px;
    top:74px;
    scrollbar-width:thin;
    scrollbar-color:rgba(234,215,176,.65) rgba(255,255,255,.09);
  }
  .filters::-webkit-scrollbar{display:block!important;height:7px}
  .filters::-webkit-scrollbar-track{background:rgba(255,255,255,.09);border-radius:999px}
  .filters::-webkit-scrollbar-thumb{background:rgba(234,215,176,.70);border-radius:999px}
  .filter-btn{min-height:44px;padding:11px 17px}
}

/* v9: cleaner mobile categories + header stays at the top of the page only */
.site-header{
  position:absolute;
  top:14px;
  left:50%;
  transform:translateX(-50%);
}
.filters{
  position:relative;
  top:auto;
  z-index:20;
  flex-wrap:nowrap;
  overflow-x:auto;
  overflow-y:hidden;
  padding:10px;
  margin:0 0 20px;
  border-radius:24px;
  scroll-snap-type:x proximity;
  scrollbar-width:thin;
  scrollbar-color:rgba(234,215,176,.70) rgba(255,255,255,.08);
}
.filters::-webkit-scrollbar{display:block!important;height:7px}
.filters::-webkit-scrollbar-track{background:rgba(255,255,255,.08);border-radius:999px}
.filters::-webkit-scrollbar-thumb{background:rgba(234,215,176,.75);border-radius:999px}
.filter-btn{
  flex:0 0 auto;
  min-height:44px;
  padding:11px 18px;
  scroll-snap-align:start;
}
@media (min-width:981px){
  .site-header{position:absolute}
}
@media (max-width:980px){
  .site-header{position:absolute;top:12px}
  .hero{padding-top:104px}
  .filters{top:auto}
}
@media (max-width:640px){
  .site-header{
    position:absolute;
    top:10px;
    width:calc(100% - 22px);
    min-height:68px;
    border-radius:20px;
    padding:9px 12px;
  }
  .brand img{width:88px;max-height:52px}
  .cart-pill{min-height:42px;height:42px;padding:8px 12px;font-size:16px}
  .hero{padding-top:104px}
  .menu-section .section-head h2{font-size:40px;line-height:1.05}
  .menu-shell{padding:12px;border-radius:24px;overflow:hidden}
  .menu-toolbar{gap:10px;margin-bottom:12px}
  .search-wrap input{height:52px;border-radius:20px;padding:0 16px;font-size:15px}
  .cart-toggle{height:52px;border-radius:999px;width:100%}
  .filters{
    position:relative;
    top:auto;
    z-index:5;
    gap:8px;
    padding:9px 9px 12px;
    margin:0 0 16px;
    border-radius:22px;
    background:linear-gradient(145deg,rgba(8,40,59,.96),rgba(16,63,86,.88));
    box-shadow:inset 0 1px 0 rgba(255,255,255,.11),0 14px 34px rgba(0,0,0,.18);
  }
  .filter-btn{min-height:42px;padding:10px 16px;font-size:14px;border-radius:999px}
  .filter-btn.active{box-shadow:0 10px 22px rgba(255,255,255,.12)}
}

/* v10: category-first mobile UX, no horizontal scrolling */
.menu-flow-shell{overflow:visible}
.category-screen.is-hidden,.items-screen.is-hidden{display:none!important}
.category-screen-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:20px}
.category-screen-head h3{margin:0 0 8px;font-size:clamp(28px,4vw,44px);line-height:1.05;color:#fff;letter-spacing:-.035em}
.category-screen-head p:not(.eyebrow){margin:0;color:rgba(255,255,255,.68);font-weight:700;line-height:1.65;max-width:660px}
.category-cart{flex:0 0 auto;height:54px;white-space:nowrap}
.category-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.category-tile{position:relative;min-height:132px;text-align:left;border:1px solid rgba(255,255,255,.15);border-radius:26px;background:linear-gradient(145deg,rgba(255,255,255,.13),rgba(255,255,255,.055));color:#fff;padding:18px;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.09),0 18px 44px rgba(0,0,0,.16);transition:transform .22s ease,border-color .22s ease,background .22s ease,box-shadow .22s ease}
.category-tile:before{content:"";position:absolute;right:-30px;bottom:-40px;width:112px;height:112px;border-radius:50%;background:radial-gradient(circle,rgba(234,215,176,.22),rgba(234,215,176,0) 68%);transition:transform .25s ease,opacity .25s ease}
.category-tile span{display:block;position:relative;z-index:1;font-size:20px;font-weight:950;line-height:1.15;letter-spacing:-.025em}
.category-tile small{display:block;position:relative;z-index:1;margin-top:10px;color:rgba(255,255,255,.58);font-weight:850}
.category-tile b{display:inline-flex;position:relative;z-index:1;margin-top:18px;color:var(--sand-2);font-size:13px;text-transform:uppercase;letter-spacing:.07em}
.category-tile:hover{transform:translateY(-3px);border-color:rgba(234,215,176,.42);background:linear-gradient(145deg,rgba(255,255,255,.18),rgba(255,255,255,.075));box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 24px 56px rgba(0,0,0,.22)}
.category-tile:hover:before{transform:scale(1.12);opacity:.9}
.all-category-tile{order:99;background:linear-gradient(145deg,rgba(198,163,106,.24),rgba(255,255,255,.06));border-color:rgba(234,215,176,.30)}
.selected-category-bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;margin-bottom:16px;padding:12px;border-radius:24px;border:1px solid rgba(255,255,255,.15);background:linear-gradient(145deg,rgba(4,19,28,.72),rgba(18,64,86,.52));box-shadow:inset 0 1px 0 rgba(255,255,255,.10)}
.back-category-btn{height:46px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.09);color:#fff;border-radius:999px;padding:0 16px;font-weight:950;transition:.22s}
.back-category-btn:hover{background:#fff;color:var(--navy)}
.selected-category-bar span{display:block;color:var(--sand-2);font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.12em;margin-bottom:2px}
.selected-category-bar strong{display:block;color:#fff;font-size:24px;line-height:1.15;letter-spacing:-.03em}
.selected-cart{height:46px;min-height:46px;white-space:nowrap;padding:0 18px}
.compact-menu-toolbar{grid-template-columns:1fr;margin-bottom:18px}
.items-screen .menu-grid{margin-top:0}

@media (max-width:980px){
  .category-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .category-screen-head{align-items:stretch;flex-direction:column}
  .category-cart{width:100%}
}
@media (max-width:640px){
  .menu-shell{overflow:visible}
  .category-screen-head{gap:14px;margin-bottom:16px}
  .category-screen-head h3{font-size:31px}
  .category-screen-head p:not(.eyebrow){font-size:14px;line-height:1.6}
  .category-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .category-tile{min-height:112px;border-radius:22px;padding:14px}
  .category-tile span{font-size:16px;line-height:1.2}
  .category-tile small{font-size:12px;margin-top:8px}
  .category-tile b{font-size:10px;margin-top:14px;letter-spacing:.06em}
  .selected-category-bar{grid-template-columns:1fr auto;gap:10px;padding:10px;border-radius:20px}
  .back-category-btn{grid-column:1 / -1;width:max-content;height:42px;padding:0 14px;font-size:14px}
  .selected-category-bar strong{font-size:20px}
  .selected-cart{height:42px;min-height:42px;padding:0 14px;font-size:14px}
  .compact-menu-toolbar{margin-bottom:14px}
  .menu-grid{grid-template-columns:1fr}
}
@media (max-width:390px){
  .category-grid{gap:8px}
  .category-tile{padding:12px;min-height:104px;border-radius:20px}
  .category-tile span{font-size:15px}
}

/* v11: room lookup entry + direct WhatsApp ordering */
.guest-bar{
  position:absolute;
  top:104px;
  left:50%;
  transform:translateX(-50%);
  z-index:950;
  width:min(760px,calc(100% - 32px));
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:12px 14px 12px 18px;
  border-radius:999px;
  border:1px solid rgba(234,215,176,.22);
  background:linear-gradient(135deg,rgba(4,19,28,.78),rgba(11,52,72,.64));
  color:#fff;
  box-shadow:0 18px 46px rgba(0,0,0,.20),inset 0 1px 0 rgba(255,255,255,.12);
  backdrop-filter:blur(20px);
}
.guest-bar[hidden]{display:none!important}
.guest-bar span{display:block;color:var(--sand-2);font-size:12px;font-weight:950;letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px}
.guest-bar strong{display:block;font-size:15px;line-height:1.25;color:#fff}
.guest-bar button{border:0;border-radius:999px;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.16);font-weight:950;padding:10px 14px;white-space:nowrap;transition:.22s}
.guest-bar button:hover{background:#fff;color:var(--navy)}
.room-modal{position:fixed;inset:0;z-index:2200;display:grid;place-items:center;padding:18px;opacity:0;visibility:hidden;transition:.24s ease}
.room-modal.open{opacity:1;visibility:visible}
.room-modal-backdrop{position:absolute;inset:0;background:rgba(2,10,15,.72);backdrop-filter:blur(10px)}
.room-card{position:relative;width:min(520px,100%);border-radius:34px;padding:32px;background:linear-gradient(145deg,#fffaf0,#f6eee0);box-shadow:0 34px 100px rgba(0,0,0,.34);color:var(--deep);overflow:hidden;transform:translateY(18px) scale(.98);transition:.24s ease}
.room-modal.open .room-card{transform:translateY(0) scale(1)}
.room-card:before{content:"";position:absolute;right:-80px;top:-90px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(198,163,106,.28),transparent 68%)}
.room-card img{width:190px;margin:0 auto 18px;position:relative;z-index:1}.room-card h3{position:relative;z-index:1;margin:0 0 10px;font-size:34px;line-height:1.05;letter-spacing:-.04em;color:var(--deep)}
.room-card p:not(.eyebrow){position:relative;z-index:1;margin:0 0 20px;color:var(--muted);font-weight:800;line-height:1.75}.room-card form{position:relative;z-index:1;display:grid;gap:14px}.room-card label{font-weight:950;color:var(--navy)}
.room-card input{width:100%;height:58px;border-radius:20px;border:1px solid rgba(8,40,59,.12);background:#fff;padding:0 16px;margin-top:8px;outline:none;font-size:22px;font-weight:900;letter-spacing:.02em;color:var(--deep)}
.room-card input:focus{border-color:rgba(198,163,106,.55);box-shadow:0 0 0 4px rgba(198,163,106,.12)}.room-card button:disabled{opacity:.65;cursor:wait}.room-feedback{position:relative;z-index:1;min-height:24px;margin-top:14px;color:var(--ocean);font-weight:900;line-height:1.5}.room-skip{position:relative;z-index:1;margin:8px auto 0;display:flex;border:0;background:transparent;color:var(--muted);font-weight:900;text-decoration:underline;text-underline-offset:4px}
@media (max-width:980px){.guest-bar{top:88px}.hero{padding-top:128px}}
@media (max-width:640px){.guest-bar{top:86px;width:calc(100% - 22px);border-radius:22px;align-items:flex-start}.guest-bar strong{font-size:13px}.guest-bar button{padding:9px 11px;font-size:12px}.hero{padding-top:128px}.room-card{padding:26px 20px;border-radius:28px}.room-card img{width:160px}.room-card h3{font-size:30px}.room-card input{height:56px}}


/* v12: slimmer persistent guest welcome chip + cleaner room entry */
.guest-bar{
  position:fixed;
  top:104px;
  left:50%;
  transform:translateX(-50%);
  z-index:1001;
  width:max-content;
  max-width:calc(100% - 32px);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0;
  padding:10px 18px;
  border-radius:999px;
  border:1px solid rgba(234,215,176,.28);
  background:linear-gradient(135deg,rgba(4,19,28,.84),rgba(11,52,72,.70));
  color:#fff;
  box-shadow:0 16px 42px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.12);
  backdrop-filter:blur(20px);
  pointer-events:none;
}
.guest-bar span{
  margin:0;
  display:block;
  color:var(--sand-2);
  font-size:13px;
  font-weight:950;
  line-height:1.2;
  letter-spacing:.06em;
  text-transform:uppercase;
  white-space:nowrap;
}
.guest-bar strong,.guest-bar button{display:none!important}
.room-card h3{margin-bottom:20px}
.room-card p:not(.eyebrow){display:none!important}
.room-card form{margin-top:0}
@media (max-width:980px){
  .guest-bar{top:92px;padding:9px 14px;max-width:calc(100% - 24px)}
  .hero{padding-top:132px}
}
@media (max-width:640px){
  .guest-bar{top:92px;width:max-content;max-width:calc(100% - 20px);border-radius:999px;padding:8px 12px;align-items:center}
  .guest-bar span{font-size:11px;max-width:calc(100vw - 56px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .hero{padding-top:132px}
  .room-card{padding:28px 20px;border-radius:28px}
  .room-card img{width:156px;margin-bottom:16px}
  .room-card h3{font-size:30px;line-height:1.05;margin-bottom:18px}
}


/* v13: guest welcome chip docks upward with a soft glow while scrolling */
.guest-bar{
  transition: top .32s ease, transform .32s ease, box-shadow .32s ease, background .32s ease, border-color .32s ease, padding .32s ease;
  will-change: top, transform;
}
.guest-bar.is-docked{
  top:8px;
  transform:translateX(-50%) scale(.94);
  z-index:1400;
  padding:8px 16px;
  border-color:rgba(234,215,176,.46);
  background:linear-gradient(135deg,rgba(4,19,28,.94),rgba(13,61,86,.88));
  box-shadow:0 0 0 1px rgba(234,215,176,.12),0 0 28px rgba(198,163,106,.28),0 14px 36px rgba(0,0,0,.30),inset 0 1px 0 rgba(255,255,255,.14);
}
.guest-bar.is-docked span{
  color:#fff4d7;
  text-shadow:0 0 18px rgba(234,215,176,.28);
}
@media (max-width:980px){
  .guest-bar.is-docked{top:8px;max-width:calc(100% - 150px);padding:7px 12px}
}
@media (max-width:640px){
  .guest-bar.is-docked{top:14px;left:52%;max-width:calc(100% - 170px);padding:7px 10px}
  .guest-bar.is-docked span{font-size:10px;max-width:100%}
}


/* v14: darker navbar-matched guest chip with a single room-switch icon */
.guest-bar{
  pointer-events:auto;
  gap:10px;
  padding:9px 10px 9px 18px;
  background:rgba(4,19,28,.72);
  border-color:rgba(255,255,255,.22);
  box-shadow:0 18px 50px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.12);
}
.guest-room-exit{
  display:inline-grid!important;
  place-items:center;
  width:34px;
  height:34px;
  flex:0 0 34px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:#fff;
  padding:0!important;
  opacity:.86;
  cursor:pointer;
  transition:transform .22s ease, background .22s ease, border-color .22s ease, opacity .22s ease, box-shadow .22s ease;
}
.guest-room-exit svg{
  width:17px;
  height:17px;
  fill:none;
  stroke:currentColor;
  stroke-width:2.25;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.guest-room-exit:hover{
  opacity:1;
  transform:translateY(-1px);
  background:rgba(234,215,176,.16);
  border-color:rgba(234,215,176,.38);
  box-shadow:0 0 18px rgba(198,163,106,.18);
}
.guest-room-exit:focus-visible{
  outline:3px solid rgba(234,215,176,.38);
  outline-offset:3px;
}
.guest-bar.is-docked{
  background:rgba(4,19,28,.90);
  border-color:rgba(255,255,255,.24);
  padding:8px 10px 8px 16px;
}
.guest-bar.is-docked .guest-room-exit{
  width:32px;
  height:32px;
  flex-basis:32px;
  background:rgba(255,255,255,.11);
}
@media (max-width:640px){
  .guest-bar{gap:8px;padding:8px 8px 8px 12px}
  .guest-room-exit{width:30px;height:30px;flex-basis:30px}
  .guest-room-exit svg{width:15px;height:15px}
  .guest-bar.is-docked{padding:7px 8px 7px 10px}
}
.guest-bar .guest-room-exit{display:inline-grid!important}

/* v15: compact guest chip so it does not cover the hero headline */
.guest-bar{
  top:118px;
  width:max-content;
  max-width:min(620px,calc(100% - 56px));
  min-height:38px;
  gap:7px;
  padding:6px 7px 6px 14px;
  border-radius:999px;
  background:rgba(4,19,28,.74);
  border-color:rgba(255,255,255,.18);
  box-shadow:0 10px 28px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.10);
}
.guest-bar span{
  font-size:11px;
  line-height:1;
  letter-spacing:.075em;
  max-width:min(460px,calc(100vw - 124px));
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.guest-room-exit{
  width:26px;
  height:26px;
  flex:0 0 26px;
  opacity:.78;
}
.guest-room-exit svg{width:13px;height:13px;stroke-width:2.15}
.guest-bar.is-docked{
  top:10px;
  padding:6px 7px 6px 12px;
  transform:translateX(-50%) scale(.94);
  box-shadow:0 0 0 1px rgba(234,215,176,.10),0 0 20px rgba(198,163,106,.18),0 10px 28px rgba(0,0,0,.26),inset 0 1px 0 rgba(255,255,255,.12);
}
.guest-bar.is-docked .guest-room-exit{width:25px;height:25px;flex-basis:25px}
@media (max-width:980px){
  .guest-bar{top:96px;max-width:calc(100% - 28px);padding:6px 7px 6px 12px}
  .guest-bar span{font-size:10.5px;max-width:calc(100vw - 92px)}
  .guest-bar.is-docked{top:8px;max-width:calc(100% - 128px);padding:6px 7px 6px 10px}
}
@media (max-width:640px){
  .guest-bar{top:92px;max-width:calc(100% - 24px);min-height:34px;padding:5px 6px 5px 10px;gap:6px}
  .guest-bar span{font-size:10px;letter-spacing:.055em;max-width:calc(100vw - 78px)}
  .guest-room-exit{width:24px;height:24px;flex-basis:24px}
  .guest-room-exit svg{width:12px;height:12px}
  .guest-bar.is-docked{top:8px;left:50%;transform:translateX(-50%) scale(.94);max-width:calc(100% - 116px);padding:5px 6px 5px 9px}
}


/* v17: extra-compact guest chip so the resort line remains visible */
.guest-bar{
  top:108px;
  min-height:30px;
  max-width:340px;
  gap:5px;
  padding:4px 5px 4px 10px;
  border-radius:999px;
  background:rgba(4,19,28,.76);
  box-shadow:0 8px 22px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.09);
}
.guest-bar span{
  font-size:9.6px;
  letter-spacing:.065em;
  line-height:1;
  max-width:285px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.guest-room-exit{
  width:22px;
  height:22px;
  flex:0 0 22px;
  opacity:.76;
}
.guest-room-exit svg{width:11px;height:11px;stroke-width:2.1}
.guest-bar.is-docked{
  top:8px;
  max-width:330px;
  min-height:30px;
  padding:4px 5px 4px 9px;
  transform:translateX(-50%) scale(.92);
  box-shadow:0 0 0 1px rgba(234,215,176,.10),0 0 16px rgba(198,163,106,.16),0 8px 22px rgba(0,0,0,.24),inset 0 1px 0 rgba(255,255,255,.11);
}
.guest-bar.is-docked .guest-room-exit{width:22px;height:22px;flex-basis:22px}
@media (max-width:980px){
  .guest-bar{top:90px;max-width:300px;min-height:29px;padding:4px 5px 4px 9px}
  .guest-bar span{font-size:9.2px;max-width:245px}
  .guest-room-exit{width:21px;height:21px;flex-basis:21px}
  .guest-room-exit svg{width:10.5px;height:10.5px}
  .guest-bar.is-docked{top:7px;max-width:280px;transform:translateX(-50%) scale(.91)}
}
@media (max-width:640px){
  .guest-bar{top:86px;max-width:calc(100% - 96px);min-height:28px;padding:4px 5px 4px 8px;gap:4px}
  .guest-bar span{font-size:8.8px;letter-spacing:.045em;max-width:calc(100vw - 150px)}
  .guest-room-exit{width:20px;height:20px;flex-basis:20px}
  .guest-room-exit svg{width:10px;height:10px}
  .guest-bar.is-docked{top:7px;max-width:calc(100% - 120px);padding:4px 5px 4px 8px;transform:translateX(-50%) scale(.9)}
}

/* v18: balanced guest chip — larger than v17 but still clear of the hero meta line */
.guest-bar{
  top:112px;
  min-height:34px;
  max-width:440px;
  gap:7px;
  padding:6px 7px 6px 13px;
  border-radius:999px;
  background:rgba(4,19,28,.78);
  border-color:rgba(255,255,255,.18);
  box-shadow:0 10px 26px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.10);
}
.guest-bar span{
  font-size:10.8px;
  letter-spacing:.07em;
  line-height:1;
  max-width:360px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.guest-room-exit{
  width:25px;
  height:25px;
  flex:0 0 25px;
  opacity:.78;
}
.guest-room-exit svg{width:12.5px;height:12.5px;stroke-width:2.15}
.guest-bar.is-docked{
  top:9px;
  max-width:420px;
  min-height:34px;
  padding:6px 7px 6px 12px;
  transform:translateX(-50%) scale(.95);
  box-shadow:0 0 0 1px rgba(234,215,176,.12),0 0 20px rgba(198,163,106,.18),0 10px 28px rgba(0,0,0,.26),inset 0 1px 0 rgba(255,255,255,.12);
}
.guest-bar.is-docked .guest-room-exit{width:24px;height:24px;flex-basis:24px}
@media (max-width:980px){
  .guest-bar{top:92px;max-width:360px;min-height:32px;padding:5px 6px 5px 11px;gap:6px}
  .guest-bar span{font-size:10px;max-width:300px;letter-spacing:.06em}
  .guest-room-exit{width:23px;height:23px;flex-basis:23px}
  .guest-room-exit svg{width:11.5px;height:11.5px}
  .guest-bar.is-docked{top:8px;max-width:340px;transform:translateX(-50%) scale(.94)}
}
@media (max-width:640px){
  .guest-bar{top:88px;max-width:calc(100% - 64px);min-height:31px;padding:5px 6px 5px 10px;gap:5px}
  .guest-bar span{font-size:9.6px;letter-spacing:.05em;max-width:calc(100vw - 126px)}
  .guest-room-exit{width:22px;height:22px;flex-basis:22px}
  .guest-room-exit svg{width:10.8px;height:10.8px}
  .guest-bar.is-docked{top:7px;max-width:calc(100% - 110px);padding:5px 6px 5px 9px;transform:translateX(-50%) scale(.93)}
}
