
:root {
  --bg: #050505; --bg-soft: #090909; --bg-card: #0f0f0f; --bg-card-2: #151515;
  --text: #ffffff; --text-soft: rgba(255,255,255,.78); --text-muted: rgba(255,255,255,.50);
  --line: rgba(255,255,255,.08); --line-strong: rgba(255,255,255,.14);
  --accent: #ffffff; --success: #79e39b;
  --radius-xl: 30px; --radius-lg: 24px; --radius-md: 20px; --radius-sm: 14px;
  --shadow-soft: 0 16px 44px rgba(0,0,0,.28);
  --shadow-card: 0 8px 28px rgba(0,0,0,.22);
  --nav-height: 74px; --ease: 220ms cubic-bezier(.2,.8,.2,1);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{margin:0;font-family:Manrope,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--text);background:radial-gradient(circle at top,rgba(255,255,255,.03),transparent 24%),linear-gradient(180deg,#080808,#040404);min-height:100vh;padding-bottom:calc(var(--nav-height) + env(safe-area-inset-bottom) + 16px);overflow-x:hidden}
img{max-width:100%;display:block} a{color:inherit;text-decoration:none} button,input,textarea,select{font:inherit}
.app{width:min(100%,1100px);margin:0 auto;padding:16px}
.loader{position:fixed;inset:0;display:grid;place-items:center;background:radial-gradient(circle at center,rgba(255,255,255,.03),transparent 32%),#050505;z-index:999;transition:opacity .45s ease,visibility .45s ease}.loader.hidden{opacity:0;visibility:hidden}
.loader__content{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}.loader__logo-wrap{position:relative;width:170px;height:72px;display:flex;align-items:center;justify-content:center}.loader__glow{position:absolute;width:140px;height:50px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 72%);filter:blur(12px);opacity:0;animation:loaderGlow 1.2s ease forwards}.loader__logo{position:relative;z-index:1;width:150px;height:auto;object-fit:contain;opacity:0;transform:scale(.94) translateY(6px);animation:loaderLogoIn .8s cubic-bezier(.2,.8,.2,1) forwards}.loader__text{margin-top:14px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);opacity:0;animation:loaderTextIn .8s ease forwards;animation-delay:.18s}
@keyframes loaderLogoIn{to{opacity:1;transform:scale(1) translateY(0)}} @keyframes loaderTextIn{to{opacity:1}} @keyframes loaderGlow{0%{opacity:0;transform:scale(.8)}100%{opacity:1;transform:scale(1)}}
.hero,.bottom-nav,.hero__status,.section-card,.menu-card,.booking-panel,.contact-row,.promo,.guest-card{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px) padding: 20px;}
.hero{position:relative;overflow:hidden;border-radius:var(--radius-xl);border:1px solid var(--line);padding:20px 16px 16px;background:radial-gradient(circle at top right,rgba(255,255,255,.08),transparent 28%),radial-gradient(circle at bottom left,rgba(255,255,255,.04),transparent 24%),linear-gradient(135deg,rgba(18,18,18,.98),rgba(8,8,8,.98) 55%,rgba(20,20,20,.96));box-shadow:var(--shadow-soft)}
.hero__status{position:absolute;top:16px;right:16px;display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid var(--line-strong);font-size:12px;color:var(--text-soft)}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:statusPulse 2s infinite}@keyframes statusPulse{0%{box-shadow:0 0 0 0 rgba(121,227,155,.55)}70%{box-shadow:0 0 0 8px rgba(121,227,155,0)}100%{box-shadow:0 0 0 0 rgba(121,227,155,0)}}
.hero__content{display:flex;flex-direction:column;align-items:center;text-align:center;min-height:420px;justify-content:center}.hero__logo{position:relative;margin-bottom:18px;display:flex;justify-content:center}.hero__logo-glow{position:absolute;width:150px;height:64px;left:50%;top:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,255,255,.09),transparent 70%);filter:blur(12px);pointer-events:none}.hero__logo-img{position:relative;z-index:1;width:150px;height:auto;object-fit:contain;opacity:.98;image-rendering:-webkit-optimize-contrast}.hero__badge{margin-bottom:14px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:800;color:rgba(255,255,255,.9)}.hero__description{max-width:30ch;font-size:16px;line-height:1.65;color:var(--text-soft);font-weight:700}.hero__actions{width:100%;max-width:420px;display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:26px}.hero__stats{display:grid;grid-template-columns:1fr;gap:10px;margin-top:16px}
.hero-stat,.section-card,.menu-card,.booking-panel,.contact-row,.promo,.guest-card{border-radius:var(--radius-md);background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.025));border:1px solid var(--line);box-shadow:var(--shadow-card)}
.hero-stat{padding:15px 16px}.hero-stat__value{font-weight:800;font-size:15px;display:block}.hero-stat__label{font-size:12px;color:var(--text-muted);margin-top:4px;display:block}
.section{margin-top:32px}.section__head{margin-bottom:14px}.section__title{font-family:Manrope,system-ui,sans-serif;font-size:30px;font-weight:800;letter-spacing:-.03em;margin:0}.section__text{margin-top:6px;font-size:14px;color:var(--text-soft);line-height:1.6;font-weight:600}
.cards-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:16px}.section-card{position:relative;overflow:hidden;padding:18px;min-height:156px;cursor:pointer;transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease)}.section-card:hover{transform:translateY(-2px)}.section-card:active{transform:scale(.98)}.section-card::after{content:"";position:absolute;inset:auto -20% -40% auto;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.07),transparent 70%);pointer-events:none;transition:transform var(--ease),opacity var(--ease);opacity:.8}.section-card:hover::after{transform:scale(1.08)}.section-card__icon{width:42px;height:42px;display:grid;place-items:center;border-radius:14px;background:rgba(255,255,255,.05);border:1px solid var(--line);margin-bottom:12px;font-size:20px}.section-card__title{font-weight:800;margin:0 0 4px;font-size:19px}.section-card__desc{font-size:14px;color:var(--text-soft);line-height:1.6;margin:0;font-weight:600}
.promo{position:relative;overflow:hidden;margin-bottom:12px;padding:18px;border-radius:var(--radius-lg);background:radial-gradient(circle at top right,rgba(255,255,255,.12),transparent 32%),linear-gradient(135deg,rgba(18,18,18,.96),rgba(8,8,8,.96))}.promo__shine{position:absolute;right:-40px;top:-40px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 65%);pointer-events:none}.promo__row{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;position:relative;z-index:1}.promo__badge,.promo__chips span,.menu-card__tag{display:inline-flex;align-items:center;min-height:32px;padding:0 12px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid var(--line);color:rgba(255,255,255,.9);font-size:11px;font-weight:800;letter-spacing:.08em}.promo__chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.promo__title{position:relative;z-index:1;margin:16px 0 8px;font-family:"Space Grotesk",sans-serif;font-size:clamp(38px,12vw,56px);line-height:.9;letter-spacing:-.06em}.promo__title span{color:rgba(255,255,255,.7)}.promo__text{position:relative;z-index:1;margin:0;max-width:30ch;font-size:14px;color:var(--text-soft);line-height:1.6;font-weight:700}
.menu-grid{display:grid;gap:14px;margin-top:14px}.menu-card{padding:20px;transition:transform var(--ease),box-shadow var(--ease)}.menu-card:hover{transform:translateY(-2px)}.menu-card__top{margin-bottom:8px;display:flex;flex-direction:column;align-items:flex-start;gap:10px}.menu-card__title{font-weight:800;font-size:20px;letter-spacing:-.02em;margin:0}.menu-card__desc{font-size:14px;color:var(--text-soft);margin:0;line-height:1.55;font-weight:600}.menu-card__actions{margin-top:14px}
.booking-panel{margin-top:16px;padding:20px;border-radius:var(--radius-lg)}.field{display:flex;flex-direction:column;margin-bottom:14px}.field--2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.label{font-size:13px;margin-bottom:6px;color:var(--text-soft);font-weight:700}.control{min-height:52px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);padding:0 14px;outline:none;transition:border-color var(--ease),background var(--ease),box-shadow var(--ease)}textarea.control{min-height:110px;padding:12px 14px;resize:vertical}select.control{appearance:none}.control:focus{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.06);box-shadow:0 0 0 3px rgba(255,255,255,.05)}.control::placeholder{color:rgba(255,255,255,.35)}.booking-note{font-size:12px;color:var(--text-muted);margin-top:8px;line-height:1.5;font-weight:600}
.btn{position:relative;overflow:hidden;isolation:isolate;width:100%;min-height:56px;padding:0 18px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:800;cursor:pointer;border:none;text-align:center;white-space:nowrap;transition:transform var(--ease),background var(--ease),box-shadow var(--ease),border-color var(--ease),filter var(--ease)}.btn:hover{transform:translateY(-1px)}.btn:active,.btn.is-pressed{transform:scale(.98)}.btn--primary{ background: linear-gradient(180deg, #ffffff, #eaeaea);
  box-shadow: 
    0 10px 30px rgba(255,255,255,0.15),
    inset 0 1px 0 rgba(255,255,255,0.5);
}.btn--secondary{background:rgba(255,255,255,.04);border:1px solid var(--line);color:#fff}.btn--full{width:100%}.btn--with-sticker .btn__sticker{width:28px;height:28px;display:inline-grid;place-items:center;border-radius:999px;background:rgba(0,0,0,.08);font-size:15px;flex:0 0 28px}.btn--secondary .btn__sticker{background:rgba(255,255,255,.08)}.btn__ripple{position:absolute;border-radius:50%;transform:translate(-50%,-50%) scale(0);pointer-events:none;background:rgba(255,255,255,.35);animation:ripple .6s ease-out}.btn--primary .btn__ripple{background:rgba(10,10,10,.12)}@keyframes ripple{to{transform:translate(-50%,-50%) scale(13);opacity:0}}
.guest-card{position:relative;overflow:hidden;padding:22px;border-radius:30px;background:radial-gradient(circle at top right,rgba(255,255,255,.12),transparent 30%),linear-gradient(135deg,#151515,#0b0b0b)}.guest-card__glow{position:absolute;width:240px;height:240px;top:-90px;right:-50px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.14),transparent 70%);pointer-events:none}.guest-card__grid{position:absolute;inset:0;background:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:22px 22px;mask-image:linear-gradient(180deg,rgba(0,0,0,.22),transparent 70%);pointer-events:none}.guest-card__top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;position:relative;z-index:1}.guest-card__brand{font-family:"Space Grotesk",sans-serif;font-size:24px;letter-spacing:-.03em}.guest-card__caption{margin:6px 0 0;font-size:14px;color:var(--text-soft);font-weight:700;line-height:1.5}.guest-card__badge{min-height:36px;padding:0 14px;display:inline-flex;align-items:center;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid var(--line);font-size:12px;color:#fff;font-weight:800}.guest-card__chips{display:flex;flex-wrap:wrap;gap:8px;position:relative;z-index:1;margin-bottom:20px}.guest-card__chips span{min-height:30px;padding:0 12px;display:inline-flex;align-items:center;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid var(--line);font-size:11px;font-weight:800}.guest-card__number{position:relative;z-index:1;margin-bottom:20px;font-family:"Space Grotesk",sans-serif;font-size:clamp(30px,7vw,40px);letter-spacing:.12em}.guest-card__progress{position:relative;z-index:1;margin-bottom:18px;padding:14px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid var(--line)}.guest-card__progress-top{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:var(--text-soft);margin-bottom:10px;font-weight:700}.guest-card__progress-bar{height:10px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}.guest-card__progress-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,.95),rgba(255,255,255,.45))}.guest-card__meta{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}.guest-card__meta-item{padding:14px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid var(--line)}.guest-card__meta-label{display:block;margin-bottom:6px;font-size:12px;color:var(--text-muted);font-weight:700}.guest-card__meta-value{display:block;font-size:15px;font-weight:800}.guest-card__features{display:grid;grid-template-columns:1fr;gap:12px;position:relative;z-index:1}.guest-feature{padding:16px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid var(--line)}.guest-feature__value{display:block;margin-bottom:6px;font-size:15px;font-weight:800}.guest-feature__label{font-size:13px;line-height:1.55;color:var(--text-muted);font-weight:600}
.contacts-panel{margin-top:14px;display:grid;gap:12px}.contact-row{padding:16px}.contact-row__label{font-size:12px;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em;font-weight:800}.contact-row__value{font-size:15px;line-height:1.55;font-weight:700}.contact-actions{display:grid;grid-template-columns:1fr;gap:10px;margin-top:10px}
.bottom-nav{position:fixed;left:10px;right:10px;bottom:calc(env(safe-area-inset-bottom) + 8px);display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:8px;border-radius:22px;background:linear-gradient(180deg,rgba(22,22,22,.92),rgba(10,10,10,.94));border:1px solid rgba(255,255,255,.08);box-shadow:0 12px 40px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.04);z-index:50}.bottom-nav__item{min-height:56px;border:none;border-radius:16px;background:transparent;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:11px;font-weight:700;transition:transform var(--ease),background var(--ease),color var(--ease)}.bottom-nav__item:hover{transform:translateY(-1px)}.bottom-nav__item:active{transform:scale(.95)}.bottom-nav__item.active{color:#fff;background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.05));box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 6px 18px rgba(0,0,0,.24)}.bottom-nav__icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;font-size:16px}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .45s ease,transform .45s ease}.reveal.is-visible{opacity:1;transform:translateY(0)}
.toast{position:fixed;left:50%;transform:translateX(-50%);bottom:120px;background:rgba(0,0,0,.9);border:1px solid rgba(255,255,255,.08);padding:12px 16px;border-radius:14px;font-size:14px;font-weight:700;opacity:0;pointer-events:none;transition:.3s ease;z-index:80}.toast.show{opacity:1}
.consent{margin:6px 0 14px}.consent__label{display:flex;align-items:flex-start;gap:10px;font-size:12px;line-height:1.55;color:var(--text-muted);font-weight:600}.consent__checkbox{margin:2px 0 0;width:16px;height:16px;flex:0 0 16px;accent-color:#ffffff}.consent__label a{color:#ffffff;text-decoration:underline;text-underline-offset:2px}
.booking-success{text-align:center;padding:18px 6px 4px}.booking-success__icon{width:56px;height:56px;margin:0 auto 14px;border-radius:50%;display:grid;place-items:center;background:rgba(121,227,155,.12);border:1px solid rgba(121,227,155,.2);color:#d8ffe5;font-size:24px;font-weight:700}.booking-success__title{margin:0 0 8px;font-size:22px;font-weight:800}.booking-success__text{margin:0 0 18px;font-size:14px;line-height:1.6;color:var(--text-soft);font-weight:600}
@media (max-width:480px){.hero{padding:18px 14px 16px;border-radius:26px}.hero__content{min-height:auto;padding-top:46px;padding-bottom:6px}.hero__status{top:12px;right:12px;min-height:34px;padding:0 11px;font-size:11px}.hero__logo{margin-bottom:16px}.hero__logo-img{width:132px}.hero__badge{margin-bottom:12px;font-size:11px;letter-spacing:.14em}.hero__description{max-width:18ch;font-size:15px;line-height:1.55}.hero__actions{grid-template-columns:1fr;max-width:290px;gap:10px;margin-top:24px}.btn{min-height:52px;font-size:15px;border-radius:16px}.hero__stats{margin-top:14px;gap:8px}.hero-stat{padding:12px 14px}.field--2,.guest-card__meta{grid-template-columns:1fr}.promo__row{flex-direction:column;align-items:flex-start}.promo__chips{justify-content:flex-start}.guest-card__top{flex-direction:column;align-items:flex-start}.guest-card__badge{align-self:flex-start}}
@media (min-width:700px){.hero{padding:28px}.hero__logo-glow{width:220px;height:84px}.hero__logo-img{width:180px}.hero__stats{grid-template-columns:repeat(3,1fr)}.cards-grid,.menu-grid{grid-template-columns:repeat(2,1fr)}.guest-card__features,.contact-actions{grid-template-columns:1fr 1fr}.bottom-nav{left:50%;right:auto;transform:translateX(-50%);width:min(560px,calc(100% - 20px))}}


/* fix2 overrides */
.hero__actions .btn--with-sticker,.menu-card__actions .btn--with-sticker,.contact-actions .btn--with-sticker,.booking-panel .btn--with-sticker{gap:0}
.hero__actions .btn__sticker,.menu-card__actions .btn__sticker,.contact-actions .btn__sticker,.booking-panel .btn__sticker{display:none !important}
.menu-card__tag{display:none !important}
.section-card__icon{width:42px;height:42px;display:grid;place-items:center;border-radius:14px;margin-bottom:16px;font-size:18px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 8px 18px rgba(0,0,0,.22)}
.bottom-nav__item{gap:4px}
.bottom-nav__icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;font-size:15px}
.slot-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:6px}
.slot-btn{min-height:46px;padding:0 12px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);font:inherit;cursor:pointer;transition:.2s ease;font-weight:700}
.slot-btn--active{background:#fff;color:#0b0b0b;border-color:#fff;box-shadow:0 8px 20px rgba(255,255,255,.08)}
.slot-btn--disabled,.slot-btn:disabled{opacity:.34;cursor:not-allowed}
.slot-btn:not(:disabled):active{transform:scale(.98)}
select.control{background-image:linear-gradient(45deg,transparent 50%,rgba(255,255,255,.7) 50%),linear-gradient(135deg,rgba(255,255,255,.7) 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:36px}
.guest-card__chips,.guest-card__progress,.guest-card__grid,.guest-card__features{display:none !important}
.guest-card__caption{margin:6px 0 0;font-size:14px;color:var(--text-soft);font-weight:700;line-height:1.5}
.guest-card__number{margin-bottom:18px;font-family:"Space Grotesk",sans-serif;font-size:clamp(32px,7vw,42px);letter-spacing:.08em}
.guest-card__meta{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.guest-card__meta-item{padding:16px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid var(--line)}
.guest-card__meta-label{display:block;margin-bottom:6px;font-size:12px;color:var(--text-muted);font-weight:700;line-height:1.45}
.guest-card__meta-value{display:block;font-size:15px;font-weight:800;line-height:1.45}
.viewer-page .viewer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.viewer-back{width:auto;min-width:110px}
.viewer-actions{margin-top:12px}
.viewer-actions .btn{width:100%}
.viewer-loading{margin-top:10px;font-size:14px;color:var(--text-soft);font-weight:600}
.viewer-frame{width:100%;height:72vh;border:1px solid var(--line);border-radius:24px;background:#050505;margin-top:10px}
@media (max-width:560px){.slot-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.guest-card__meta{grid-template-columns:1fr}.viewer-page .viewer-head{flex-direction:column}.viewer-back{width:100%}}
.control option {
  background: #111;
  color: #fff;
}


.section-card__icon,
.bottom-nav__icon {
  display: inline-grid;
  place-items: center;
}

.section-card__icon {
  width: 40px;
  height: 40px;
  margin-bottom: 16px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    0 8px 18px rgba(0,0,0,0.22);
}

.section-card__icon svg,
.bottom-nav__icon svg {
  width: 18px;
  height: 18px;
  stroke: rgba(255,255,255,0.9);
  stroke-width: 1.7;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.bottom-nav__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.bottom-nav__icon {
  width: 18px;
  height: 18px;
}

.bottom-nav__item.active .bottom-nav__icon svg {
  stroke: #fff;
}

.modal {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}



.modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(6px);
}

.modal__content {
  position: relative;
  width: calc(100% - 32px);
  max-width: 420px;
  background: #0f0f0f;
  border-radius: 24px;
  padding: 24px 20px;
  text-align: center;
  border: 1px solid rgba(255,255,255,0.08);
}

.modal__icon {
  width: 60px;
  height: 60px;
  margin: 0 auto 14px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(121,227,155,0.12);
  border: 1px solid rgba(121,227,155,0.2);
  font-size: 24px;
  font-weight: 700;
  color: #d8ffe5;
}

.modal__title {
  margin: 0 0 8px;
  font-size: 20px;
  font-weight: 800;
}

.modal__text {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
  margin-bottom: 18px;
}

.install-hint {
  position: fixed;
  bottom: 100px;
  left: 16px;
  right: 16px;
  z-index: 90;
}

.install-hint__content {
  background: #111;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 16px;
  padding: 14px;
  font-size: 13px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.app {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.app.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.guest-card {
  padding: 16px;
}

.guest-card__inner {
  position: relative;
  padding: 24px;
  border-radius: 28px;
  min-height: 480px;
  display: flex;
  flex-direction: column;
  background:
  radial-gradient(circle at 80% 20%, rgba(255,255,255,0.18), transparent 40%),
  radial-gradient(circle at 20% 80%, rgba(255,255,255,0.08), transparent 50%),
  linear-gradient(135deg, #0f0f0f, #1c1c1c 60%, #0a0a0a);

  border: 1px solid rgba(255,255,255,0.08);

  box-shadow:
    0 25px 70px rgba(0,0,0,0.8),
    inset 0 1px 0 rgba(255,255,255,0.05);

  overflow: hidden;
}

/* shine эффект */
.guest-card__shine {
  position: absolute;
  top: -60px;
  right: -40px;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(255,255,255,0.15), transparent 70%);
  filter: blur(40px);
}

/* верх */
.guest-card__top {
  display: flex;
  justify-content: space-between;
  margin-bottom: 16px;
  align-items: flex-start;
}

.guest-card__brand {
  font-size: 12px;
  letter-spacing: 3px;
  opacity: 0.6;
}

.guest-card__status {
  position: absolute;
  font-size: 11px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  top: 16px;
  right: 16px;
}

/* название */
.guest-card__number {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 1px;
  margin-bottom: 14px;
}

/* имя */
.guest-card__name {
  font-size: 18px;
  margin-bottom: 10px;
  opacity: 0.9;
  font-weight: 600;
}

/* баланс */
.guest-card__balance {
  margin: 28px 0 24px;
}

.guest-card__balance-value {
  font-size: 56px;
  font-weight: 900;
  letter-spacing: -1px;
}

.guest-card__balance-unit {
  font-size: 13px;
  opacity: 0.6;
}

/* QR */

.guest-card__qr img {
  width: 160px;
  height: 160px;
  border-radius: 12px;
  background: #fff;
  padding: 6px;
}

/* низ */
.guest-card__footer {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  opacity: 0.6;
  margin-top: 10px;
}

/* кнопка */
.guest-card__btn {
  width: 100%;
  padding: 18px;
  border-radius: 18px;
  background: white;
  color: black;
  font-weight: 700;
  border: none;
  margin-top: 12px;
  font-size: 16px;
}

/* анимация нажатия */
.guest-card__inner:active {
  transform: scale(0.98);
  transition: 0.2s;
}

.guest-auth {
  padding: 16px;
}

.guest-auth__title {
  font-size: 16px;
  margin-bottom: 12px;
  font-weight: 600;
}

.guest-auth__input {
  width: 100%;
  padding: 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.1);
  background: #111;
  color: white;
  margin-bottom: 12px;
}

.guest-auth__btn {
  width: 100%;
  padding: 14px;
  border-radius: 12px;
  background: white;
  color: black;
  font-weight: 600;
}

.guest-card__qr {
  margin-top: 16px;
  padding: 12px;
  background: white;
  border-radius: 12px;
  display: flex;
  justify-content: center;
}

.app {
  opacity: 0;
  transform: translateY(10px);
  filter: blur(6px);
  transition: opacity 0.6s ease, transform 0.6s ease, filter 0.6s ease;
}

.app.is-visible {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.guest-card__inner {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.guest-card__inner:active {
  transform: scale(0.98);
}
.guest-card__qr img {
  width: 120px;
  height: 120px;
}
.guest-card__inner::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 28px;
  background: radial-gradient(circle at 80% 20%, rgba(255,255,255,0.08), transparent 40%);
  pointer-events: none;
}
.guest-title {
  margin-bottom: 12px;
  font-size: 18px;
  font-weight: 700;
}

.guest-card__brand img {
  width: 70px;
  opacity: 0.9;
}
.modal[hidden] {
  display: none !important;
}

.viewer-back {
  position: fixed;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);

  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(10px);

  padding: 10px 18px;
  border-radius: 16px;
}

.guest-card__inner {
  border-radius: 24px;
  background: radial-gradient(circle at 80% 20%, rgba(255,255,255,0.08), transparent),
              #0b0b0b;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
}

.guest-card__btn--secondary {
  background: rgba(255,255,255,0.08);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.1);
}
.consent__label a {
  color: #fff;
  text-decoration: underline;
  opacity: 0.9;
}

.bottom-nav__item.active svg {
  transform: scale(1.1);
}
.qr-wrap {
  display: flex;
  justify-content: center;
  margin: 20px 0;
}
.qr-box canvas {
  width: 220px !important;
  height: 220px !important;
}
.qr-box {
  background: #fff;
  padding: 20px;
  border-radius: 20px;

  display: flex;
  justify-content: center;
  align-items: center;

  box-shadow:
    0 20px 40px rgba(0,0,0,0.6),
    inset 0 1px 0 rgba(0,0,0,0.1);
}

.qr-box img {
  width: 220px;
  height: 220px;
}
.referral-block {
  margin-top: 16px;
  padding: 16px;
  border-radius: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  text-align: center;
}

.referral-title {
  font-weight: 700;
  margin-bottom: 6px;
}

.referral-text {
  font-size: 13px;
  opacity: 0.7;
  margin-bottom: 10px;
}
.viewer-container {
  padding: 12px;
}

.viewer-frame {
  width: 100%;
  height: 80vh;

  border-radius: 20px;
  border: none;

  background: #fff;

  transform: scale(0.92);
  transform-origin: top center;
}
.guest-card__partners {
  margin-top: 16px;
  font-size: 12px;
  opacity: 0.6;
}

.partners-list {
  display: flex;
  gap: 10px;
  margin-top: 6px;
}

.partners-list img {
  height: 18px;
  opacity: 0.8;
}
.guest-card__subtitle {
  font-size: 12px;
  letter-spacing: 0.3px;
  opacity: 0.55;
  margin-bottom: 16px;
  text-transform: uppercase;
}
.guest-card__subtitle strong {
  opacity: 0.9;
  font-weight: 700;
}
.guest-card__brands {
  display: flex;
  align-items: center;
  gap: 12px;
}

.brand-main {
  height: 20px;
  opacity: 0.9;
}

.brand-partner {
  height: 18px;
  object-fit: contain;
  filter: none;
}
.guest-card__brands {
  display: flex;
  align-items: center;
  gap: 10px;
}
/* линия между логотипами */
.brand-divider {
  width: 1px;
  height: 16px;
  background: linear-gradient(
    to bottom,
    transparent,
    rgba(255,255,255,0.4),
    transparent
  );
  opacity: 0.6;
}
.brand-divider {
  box-shadow: 0 0 6px rgba(255,255,255,0.2);
}




/* ===== NEW GUEST CARD DESIGN (REPLACEMENT) ===== */

.guest-card {
  margin-top: 20px;
  border-radius: 24px;
  padding: 2px;
  background: linear-gradient(
    145deg,
    rgba(255, 255, 255, 0.08),
    rgba(255, 255, 255, 0.02)
  );
}

.guest-card__inner {
  position: relative;
  border-radius: 22px;
  padding: 22px;
  min-height: 420px;
  display: flex;
  flex-direction: column;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.08), transparent 60%),
    #0a0a0a;
  overflow: hidden;
}

.guest-card__shine {
  position: absolute;
  top: -40%;
  right: -40%;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(255,255,255,0.15), transparent);
  filter: blur(40px);
}

.guest-card__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.guest-card__brands {
  display: flex;
  align-items: center;
  gap: 10px;
}

.brand-main {
  height: 20px;
}

.brand-partner {
  height: 18px;
  object-fit: contain;
}

.brand-divider {
  width: 1px;
  height: 16px;
  background: rgba(255,255,255,0.3);
}

.guest-card__status {
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
}

.guest-card__user {
  margin-top: 16px;
}

.guest-card__name {
  font-size: 20px;
  font-weight: 600;
}

.guest-card__balance {
  margin-top: 20px;
}

.guest-card__balance-value {
  font-size: 52px;
  font-weight: 800;
}

.guest-card__balance-unit {
  opacity: 0.6;
}

.guest-card__footer {
  display: flex;
  justify-content: space-between;
  margin-top: 16px;
  font-size: 12px;
  opacity: 0.6;
}

.guest-card__btn {
  margin-top: 20px;
  width: 100%;
  padding: 16px;
  border-radius: 14px;
  background: #ffffff;
  color: #000000;
  font-weight: 600;
}

.qr-box {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  padding: 20px;
  border-radius: 20px;
}

.qr-box img {
  width: 220px;
  height: 220px;
}

.guest-card__btn.secondary {
  margin-top: 10px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.2);
  color: #aaa;
}

.guest-card__btn.secondary:hover {
  background: rgba(255,255,255,0.05);
}
/* QR MODAL */

.qr-modal {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.qr-modal.hidden {
  display: none;
}

.qr-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(8px);
}

.qr-modal__content {
  position: relative;
  z-index: 2;
  background: #111;
  padding: 24px;
  border-radius: 24px;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
  animation: scaleIn 0.25s ease;
}

@keyframes scaleIn {
  from { transform: scale(0.9); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

.qr-container {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 20px 0;
}

.qr-container img {
  width: 220px;
  height: 220px;
  border-radius: 16px;
}

.qr-close {
  position: absolute;
  top: 10px;
  right: 10px;
  border: none;
  background: rgba(255,255,255,0.1);
  color: #fff;
  border-radius: 10px;
  padding: 6px 10px;
  cursor: pointer;
}

.qr-text {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
}
/* GUEST AUTH */

.guest-auth {
  margin-top: 16px;
}

.guest-auth__card {
  padding: 20px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(16px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}

.guest-auth__title {
  font-size: 20px;
  font-weight: 800;
  margin-bottom: 6px;
}

.guest-auth__subtitle {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  margin-bottom: 16px;
}

/* input */
.guest-auth__input {
  width: 100%;
  height: 52px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.05);
  color: #fff;
  padding: 0 14px;
  font-size: 15px;
  margin-bottom: 12px;
  outline: none;
}

.guest-auth__input:focus {
  border-color: rgba(255,255,255,0.25);
  background: rgba(255,255,255,0.08);
}

/* button */
.guest-auth__button {
  width: 100%;
  height: 54px;
  border-radius: 16px;
  border: none;
  background: #fff;
  color: #000;
  font-weight: 800;
  font-size: 15px;
  cursor: pointer;
  transition: 0.2s ease;
}

.guest-auth__button:active {
  transform: scale(0.97);
}
.btn {
  transition: all 0.2s ease;
}

.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(255,255,255,0.08);
}

.btn:active {
  transform: scale(0.96);
}

/* ЖИВОЙ СВЕТ */
@keyframes glowMove {
  0% { transform: translateX(-20%) translateY(-10%); }
  50% { transform: translateX(10%) translateY(10%); }
  100% { transform: translateX(-20%) translateY(-10%); }
}

.guest-card__shine {
  animation: glowMove 6s ease-in-out infinite;
}

.guest-card__inner:hover {
  transform: translateY(-4px) scale(1.01);
  box-shadow: 0 30px 80px rgba(0,0,0,0.9);
}
.hero::before {
  content: "";
  position: absolute;
  top: -100px;
  left: 50%;
  transform: translateX(-50%);
  width: 500px;
  height: 300px;
  background: radial-gradient(circle, rgba(255,255,255,0.08), transparent 70%);
  filter: blur(60px);
  animation: glowMove 8s ease-in-out infinite;
}
.qr-container::before {
  content: "";
  position: absolute;
  width: 260px;
  height: 260px;
  background: radial-gradient(circle, rgba(255,255,255,0.2), transparent 70%);
  filter: blur(30px);
  z-index: -1;
}
.guest-card {
  animation: cardEnter 0.5s ease;
}

@keyframes cardEnter {
  0% {
    transform: translateY(40px) scale(0.95);
    opacity: 0;
  }
  60% {
    transform: translateY(-4px) scale(1.02);
  }
  100% {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}
.btn--primary:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
/* AUTH SCREEN */

.auth-screen {
  text-align: center;
  padding: 40px 20px;
}

.auth-title {
  font-size: 28px;
  font-weight: 800;
  margin-bottom: 10px;
}

.auth-subtitle {
  font-size: 14px;
  color: rgba(255,255,255,0.6);
  margin-bottom: 30px;
}

.auth-btn {
  width: 100%;
  max-width: 320px;
  margin: 10px auto;
  display: block;
}

.auth-hint {
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  margin-bottom: 20px;
}
/* CUSTOM CHECKBOX */

.auth-checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  cursor: pointer;
}

.auth-checkbox__box {
  width: 18px;
  height: 18px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.05);
  position: relative;
  transition: all 0.2s ease;
}

.auth-checkbox__text {
  font-size: 13px;
  color: rgba(255,255,255,0.7);
}

.auth-checkbox a {
  color: #6aa9ff;
  text-decoration: none;
}

.auth-checkbox a:hover {
  text-decoration: underline;
}

/* CHECKED STATE */
.auth-checkbox input:checked + .auth-checkbox__box {
  background: #fff;
  border-color: #fff;
}

.auth-checkbox input:checked + .auth-checkbox__box::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -55%);
  font-size: 12px;
  color: #000;
}
.auth-checkbox:active {
  transform: scale(0.97);
}
.auth-checkbox {
  justify-content: center;
  text-align: left;
}
.auth-checkbox__text {
  max-width: 260px;
}
.modal {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal[hidden] {
  display: none;
}

.modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(10px);
}

.modal__content {
  width: 92%;
  max-width: 420px;
  padding: 28px 20px;
  border-radius: 24px;

  background: linear-gradient(180deg, #0b0b0b, #050505);
  border: 1px solid rgba(255,255,255,0.08);

  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
}

@keyframes modalPop {
  from {
    transform: scale(0.9);
    opacity: 0;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
.auth-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.auth-modal[hidden] {
  display: none;
}

.auth-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(10px);
}

.auth-modal__content {
  position: relative;
  width: 100%;
  max-width: 420px;
  background: #111;
  border-radius: 24px 24px 0 0;
  padding: 24px;
  text-align: center;
  animation: slideUp 0.3s ease;
}

@keyframes slideUp {
  from {
    transform: translateY(100%);
  }
  to {
    transform: translateY(0);
  }
}
.modal__overlay {
  z-index: 1;
}

.modal__content {
  z-index: 2;
}
.slot-btn {
  padding: 10px;
  border-radius: 12px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  color: #fff;
  cursor: pointer;
  transition: 0.2s;
}

.slot-btn:hover {
  background: rgba(255,255,255,0.15);
  transform: translateY(-2px);
}

.slot-btn--active {
  background: #fff;
  color: #000;
  box-shadow: 0 0 20px rgba(255,255,255,0.4);
}

.slot-btn--disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.menu {
  padding: 16px;
  color: #fff;
  max-width: 600px;
  margin: 0 auto;
}

.menu-section {
  margin-bottom: 32px;
}

.menu-section h2 {
  font-size: 20px;
  margin-bottom: 16px;
}

.menu-item {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.title {
  font-weight: 500;
}

.desc {
  font-size: 12px;
  color: #aaa;
}

.price {
  font-weight: 600;
}
.menu-header {
  font-size: 18px;
  font-weight: 600;
  padding: 14px 0;
  cursor: pointer;
}

.menu-content {
  display: none;
  animation: fadeIn 0.3s ease;
}

.menu-section.active .menu-content {
  display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(-5px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.menu-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
  overflow-x: auto;
}

.menu-tab {
  padding: 10px 14px;
  border-radius: 12px;
  background: #111;
  color: #aaa;
  border: none;
  cursor: pointer;
  white-space: nowrap;
}

.menu-tab.active {
  background: #fff;
  color: #000;
}

.menu-group {
  display: none;
}

.menu-group.active {
  display: block;
}
.menu-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
  overflow-x: auto;
}

.menu-tab {
  padding: 10px 14px;
  border-radius: 12px;
  background: #111;
  color: #aaa;
  border: none;
  cursor: pointer;
  white-space: nowrap;
}

.menu-tab.active {
  background: #fff;
  color: #000;
}

.menu-group {
  display: none;
}

.menu-group.active {
  display: block;
}
.menu-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.menu-card {
  position: relative;
  background: linear-gradient(180deg, #0b0b0b, #050505);
  border-radius: 20px;
  padding: 20px;
  border: 1px solid rgba(255,255,255,0.06);
  overflow: hidden;
  transition: all 0.3s ease;
}
.menu-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(255,255,255,0.15), transparent 40%);
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
}

.menu-card__title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 4px;
}

.menu-card__desc {
  font-size: 13px;
  opacity: 0.6;
  margin-bottom: 16px;
}

.menu-card__btn {
  width: 100%;
  padding: 14px;
  border-radius: 14px;
  border: none;
  background: #eaeaea;
  color: #000;
  font-weight: 600;
  cursor: pointer;
}
@media (max-width: 600px) {
  .menu-cards {
    grid-template-columns: 1fr;
  }
}
.menu-card:nth-child(3) {
  grid-column: span 2;
}
.menu-card:hover {
  transform: translateY(-3px);
  border-color: rgba(255,255,255,0.15);
}
.menu-card:hover::before {
  opacity: 1;
}
.menu-card__title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 4px;
}
.menu-card__desc {
  font-size: 13px;
  opacity: 0.6;
  margin-bottom: 16px;
}

/* 💎 кнопка */
.menu-card__btn {
  width: 100%;
  padding: 14px;
  border-radius: 14px;
  border: none;
  background: linear-gradient(180deg, #ffffff, #dcdcdc);
  color: #000;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

/* 👆 нажатие */
.menu-card__btn:active {
  transform: scale(0.97);
}

/* ✨ hover кнопки */
.menu-card__btn:hover {
  background: linear-gradient(180deg, #ffffff, #cfcfcf);
}
.menu-card__btn {
  position: relative;
  z-index: 2;
}
.btn {
  padding: 18px;
  font-size: 16px;
  border-radius: 18px;
}
.btn--primary {
  background: linear-gradient(180deg, #ffffff, #dcdcdc);
  color: #000;
  font-weight: 700;
}
.btn--secondary {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
}
.guest-auth__input {
  padding: 18px;
  border-radius: 16px;
  font-size: 16px;
}
.slot-btn {
  padding: 12px;
  border-radius: 12px;
  background: rgba(255,255,255,0.05);
  border: none;
  color: #fff;
  cursor: pointer;
}

.slot-btn.active {
  background: #fff;
  color: #000;
}

.slot-btn.disabled {
  opacity: 0.3;
  pointer-events: none;
}
.slot-grid .busy {
  opacity: 0.4;
}
.slot-btn span {
  font-size: 10px;
  color: rgba(255,255,255,0.6);
  display: block;
}

.slot-btn--active {
  background: #fff;
  color: #000;
}
.success-modal[hidden] {
  display: none;
}

.success-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.success-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.success-modal__card {
  position: relative;
  z-index: 1;
  width: min(100%, 420px);
  padding: 24px 20px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(20,20,20,.98), rgba(10,10,10,.98));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 24px 80px rgba(0,0,0,.45);
  text-align: center;
}

.success-modal .booking-success__icon {
  margin: 0 auto 14px;
}

.success-modal .booking-success__title {
  margin-bottom: 8px;
}

.success-modal .booking-success__text {
  margin-bottom: 18px;
}
/* ===== AUTH MODAL IMPROVE ===== */

#authModal .modal__content {
  width: min(92vw, 520px);
  max-width: 520px;
  padding: 32px 20px 20px;
  border-radius: 28px;
  text-align: center;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.08), transparent 45%),
    linear-gradient(180deg, #0f0f0f, #050505);
  box-shadow: 0 24px 80px rgba(0,0,0,0.55);
}

#authModal h3 {
  margin: 0 0 18px;
  font-size: 30px;
  line-height: 1.1;
  font-weight: 800;
}

#authModal .btn {
  min-height: 58px;
}

