/* ══ PS5 Arena V10 CSS — Mobile fixes, promo banners, booking status ══ */

/* ─── MOBILE HAMBURGER FIX ───────────────────────────────────── */
.ps-menu-btn{display:none!important}
@media(max-width:768px){
  .ps-menu-btn{display:flex!important;align-items:center;justify-content:center;
    width:40px;height:40px;border-radius:8px;border:1.5px solid var(--border);
    background:var(--card);cursor:pointer;padding:0;margin-right:6px;flex-shrink:0}
  .ps-menu-btn.hidden-when-logged-out{display:none!important}
  /* Sidebar mobile overlay */
  .sidebar{transform:translateX(-110%);transition:transform .25s cubic-bezier(.4,0,.2,1);
    position:fixed;top:0;left:0;height:100vh;z-index:1000;width:230px!important;
    padding-top:64px}
  .sidebar.open{transform:translateX(0);box-shadow:4px 0 20px rgba(0,0,0,.4)}
  .sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999}
  .sidebar-overlay.visible{display:block}
  .main-wrap{margin-left:0!important;padding:12px!important}
  .hdr{padding:0 10px;gap:6px}
  .logo-text{font-size:.85rem}
  .hdr-space{flex:1}
}

/* ─── RESPONSIVE CALENDAR ────────────────────────────────────── */
@media(max-width:900px){
  .cal-body{flex-direction:column!important;gap:10px}
  .cal-sidebar-panel{min-width:unset!important;width:100%!important;max-height:unset!important;
    flex-direction:row;flex-wrap:wrap;gap:8px}
  .mini-cal-hdr,.mini-grid{width:100%}
  .upcoming-list{display:none}
  .cal-main-panel{width:100%!important}
}
@media(max-width:600px){
  .cal-toolbar{flex-wrap:wrap;gap:6px;padding:8px}
  .cal-dname{font-size:.65rem!important;padding:3px 0!important}
  .cal-cell{min-height:44px!important}
  .cal-dn{font-size:.75rem!important}
  .cc{font-size:.62rem!important;padding:1px 3px!important}
  .week-grid{font-size:.72rem}
  .cal-wrap{overflow-x:auto}
  .cal-grid{grid-template-columns:repeat(7,minmax(38px,1fr))!important}
  .cdp-slot{padding:8px!important}
}

/* ─── PROMO FLASH BANNER ─────────────────────────────────────── */
.promo-banner-bar{
  background:linear-gradient(90deg,#0f2027,#203a43,#2c5364);
  border-bottom:1.5px solid rgba(59,130,246,.35);
  padding:0;overflow:hidden;position:relative;min-height:36px;
}
.promo-banner-track{
  display:flex;align-items:center;gap:0;white-space:nowrap;
  animation:bannerScroll 28s linear infinite;
}
.promo-banner-track:hover{animation-play-state:paused}
.promo-banner-item{
  display:inline-flex;align-items:center;gap:8px;padding:7px 28px;
  font-size:.8rem;font-weight:600;color:#fff;border-right:1px solid rgba(255,255,255,.12)
}
.promo-banner-code{
  background:linear-gradient(90deg,var(--gold),#f59e0b);color:#000;
  font-family:"JetBrains Mono",monospace;font-size:.77rem;font-weight:700;
  padding:2px 8px;border-radius:4px;cursor:pointer;letter-spacing:.04em
}
.promo-banner-val{color:var(--teal);font-size:.78rem;font-weight:700}
@keyframes bannerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─── PROMO badge in booking modal ──────────────────────────── */
.promo-applied-box{
  background:rgba(20,184,166,.12);border:1px solid rgba(20,184,166,.35);
  border-radius:8px;padding:8px 12px;font-size:.82rem;color:var(--teal);
  display:flex;align-items:center;justify-content:space-between;margin:8px 0;
}
.promo-error-box{
  background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);
  border-radius:8px;padding:8px 12px;font-size:.8rem;color:var(--red);margin:4px 0
}
.promo-row{display:flex;gap:6px;align-items:center;margin:8px 0}
.promo-row .fi{flex:1}

/* ─── BOOKING ADMIN STATUS ───────────────────────────────────── */
.admin-status-pending{
  display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;
  background:rgba(245,158,11,.15);color:#f59e0b;font-size:.74rem;font-weight:700;border:1px solid rgba(245,158,11,.3)
}
.admin-status-confirmed{
  display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;
  background:rgba(34,197,94,.15);color:#22c55e;font-size:.74rem;font-weight:700;border:1px solid rgba(34,197,94,.3)
}
.admin-status-rejected{
  display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;
  background:rgba(239,68,68,.13);color:#ef4444;font-size:.74rem;font-weight:700;border:1px solid rgba(239,68,68,.3)
}

/* ─── BOOKING APPROVALS ADMIN TAB ──────────────────────────── */
.approval-card{
  background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;
  justify-content:space-between;gap:12px;flex-wrap:wrap
}
.approval-card-info{flex:1;min-width:0}
.approval-card-title{font-weight:700;font-size:.9rem;margin-bottom:2px}
.approval-card-meta{font-size:.76rem;color:var(--tx2);line-height:1.6}

/* ─── REAL-TIME CHAT ─────────────────────────────────────────── */
.chat-typing-ws{
  display:flex;align-items:center;gap:6px;padding:4px 12px;
  font-size:.78rem;color:var(--tx3);font-style:italic;min-height:24px
}
.ws-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);
  animation:wsBounce .9s ease-in-out infinite}