#authModal #tgLoginBtn,
#authModal #phoneLoginBtn,
#authModal #guestLoginBtnModal {
  width: 100%;
}

#authModal #phoneLoginBtn {
  margin-top: 12px;
}

#phoneBlock {
  margin-top: 16px;
  display: grid;
  gap: 12px;
  width: 100%;
  animation: phoneBlockFade 0.22s ease;
}

#phoneBlock[hidden] {
  display: none !important;
}

#guestPhoneModal {
  width: 100%;
  min-height: 58px;
  padding: 0 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.12);
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));
  color: #fff;
  font-size: 18px;
}

#guestPhoneModal::placeholder {
  color: rgba(255,255,255,0.38);
}

#guestPhoneModal:focus {
  border-color: rgba(255,255,255,0.22);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.05);
  outline: none;
}

@keyframes phoneBlockFade {
  from {
    opacity: 0;
    transform: translateY(-6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 480px) {
  #authModal .modal__content {
    width: calc(100% - 24px);
    max-width: none;
    padding: 28px 16px 18px;
    border-radius: 24px;
  }

  #authModal h3 {
    font-size: 24px;
  }

  #guestPhoneModal {
    font-size: 16px;
  }
}
/* PHONE INPUT IMPROVE */

#phone,
#guestPhoneModal {
  letter-spacing: 0.2px;
  font-weight: 700;
}

#phone::placeholder,
#guestPhoneModal::placeholder {
  color: rgba(255,255,255,0.32);
}

#phone:focus,
#guestPhoneModal:focus {
  border-color: rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.05);
}
/* AUTH MODAL FINAL FIX */

#authModal .modal__content {
  width: min(92vw, 520px);
  max-width: 520px;
  padding: 32px 20px 20px;
  border-radius: 28px;
}

#authModal h3 {
  margin: 0 0 18px;
  font-size: 30px;
  line-height: 1.1;
  font-weight: 800;
}

#phoneBlock {
  margin-top: 14px;
  display: grid;
  gap: 12px;
  width: 100%;
}

#phoneBlock[hidden] {
  display: none !important;
}

#authModal #guestPhoneModal {
  width: 100%;
  min-height: 58px;
  border-radius: 18px;
  padding: 0 18px;
  font-size: 18px;
}

#authModal #tgLoginBtn,
#authModal #phoneLoginBtn,
#authModal #guestLoginBtnModal {
  width: 100%;
}

@media (max-width: 480px) {
  #authModal .modal__content {
    width: calc(100% - 24px);
    max-width: none;
    padding: 28px 16px 18px;
  }

  #authModal h3 {
    font-size: 24px;
  }

  #authModal #guestPhoneModal {
    font-size: 16px;
  }
}
/* GUEST CARD BUTTONS INTERACTION FIX */

.guest-card__btn {
  cursor: pointer;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease,
    opacity 0.18s ease;
}

.guest-card__btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(255,255,255,0.10);
}

.guest-card__btn:active {
  transform: scale(0.97);
  box-shadow: 0 8px 18px rgba(255,255,255,0.06);
}

.guest-card__btn:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 3px rgba(255,255,255,0.08),
    0 14px 30px rgba(255,255,255,0.10);
}

.guest-card__btn--secondary {
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease,
    opacity 0.18s ease;
}

.guest-card__btn--secondary:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.18);
  box-shadow: 0 10px 24px rgba(0,0,0,0.28);
}

.guest-card__btn--secondary:active {
  transform: scale(0.97);
}

@media (hover: none) {
  .guest-card__btn:hover,
  .guest-card__btn--secondary:hover {
    transform: none;
    box-shadow: none;
  }
}
/* GUEST CARD BUTTONS PREMIUM TUNE */

.guest-card__btn {
  width: 100%;
  min-height: 54px;
  padding: 0 18px;
  border-radius: 16px;
  border: none;
  margin-top: 10px;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.01em;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: linear-gradient(180deg, #ffffff, #e8e8e8);
  color: #050505;

  box-shadow:
    0 10px 24px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.45);
}

.guest-card__btn--secondary {
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04));
  color: #ffffff;
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow:
    0 8px 20px rgba(0,0,0,0.22),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

.guest-card__btn + .guest-card__btn {
  margin-top: 10px;
}

@media (max-width: 480px) {
  .guest-card__btn {
    min-height: 52px;
    font-size: 15px;
    border-radius: 15px;
  }
}
/* GUEST CARD BUTTONS STRONGER OVERRIDE */

.guest-card__btn {
  width: min(100%, 420px);
  margin: 12px auto 0;
  min-height: 52px;
  padding: 0 18px;
  border-radius: 18px;
  font-size: 15px;
  font-weight: 800;

  display: flex;
  align-items: center;
  justify-content: center;

  background: linear-gradient(180deg, #ffffff, #e7e7e7);
  color: #050505;
  border: none;

  box-shadow:
    0 12px 28px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.45);

  cursor: pointer;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    opacity 0.18s ease;
}

.guest-card__btn:hover {
  transform: translateY(-2px);
  box-shadow:
    0 16px 34px rgba(255,255,255,0.12),
    inset 0 1px 0 rgba(255,255,255,0.5);
}

.guest-card__btn:active {
  transform: scale(0.97);
}

.guest-card__btn--secondary {
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  color: #fff;
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow:
    0 10px 24px rgba(0,0,0,0.26),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

.guest-card__btn--secondary:hover {
  background: linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.05));
}

@media (max-width: 480px) {
  .guest-card__btn {
    width: 100%;
  }
}
/* GUEST CARD PREMIUM LAYOUT TUNE */

.guest-card {
  margin-top: 24px;
  padding: 3px;
  border-radius: 28px;
  background:
    linear-gradient(145deg, rgba(255,255,255,0.10), rgba(255,255,255,0.02));
  box-shadow:
    0 24px 80px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.04);
}

.guest-card__inner {
  position: relative;
  min-height: 420px;
  padding: 26px 24px 24px;
  border-radius: 26px;
  overflow: hidden;

  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto 1fr auto auto;
  gap: 14px;

  background:
    radial-gradient(circle at 85% 18%, rgba(255,255,255,0.10), transparent 30%),
    radial-gradient(circle at 15% 100%, rgba(255,255,255,0.04), transparent 35%),
    linear-gradient(135deg, #080808 0%, #0d0d0d 42%, #161616 100%);

  border: 1px solid rgba(255,255,255,0.06);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.05),
    inset 0 -1px 0 rgba(255,255,255,0.02);
}

.guest-card__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.025) 36%, transparent 60%);
}

.guest-card__shine {
  top: -70px;
  right: -30px;
  width: 240px;
  height: 240px;
  opacity: 0.9;
  filter: blur(42px);
}

.guest-card__top {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 2px;
}

.guest-card__brands {
  gap: 14px;
}

.brand-main {
  height: 22px;
  opacity: 0.95;
}

.brand-partner {
  height: 20px;
  opacity: 0.95;
}

.brand-divider {
  height: 18px;
  opacity: 0.7;
}

.guest-card__status {
  position: static;
  align-self: flex-start;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: -0.01em;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}

.guest-card__name {
  position: relative;
  z-index: 1;
  margin-top: 2px;
  font-size: 17px;
  font-weight: 700;
  color: rgba(255,255,255,0.92);
  letter-spacing: -0.01em;
}

.guest-card__balance {
  position: relative;
  z-index: 1;
  margin: 8px 0 2px;
}

.guest-card__balance-value {
  font-size: clamp(54px, 10vw, 76px);
  line-height: 0.95;
  font-weight: 900;
  letter-spacing: -0.05em;
  color: #ffffff;
  text-shadow: 0 4px 24px rgba(255,255,255,0.05);
}

.guest-card__balance-unit {
  margin-top: 6px;
  font-size: 15px;
  font-weight: 600;
  opacity: 0.72;
}

.guest-card__footer {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  margin-top: 2px;
  font-size: 13px;
  opacity: 0.9;
}

.guest-card__id {
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: rgba(255,255,255,0.78);
}

.guest-card__rate {
  font-size: 14px;
  font-weight: 700;
  color: rgba(255,255,255,0.62);
  white-space: nowrap;
}

.guest-card__btn {
  position: relative;
  z-index: 1;
}

.guest-card__btn:first-of-type {
  margin-top: 6px;
}