.ws-dot:nth-child(2){animation-delay:.2s}
.ws-dot:nth-child(3){animation-delay:.4s}
@keyframes wsBounce{0%,80%,100%{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}
.chat-live-badge{
  display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;
  background:rgba(34,197,94,.15);color:var(--green);font-size:.7rem;font-weight:700;
  border:1px solid rgba(34,197,94,.3);margin-left:6px
}
.chat-live-dot{width:6px;height:6px;border-radius:50%;background:var(--green);
  animation:livePulse 1.5s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}

/* ─── LIVE SESSION ────────────────────────────────────────────── */
.live-url-hardcoded{
  background:rgba(59,130,246,.08);border:1px dashed rgba(59,130,246,.3);
  border-radius:8px;padding:8px 12px;font-size:.76rem;color:var(--tx2);
  margin-bottom:6px;display:flex;align-items:center;justify-content:space-between
}

/* ─── PROMO MANAGEMENT TABLE ─────────────────────────────────── */
.promo-flash-tag{
  display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:4px;
  background:linear-gradient(90deg,rgba(245,158,11,.2),rgba(234,88,12,.2));
  color:var(--gold);font-size:.72rem;font-weight:700;border:1px solid rgba(245,158,11,.3)
}
.promo-welcome-tag{
  display:inline-flex;padding:2px 7px;border-radius:4px;
  background:rgba(20,184,166,.15);color:var(--teal);font-size:.72rem;font-weight:700;
  border:1px solid rgba(20,184,166,.3)
}

/* ─── MOBILE SIDEBAR NAV ─────────────────────────────────────── */
@media(max-width:768px){
  .sidebar{overflow-y:auto}
  .sidebar .nav-item{padding:10px 14px;font-size:.86rem}
  .sidebar .nav-icon{width:20px;font-size:.9rem}
}

/* ─── RESPONSIVE TABLES ──────────────────────────────────────── */
@media(max-width:640px){
  .tw table{min-width:480px}
  .order-card{padding:12px}
  .order-meta{grid-template-columns:1fr 1fr!important}
  .order-actions{flex-wrap:wrap;gap:6px}
}

/* ─── GENERAL MOBILE PADDING ─────────────────────────────────── */
@media(max-width:480px){
  .ph{padding:12px 0}
  .ph h1{font-size:1.3rem}
  .stats{grid-template-columns:repeat(2,1fr)!important}
  .slot-card{padding:12px}
  .modal-inner{padding:16px!important;width:calc(100vw - 20px)!important}
}