@media (max-width: 700px) {
  .guest-card__inner {
    min-height: auto;
    padding: 22px 18px 18px;
    gap: 12px;
  }

  .guest-card__top {
    align-items: center;
  }

  .guest-card__status {
    font-size: 11px;
    padding: 6px 10px;
  }

  .guest-card__name {
    font-size: 16px;
  }

  .guest-card__balance-value {
    font-size: 56px;
  }

  .guest-card__footer {
    align-items: flex-start;
    flex-direction: row;
  }

  .guest-card__id {
    font-size: 18px;
  }

  .guest-card__rate {
    font-size: 12px;
  }
}
/* QR MODAL PREMIUM TUNE */

.qr-modal-card {
  width: min(100%, 460px);
  padding: 28px 20px 20px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.08), transparent 42%),
    linear-gradient(180deg, #101010, #060606);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 28px 80px rgba(0,0,0,0.52);
}

.qr-modal__header {
  text-align: center;
  margin-bottom: 8px;
}

.qr-modal__title {
  margin: 0 0 8px;
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #fff;
}

.qr-modal__subtitle {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255,255,255,0.68);
  font-weight: 600;
}

.qr-wrap {
  display: flex;
  justify-content: center;
  margin: 22px 0 18px;
}

.qr-box {
  width: min(100%, 280px);
  min-height: 280px;
  padding: 18px;
  border-radius: 26px;
  background:
    linear-gradient(180deg, #ffffff, #f3f3f3);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    0 18px 40px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.75);
}

.qr-box img,
.qr-box canvas {
  width: 100% !important;
  max-width: 220px;
  height: auto !important;
  display: block;
}

#qrModal .btn {
  width: min(100%, 360px);
  margin-left: auto;
  margin-right: auto;
}

#qrModal .referral-block {
  margin-top: 16px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
}

#qrModal .referral-title {
  font-size: 15px;
  font-weight: 800;
  margin-bottom: 6px;
}

#qrModal .referral-text {
  font-size: 13px;
  color: rgba(255,255,255,0.68);
  margin-bottom: 12px;
  line-height: 1.5;
}

@media (max-width: 480px) {
  .qr-modal-card {
    width: calc(100% - 20px);
    padding: 24px 16px 18px;
    border-radius: 24px;
  }

  .qr-modal__title {
    font-size: 22px;
  }

  .qr-box {
    min-height: 240px;
    padding: 14px;
    border-radius: 22px;
  }

  .qr-box img,
  .qr-box canvas {
    max-width: 190px;
  }

  #qrModal .btn {
    width: 100%;
  }
}
/* QR CARD NUMBER */

.qr-card-number {
  margin: -4px 0 18px;
  text-align: center;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: rgba(255,255,255,0.92);
}

.qr-card-number span {
  color: rgba(255,255,255,0.55);
  font-weight: 700;
  margin-right: 6px;
}
/* MOBILE FIX: selected time slot must stay white */

.slot-btn {
  -webkit-appearance: none;
  appearance: none;
}

.slot-btn--active,
.slot-btn.slot-btn--active,
.slot-grid .slot-btn--active {
  background: #ffffff !important;
  color: #050505 !important;
  border: 1px solid #ffffff !important;
  box-shadow: 0 10px 24px rgba(255,255,255,0.18) !important;
  opacity: 1 !important;
}

.slot-btn--active span,
.slot-grid .slot-btn--active span {
  color: rgba(0,0,0,0.55) !important;
}

.slot-btn:not(.slot-btn--active) {
  background: rgba(255,255,255,0.05);
  color: #ffffff;
}

.slot-btn--disabled,
.slot-btn:disabled {
  opacity: 0.32 !important;
  background: rgba(255,255,255,0.04) !important;
  color: rgba(255,255,255,0.55) !important;
  box-shadow: none !important;
} 
/* MOBILE FIX: menu cards in one column */

@media (max-width: 820px) {
  .menu-cards {
    grid-template-columns: 1fr !important;
  }

  .menu-card:nth-child(3) {
    grid-column: span 1 !important;
  }

  .menu-card {
    min-height: auto;
  }

  .menu-card__btn {
    width: 100%;
    min-height: 56px;
    white-space: normal;
    line-height: 1.2;
  }
}
/* SUCCESS MODAL FIX FOR MOBILE */

.success-modal {
  position: fixed;
  inset: 0;
  z-index: 4000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(20px, env(safe-area-inset-top)) 16px max(20px, env(safe-area-inset-bottom));
}

.success-modal__card {
  width: min(100%, 420px);
  max-height: calc(100vh - 40px);
  overflow-y: auto;
}

@media (max-width: 480px) {
  .success-modal {
    align-items: center;
    justify-content: center;
    padding: 16px;
  }

  .success-modal__card {
    width: 100%;
    border-radius: 24px;
  }
}
/* GUEST CARD MOBILE BORDER FIX */

.guest-card {
  overflow: hidden;
}

.guest-card__inner {
  overflow: hidden;
}

@media (max-width: 640px) {
  .guest-card {
    padding: 1px;
    border-radius: 24px;
    background: linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.015));
    box-shadow: 0 18px 48px rgba(0,0,0,0.42);
  }

  .guest-card__inner {
    border-radius: 23px;
    min-height: auto;
    padding: 20px 16px 18px;
    gap: 12px;
    background:
      radial-gradient(circle at 85% 18%, rgba(255,255,255,0.08), transparent 28%),
      linear-gradient(135deg, #090909 0%, #101010 55%, #171717 100%);
    border: 1px solid rgba(255,255,255,0.05);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.04),
      0 8px 24px rgba(0,0,0,0.22);
  }

  .guest-card__top {
    gap: 12px;
  }

  .guest-card__brands {
    gap: 10px;
    flex-wrap: wrap;
  }

  .guest-card__name {
    font-size: 16px;
  }

  .guest-card__balance {
    margin: 4px 0 2px;
  }

  .guest-card__balance-value {
    font-size: 52px;
  }

  .guest-card__footer {
    align-items: center;
    gap: 10px;
  }

  .guest-card__id {
    font-size: 18px;
  }

  .guest-card__rate {
    font-size: 12px;
    text-align: right;
  }
}
/* FINAL MOBILE FIX: guest card */

#openAuthBtn[hidden] {
  display: none !important;
}

.guest-card,
.guest-card__inner {
  box-sizing: border-box;
}

.guest-card {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.guest-card__inner {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

@media (max-width: 640px) {
  .guest-card {
    margin-top: 20px;
    padding: 1px;
    border-radius: 24px;
    background: linear-gradient(
      145deg,
      rgba(255,255,255,0.06),
      rgba(255,255,255,0.015)
    );
    box-shadow: 0 14px 36px rgba(0,0,0,0.34);
  }

  .guest-card__inner {
    min-height: auto;
    padding: 18px 14px 16px;
    border-radius: 23px;
    background:
      radial-gradient(circle at 82% 16%, rgba(255,255,255,0.08), transparent 28%),
      linear-gradient(135deg, #080808 0%, #0f0f0f 55%, #171717 100%);
    border: 1px solid rgba(255,255,255,0.045);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.035),
      0 8px 20px rgba(0,0,0,0.18);
  }

  .guest-card__top {
    margin-bottom: 4px;
    gap: 10px;
    align-items: flex-start;
  }

  .guest-card__brands {
    gap: 8px;
    flex-wrap: wrap;
  }

  .brand-main {
    height: 20px;
  }

  .brand-partner {
    height: 18px;
  }

  .guest-card__status {
    padding: 6px 10px;
    font-size: 11px;
    border-radius: 999px;
  }

  .guest-card__name {
    margin-top: 0;
    font-size: 15px;
  }

  .guest-card__balance {
    margin: 0;
  }

  .guest-card__balance-value {
    font-size: 48px;
    line-height: 0.95;
  }

  .guest-card__balance-unit {
    margin-top: 4px;
    font-size: 14px;
  }

  .guest-card__footer {
    margin-top: 0;
    align-items: flex-end;
    gap: 10px;
  }

  .guest-card__id {
    font-size: 16px;
    line-height: 1.2;
  }

  .guest-card__rate {
    font-size: 11px;
    line-height: 1.2;
    text-align: right;
    white-space: nowrap;
  }

  .guest-card__btn {
    width: 100%;
    max-width: none;
    margin-top: 12px;
    min-height: 54px;
  }
}
/* GUEST CARD TOP FIX ON MOBILE */

@media (max-width: 640px) {
  .guest-card__top {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 12px !important;
  }

  .guest-card__brands {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
  }

  .guest-card__status {
    flex: 0 0 auto;
    margin-left: auto;
    align-self: flex-start;
    white-space: nowrap;
  }
}
/* CONSENT FIX FOR MOBILE */

.consent {
  margin: 10px 0 16px;
}

.consent__label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  user-select: none;
}

.consent__checkbox {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  margin-top: 1px;
  accent-color: #ffffff;
}

@media (max-width: 640px) {
  .consent__label {
    font-size: 13px;
    line-height: 1.5;
  }

  .consent__checkbox {
    width: 22px;
    height: 22px;
    flex-basis: 22px;
  }
}
/* OFFERS SECTION */

.offer-card {
  width: 100%;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 18px;
  padding: 18px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.08), transparent 32%),
    linear-gradient(135deg, #0b0b0b 0%, #111111 55%, #181818 100%);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 22px 60px rgba(0,0,0,0.34);
  overflow: hidden;
}

.offer-card__media {
  min-width: 0;
}

.offer-card__image {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.06);
  background: #0b0b0b;
}

.offer-card__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.offer-card__badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.08);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.offer-card__title {
  margin: 0 0 10px;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 0.98;
  font-weight: 900;
  letter-spacing: -0.05em;
  color: #fff;
}

.offer-card__meta {
  margin: 0 0 12px;
  color: rgba(255,255,255,0.72);
  font-size: 15px;
  font-weight: 700;
}

.offer-card__text {
  margin: 0 0 18px;
  color: rgba(255,255,255,0.76);
  font-size: 16px;
  line-height: 1.6;
}

.offer-card__footer {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  color: rgba(255,255,255,0.58);
  font-size: 13px;
  font-weight: 700;
}

@media (max-width: 900px) {
  .offer-card {
    grid-template-columns: 1fr;
  }

  .offer-card__image {
    min-height: 280px;
  }
}

@media (max-width: 640px) {
  .offer-card__image {
    border-radius: 18px;
  }
}

  .offer-card__image {
    min-height: 220px;
    border-radius: 18px;
  }

  .offer-card__title {
    font-size: 34px;
  }

  .offer-card__meta {
    font-size: 14px;
  }

  .offer-card__text {
    font-size: 15px;
  }

  .offer-card__footer {
    font-size: 12px;
  }
}
.offers-slider {
  display: grid;
  gap: 18px;
}

.offers-slider::-webkit-scrollbar {
  display: none;
}
@media (max-width: 640px) {
  .offers-slider {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 6px;
    padding-right: 20px;
    padding-left: 0;
  }

  .offers-slider::-webkit-scrollbar {
    display: none;
  }

  .offer-card {
    flex: 0 0 86%;
    width: auto;
    scroll-snap-align: start;
  }
}
.install-hint-overlay[hidden] {
  display: none !important;
}

.install-hint-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.install-hint-modal {
  width: 100%;
  max-width: 420px;
  background: #111;
  color: #fff;
  border-radius: 18px;
  padding: 20px 18px 18px;
  position: relative;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

.install-hint-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 34px;
  height: 34px;
  border: none;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  color: #fff;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

.install-hint-title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 10px;
  padding-right: 36px;
}

.install-hint-text {
  font-size: 14px;
  line-height: 1.5;
  opacity: 0.92;
}

.install-hint-actions {
  margin-top: 18px;
}

.install-hint-btn {
  width: 100%;
  height: 44px;
  border: none;
  border-radius: 12px;
  background: #fff;
  color: #111;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
}
.install-tip[hidden] {
  display: none !important;
}

.install-tip {
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 9999;
  background: rgba(17, 17, 17, 0.96);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 14px 14px 12px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(10px);
  animation: installTipSlideUp 0.28s ease;
}

.install-tip__close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 30px;
  height: 30px;
  border: none;
  border-radius: 10px;
  background: rgba(255,255,255,0.08);
  color: #fff;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}

.install-tip__title {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 6px;
  padding-right: 36px;
}

.install-tip__text {
  font-size: 13px;
  line-height: 1.45;
  color: rgba(255,255,255,0.86);
}

.install-tip__btn {
  margin-top: 12px;
  width: 100%;
  height: 40px;
  border: none;
  border-radius: 12px;
  background: #fff;
  color: #111;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

@keyframes installTipSlideUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (min-width: 768px) {
  .install-tip {
    left: auto;
    right: 16px;
    bottom: 16px;
    width: 340px;
  }
}
.auth-phone-hint {
  margin-bottom: 10px;
  font-size: 12px;
  line-height: 1.45;
  color: rgba(255,255,255,0.62);
}
.auth-phone-hint {
  margin-bottom: 10px;
  font-size: 12px;
  line-height: 1.45;
  color: rgba(255,255,255,0.62);
}
/* ===== DEMO THEME: NOIR LOUNGE / MINIMAL LUXURY ===== */

body[data-venue="lounge_demo"] {
  --bg: #0a0b0d;
  --bg-soft: #101114;
  --bg-card: #121418;
  --bg-card-2: #171a1f;
  --text: #f3f4f6;
  --text-soft: rgba(243, 244, 246, 0.82);
  --text-muted: rgba(243, 244, 246, 0.50);
  --line: rgba(255, 255, 255, 0.07);
  --line-strong: rgba(255, 255, 255, 0.12);
  --success: #d7dde5;
  --shadow-soft: 0 10px 30px rgba(0, 0, 0, 0.18);
  --shadow-card: 0 8px 24px rgba(0, 0, 0, 0.14);

  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.03), transparent 24%),
    linear-gradient(180deg, #090a0c, #07080a);
}

body[data-venue="lounge_demo"] .hero {
  background: linear-gradient(180deg, rgba(14,16,20,0.98), rgba(9,10,13,0.98));
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.18);
}

body[data-venue="lounge_demo"] .hero::before,
body[data-venue="lounge_demo"] .hero__logo-glow,
body[data-venue="lounge_demo"] .loader__glow,
body[data-venue="lounge_demo"] .guest-card__shine {
  display: none;
}

body[data-venue="lounge_demo"] .hero__badge {
  color: rgba(243, 244, 246, 0.88);
  letter-spacing: 0.16em;
}

body[data-venue="lounge_demo"] .hero__description,
body[data-venue="lounge_demo"] .section__text,
body[data-venue="lounge_demo"] .menu-card__desc,
body[data-venue="lounge_demo"] .offer-card__text,
body[data-venue="lounge_demo"] .offer-card__meta,
body[data-venue="lounge_demo"] .contact-row__label,
body[data-venue="lounge_demo"] .booking-note,
body[data-venue="lounge_demo"] .guest-subtitle {
  color: rgba(243, 244, 246, 0.60);
}

body[data-venue="lounge_demo"] .btn--primary {
  background: #eef1f4;
  color: #111317;
  border: 1px solid rgba(255,255,255,0.16);
  box-shadow: none;
}

body[data-venue="lounge_demo"] .btn--primary:hover {
  background: #ffffff;
}

body[data-venue="lounge_demo"] .btn--secondary {
  background: rgba(255, 255, 255, 0.01);
  color: #f3f4f6;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: none;
}

body[data-venue="lounge_demo"] .section-card,
body[data-venue="lounge_demo"] .booking-panel,
body[data-venue="lounge_demo"] .contact-row,
body[data-venue="lounge_demo"] .menu-card,
body[data-venue="lounge_demo"] .offer-card,
body[data-venue="lounge_demo"] .hero-stat {
  background: linear-gradient(180deg, #121418, #0f1114);
  border: 1px solid rgba(255, 255, 255, 0.07);
  box-shadow: none;
}

body[data-venue="lounge_demo"] .menu-card::before {
  display: none;
}

body[data-venue="lounge_demo"] .offer-card__badge,
body[data-venue="lounge_demo"] .guest-card__status {
  background: rgba(255, 255, 255, 0.04);
  color: #e8edf3;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

body[data-venue="lounge_demo"] .hero-stat__value,
body[data-venue="lounge_demo"] .section-card__title,
body[data-venue="lounge_demo"] .offer-card__title,
body[data-venue="lounge_demo"] .guest-title,
body[data-venue="lounge_demo"] .section__title,
body[data-venue="lounge_demo"] .contact-row__value,
body[data-venue="lounge_demo"] .guest-card__name,
body[data-venue="lounge_demo"] .guest-card__balance-value {
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] .hero-stat__label {
  color: rgba(243, 244, 246, 0.48);
}

body[data-venue="lounge_demo"] .guest-card {
  background: transparent;
  box-shadow: none;
}

body[data-venue="lounge_demo"] .guest-card__inner {
  background: linear-gradient(180deg, #121418, #0f1114);
  border: 1px solid rgba(255, 255, 255, 0.07);
  box-shadow: none;
}

body[data-venue="lounge_demo"] .slot-btn--active,
body[data-venue="lounge_demo"] .slot-btn.slot-btn--active,
body[data-venue="lounge_demo"] .slot-grid .slot-btn--active {
  background: #eef1f4 !important;
  color: #111317 !important;
  border-color: #eef1f4 !important;
  box-shadow: none !important;
}

body[data-venue="lounge_demo"] .slot-btn--active span,
body[data-venue="lounge_demo"] .slot-grid .slot-btn--active span {
  color: rgba(17, 19, 23, 0.58) !important;
}

body[data-venue="lounge_demo"] .bottom-nav {
  background: rgba(10, 11, 13, 0.96);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: none;
}

body[data-venue="lounge_demo"] .bottom-nav__item.active {
  background: rgba(255, 255, 255, 0.04);
}

body[data-venue="lounge_demo"] .section-card__icon,
body[data-venue="lounge_demo"] .bottom-nav__icon {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.07);
}

body[data-venue="lounge_demo"] .status-dot {
  background: #cfd8e3;
  box-shadow: none;
}

body[data-venue="lounge_demo"] .loader,
body[data-venue="lounge_demo"] .modal__content,
body[data-venue="lounge_demo"] .qr-modal-card,
body[data-venue="lounge_demo"] .success-modal__card {
  background: linear-gradient(180deg, #121418, #0f1114);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: none;
}
/* ===== MONO TEXT BRAND ===== */

body[data-venue="lounge_demo"] .brand-text-logo {
  display: block;
  color: #f3f4f6;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  line-height: 1;
}

body[data-venue="lounge_demo"] .hero__logo .brand-text-logo {
  font-size: 68px;
}

body[data-venue="lounge_demo"] .loader__logo-wrap .brand-text-logo {
  font-size: 34px;
}

body[data-venue="lounge_demo"] .guest-card__brands .brand-text-logo {
  font-size: 20px;
  letter-spacing: 0.18em;
}

body[data-venue="lounge_demo"] .guest-card__brands {
  align-items: center;
}

body[data-venue="lounge_demo"] .hero__logo-img[hidden],
body[data-venue="lounge_demo"] .loader__logo[hidden],
body[data-venue="lounge_demo"] .brand-main[hidden] {
  display: none !important;
}
/* ===== MONO HERO FINAL TUNE ===== */

body[data-venue="lounge_demo"] .hero {
  padding: 22px 22px 20px;
  border-radius: 30px;
  background:
    linear-gradient(180deg, rgba(11,13,16,0.98), rgba(7,8,10,0.98));
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: none;
}

body[data-venue="lounge_demo"] .hero__status {
  top: 18px;
  right: 18px;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.08);
  color: rgba(243,244,246,0.72);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

body[data-venue="lounge_demo"] .status-dot {
  width: 7px;
  height: 7px;
  background: rgba(243,244,246,0.78);
  animation: none;
  box-shadow: none;
}

body[data-venue="lounge_demo"] .hero__content {
  min-height: 0;
  padding: 72px 0 30px;
  justify-content: flex-start;
}

body[data-venue="lounge_demo"] .hero__logo {
  margin-bottom: 22px;
}

body[data-venue="lounge_demo"] .hero__logo-img {
  width: 190px;
  opacity: 0.96;
}

body[data-venue="lounge_demo"] .hero__badge {
  margin-bottom: 18px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.18em;
  color: rgba(243,244,246,0.92);
}

body[data-venue="lounge_demo"] .hero__description {
  max-width: 560px;
  margin: 0 auto;
  font-size: 18px;
  line-height: 1.6;
  font-weight: 600;
  color: rgba(243,244,246,0.66);
}

body[data-venue="lounge_demo"] .hero__actions {
  max-width: 440px;
  gap: 14px;
  margin-top: 30px;
}

body[data-venue="lounge_demo"] .hero__actions .btn {
  min-height: 60px;
  border-radius: 18px;
  font-size: 17px;
}

body[data-venue="lounge_demo"] .hero__stats {
  margin-top: 0;
  padding-top: 18px;
  gap: 12px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

body[data-venue="lounge_demo"] .hero-stat {
  min-height: 88px;
  padding: 18px 18px 16px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.015));
  border: 1px solid rgba(255,255,255,0.06);
}

body[data-venue="lounge_demo"] .hero-stat__value {
  font-size: 24px;
  line-height: 1.05;
  font-weight: 800;
  color: #f3f4f6;
  letter-spacing: -0.03em;
}

body[data-venue="lounge_demo"] .hero-stat__label {
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.4;
  color: rgba(243,244,246,0.50);
}

@media (min-width: 700px) {
  body[data-venue="lounge_demo"] .hero {
    padding: 24px 28px 24px;
  }

  body[data-venue="lounge_demo"] .hero__content {
    padding: 86px 0 34px;
  }

  body[data-venue="lounge_demo"] .hero__logo-img {
    width: 220px;
  }

  body[data-venue="lounge_demo"] .hero__description {
    max-width: 640px;
    font-size: 19px;
  }

  body[data-venue="lounge_demo"] .hero__stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .hero {
    padding: 18px 14px 16px;
    border-radius: 26px;
  }

  body[data-venue="lounge_demo"] .hero__status {
    top: 12px;
    right: 12px;
    min-height: 34px;
    padding: 0 12px;
    font-size: 11px;
  }

  body[data-venue="lounge_demo"] .hero__content {
    padding: 54px 0 20px;
  }

  body[data-venue="lounge_demo"] .hero__logo {
    margin-bottom: 18px;
  }

  body[data-venue="lounge_demo"] .hero__logo-img {
    width: 148px;
  }

  body[data-venue="lounge_demo"] .hero__badge {
    margin-bottom: 12px;
    font-size: 11px;
    letter-spacing: 0.14em;
  }

  body[data-venue="lounge_demo"] .hero__description {
    max-width: 19ch;
    font-size: 15px;
    line-height: 1.55;
  }

  body[data-venue="lounge_demo"] .hero__actions {
    grid-template-columns: 1fr;
    max-width: 100%;
    gap: 10px;
    margin-top: 24px;
  }

  body[data-venue="lounge_demo"] .hero__actions .btn {
    min-height: 54px;
    font-size: 15px;
    border-radius: 16px;
  }

  body[data-venue="lounge_demo"] .hero__stats {
    padding-top: 14px;
    gap: 8px;
  }

  body[data-venue="lounge_demo"] .hero-stat {
    min-height: 0;
    padding: 14px;
    border-radius: 18px;
  }

  body[data-venue="lounge_demo"] .hero-stat__value {
    font-size: 16px;
  }

  body[data-venue="lounge_demo"] .hero-stat__label {
    margin-top: 4px;
    font-size: 12px;
  }
}
/* ===== WOW PASS 01 / MONO MAIN PAGE ===== */

body[data-venue="lounge_demo"] {
  background:
    radial-gradient(circle at 50% -10%, rgba(255,255,255,0.06), transparent 26%),
    radial-gradient(circle at 100% 0%, rgba(255,255,255,0.025), transparent 22%),
    linear-gradient(180deg, #06070a 0%, #090b10 40%, #06070a 100%);
}

body[data-venue="lounge_demo"] .app {
  width: min(100%, 1180px);
  padding: 18px 16px calc(var(--nav-height) + env(safe-area-inset-bottom) + 24px);
}

/* HERO */

body[data-venue="lounge_demo"] .hero {
  padding: 24px 24px 22px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,0.04), transparent 34%),
    linear-gradient(180deg, rgba(12,14,18,0.98), rgba(8,9,12,0.98));
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow:
    0 28px 80px rgba(0,0,0,0.32),
    inset 0 1px 0 rgba(255,255,255,0.04);
}

body[data-venue="lounge_demo"] .hero__status {
  top: 18px;
  right: 18px;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.08);
  color: rgba(243,244,246,0.72);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

body[data-venue="lounge_demo"] .status-dot {
  width: 7px;
  height: 7px;
  background: rgba(243,244,246,0.78);
  animation: none;
  box-shadow: none;
}

body[data-venue="lounge_demo"] .hero__content {
  min-height: 0;
  padding: 82px 0 34px;
  justify-content: flex-start;
}

body[data-venue="lounge_demo"] .hero__logo {
  margin-bottom: 22px;
}

body[data-venue="lounge_demo"] .hero__logo-img {
  width: 228px;
  opacity: 0.98;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,0.24));
}

body[data-venue="lounge_demo"] .hero__badge {
  margin-bottom: 18px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.18em;
  color: rgba(243,244,246,0.94);
}

body[data-venue="lounge_demo"] .hero__description {
  max-width: 760px;
  margin: 0 auto;
  font-size: 20px;
  line-height: 1.65;
  font-weight: 600;
  color: rgba(243,244,246,0.64);
  text-wrap: balance;
}

body[data-venue="lounge_demo"] .hero__actions {
  max-width: 470px;
  gap: 14px;
  margin-top: 32px;
}

body[data-venue="lounge_demo"] .hero__actions .btn {
  min-height: 60px;
  border-radius: 18px;
  font-size: 17px;
}

body[data-venue="lounge_demo"] .hero__stats {
  margin-top: 0;
  padding-top: 18px;
  gap: 12px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

body[data-venue="lounge_demo"] .hero-stat {
  min-height: 92px;
  padding: 18px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.012));
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 12px 30px rgba(0,0,0,0.18);
}

body[data-venue="lounge_demo"] .hero-stat__value {
  font-size: 24px;
  line-height: 1.05;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] .hero-stat__label {
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.4;
  color: rgba(243,244,246,0.48);
}

/* BUTTONS */

body[data-venue="lounge_demo"] .btn--primary {
  background: linear-gradient(180deg, #f4f6f8, #e9edf1);
  color: #0b0d11;
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow:
    0 14px 34px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.50);
}

body[data-venue="lounge_demo"] .btn--secondary {
  background: rgba(255,255,255,0.02);
  color: #f3f4f6;
  border: 1px solid rgba(255,255,255,0.08);
}

@media (hover: hover) {
  body[data-venue="lounge_demo"] .btn--primary:hover {
    transform: translateY(-2px);
    background: linear-gradient(180deg, #ffffff, #eef2f5);
    box-shadow:
      0 18px 38px rgba(255,255,255,0.10),
      inset 0 1px 0 rgba(255,255,255,0.55);
  }

  body[data-venue="lounge_demo"] .btn--secondary:hover {
    transform: translateY(-2px);
    background: rgba(255,255,255,0.04);
    border-color: rgba(255,255,255,0.12);
  }
}

/* SECTIONS */

body[data-venue="lounge_demo"] .section {
  margin-top: 42px;
}

body[data-venue="lounge_demo"] .section__head {
  margin-bottom: 18px;
}

body[data-venue="lounge_demo"] .section__title {
  font-size: 46px;
  line-height: 0.96;
  letter-spacing: -0.05em;
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] .section__text {
  margin-top: 10px;
  max-width: 640px;
  font-size: 15px;
  line-height: 1.7;
  color: rgba(243,244,246,0.58);
}

/* SECTION CARDS */

body[data-venue="lounge_demo"] .cards-grid {
  gap: 18px;
  margin-top: 18px;
}

body[data-venue="lounge_demo"] .section-card {
  position: relative;
  min-height: 176px;
  padding: 22px;
  border-radius: 26px;
  overflow: hidden;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.05), transparent 32%),
    linear-gradient(180deg, #11141a, #0c0f14);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 16px 36px rgba(0,0,0,0.18);
}

body[data-venue="lounge_demo"] .section-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.025), transparent 36%);
  opacity: 0.9;
}

body[data-venue="lounge_demo"] .section-card__icon {
  width: 46px;
  height: 46px;
  margin-bottom: 18px;
  border-radius: 15px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
}

body[data-venue="lounge_demo"] .section-card__title {
  font-size: 20px;
  line-height: 1.1;
  letter-spacing: -0.03em;
  margin-bottom: 8px;
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] .section-card__desc {
  max-width: 30ch;
  font-size: 15px;
  line-height: 1.6;
  color: rgba(243,244,246,0.60);
}

@media (hover: hover) {
  body[data-venue="lounge_demo"] .section-card:hover {
    transform: translateY(-4px);
    border-color: rgba(255,255,255,0.11);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.04),
      0 22px 48px rgba(0,0,0,0.24);
  }
}

/* MENU CARDS */

body[data-venue="lounge_demo"] .menu-cards {
  gap: 18px;
  margin-top: 18px;
}

body[data-venue="lounge_demo"] .menu-card {
  min-height: 210px;
  padding: 22px;
  border-radius: 26px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.05), transparent 34%),
    linear-gradient(180deg, #11141a, #0c0f14);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 16px 36px rgba(0,0,0,0.18);
}

body[data-venue="lounge_demo"] .menu-card__title {
  font-size: 22px;
  line-height: 1.04;
  letter-spacing: -0.03em;
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] .menu-card__desc {
  margin-top: 8px;
  font-size: 15px;
  line-height: 1.65;
  color: rgba(243,244,246,0.58);
}

body[data-venue="lounge_demo"] .menu-card__btn,
body[data-venue="lounge_demo"] .menu-card .btn {
  min-height: 54px;
  border-radius: 16px;
}

/* OFFERS */

body[data-venue="lounge_demo"] .offer-card {
  border-radius: 30px;
  padding: 22px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.05), transparent 32%),
    linear-gradient(180deg, #11141a, #0c0f14);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 18px 40px rgba(0,0,0,0.18);
}

/* CONTACTS */

body[data-venue="lounge_demo"] .contacts-panel {
  gap: 14px;
}

body[data-venue="lounge_demo"] .contact-row {
  padding: 18px 18px 16px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.012));
  border: 1px solid rgba(255,255,255,0.07);
}

body[data-venue="lounge_demo"] .contact-row__label {
  margin-bottom: 8px;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: rgba(243,244,246,0.45);
}

body[data-venue="lounge_demo"] .contact-row__value {
  font-size: 16px;
  line-height: 1.5;
  color: #f3f4f6;
}

/* BOTTOM NAV */

body[data-venue="lounge_demo"] .bottom-nav {
  background: rgba(8,10,13,0.90);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 16px 40px rgba(0,0,0,0.24),
    inset 0 1px 0 rgba(255,255,255,0.03);
}

body[data-venue="lounge_demo"] .bottom-nav__item.active {
  background: rgba(255,255,255,0.05);
  color: #fff;
}

/* DESKTOP GRID */

@media (min-width: 820px) {
  body[data-venue="lounge_demo"] .cards-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* MOBILE */

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .app {
    padding: 14px 12px calc(var(--nav-height) + env(safe-area-inset-bottom) + 18px);
  }

  body[data-venue="lounge_demo"] .hero {
    padding: 18px 14px 16px;
    border-radius: 26px;
  }

  body[data-venue="lounge_demo"] .hero__status {
    top: 12px;
    right: 12px;
    min-height: 34px;
    padding: 0 12px;
    font-size: 11px;
  }

  body[data-venue="lounge_demo"] .hero__content {
    padding: 56px 0 22px;
  }

  body[data-venue="lounge_demo"] .hero__logo {
    margin-bottom: 18px;
  }

  body[data-venue="lounge_demo"] .hero__logo-img {
    width: 168px;
  }

  body[data-venue="lounge_demo"] .hero__badge {
    margin-bottom: 12px;
    font-size: 11px;
    letter-spacing: 0.14em;
  }

  body[data-venue="lounge_demo"] .hero__description {
    max-width: 20ch;
    font-size: 15px;
    line-height: 1.55;
  }

  body[data-venue="lounge_demo"] .hero__actions {
    grid-template-columns: 1fr;
    max-width: 100%;
    gap: 10px;
    margin-top: 24px;
  }

  body[data-venue="lounge_demo"] .hero__actions .btn {
    min-height: 54px;
    font-size: 15px;
    border-radius: 16px;
  }

  body[data-venue="lounge_demo"] .hero__stats {
    padding-top: 14px;
    gap: 8px;
  }

  body[data-venue="lounge_demo"] .hero-stat {
    min-height: 0;
    padding: 14px;
    border-radius: 18px;
  }

  body[data-venue="lounge_demo"] .hero-stat__value {
    font-size: 16px;
  }

  body[data-venue="lounge_demo"] .hero-stat__label {
    margin-top: 4px;
    font-size: 12px;
  }

  body[data-venue="lounge_demo"] .section {
    margin-top: 34px;
  }

  body[data-venue="lounge_demo"] .section__title {
    font-size: 34px;
  }

  body[data-venue="lounge_demo"] .section__text {
    font-size: 14px;
    line-height: 1.6;
  }

  body[data-venue="lounge_demo"] .cards-grid,
  body[data-venue="lounge_demo"] .menu-cards {
    gap: 14px;
  }

  body[data-venue="lounge_demo"] .section-card,
  body[data-venue="lounge_demo"] .menu-card {
    min-height: 0;
    padding: 18px;
    border-radius: 22px;
  }

  body[data-venue="lounge_demo"] .section-card__title,
  body[data-venue="lounge_demo"] .menu-card__title {
    font-size: 18px;
  }

  body[data-venue="lounge_demo"] .section-card__desc,
  body[data-venue="lounge_demo"] .menu-card__desc {
    font-size: 14px;
  }

  body[data-venue="lounge_demo"] .offer-card {
    border-radius: 24px;
    padding: 18px;
  }

  body[data-venue="lounge_demo"] .contact-row {
    border-radius: 18px;
    padding: 16px 16px 14px;
  }
}
/* ===== WOW PASS 02 / ATMOSPHERE + DEPTH ===== */

body[data-venue="lounge_demo"] .app {
  position: relative;
}

body[data-venue="lounge_demo"] .app::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,0.035), transparent 20%),
    radial-gradient(circle at 10% 20%, rgba(255,255,255,0.018), transparent 18%),
    radial-gradient(circle at 90% 24%, rgba(255,255,255,0.02), transparent 18%);
  opacity: 0.9;
  z-index: 0;
}

body[data-venue="lounge_demo"] .hero,
body[data-venue="lounge_demo"] .section,
body[data-venue="lounge_demo"] .bottom-nav {
  position: relative;
  z-index: 1;
}

/* HERO */

body[data-venue="lounge_demo"] .hero {
  overflow: hidden;
}

body[data-venue="lounge_demo"] .hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 8%, rgba(255,255,255,0.055), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,0.018), transparent 26%);
  opacity: 0.9;
}

body[data-venue="lounge_demo"] .hero__logo-img {
  width: 238px;
  filter:
    drop-shadow(0 10px 28px rgba(0,0,0,0.34))
    drop-shadow(0 0 18px rgba(255,255,255,0.045));
}

body[data-venue="lounge_demo"] .hero__badge {
  position: relative;
  padding: 0 16px;
}

body[data-venue="lounge_demo"] .hero__badge::before,
body[data-venue="lounge_demo"] .hero__badge::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 22px;
  height: 1px;
  background: rgba(255,255,255,0.18);
}

body[data-venue="lounge_demo"] .hero__badge::before {
  left: -10px;
}

body[data-venue="lounge_demo"] .hero__badge::after {
  right: -10px;
}

body[data-venue="lounge_demo"] .hero__description {
  max-width: 720px;
  font-size: 19px;
  line-height: 1.72;
  color: rgba(243,244,246,0.68);
}

body[data-venue="lounge_demo"] .hero__actions {
  margin-top: 34px;
}

body[data-venue="lounge_demo"] .hero__stats {
  padding-top: 20px;
}

body[data-venue="lounge_demo"] .hero-stat {
  position: relative;
  overflow: hidden;
}

body[data-venue="lounge_demo"] .hero-stat::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,0.028), transparent 42%);
}

body[data-venue="lounge_demo"] .hero-stat__value {
  font-size: 25px;
}

body[data-venue="lounge_demo"] .hero-stat__label {
  color: rgba(243,244,246,0.52);
}

/* SECTION HEADINGS */

body[data-venue="lounge_demo"] .section__head {
  position: relative;
}

body[data-venue="lounge_demo"] .section__title {
  display: inline-block;
  position: relative;
}

body[data-venue="lounge_demo"] .section__title::after {
  content: "";
  display: block;
  width: 52px;
  height: 2px;
  margin-top: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255,255,255,0.85), rgba(255,255,255,0.14));
}

body[data-venue="lounge_demo"] .section__text {
  margin-top: 12px;
}

/* CARDS */

body[data-venue="lounge_demo"] .section-card,
body[data-venue="lounge_demo"] .menu-card,
body[data-venue="lounge_demo"] .contact-row,
body[data-venue="lounge_demo"] .offer-card {
  position: relative;
  overflow: hidden;
}

body[data-venue="lounge_demo"] .section-card::after,
body[data-venue="lounge_demo"] .menu-card::after,
body[data-venue="lounge_demo"] .contact-row::after,
body[data-venue="lounge_demo"] .offer-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.028), transparent 32%);
  opacity: 0.85;
}

body[data-venue="lounge_demo"] .section-card__title,
body[data-venue="lounge_demo"] .menu-card__title {
  margin-bottom: 10px;
}

body[data-venue="lounge_demo"] .section-card__desc,
body[data-venue="lounge_demo"] .menu-card__desc {
  color: rgba(243,244,246,0.62);
}

body[data-venue="lounge_demo"] .section-card__icon {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    0 10px 24px rgba(0,0,0,0.18);
}

@media (hover: hover) {
  body[data-venue="lounge_demo"] .section-card:hover,
  body[data-venue="lounge_demo"] .menu-card:hover {
    transform: translateY(-5px);
    border-color: rgba(255,255,255,0.12);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.05),
      0 24px 50px rgba(0,0,0,0.26);
  }

  body[data-venue="lounge_demo"] .section-card:hover .section-card__icon,
  body[data-venue="lounge_demo"] .menu-card:hover .section-card__icon {
    border-color: rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.04);
  }
}

/* MENU BUTTONS */

body[data-venue="lounge_demo"] .menu-card__btn,
body[data-venue="lounge_demo"] .menu-card .btn {
  box-shadow:
    0 12px 28px rgba(255,255,255,0.07),
    inset 0 1px 0 rgba(255,255,255,0.46);
}

@media (hover: hover) {
  body[data-venue="lounge_demo"] .menu-card__btn:hover,
  body[data-venue="lounge_demo"] .menu-card .btn:hover {
    transform: translateY(-2px);
    box-shadow:
      0 16px 34px rgba(255,255,255,0.10),
      inset 0 1px 0 rgba(255,255,255,0.52);
  }
}

/* CONTACTS */

body[data-venue="lounge_demo"] .contact-row__value a {
  transition: opacity 0.2s ease;
}

body[data-venue="lounge_demo"] .contact-row__value a:hover {
  opacity: 0.84;
}

/* MOBILE */

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .hero__logo-img {
    width: 176px;
  }

  body[data-venue="lounge_demo"] .hero__badge {
    padding: 0 12px;
  }

  body[data-venue="lounge_demo"] .hero__badge::before,
  body[data-venue="lounge_demo"] .hero__badge::after {
    width: 14px;
  }

  body[data-venue="lounge_demo"] .hero__badge::before {
    left: -4px;
  }

  body[data-venue="lounge_demo"] .hero__badge::after {
    right: -4px;
  }

  body[data-venue="lounge_demo"] .hero__description {
    font-size: 15px;
    line-height: 1.62;
    max-width: 21ch;
  }

  body[data-venue="lounge_demo"] .section__title::after {
    width: 38px;
    margin-top: 10px;
  }
}
/* ===== WOW PASS 03 / DESKTOP COMPOSITION ===== */

@media (min-width: 1280px) {
  body[data-venue="lounge_demo"] .app {
    width: min(100%, 1380px);
    padding-left: 24px;
    padding-right: 24px;
  }

  body[data-venue="lounge_demo"] .hero {
    padding: 28px 30px 24px;
    border-radius: 36px;
  }

  body[data-venue="lounge_demo"] .hero__content {
    padding: 88px 0 38px;
  }

  body[data-venue="lounge_demo"] .hero__logo-img {
    width: 248px;
  }

  body[data-venue="lounge_demo"] .hero__description {
    max-width: 860px;
    font-size: 21px;
    line-height: 1.7;
  }

  body[data-venue="lounge_demo"] .hero__actions {
    max-width: 500px;
  }

  body[data-venue="lounge_demo"] .hero__stats {
    gap: 14px;
    padding-top: 20px;
  }

  body[data-venue="lounge_demo"] .hero-stat {
    min-height: 96px;
    border-radius: 24px;
  }

  body[data-venue="lounge_demo"] .section {
    margin-top: 46px;
  }

  body[data-venue="lounge_demo"] .section__title {
    font-size: 50px;
  }

  body[data-venue="lounge_demo"] .section__text {
    max-width: 720px;
  }

  body[data-venue="lounge_demo"] .cards-grid,
  body[data-venue="lounge_demo"] .menu-cards {
    gap: 20px;
  }

  body[data-venue="lounge_demo"] .section-card,
  body[data-venue="lounge_demo"] .menu-card {
    min-height: 190px;
    padding: 24px;
    border-radius: 28px;
  }

  body[data-venue="lounge_demo"] .offer-card {
    border-radius: 32px;
  }
}

@media (min-width: 1600px) {
  body[data-venue="lounge_demo"] .app {
    width: min(100%, 1480px);
  }

  body[data-venue="lounge_demo"] .hero__logo-img {
    width: 262px;
  }

  body[data-venue="lounge_demo"] .hero__description {
    max-width: 920px;
  }
}
/* ===== WOW PASS 04 / LOWER BLOCK POLISH ===== */

body[data-venue="lounge_demo"] .section-card,
body[data-venue="lounge_demo"] .menu-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

body[data-venue="lounge_demo"] .section-card__icon {
  margin-bottom: 20px;
}

body[data-venue="lounge_demo"] .section-card__title,
body[data-venue="lounge_demo"] .menu-card__title {
  font-size: 24px;
  line-height: 1.04;
  letter-spacing: -0.035em;
  margin: 0 0 10px;
}

body[data-venue="lounge_demo"] .section-card__desc,
body[data-venue="lounge_demo"] .menu-card__desc {
  max-width: 32ch;
  font-size: 15px;
  line-height: 1.65;
  color: rgba(243,244,246,0.64);
}

body[data-venue="lounge_demo"] .menu-card__top {
  gap: 12px;
}

body[data-venue="lounge_demo"] .menu-card__actions {
  margin-top: 20px;
}

body[data-venue="lounge_demo"] .menu-card__btn,
body[data-venue="lounge_demo"] .menu-card .btn {
  min-height: 56px;
  font-size: 15px;
  font-weight: 800;
  border-radius: 17px;
}

body[data-venue="lounge_demo"] .section__text,
body[data-venue="lounge_demo"] #menuSectionText,
body[data-venue="lounge_demo"] #sectionsDescription {
  color: rgba(243,244,246,0.54);
}

body[data-venue="lounge_demo"] .cards-grid {
  margin-top: 22px;
}

body[data-venue="lounge_demo"] .menu-cards {
  margin-top: 22px;
}

@media (min-width: 1280px) {
  body[data-venue="lounge_demo"] .section-card,
  body[data-venue="lounge_demo"] .menu-card {
    min-height: 206px;
  }

  body[data-venue="lounge_demo"] .section-card__title,
  body[data-venue="lounge_demo"] .menu-card__title {
    font-size: 26px;
  }
}

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .section-card__title,
  body[data-venue="lounge_demo"] .menu-card__title {
    font-size: 20px;
    margin-bottom: 8px;
  }

  body[data-venue="lounge_demo"] .section-card__desc,
  body[data-venue="lounge_demo"] .menu-card__desc {
    font-size: 14px;
    line-height: 1.58;
  }

  body[data-venue="lounge_demo"] .menu-card__actions {
    margin-top: 16px;
  }
}
/* ===== WOW PASS 05 / BLOCKS + TEXT + BUTTONS ===== */

body[data-venue="lounge_demo"] .section__head {
  margin-bottom: 20px;
}

body[data-venue="lounge_demo"] .section__text,
body[data-venue="lounge_demo"] #sectionsDescription,
body[data-venue="lounge_demo"] #menuSectionText,
body[data-venue="lounge_demo"] #offersDescription,
body[data-venue="lounge_demo"] #contactsSectionText,
body[data-venue="lounge_demo"] #bookingSectionText {
  max-width: 640px;
  font-size: 15px;
  line-height: 1.72;
  font-weight: 600;
  color: rgba(243,244,246,0.54);
}

body[data-venue="lounge_demo"] .section-card,
body[data-venue="lounge_demo"] .menu-card,
body[data-venue="lounge_demo"] .contact-row,
body[data-venue="lounge_demo"] .booking-panel,
body[data-venue="lounge_demo"] .offer-card {
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.04), transparent 34%),
    linear-gradient(180deg, #101319 0%, #0b0e13 100%);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 18px 36px rgba(0,0,0,0.16);
}

body[data-venue="lounge_demo"] .section-card,
body[data-venue="lounge_demo"] .menu-card {
  min-height: 220px;
  padding: 24px;
  border-radius: 28px;
}

body[data-venue="lounge_demo"] .section-card__icon {
  width: 44px;
  height: 44px;
  margin-bottom: 20px;
  border-radius: 14px;
  background: rgba(255,255,255,0.022);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 10px 22px rgba(0,0,0,0.16);
}

body[data-venue="lounge_demo"] .section-card__title,
body[data-venue="lounge_demo"] .menu-card__title {
  margin: 0 0 10px;
  font-size: 24px;
  line-height: 1.05;
  letter-spacing: -0.035em;
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] .section-card__desc,
body[data-venue="lounge_demo"] .menu-card__desc {
  max-width: 32ch;
  margin: 0;
  font-size: 15px;
  line-height: 1.68;
  font-weight: 600;
  color: rgba(243,244,246,0.62);
}

body[data-venue="lounge_demo"] .menu-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

body[data-venue="lounge_demo"] .menu-card__top {
  gap: 12px;
}

body[data-venue="lounge_demo"] .menu-card__actions {
  margin-top: auto;
  padding-top: 22px;
}

body[data-venue="lounge_demo"] .btn {
  letter-spacing: -0.01em;
}

body[data-venue="lounge_demo"] .btn--primary {
  background: linear-gradient(180deg, #f7f8fa, #e8edf1);
  color: #0b0d11;
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow:
    0 14px 30px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.52);
}

body[data-venue="lounge_demo"] .btn--secondary {
  background: rgba(255,255,255,0.018);
  color: rgba(243,244,246,0.94);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.025),
    0 10px 22px rgba(0,0,0,0.14);
}

body[data-venue="lounge_demo"] .menu-card__btn,
body[data-venue="lounge_demo"] .menu-card .btn,
body[data-venue="lounge_demo"] .contact-actions .btn,
body[data-venue="lounge_demo"] .booking-panel .btn--full {
  min-height: 56px;
  border-radius: 17px;
  font-size: 15px;
  font-weight: 800;
}

body[data-venue="lounge_demo"] .label {
  font-size: 12px;
  letter-spacing: 0.03em;
  color: rgba(243,244,246,0.58);
}

body[data-venue="lounge_demo"] .control {
  min-height: 54px;
  border-radius: 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] .control:focus {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.14);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.04);
}

body[data-venue="lounge_demo"] .contact-row {
  padding: 20px 20px 18px;
  border-radius: 24px;
}

body[data-venue="lounge_demo"] .contact-row__label {
  margin-bottom: 8px;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: rgba(243,244,246,0.44);
}

body[data-venue="lounge_demo"] .contact-row__value {
  font-size: 16px;
  line-height: 1.55;
  color: #f3f4f6;
}

@media (hover: hover) {
  body[data-venue="lounge_demo"] .section-card:hover,
  body[data-venue="lounge_demo"] .menu-card:hover,
  body[data-venue="lounge_demo"] .contact-row:hover {
    transform: translateY(-4px);
    border-color: rgba(255,255,255,0.10);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.04),
      0 24px 46px rgba(0,0,0,0.22);
  }

  body[data-venue="lounge_demo"] .btn--primary:hover {
    background: linear-gradient(180deg, #ffffff, #eef2f5);
    box-shadow:
      0 18px 34px rgba(255,255,255,0.10),
      inset 0 1px 0 rgba(255,255,255,0.56);
  }

  body[data-venue="lounge_demo"] .btn--secondary:hover {
    background: rgba(255,255,255,0.035);
    border-color: rgba(255,255,255,0.11);
  }
}

@media (min-width: 1280px) {
  body[data-venue="lounge_demo"] .section-card__title,
  body[data-venue="lounge_demo"] .menu-card__title {
    font-size: 26px;
  }

  body[data-venue="lounge_demo"] .section-card,
  body[data-venue="lounge_demo"] .menu-card {
    min-height: 230px;
  }
}

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .section__text,
  body[data-venue="lounge_demo"] #sectionsDescription,
  body[data-venue="lounge_demo"] #menuSectionText,
  body[data-venue="lounge_demo"] #offersDescription,
  body[data-venue="lounge_demo"] #contactsSectionText,
  body[data-venue="lounge_demo"] #bookingSectionText {
    font-size: 14px;
    line-height: 1.62;
  }

  body[data-venue="lounge_demo"] .section-card,
  body[data-venue="lounge_demo"] .menu-card {
    min-height: 0;
    padding: 18px;
    border-radius: 22px;
  }

  body[data-venue="lounge_demo"] .section-card__title,
  body[data-venue="lounge_demo"] .menu-card__title {
    font-size: 20px;
    margin-bottom: 8px;
  }

  body[data-venue="lounge_demo"] .section-card__desc,
  body[data-venue="lounge_demo"] .menu-card__desc {
    font-size: 14px;
    line-height: 1.58;
  }

  body[data-venue="lounge_demo"] .menu-card__actions {
    padding-top: 16px;
  }

  body[data-venue="lounge_demo"] .menu-card__btn,
  body[data-venue="lounge_demo"] .menu-card .btn,
  body[data-venue="lounge_demo"] .contact-actions .btn,
  body[data-venue="lounge_demo"] .booking-panel .btn--full {
    min-height: 54px;
    font-size: 15px;
    border-radius: 16px;
  }

  body[data-venue="lounge_demo"] .contact-row {
    padding: 16px 16px 14px;
    border-radius: 18px;
  }
}
/* ===== WOW PASS 06 / BOOKING BLOCK ===== */

body[data-venue="lounge_demo"] #booking .section__head {
  margin-bottom: 22px;
}

body[data-venue="lounge_demo"] .booking-panel {
  padding: 26px;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.04), transparent 34%),
    linear-gradient(180deg, #101319 0%, #0b0e13 100%);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 20px 40px rgba(0,0,0,0.18);
}

body[data-venue="lounge_demo"] #bookingForm {
  display: grid;
  gap: 2px;
}

body[data-venue="lounge_demo"] .field {
  margin-bottom: 16px;
}

body[data-venue="lounge_demo"] .field:last-of-type {
  margin-bottom: 10px;
}

body[data-venue="lounge_demo"] .label {
  margin-bottom: 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: rgba(243,244,246,0.56);
}

body[data-venue="lounge_demo"] .control {
  min-height: 56px;
  padding: 0 16px;
  border-radius: 17px;
  background: rgba(255,255,255,0.028);
  border: 1px solid rgba(255,255,255,0.08);
  color: #f3f4f6;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}

body[data-venue="lounge_demo"] textarea.control {
  min-height: 132px;
  padding: 14px 16px;
  line-height: 1.6;
}

body[data-venue="lounge_demo"] .control::placeholder {
  color: rgba(243,244,246,0.30);
}

body[data-venue="lounge_demo"] .control:focus {
  background: rgba(255,255,255,0.045);
  border-color: rgba(255,255,255,0.14);
  box-shadow:
    0 0 0 3px rgba(255,255,255,0.04),
    inset 0 1px 0 rgba(255,255,255,0.03);
}

body[data-venue="lounge_demo"] .field--2 {
  gap: 14px;
}

body[data-venue="lounge_demo"] #booking .booking-note {
  font-size: 12px;
  line-height: 1.6;
  color: rgba(243,244,246,0.46);
}

body[data-venue="lounge_demo"] #booking div[style*="font-size:12px;color:#aaa"] {
  margin-bottom: 8px !important;
  color: rgba(243,244,246,0.48) !important;
  font-size: 12px !important;
  line-height: 1.55;
}

body[data-venue="lounge_demo"] #selectedTimeText {
  margin-top: 12px !important;
  font-size: 12px !important;
  line-height: 1.5;
  color: rgba(243,244,246,0.58) !important;
}

body[data-venue="lounge_demo"] .slot-grid {
  gap: 10px;
  margin-top: 8px;
}

body[data-venue="lounge_demo"] .slot-btn {
  min-height: 50px;
  border-radius: 15px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  color: #f3f4f6;
  font-size: 14px;
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}

body[data-venue="lounge_demo"] .slot-btn span {
  margin-top: 2px;
  font-size: 10px;
  color: rgba(243,244,246,0.40);
}

body[data-venue="lounge_demo"] .slot-btn--active,
body[data-venue="lounge_demo"] .slot-btn.slot-btn--active,
body[data-venue="lounge_demo"] .slot-grid .slot-btn--active {
  background: linear-gradient(180deg, #f4f6f8, #e9edf1) !important;
  color: #0b0d11 !important;
  border-color: rgba(255,255,255,0.20) !important;
  box-shadow:
    0 12px 26px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.55) !important;
}

body[data-venue="lounge_demo"] .slot-btn--active span,
body[data-venue="lounge_demo"] .slot-grid .slot-btn--active span {
  color: rgba(11,13,17,0.52) !important;
}

body[data-venue="lounge_demo"] .slot-btn--disabled,
body[data-venue="lounge_demo"] .slot-btn:disabled {
  opacity: 0.28 !important;
  background: rgba(255,255,255,0.02) !important;
  border-color: rgba(255,255,255,0.05) !important;
  box-shadow: none !important;
}

body[data-venue="lounge_demo"] .consent {
  margin: 12px 0 18px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
}

body[data-venue="lounge_demo"] .consent__label {
  gap: 12px;
  font-size: 12px;
  line-height: 1.65;
  color: rgba(243,244,246,0.54);
}

body[data-venue="lounge_demo"] .consent__checkbox {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  margin-top: 1px;
  accent-color: #f3f4f6;
}

body[data-venue="lounge_demo"] .consent__label a {
  color: rgba(243,244,246,0.88);
  text-decoration-color: rgba(243,244,246,0.34);
}

body[data-venue="lounge_demo"] .booking-panel .btn--full {
  min-height: 58px;
  border-radius: 18px;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.01em;
  background: linear-gradient(180deg, #f7f8fa, #e8edf1);
  color: #0b0d11;
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow:
    0 14px 30px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.52);
}

body[data-venue="lounge_demo"] .booking-panel .btn--full:disabled {
  opacity: 0.42;
  box-shadow: none;
}

@media (hover: hover) {
  body[data-venue="lounge_demo"] .slot-btn:not(:disabled):hover {
    transform: translateY(-2px);
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.11);
  }

  body[data-venue="lounge_demo"] .booking-panel .btn--full:hover {
    transform: translateY(-2px);
    background: linear-gradient(180deg, #ffffff, #eef2f5);
    box-shadow:
      0 18px 34px rgba(255,255,255,0.10),
      inset 0 1px 0 rgba(255,255,255,0.56);
  }
}

@media (min-width: 1280px) {
  body[data-venue="lounge_demo"] .booking-panel {
    padding: 28px;
  }

  body[data-venue="lounge_demo"] .slot-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .booking-panel {
    padding: 18px;
    border-radius: 24px;
  }

  body[data-venue="lounge_demo"] .field {
    margin-bottom: 14px;
  }

  body[data-venue="lounge_demo"] .field--2 {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  body[data-venue="lounge_demo"] .control {
    min-height: 54px;
    border-radius: 16px;
  }

  body[data-venue="lounge_demo"] textarea.control {
    min-height: 116px;
  }

  body[data-venue="lounge_demo"] .slot-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  body[data-venue="lounge_demo"] .slot-btn {
    min-height: 48px;
    border-radius: 14px;
    font-size: 13px;
  }

  body[data-venue="lounge_demo"] .consent {
    padding: 12px 14px;
    border-radius: 16px;
  }

  body[data-venue="lounge_demo"] .booking-panel .btn--full {
    min-height: 54px;
    border-radius: 16px;
  }
}
/* ===== WOW PASS 07 / GUEST CARD ===== */

body[data-venue="lounge_demo"] #guest-card {
  margin-top: 46px;
}

body[data-venue="lounge_demo"] .guest-title {
  margin: 0 0 10px;
  font-size: 50px;
  line-height: 0.96;
  letter-spacing: -0.05em;
  font-weight: 800;
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] .guest-title::after {
  content: "";
  display: block;
  width: 52px;
  height: 2px;
  margin-top: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255,255,255,0.85), rgba(255,255,255,0.14));
}

body[data-venue="lounge_demo"] .guest-subtitle {
  max-width: 640px;
  margin: 12px 0 22px;
  font-size: 15px;
  line-height: 1.72;
  font-weight: 600;
  color: rgba(243,244,246,0.54);
}

body[data-venue="lounge_demo"] #openAuthBtn {
  width: min(100%, 420px);
  min-height: 58px;
  border-radius: 18px;
  font-size: 15px;
  font-weight: 800;
  background: linear-gradient(180deg, #f7f8fa, #e8edf1);
  color: #0b0d11;
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow:
    0 14px 30px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.52);
}

body[data-venue="lounge_demo"] .guest-card {
  margin-top: 24px;
  padding: 2px;
  border-radius: 32px;
  background:
    linear-gradient(145deg, rgba(255,255,255,0.09), rgba(255,255,255,0.02));
  box-shadow:
    0 26px 70px rgba(0,0,0,0.28),
    inset 0 1px 0 rgba(255,255,255,0.04);
}

body[data-venue="lounge_demo"] .guest-card__inner {
  min-height: 440px;
  padding: 28px;
  border-radius: 30px;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto auto 1fr auto auto;
  gap: 14px;
  background:
    radial-gradient(circle at 84% 16%, rgba(255,255,255,0.08), transparent 30%),
    radial-gradient(circle at 12% 100%, rgba(255,255,255,0.04), transparent 34%),
    linear-gradient(180deg, #11141a 0%, #0b0e13 100%);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    inset 0 -1px 0 rgba(255,255,255,0.02);
}

body[data-venue="lounge_demo"] .guest-card__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(125deg, rgba(255,255,255,0.03), transparent 34%);
}

body[data-venue="lounge_demo"] .guest-card__shine {
  width: 220px;
  height: 220px;
  top: -70px;
  right: -30px;
  opacity: 0.65;
  filter: blur(42px);
  background: radial-gradient(circle, rgba(255,255,255,0.12), transparent 68%);
}

body[data-venue="lounge_demo"] .guest-card__top {
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 2px;
}

body[data-venue="lounge_demo"] .guest-card__brands {
  display: flex;
  align-items: center;
  gap: 14px;
}

body[data-venue="lounge_demo"] .brand-main {
  height: 24px;
  opacity: 0.96;
}

body[data-venue="lounge_demo"] .brand-partner {
  height: 20px;
  opacity: 0.92;
}

body[data-venue="lounge_demo"] .brand-divider {
  width: 1px;
  height: 18px;
  opacity: 0.65;
  background: linear-gradient(
    to bottom,
    transparent,
    rgba(255,255,255,0.45),
    transparent
  );
  box-shadow: none;
}

body[data-venue="lounge_demo"] .guest-card__status {
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: rgba(243,244,246,0.90);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

body[data-venue="lounge_demo"] .guest-card__name {
  margin-top: 2px;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: rgba(243,244,246,0.94);
}

body[data-venue="lounge_demo"] .guest-card__balance {
  margin: 6px 0 2px;
}

body[data-venue="lounge_demo"] .guest-card__balance-value {
  font-size: clamp(64px, 9vw, 88px);
  line-height: 0.92;
  font-weight: 900;
  letter-spacing: -0.06em;
  color: #ffffff;
  text-shadow: 0 4px 24px rgba(255,255,255,0.05);
}

body[data-venue="lounge_demo"] .guest-card__balance-unit {
  margin-top: 8px;
  font-size: 15px;
  font-weight: 600;
  color: rgba(243,244,246,0.62);
}

body[data-venue="lounge_demo"] .guest-card__footer {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  margin-top: 4px;
  padding-top: 4px;
  font-size: 13px;
}

body[data-venue="lounge_demo"] .guest-card__id {
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: rgba(243,244,246,0.80);
}

body[data-venue="lounge_demo"] .guest-card__rate {
  font-size: 14px;
  font-weight: 700;
  color: rgba(243,244,246,0.56);
  white-space: nowrap;
}

body[data-venue="lounge_demo"] .guest-card__btn {
  width: 100%;
  max-width: none;
  min-height: 56px;
  border-radius: 18px;
  margin-top: 0;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.01em;
}

body[data-venue="lounge_demo"] .guest-card__btn + .guest-card__btn {
  margin-top: 10px;
}

body[data-venue="lounge_demo"] .guest-card__btn--secondary {
  background: rgba(255,255,255,0.03);
  color: #f3f4f6;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.02),
    0 10px 22px rgba(0,0,0,0.14);
}

body[data-venue="lounge_demo"] .guest-card__btn--secondary:hover {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.10);
}

/* AUTH MODAL */

body[data-venue="lounge_demo"] #authModal .modal__content {
  width: min(92vw, 520px);
  max-width: 520px;
  padding: 30px 20px 20px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.06), transparent 42%),
    linear-gradient(180deg, #11141a 0%, #0b0e13 100%);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 26px 60px rgba(0,0,0,0.28);
}

body[data-venue="lounge_demo"] #authModal h3 {
  margin: 0 0 18px;
  font-size: 30px;
  line-height: 1.06;
  letter-spacing: -0.04em;
  font-weight: 800;
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] #phoneBlock {
  margin-top: 16px;
  gap: 12px;
}

body[data-venue="lounge_demo"] .auth-phone-hint {
  font-size: 12px;
  line-height: 1.55;
  color: rgba(243,244,246,0.52);
}

body[data-venue="lounge_demo"] #guestPhoneModal {
  min-height: 56px;
  border-radius: 17px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  color: #f3f4f6;
}

/* QR MODAL */

body[data-venue="lounge_demo"] .qr-modal-card {
  width: min(100%, 460px);
  padding: 28px 20px 20px;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.06), transparent 42%),
    linear-gradient(180deg, #11141a 0%, #0b0e13 100%);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 28px 64px rgba(0,0,0,0.30);
}

body[data-venue="lounge_demo"] .qr-modal__title {
  font-size: 28px;
  letter-spacing: -0.03em;
}

body[data-venue="lounge_demo"] .qr-modal__subtitle {
  color: rgba(243,244,246,0.60);
}

body[data-venue="lounge_demo"] .qr-box {
  background: linear-gradient(180deg, #ffffff, #f2f4f7);
  box-shadow:
    0 18px 40px rgba(0,0,0,0.30),
    inset 0 1px 0 rgba(255,255,255,0.75);
}

body[data-venue="lounge_demo"] .qr-card-number {
  color: rgba(243,244,246,0.92);
}

body[data-venue="lounge_demo"] #qrModal .referral-block {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
}

body[data-venue="lounge_demo"] #qrModal .referral-text {
  color: rgba(243,244,246,0.62);
}

@media (hover: hover) {
  body[data-venue="lounge_demo"] #openAuthBtn:hover {
    transform: translateY(-2px);
    background: linear-gradient(180deg, #ffffff, #eef2f5);
    box-shadow:
      0 18px 34px rgba(255,255,255,0.10),
      inset 0 1px 0 rgba(255,255,255,0.56);
  }

  body[data-venue="lounge_demo"] .guest-card__inner:hover {
    transform: translateY(-4px);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.03),
      0 28px 64px rgba(0,0,0,0.30);
  }
}

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] #guest-card {
    margin-top: 34px;
  }

  body[data-venue="lounge_demo"] .guest-title {
    font-size: 34px;
  }

  body[data-venue="lounge_demo"] .guest-title::after {
    width: 38px;
    margin-top: 10px;
  }

  body[data-venue="lounge_demo"] .guest-subtitle {
    font-size: 14px;
    line-height: 1.62;
    margin-bottom: 18px;
  }

  body[data-venue="lounge_demo"] #openAuthBtn {
    width: 100%;
    min-height: 54px;
    border-radius: 16px;
  }

  body[data-venue="lounge_demo"] .guest-card {
    margin-top: 18px;
    border-radius: 24px;
    padding: 1px;
  }

  body[data-venue="lounge_demo"] .guest-card__inner {
    min-height: auto;
    padding: 20px 16px 16px;
    border-radius: 23px;
    gap: 12px;
  }

  body[data-venue="lounge_demo"] .guest-card__top {
    gap: 12px;
  }

  body[data-venue="lounge_demo"] .guest-card__brands {
    gap: 10px;
    flex-wrap: wrap;
  }

  body[data-venue="lounge_demo"] .brand-main {
    height: 20px;
  }

  body[data-venue="lounge_demo"] .brand-partner {
    height: 18px;
  }

  body[data-venue="lounge_demo"] .guest-card__status {
    font-size: 11px;
    padding: 6px 10px;
  }

  body[data-venue="lounge_demo"] .guest-card__name {
    font-size: 16px;
  }

  body[data-venue="lounge_demo"] .guest-card__balance-value {
    font-size: 54px;
  }

  body[data-venue="lounge_demo"] .guest-card__balance-unit {
    font-size: 14px;
  }

  body[data-venue="lounge_demo"] .guest-card__footer {
    align-items: flex-start;
    gap: 10px;
  }

  body[data-venue="lounge_demo"] .guest-card__id {
    font-size: 18px;
  }

  body[data-venue="lounge_demo"] .guest-card__rate {
    font-size: 12px;
    text-align: right;
  }

  body[data-venue="lounge_demo"] .guest-card__btn {
    min-height: 52px;
    border-radius: 16px;
  }

  body[data-venue="lounge_demo"] #authModal .modal__content,
  body[data-venue="lounge_demo"] .qr-modal-card {
    width: calc(100% - 20px);
    padding: 24px 16px 18px;
    border-radius: 24px;
  }

  body[data-venue="lounge_demo"] #authModal h3,
  body[data-venue="lounge_demo"] .qr-modal__title {
    font-size: 24px;
  }
}
/* ===== FINAL GUEST CARD CLEANUP / MONO ONLY ===== */

body[data-venue="lounge_demo"] #guestPartnerLogo,
body[data-venue="lounge_demo"] #guestBrandDivider {
  display: none !important;
}

body[data-venue="lounge_demo"] .guest-card__brands {
  gap: 0;
  align-items: center;
}

body[data-venue="lounge_demo"] .brand-main {
  height: 26px;
  opacity: 0.98;
}

body[data-venue="lounge_demo"] .guest-card__top {
  align-items: center;
  margin-bottom: 6px;
}

body[data-venue="lounge_demo"] .guest-card__status {
  padding: 8px 13px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  color: rgba(243,244,246,0.86);
}

body[data-venue="lounge_demo"] .guest-card__name {
  margin-top: 6px;
}

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .brand-main {
    height: 22px;
  }

  body[data-venue="lounge_demo"] .guest-card__top {
    align-items: flex-start;
  }

  body[data-venue="lounge_demo"] .guest-card__status {
    padding: 6px 10px;
  }
}
/* ===== WOW PASS 08 / FINAL MICRO POLISH ===== */

body[data-venue="lounge_demo"] .loader {
  background:
    radial-gradient(circle at 50% 20%, rgba(255,255,255,0.04), transparent 24%),
    linear-gradient(180deg, #090b10 0%, #06070a 100%);
}

body[data-venue="lounge_demo"] .loader__logo-wrap {
  width: 220px;
  height: 90px;
}

body[data-venue="lounge_demo"] .loader__logo {
  width: 180px;
  opacity: 0.98;
}

body[data-venue="lounge_demo"] .loader__text {
  margin-top: 16px;
  font-size: 11px;
  letter-spacing: 0.22em;
  color: rgba(243,244,246,0.56);
}

body[data-venue="lounge_demo"] .toast {
  bottom: 116px;
  min-height: 48px;
  padding: 12px 16px;
  border-radius: 16px;
  background: rgba(13,15,19,0.94);
  color: #f3f4f6;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 18px 40px rgba(0,0,0,0.26),
    inset 0 1px 0 rgba(255,255,255,0.03);
}

body[data-venue="lounge_demo"] .modal__content,
body[data-venue="lounge_demo"] .success-modal__card,
body[data-venue="lounge_demo"] .qr-modal-card {
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.05), transparent 42%),
    linear-gradient(180deg, #11141a 0%, #0b0e13 100%);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 28px 64px rgba(0,0,0,0.30);
}

body[data-venue="lounge_demo"] .modal__title,
body[data-venue="lounge_demo"] .booking-success__title {
  letter-spacing: -0.03em;
}

body[data-venue="lounge_demo"] .modal__text,
body[data-venue="lounge_demo"] .booking-success__text {
  color: rgba(243,244,246,0.62);
}

body[data-venue="lounge_demo"] .modal__icon,
body[data-venue="lounge_demo"] .booking-success__icon {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  color: #f3f4f6;
}

body[data-venue="lounge_demo"] .bottom-nav {
  padding: 8px;
  border-radius: 24px;
  background: rgba(9,11,14,0.92);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 18px 40px rgba(0,0,0,0.22),
    inset 0 1px 0 rgba(255,255,255,0.03);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

body[data-venue="lounge_demo"] .bottom-nav__item {
  min-height: 58px;
  border-radius: 16px;
  color: rgba(243,244,246,0.46);
}

body[data-venue="lounge_demo"] .bottom-nav__item span:last-child {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

body[data-venue="lounge_demo"] .bottom-nav__item.active {
  background: rgba(255,255,255,0.05);
  color: #f3f4f6;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 10px 24px rgba(0,0,0,0.18);
}

body[data-venue="lounge_demo"] .bottom-nav__icon {
  opacity: 0.92;
}

body[data-venue="lounge_demo"] .install-tip {
  left: auto;
  right: 16px;
  bottom: 16px;
  width: 340px;
  border-radius: 22px;
  padding: 16px 16px 14px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.05), transparent 42%),
    rgba(12,14,18,0.96);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 22px 48px rgba(0,0,0,0.26),
    inset 0 1px 0 rgba(255,255,255,0.03);
}

body[data-venue="lounge_demo"] .install-tip__title {
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.02em;
}

body[data-venue="lounge_demo"] .install-tip__text {
  font-size: 13px;
  line-height: 1.55;
  color: rgba(243,244,246,0.66);
}

body[data-venue="lounge_demo"] .install-tip__btn,
body[data-venue="lounge_demo"] .install-tip__close {
  border: 1px solid rgba(255,255,255,0.08);
}

body[data-venue="lounge_demo"] .install-tip__btn {
  min-height: 42px;
  border-radius: 14px;
  background: linear-gradient(180deg, #f7f8fa, #e8edf1);
  color: #0b0d11;
  font-weight: 800;
  box-shadow:
    0 12px 26px rgba(255,255,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.52);
}

body[data-venue="lounge_demo"] .install-tip__close {
  background: rgba(255,255,255,0.03);
  color: #f3f4f6;
}

@media (hover: hover) {
  body[data-venue="lounge_demo"] .bottom-nav__item:hover {
    transform: translateY(-2px);
    color: rgba(243,244,246,0.74);
  }

  body[data-venue="lounge_demo"] .install-tip__btn:hover {
    transform: translateY(-2px);
    background: linear-gradient(180deg, #ffffff, #eef2f5);
  }
}

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .toast {
    left: 12px;
    right: 12px;
    bottom: 96px;
    transform: none;
  }

  body[data-venue="lounge_demo"] .bottom-nav {
    left: 10px;
    right: 10px;
    width: auto;
    border-radius: 20px;
  }

  body[data-venue="lounge_demo"] .bottom-nav__item {
    min-height: 54px;
    border-radius: 14px;
  }

  body[data-venue="lounge_demo"] .install-tip {
    left: 12px;
    right: 12px;
    width: auto;
    bottom: 12px;
    border-radius: 18px;
    padding: 14px 14px 12px;
  }

  body[data-venue="lounge_demo"] .install-tip__btn {
    min-height: 40px;
    border-radius: 12px;
  }
}
/* ===== MOBILE FINAL TUNE / MONO ===== */

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .app {
    padding: 12px 12px calc(var(--nav-height) + env(safe-area-inset-bottom) + 18px);
  }

  body[data-venue="lounge_demo"] .hero {
    padding: 16px 12px 14px;
    border-radius: 24px;
  }

  body[data-venue="lounge_demo"] .hero__status {
    top: 10px;
    right: 10px;
    min-height: 32px;
    padding: 0 11px;
    font-size: 11px;
  }

  body[data-venue="lounge_demo"] .hero__content {
    padding: 58px 6px 18px;
  }

  body[data-venue="lounge_demo"] .hero__logo {
    margin-bottom: 16px;
  }

  body[data-venue="lounge_demo"] .hero__logo-img {
    width: 160px;
  }

  body[data-venue="lounge_demo"] .hero__badge {
    margin-bottom: 14px;
    font-size: 11px;
    letter-spacing: 0.12em;
  }

  body[data-venue="lounge_demo"] .hero__description {
    max-width: 300px;
    font-size: 16px;
    line-height: 1.58;
    font-weight: 600;
    color: rgba(243,244,246,0.72);
    text-wrap: balance;
  }

  body[data-venue="lounge_demo"] .hero__actions {
    margin-top: 22px;
    gap: 10px;
  }

  body[data-venue="lounge_demo"] .hero__actions .btn {
    min-height: 56px;
    font-size: 16px;
    border-radius: 16px;
  }

  body[data-venue="lounge_demo"] .hero__stats {
    padding-top: 12px;
    gap: 10px;
  }

  body[data-venue="lounge_demo"] .hero-stat {
    padding: 16px 16px 14px;
    border-radius: 18px;
  }

  body[data-venue="lounge_demo"] .hero-stat__value {
    font-size: 18px;
  }

  body[data-venue="lounge_demo"] .hero-stat__label {
    margin-top: 5px;
    font-size: 13px;
    line-height: 1.4;
  }

  body[data-venue="lounge_demo"] .section {
    margin-top: 30px;
  }

  body[data-venue="lounge_demo"] .section__title,
  body[data-venue="lounge_demo"] .guest-title {
    font-size: 30px;
    line-height: 1;
    letter-spacing: -0.04em;
  }

  body[data-venue="lounge_demo"] .section__title::after,
  body[data-venue="lounge_demo"] .guest-title::after {
    width: 36px;
    margin-top: 10px;
  }

  body[data-venue="lounge_demo"] .section__text,
  body[data-venue="lounge_demo"] .guest-subtitle,
  body[data-venue="lounge_demo"] #sectionsDescription,
  body[data-venue="lounge_demo"] #menuSectionText,
  body[data-venue="lounge_demo"] #offersDescription,
  body[data-venue="lounge_demo"] #contactsSectionText,
  body[data-venue="lounge_demo"] #bookingSectionText {
    max-width: 320px;
    font-size: 14px;
    line-height: 1.58;
    color: rgba(243,244,246,0.60);
  }

  body[data-venue="lounge_demo"] .cards-grid,
  body[data-venue="lounge_demo"] .menu-cards {
    gap: 12px;
    margin-top: 16px;
  }

  body[data-venue="lounge_demo"] .section-card,
  body[data-venue="lounge_demo"] .menu-card {
    min-height: 168px;
    padding: 20px;
    border-radius: 22px;
    background:
      radial-gradient(circle at top right, rgba(255,255,255,0.06), transparent 30%),
      linear-gradient(180deg, #11141a 0%, #0b0e13 100%);
    border: 1px solid rgba(255,255,255,0.07);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.03),
      0 14px 30px rgba(0,0,0,0.18);
  }

  body[data-venue="lounge_demo"] .section-card__icon {
    width: 42px;
    height: 42px;
    margin-bottom: 18px;
    border-radius: 14px;
  }

  body[data-venue="lounge_demo"] .section-card__title,
  body[data-venue="lounge_demo"] .menu-card__title {
    font-size: 18px;
    line-height: 1.08;
    margin: 0 0 8px;
  }

  body[data-venue="lounge_demo"] .section-card__desc,
  body[data-venue="lounge_demo"] .menu-card__desc {
    max-width: none;
    font-size: 14px;
    line-height: 1.55;
    color: rgba(243,244,246,0.66);
  }

  body[data-venue="lounge_demo"] .menu-card__actions {
    padding-top: 16px;
  }

  body[data-venue="lounge_demo"] .menu-card__btn,
  body[data-venue="lounge_demo"] .menu-card .btn {
    min-height: 52px;
    border-radius: 16px;
    font-size: 15px;
  }

  body[data-venue="lounge_demo"] .booking-panel {
    padding: 18px;
    border-radius: 24px;
  }

  body[data-venue="lounge_demo"] .contact-row {
    padding: 18px 16px 16px;
    border-radius: 20px;
  }

  body[data-venue="lounge_demo"] .contact-actions {
    gap: 10px;
  }

  body[data-venue="lounge_demo"] .contact-actions .btn {
    min-height: 52px;
    border-radius: 16px;
    font-size: 15px;
  }

  body[data-venue="lounge_demo"] .guest-card {
    border-radius: 24px;
  }

  body[data-venue="lounge_demo"] .guest-card__inner {
    padding: 20px 16px 16px;
    border-radius: 23px;
  }

  body[data-venue="lounge_demo"] .guest-card__name {
    font-size: 16px;
  }

  body[data-venue="lounge_demo"] .guest-card__balance-value {
    font-size: 56px;
  }

  body[data-venue="lounge_demo"] .guest-card__id {
    font-size: 18px;
  }

  body[data-venue="lounge_demo"] .guest-card__rate {
    font-size: 12px;
  }

  body[data-venue="lounge_demo"] .guest-card__btn {
    min-height: 52px;
    border-radius: 16px;
  }
/* ===== LOADER CLEANUP / MONO ===== */

body[data-venue="lounge_demo"] .loader__content {
  gap: 0;
}

body[data-venue="lounge_demo"] .loader__text:empty {
  display: none;
  margin-top: 0;
}

body[data-venue="lounge_demo"] .loader__logo-wrap {
  width: 240px;
  height: 92px;
}

body[data-venue="lounge_demo"] .loader__logo {
  width: 190px;
  object-fit: contain;
}
/* ===== OPTICAL CENTER FIX / MONO HERO ===== */

body[data-venue="lounge_demo"] .hero__logo {
  transform: translateX(6px);
}

body[data-venue="lounge_demo"] .hero__badge {
  transform: translateX(3px);
}

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .hero__logo {
    transform: translateX(4px);
  }

  body[data-venue="lounge_demo"] .hero__badge {
    transform: translateX(2px);
  }
}
/* ===== FINAL HERO STATUS TUNE / MONO ===== */

body[data-venue="lounge_demo"] .hero__status {
  top: 14px;
  right: 14px;
  min-height: 34px;
  padding: 0 12px;
  gap: 7px;

  border-radius: 999px;
  background: rgba(255,255,255,0.028);
  border: 1px solid rgba(255,255,255,0.065);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.025);

  color: rgba(243,244,246,0.66);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: -0.01em;

  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

body[data-venue="lounge_demo"] .status-dot {
  width: 6px;
  height: 6px;
  flex: 0 0 6px;
  border-radius: 50%;

  background: rgba(243,244,246,0.72);
  box-shadow: none;
  animation: none;
}

@media (max-width: 699px) {
  body[data-venue="lounge_demo"] .hero__status {
    top: 10px;
    right: 10px;
    min-height: 30px;
    padding: 0 10px;
    gap: 6px;
    font-size: 11px;
  }

  body[data-venue="lounge_demo"] .status-dot {
    width: 5px;
    height: 5px;
    flex-basis: 5px;
  }
}















