/* ==========================================================================
   GRAND CAFÉ - Unified Brand Styling & Layout Design System
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;700;800&family=Outfit:wght@300;400;500;600;700&family=Pinyon+Script&display=swap');

/* --- Custom Variables & Tokens --- */
:root {
  --color-base-dark: #22170f;
  --color-espresso: #362517; /* Beautiful warm coffee-espresso brown! */
  --color-latte: #4c321f;
  --color-coffee-glow: #5d3d26;
  --color-creamy-coffee: #bfa895;
  --color-gold: #c5a059;
  --color-gold-hover: #e5be79;
  --color-gold-glow: rgba(197, 160, 89, 0.45);
  --color-cream: #fbf5e6;
  --color-cream-dim: #cfbaaa;
  
  --color-success: #2ecc71;
  --color-success-glow: rgba(46, 204, 113, 0.2);
  --color-alert: #e74c3c;
  --color-alert-glow: rgba(231, 76, 60, 0.2);
  --color-seen: #3498db;
  --color-seen-glow: rgba(52, 152, 219, 0.2);

  --font-display: 'Cinzel', serif;
  --font-body: 'Outfit', sans-serif;

  --transition-fast: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-normal: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  
  --shadow-glass: 0 8px 32px 0 rgba(0, 0, 0, 0.4);
  --border-glass: 1px solid rgba(197, 160, 89, 0.15);
  --bg-glass: rgba(20, 13, 8, 0.7);
  --bg-glass-heavy: rgba(12, 8, 5, 0.9);
}

/* --- Base Resets & Aesthetics --- */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  -webkit-tap-highlight-color: transparent;
}

body {
  font-family: var(--font-body);
  background-color: rgba(54, 37, 23, 0.9); /* Warm premium coffee-espresso brown */
  color: var(--color-cream);
  min-height: 100vh;
  overflow-x: hidden;
  background-image: 
    radial-gradient(circle at 10% 20%, rgba(197, 160, 89, 0.12) 0%, transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(197, 160, 89, 0.08) 0%, transparent 50%),
    linear-gradient(to bottom, rgba(54, 37, 23, 0.9), rgba(38, 26, 16, 0.9));
  background-attachment: fixed;
}

/* --- Typographical System --- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  letter-spacing: 0.05em;
  color: var(--color-gold);
}

p {
  line-height: 1.6;
  color: var(--color-cream-dim);
}

/* ==========================================================================
   CUSTOMER APP (Mobile View)
   ========================================================================== */

.customer-container {
  max-width: 480px;
  margin: 0 auto;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  padding: 1.5rem 1.5rem 150px 1.5rem; /* bottom padding to clear floating service widget */
  justify-content: space-between;
}

/* Branded Header Section */
.brand-header {
  text-align: center;
  margin-top: 1rem;
  margin-bottom: 1.5rem;
  animation: fadeInDown var(--transition-normal);
}

.brand-logo-container {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 1rem;
}

.brand-logo {
  max-width: 160px;
  height: auto;
  filter: drop-shadow(0 0 10px rgba(197, 160, 89, 0.2));
  transition: transform var(--transition-normal);
}

.brand-logo:hover {
  transform: scale(1.05);
}

.brand-header h1 {
  font-size: 1.8rem;
  margin-bottom: 0.5rem;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}

.brand-header p {
  font-size: 1rem;
  font-weight: 300;
  letter-spacing: 0.05em;
}

/* Table Pill Design */
.table-badge-container {
  display: flex;
  justify-content: center;
  margin-bottom: 1.5rem;
  animation: fadeIn var(--transition-slow);
}

.table-badge {
  background: var(--bg-glass);
  border: var(--border-glass);
  box-shadow: var(--shadow-glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 0.6rem 1.5rem;
  border-radius: 50px;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--color-gold);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  white-space: nowrap;
  flex-shrink: 0;
}

#tableText {
  white-space: nowrap;
}

.table-badge-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--color-success);
  box-shadow: 0 0 8px var(--color-success);
}

/* Action Buttons Area */
.actions-grid {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.action-btn {
  background: linear-gradient(135deg, rgba(35, 23, 14, 0.8), rgba(20, 13, 8, 0.8));
  border: var(--border-glass);
  border-radius: 18px;
  padding: 1.25rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  transition: all var(--transition-fast);
  box-shadow: var(--shadow-glass);
  position: relative;
  overflow: hidden;
  text-align: left;
  width: 100%;
}

.action-btn::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(197, 160, 89, 0.05), transparent);
  transform: translateX(-100%);
  transition: transform var(--transition-slow);
}

.action-btn:hover::after {
  transform: translateX(100%);
}

.action-btn:hover:not(:disabled) {
  border-color: var(--color-gold);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(197, 160, 89, 0.15);
}

.action-btn:active:not(:disabled) {
  transform: translateY(1px);
}

.btn-content {
  display: flex;
  align-items: center;
  gap: 1.2rem;
}

.btn-icon {
  width: 48px;
  height: 48px;
  background: rgba(197, 160, 89, 0.1);
  border: 1px solid rgba(197, 160, 89, 0.2);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gold);
  font-size: 1.5rem;
  transition: all var(--transition-fast);
}

.action-btn:hover .btn-icon {
  background: var(--color-gold);
  color: var(--color-espresso);
  box-shadow: 0 0 10px var(--color-gold-glow);
}

.btn-texts h3 {
  font-size: 1.1rem;
  margin-bottom: 0.15rem;
  color: var(--color-cream);
  transition: color var(--transition-fast);
}

.action-btn:hover .btn-texts h3 {
  color: var(--color-gold);
}

.btn-texts p {
  font-size: 0.8rem;
  font-weight: 300;
}

.ewt-value {
  color: var(--color-gold);
  font-weight: 600;
  opacity: 0.95;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  text-shadow: 0 0 8px rgba(197, 160, 89, 0.2);
}

.btn-arrow {
  color: var(--color-cream-dim);
  font-size: 1.2rem;
  transition: transform var(--transition-fast);
}

.action-btn:hover .btn-arrow {
  transform: translateX(4px);
  color: var(--color-gold);
}

/* Disabled & Cooldown States */
.action-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
  background: rgba(20, 13, 8, 0.4);
}

.action-btn.cooldown-active {
  border-color: rgba(197, 160, 89, 0.1) !important;
}

.action-btn.cooldown-active .btn-icon {
  background: rgba(197, 160, 89, 0.05);
  color: var(--color-cream-dim);
  box-shadow: none;
}

/* Spinner Cooldown Ring overlay */
.cooldown-spinner {
  position: absolute;
  right: 1.5rem;
  width: 28px;
  height: 28px;
  border: 3px solid rgba(197, 160, 89, 0.1);
  border-top: 3px solid var(--color-gold);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  display: none;
}

.cooldown-active .cooldown-spinner {
  display: block;
}
.cooldown-active .btn-arrow {
  display: none;
}

/* Placeholder buttons (Coming Soon) */
.placeholders-heading {
  font-family: var(--font-body);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-cream-dim);
  margin-bottom: 0.75rem;
  margin-top: 1rem;
  opacity: 0.7;
}

.placeholder-btn {
  background: rgba(15, 10, 6, 0.25);
  border: 1px dashed rgba(197, 160, 89, 0.15);
  cursor: not-allowed;
}

.placeholder-btn .btn-icon {
  background: rgba(255, 255, 255, 0.02);
  border-color: rgba(255, 255, 255, 0.05);
  color: var(--color-cream-dim);
  opacity: 0.6;
}

.placeholder-btn h3 {
  color: var(--color-cream-dim);
  font-weight: 400;
  opacity: 0.7;
}

.badge-soon {
  font-size: 0.7rem;
  background: rgba(197, 160, 89, 0.1);
  border: 1px solid rgba(197, 160, 89, 0.3);
  color: var(--color-gold);
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  font-family: var(--font-body);
  letter-spacing: 0.05em;
}

/* Elegant Success Toast / Popup Overlay (Non-Blocking Floating Style) */
.toast-overlay {
  position: fixed;
  top: 24px;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: fit-content;
  max-width: 90%;
  height: auto;
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10100;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-100px);
  transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity 0.3s ease;
}

.toast-overlay.active {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0);
}

.toast-content {
  background: var(--bg-glass-heavy);
  border: var(--border-glass);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), var(--shadow-glass);
  padding: 0.85rem 1.25rem;
  border-radius: 16px;
  display: flex;
  align-items: center;
  gap: 0.85rem;
  text-align: left;
  max-width: 420px;
  width: auto;
  transform: scale(0.95);
  transition: transform 0.3s ease;
}

.toast-overlay.active .toast-content {
  transform: scale(1);
}

.success-ring-container {
  display: flex;
  justify-content: center;
  margin-bottom: 1.5rem;
}

.success-ring {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(46, 204, 113, 0.1);
  border: 2px solid var(--color-success);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-success);
  font-size: 2rem;
  box-shadow: 0 0 15px var(--color-success-glow);
  animation: scaleIn var(--transition-normal) forwards;
}

.toast-content h2 {
  font-size: 1.5rem;
  margin-bottom: 0.75rem;
  color: var(--color-gold);
}

.toast-content p {
  font-size: 0.95rem;
  margin-bottom: 1.5rem;
}

.toast-btn {
  background: linear-gradient(135deg, var(--color-gold), #aa843e);
  color: var(--color-base-dark);
  border: none;
  font-family: var(--font-body);
  font-weight: 600;
  padding: 0.8rem 2rem;
  border-radius: 12px;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.05em;
  width: 100%;
}

.toast-btn:hover {
  background: linear-gradient(135deg, var(--color-gold-hover), var(--color-gold));
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(197, 160, 89, 0.4);
}

/* Guest Request Status panel (Real-Time Tracker) */
.guest-tracker-panel {
  margin-top: 1.5rem;
  margin-bottom: 1rem;
  animation: slideInUp var(--transition-normal);
}

.tracker-heading {
  font-family: var(--font-body);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-gold);
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.tracker-heading span {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--color-gold);
  animation: pulseGlow 1s infinite alternate;
}

.tracker-cards-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.tracker-card {
  background: rgba(28, 18, 12, 0.5);
  border: var(--border-glass);
  border-radius: 14px;
  padding: 1rem 1.25rem;
  box-shadow: var(--shadow-glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  animation: scaleIn var(--transition-normal);
  border-left: 4px solid var(--color-alert);
  position: relative;
}

.tracker-card.tracker-seen {
  border-left-color: var(--color-seen);
}

.tracker-card.tracker-completed {
  border-left-color: var(--color-success);
}

.tracker-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.tracker-card-title {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-cream);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.tracker-card-time {
  font-size: 0.75rem;
  color: var(--color-cream-dim);
}

.tracker-status-line {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: var(--color-cream-dim);
}

.tracker-status-bullet {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--color-alert);
}

.tracker-seen .tracker-status-bullet {
  background-color: var(--color-seen);
  box-shadow: 0 0 6px var(--color-seen);
}

.tracker-completed .tracker-status-bullet {
  background-color: var(--color-success);
  box-shadow: 0 0 6px var(--color-success);
}

.tracker-status-text {
  font-weight: 400;
}

.tracker-status-text strong {
  color: var(--color-gold-hover);
  font-weight: 600;
}

/* Footer Branded Copy */
.customer-footer {
  text-align: center;
  font-size: 0.75rem;
  color: var(--color-cream-dim);
  opacity: 0.5;
  margin-top: 1.5rem;
  font-weight: 300;
  letter-spacing: 0.05em;
}

/* ==========================================================================
   STAFF DASHBOARD (Web View)
   ========================================================================== */

.dashboard-container {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Header bar */
.dashboard-header {
  background: var(--bg-glass-heavy);
  border-bottom: 1px solid rgba(197, 160, 89, 0.15);
  padding: 1rem 2rem;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  position: sticky;
  top: 0;
  z-index: 100;
}

.dashboard-brand {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex: 0 0 auto;
}

.dashboard-logo {
  max-height: 64px;
  width: auto;
  filter: drop-shadow(0 0 8px rgba(197, 160, 89, 0.25));
  transition: transform var(--transition-normal);
}

.dashboard-logo:hover {
  transform: scale(1.04);
}

.staff-terminal-title-badge {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 600;
  background: rgba(197, 160, 89, 0.1);
  border: 1px solid rgba(197, 160, 89, 0.3);
  color: var(--color-gold);
  padding: 0.25rem 0.6rem;
  border-radius: 6px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-left: 0.5rem;
  white-space: nowrap;
}

/* User Identity Tag in header (Premium Split-Pill Control) */
.staff-welcome-tag {
  font-size: 0.85rem;
  color: var(--color-cream-dim);
  background: rgba(20, 13, 8, 0.8);
  border: 1px solid rgba(197, 160, 89, 0.2);
  padding: 0.3rem 0.6rem 0.3rem 0.6rem;
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  flex-shrink: 0;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.staff-welcome-tag:hover {
  border-color: var(--color-gold);
  box-shadow: 0 4px 20px rgba(197, 160, 89, 0.15);
}

.staff-user-identity {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.user-role-avatar {
  background: rgba(197, 160, 89, 0.1);
  border: 1px solid rgba(197, 160, 89, 0.2);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  color: var(--color-gold);
  flex-shrink: 0;
}

.staff-header-divider {
  width: 1px;
  height: 18px;
  background: rgba(197, 160, 89, 0.2);
}

.staff-logout-btn {
  background: rgba(231, 76, 60, 0.08);
  border: 1px solid rgba(231, 76, 60, 0.25);
  color: #ff6b6b;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.3rem 0.65rem;
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  transition: all var(--transition-fast);
  white-space: nowrap;
}

.staff-logout-btn:hover {
  background: rgba(231, 76, 60, 0.18);
  border-color: #ff6b6b;
  color: #fff;
  box-shadow: 0 0 8px rgba(231, 76, 60, 0.25);
}

.staff-logout-btn svg {
  transition: transform var(--transition-fast);
}

.staff-logout-btn:hover svg {
  transform: translateX(2px);
}

/* Navigation tabs */
.dashboard-nav {
  display: flex;
  gap: 1rem;
  flex: 1 1 auto;
  justify-content: center;
  min-width: 0;
}

.nav-tab {
  background: transparent;
  border: 1px solid transparent;
  color: var(--color-cream-dim);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.95rem;
  padding: 0.6rem 1.2rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.nav-tab i {
  font-size: 1rem;
}

.nav-tab:hover {
  color: var(--color-cream);
  background: rgba(255, 255, 255, 0.03);
}

.nav-tab.active {
  color: var(--color-gold);
  background: rgba(197, 160, 89, 0.08);
  border-color: rgba(197, 160, 89, 0.25);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

/* Premium Floating Profile & Sound Controller */
.dashboard-profile-floating {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 1rem;
  z-index: 105;
  flex: 0 0 auto;
}

.audio-toggle-btn {
  background: rgba(197, 160, 89, 0.05);
  border: 1px solid rgba(197, 160, 89, 0.15);
  color: var(--color-gold);
  padding: 0.5rem 1rem;
  border-radius: 8px;
  font-family: var(--font-body);
  font-size: 0.85rem;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.audio-toggle-btn:hover {
  background: rgba(197, 160, 89, 0.1);
  border-color: var(--color-gold);
}

.audio-toggle-btn.muted {
  color: var(--color-cream-dim);
  border-color: rgba(255, 255, 255, 0.1);
}

/* Dashboard Content Grid */
.dashboard-main {
  flex: 1;
  padding: 2rem;
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}

.dashboard-pane {
  display: none;
}

.dashboard-pane.active {
  display: block;
}

/* STATS BAR */
.stats-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.stat-card {
  background: var(--bg-glass);
  border: var(--border-glass);
  box-shadow: var(--shadow-glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 16px;
  padding: 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  position: relative;
  overflow: hidden;
}

.stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
  background-color: var(--color-gold);
}

.stat-card.stat-urgent::before {
  background-color: var(--color-alert);
}

.stat-icon {
  width: 52px;
  height: 52px;
  border-radius: 12px;
  background: rgba(197, 160, 89, 0.08);
  border: 1px solid rgba(197, 160, 89, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  color: var(--color-gold);
}

.stat-urgent .stat-icon {
  color: var(--color-alert);
  background: rgba(231, 76, 60, 0.08);
  border-color: rgba(231, 76, 60, 0.15);
}

.stat-info h3 {
  font-family: var(--font-body);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-cream-dim);
  margin-bottom: 0.25rem;
}

.stat-info .stat-number {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-cream);
  line-height: 1.2;
}

/* FILTER AND BAR CONTROL */
.control-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
  gap: 1rem;
  flex-wrap: wrap;
}

.filter-group {
  display: flex;
  background: rgba(20, 13, 8, 0.5);
  border: var(--border-glass);
  padding: 0.3rem;
  border-radius: 10px;
  gap: 0.25rem;
}

.filter-btn {
  background: transparent;
  border: none;
  color: var(--color-cream-dim);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.85rem;
  padding: 0.4rem 1rem;
  border-radius: 6px;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.filter-btn:hover {
  color: var(--color-cream);
}

.filter-btn.active {
  background: var(--color-gold);
  color: var(--color-espresso);
  font-weight: 600;
}

.clear-completed-btn {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--color-cream-dim);
  font-family: var(--font-body);
  font-size: 0.85rem;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.clear-completed-btn:hover {
  border-color: rgba(255, 255, 255, 0.3);
  color: var(--color-cream);
  background: rgba(255, 255, 255, 0.02);
}

/* REQUESTS WORKBOARD GRID */
.workboard-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.5rem;
  margin-bottom: 3rem;
}

/* Column Panel Design */
.board-column {
  background: rgba(12, 8, 5, 0.5);
  border: 1px solid rgba(197, 160, 89, 0.08);
  border-radius: 20px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  min-height: 500px;
}

.column-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(197, 160, 89, 0.15);
}

.column-header h2 {
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.column-count {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 600;
  background: rgba(197, 160, 89, 0.1);
  border: 1px solid rgba(197, 160, 89, 0.2);
  color: var(--color-gold);
  padding: 0.15rem 0.5rem;
  border-radius: 20px;
  min-width: 24px;
  text-align: center;
}

.board-column.col-new .column-header h2 { color: var(--color-alert); }
.board-column.col-new .column-count {
  background: rgba(231, 76, 60, 0.1);
  border-color: rgba(231, 76, 60, 0.2);
  color: var(--color-alert);
}

.board-column.col-seen .column-header h2 { color: var(--color-seen); }
.board-column.col-seen .column-count {
  background: rgba(52, 152, 219, 0.1);
  border-color: rgba(52, 152, 219, 0.2);
  color: var(--color-seen);
}

.board-column.col-completed .column-header h2 { color: var(--color-success); }
.board-column.col-completed .column-count {
  background: rgba(46, 204, 113, 0.1);
  border-color: rgba(46, 204, 113, 0.2);
  color: var(--color-success);
}

/* Request Cards Container */
.cards-container {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  flex: 1;
  overflow-y: auto;
  max-height: 650px;
  padding: 0.2rem;
}

/* REQUEST CARDS AESTHETIC */
.request-card {
  background: var(--bg-glass);
  border: var(--border-glass);
  box-shadow: var(--shadow-glass);
  border-radius: 14px;
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: all var(--transition-normal);
  animation: slideInUp var(--transition-normal) forwards;
  position: relative;
}

.request-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 15px;
  bottom: 15px;
  width: 4px;
  border-radius: 0 4px 4px 0;
  background-color: var(--color-gold);
}

.request-card.status-new::before {
  background-color: var(--color-alert);
}
.request-card.status-seen::before {
  background-color: var(--color-seen);
}
.request-card.status-completed::before {
  background-color: var(--color-success);
}

/* Urgent Pulse Glowing for New Cards */
.request-card.status-new {
  animation: pulseGlow 2s infinite alternate, slideInUp var(--transition-normal) forwards;
  border-color: rgba(231, 76, 60, 0.3);
}

.card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.card-table {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-cream);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.card-table i {
  color: var(--color-gold);
  font-size: 1rem;
}

.card-time {
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: var(--color-cream-dim);
  display: flex;
  align-items: center;
  gap: 0.3rem;
}

.card-body {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.request-badge {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.95rem;
  font-weight: 600;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  width: 100%;
}

.req-waiter {
  background: rgba(197, 160, 89, 0.1);
  border: 1px solid rgba(197, 160, 89, 0.25);
  color: var(--color-gold);
}

.req-water {
  background: rgba(52, 152, 219, 0.1);
  border: 1px solid rgba(52, 152, 219, 0.25);
  color: #5dade2;
}

.req-bill {
  background: rgba(46, 204, 113, 0.1);
  border: 1px solid rgba(46, 204, 113, 0.25);
  color: #58d68d;
}

/* Card Waiter Assignment tag */
.assigned-staff-badge {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(197, 160, 89, 0.2);
  color: var(--color-gold);
  border-radius: 6px;
  font-size: 0.78rem;
  padding: 0.25rem 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.1rem;
  align-self: flex-start;
  font-weight: 500;
}

.assigned-staff-badge svg {
  color: var(--color-gold-hover);
}

/* Card Control Actions */
.card-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.25rem;
}

.btn-card-action {
  flex: 1;
  border: 1px solid transparent;
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.8rem;
  padding: 0.5rem 0.75rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
}

.btn-seen-action {
  background: rgba(52, 152, 219, 0.08);
  border-color: rgba(52, 152, 219, 0.2);
  color: var(--color-seen);
}

.btn-seen-action:hover {
  background: var(--color-seen);
  color: #fff;
}

.btn-done-action {
  background: rgba(46, 204, 113, 0.08);
  border-color: rgba(46, 204, 113, 0.2);
  color: var(--color-success);
}

.btn-done-action:hover {
  background: var(--color-success);
  color: var(--color-base-dark);
  font-weight: 600;
}

/* Completed card styling details */
.request-card.status-completed {
  opacity: 0.6;
}
.request-card.status-completed:hover {
  opacity: 1;
}

/* Empty Board State */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem 1rem;
  color: var(--color-cream-dim);
  text-align: center;
  flex: 1;
  opacity: 0.5;
  animation: fadeIn var(--transition-normal);
}

.empty-state i {
  font-size: 2.5rem;
  margin-bottom: 1rem;
  color: var(--color-gold);
}

.empty-state p {
  font-size: 0.9rem;
}

/* ==========================================================================
   STAFF LOGIN CARD OVERLAY
   ========================================================================== */

.login-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(54, 37, 23, 0.9);
  background-image: 
    radial-gradient(circle at 10% 20%, rgba(197, 160, 89, 0.12) 0%, transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(197, 160, 89, 0.08) 0%, transparent 50%),
    linear-gradient(to bottom, rgba(54, 37, 23, 0.9), rgba(38, 26, 16, 0.9));
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  transition: opacity var(--transition-normal), visibility var(--transition-normal);
}

.login-overlay.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.login-card {
  background: rgba(20, 13, 8, 0.65); /* Elegant frosted espresso overlay */
  border: 1px solid rgba(197, 160, 89, 0.25); /* Refined gold border */
  box-shadow: var(--shadow-glass), 0 0 20px rgba(197, 160, 89, 0.15);
  border-radius: 24px;
  padding: 2.5rem 2rem;
  width: 95%;
  max-width: 420px;
  text-align: center;
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  animation: scaleIn var(--transition-normal);
  overflow: hidden;
  position: relative;
}

.login-card-logo {
  max-width: 100px;
  height: auto;
  margin-bottom: 0.5rem;
  filter: drop-shadow(0 0 8px rgba(197, 160, 89, 0.2));
}

.login-card h2 {
  font-size: 1.4rem;
  margin-bottom: 0.25rem;
}

.login-card p {
  font-size: 0.85rem;
  color: var(--color-cream-dim);
  margin-bottom: 1.5rem;
}

/* Sliding Views container */
.login-slider {
  display: flex;
  width: 200%;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.login-slider.show-keypad {
  transform: translateX(-50%);
}

.login-slide {
  width: 50%;
  flex-shrink: 0;
  padding: 0 0.25rem;
}

/* Staff profile select grid */
.staff-list-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 0.75rem;
  margin-bottom: 0.5rem;
  max-height: 270px;
  overflow-y: auto;
  padding: 0.5rem 0.2rem;
}

/* Custom scrollbar for staff select grid */
.staff-list-grid::-webkit-scrollbar {
  width: 4px;
}
.staff-list-grid::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.01);
}
/* Card Waiter Assignment tag */
.assigned-staff-badge {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(197, 160, 89, 0.2);
  color: var(--color-gold);
  border-radius: 6px;
  font-size: 0.78rem;
  padding: 0.25rem 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.1rem;
  align-self: flex-start;
  font-weight: 500;
}

.assigned-staff-badge svg {
  color: var(--color-gold-hover);
}

/* Card Control Actions */
.card-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.25rem;
}

.btn-card-action {
  flex: 1;
  border: 1px solid transparent;
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.8rem;
  padding: 0.5rem 0.75rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
}

.btn-seen-action {
  background: rgba(52, 152, 219, 0.08);
  border-color: rgba(52, 152, 219, 0.2);
  color: var(--color-seen);
}

.btn-seen-action:hover {
  background: var(--color-seen);
  color: #fff;
}

.btn-done-action {
  background: rgba(46, 204, 113, 0.08);
  border-color: rgba(46, 204, 113, 0.2);
  color: var(--color-success);
}

.btn-done-action:hover {
  background: var(--color-success);
  color: var(--color-base-dark);
  font-weight: 600;
}

/* Completed card styling details */
.request-card.status-completed {
  opacity: 0.6;
}
.request-card.status-completed:hover {
  opacity: 1;
}

/* Empty Board State */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem 1rem;
  color: var(--color-cream-dim);
  text-align: center;
  flex: 1;
  opacity: 0.5;
  animation: fadeIn var(--transition-normal);
}

.empty-state i {
  font-size: 2.5rem;
  margin-bottom: 1rem;
  color: var(--color-gold);
}

.empty-state p {
  font-size: 0.9rem;
}

/* ==========================================================================
   STAFF LOGIN CARD OVERLAY
   ========================================================================== */

.login-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(54, 37, 23, 0.9);
  background-image: 
    radial-gradient(circle at 10% 20%, rgba(197, 160, 89, 0.12) 0%, transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(197, 160, 89, 0.08) 0%, transparent 50%),
    linear-gradient(to bottom, rgba(54, 37, 23, 0.9), rgba(38, 26, 16, 0.9));
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  transition: opacity var(--transition-normal), visibility var(--transition-normal);
}

.login-overlay.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.login-card {
  background: rgba(20, 13, 8, 0.65); /* Elegant frosted espresso overlay */
  border: 1px solid rgba(197, 160, 89, 0.25); /* Refined gold border */
  box-shadow: var(--shadow-glass), 0 0 20px rgba(197, 160, 89, 0.15);
  border-radius: 24px;
  padding: 2.5rem 2rem;
  width: 95%;
  max-width: 420px;
  text-align: center;
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  animation: scaleIn var(--transition-normal);
  overflow: hidden;
  position: relative;
}

.login-card-logo {
  max-width: 100px;
  height: auto;
  margin-bottom: 0.5rem;
  filter: drop-shadow(0 0 8px rgba(197, 160, 89, 0.2));
}

.login-card h2 {
  font-size: 1.4rem;
  margin-bottom: 0.25rem;
}

.login-card p {
  font-size: 0.85rem;
  color: var(--color-cream-dim);
  margin-bottom: 1.5rem;
}

/* Sliding Views container */
.login-slider {
  display: flex;
  width: 200%;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.login-slider.show-keypad {
  transform: translateX(-50%);
}

.login-slide {
  width: 50%;
  flex-shrink: 0;
  padding: 0 0.25rem;
}

/* Staff profile select grid */
.staff-list-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 0.75rem;
  margin-bottom: 0.5rem;
  max-height: 270px;
  overflow-y: auto;
  padding: 0.5rem 0.2rem;
}

/* Custom scrollbar for staff select grid */
.staff-list-grid::-webkit-scrollbar {
  width: 4px;
}
.staff-list-grid::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.01);
}
.staff-list-grid::-webkit-scrollbar-thumb {
  background: rgba(197, 160, 89, 0.25);
  border-radius: 4px;
}

.staff-profile-card {
  background: rgba(20, 13, 8, 0.4);
  border: 1px solid rgba(197, 160, 89, 0.15);
  border-radius: 14px;
  padding: 1rem 0.5rem;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.staff-profile-card:hover {
  border-color: var(--color-gold);
  background: rgba(197, 160, 89, 0.08);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(197, 160, 89, 0.15);
}

.staff-avatar-circle {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(197, 160, 89, 0.1);
  border: 1px solid rgba(197, 160, 89, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: var(--color-gold);
  transition: all var(--transition-fast);
}

.staff-profile-card:hover .staff-avatar-circle {
  background: var(--color-gold);
  color: var(--color-espresso);
  box-shadow: 0 0 10px var(--color-gold-glow);
}

.staff-profile-name {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-cream);
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
}

.staff-profile-role-badge {
  font-size: 0.62rem;
  padding: 0.15rem 0.4rem;
  border-radius: 4px;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.05em;
}

.badge-admin {
  background: rgba(197, 160, 89, 0.12);
  border: 1px solid rgba(197, 160, 89, 0.25);
  color: var(--color-gold-hover);
}
.badge-cashier {
  background: rgba(52, 152, 219, 0.12);
  border: 1px solid rgba(52, 152, 219, 0.25);
  color: #5dade2;
}
.badge-waiter {
  background: rgba(46, 204, 113, 0.1);
  border: 1px solid rgba(46, 204, 113, 0.2);
  color: var(--color-success);
}

/* Numeric Keypad Panel */
.keypad-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
  width: 100%;
}

.btn-back-to-profiles {
  background: transparent;
  border: 1px solid rgba(197, 160, 89, 0.2);
  color: var(--color-gold);
  border-radius: 8px;
  width: 32px;
  height: 32px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
}

.btn-back-to-profiles:hover {
  border-color: var(--color-gold);
  background: rgba(197, 160, 89, 0.1);
}

.keypad-user-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-gold);
  text-align: left;
  flex: 1;
}

.pin-dots-container {
  display: flex;
  justify-content: center;
  gap: 1.25rem;
  margin-bottom: 1.75rem;
  margin-top: 0.5rem;
}

.pin-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid rgba(197, 160, 89, 0.3);
  background: transparent;
  transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
}

.pin-dot.filled {
  background: var(--color-gold);
  border-color: var(--color-gold);
  box-shadow: 0 0 10px var(--color-gold-hover);
  transform: scale(1.15);
}

.pin-dot.error {
  background: var(--color-alert) !important;
  border-color: var(--color-alert) !important;
  box-shadow: 0 0 12px var(--color-alert) !important;
  transform: scale(1.15);
}

/* Keypad Grid layout */
.keypad-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  max-width: 250px;
  margin: 0 auto;
}

.keypad-btn {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: rgba(20, 13, 8, 0.5);
  border: 1px solid rgba(197, 160, 89, 0.15);
  color: var(--color-cream);
  font-family: var(--font-body);
  font-size: 1.4rem;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  outline: none;
  margin: 0 auto;
}

.keypad-btn:hover {
  border-color: var(--color-gold);
  background: rgba(197, 160, 89, 0.1);
}

.keypad-btn:active {
  transform: scale(0.92);
  background: var(--color-gold);
  color: var(--color-espresso);
  border-color: var(--color-gold);
}

.keypad-btn.action-key {
  font-size: 1rem;
  color: var(--color-gold);
  border-color: rgba(197, 160, 89, 0.1);
  background: rgba(20, 13, 8, 0.25);
}

.keypad-btn.action-key:hover {
  background: rgba(197, 160, 89, 0.05);
}

/* Shakable animations for error states */
.shake-animation {
  animation: shake 0.4s ease-in-out;
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  15%, 45%, 75% { transform: translateX(-8px); }
  30%, 60%, 90% { transform: translateX(8px); }
}

/* ==========================================================================
   QR STATION PANEL
   ========================================================================== */

.qr-panel {
  background: var(--bg-glass);
  border: var(--border-glass);
  box-shadow: var(--shadow-glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 24px;
  padding: 2rem;
  margin-bottom: 3rem;
  animation: fadeIn var(--transition-normal);
}

.qr-panel h2 {
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.qr-panel > p {
  margin-bottom: 2rem;
}

.qr-setup-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}

@media (min-width: 768px) {
  .qr-setup-grid {
    grid-template-columns: 350px 1fr;
  }
}

/* Inputs Form */
.qr-form-card {
  background: rgba(12, 8, 5, 0.4);
  border: 1px solid rgba(197, 160, 89, 0.1);
  border-radius: 16px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  align-self: start;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.form-group label {
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-cream-dim);
}

.form-input {
  width: 100%;
  box-sizing: border-box;
  background: rgba(20, 13, 8, 0.7);
  border: 1px solid rgba(197, 160, 89, 0.2);
  border-radius: 8px;
  padding: 0.75rem 1rem;
  font-family: var(--font-body);
  color: var(--color-cream);
  font-size: 1rem;
  transition: all var(--transition-fast);
}

.form-input:focus {
  outline: none;
  border-color: var(--color-gold);
  box-shadow: 0 0 8px rgba(197, 160, 89, 0.2);
}

.btn-generate-qr {
  background: linear-gradient(135deg, var(--color-gold), #aa843e);
  color: var(--color-base-dark);
  border: none;
  font-family: var(--font-body);
  font-weight: 600;
  padding: 0.8rem 1.5rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all var(--transition-fast);
  margin-top: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-size: 0.95rem;
  width: 100%;
}

.btn-generate-qr:hover {
  background: linear-gradient(135deg, var(--color-gold-hover), var(--color-gold));
  transform: translateY(-1px);
  box-shadow: 0 4px 15px rgba(197, 160, 89, 0.3);
}

/* Printable QR templates grid */
.qr-cards-display {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.qr-header-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding-bottom: 0.75rem;
}

.qr-header-actions h3 {
  font-size: 1.1rem;
  color: var(--color-cream);
}

.btn-print-action {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--color-cream);
  padding: 0.5rem 1rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-body);
  font-size: 0.85rem;
}

.btn-print-action:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.3);
}

.qr-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.5rem;
}

/* Individual Printable Branded QR Card */
.qr-table-card {
  background: #ffffff;
  color: #1a100a;
  border-radius: 20px;
  padding: 1.75rem;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  border: 2px solid #e1d3c1;
  position: relative;
  overflow: hidden;
  transition: transform var(--transition-fast);
}

.qr-table-card:hover {
  transform: translateY(-4px);
}

.qr-table-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 6px;
  background: #c5a059;
}

.qr-card-logo {
  max-width: 100px;
  height: auto;
  margin-bottom: 0.75rem;
}

.qr-card-title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: #1a100a;
  margin-bottom: 0.25rem;
}

.qr-card-subtitle {
  font-family: var(--font-body);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #836750;
  font-weight: 600;
  margin-bottom: 1.25rem;
}

.qr-code-box {
  background: #ffffff;
  padding: 0.75rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  margin-bottom: 1.25rem;
  border: 1px solid #f0e6da;
  display: flex;
  justify-content: center;
  align-items: center;
}

.qr-code-box img {
  display: block;
  width: 140px;
  height: 140px;
}

.qr-card-table-num {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 800;
  color: #c5a059;
  margin-bottom: 0.5rem;
  letter-spacing: 0.05em;
  background: #fdfaf5;
  padding: 0.25rem 1.25rem;
  border-radius: 30px;
  border: 1px solid #f3e9db;
  display: inline-block;
}

.qr-card-instruction {
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: #8c8279;
  line-height: 1.4;
  margin-top: 0.5rem;
}

/* ==========================================================================
   ANIMATIONS & KEYFRAMES
   ========================================================================== */

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

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

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

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

@keyframes pulseGlow {
  0% {
    box-shadow: 0 0 10px rgba(231, 76, 60, 0.15);
  }
  100% {
    box-shadow: 0 0 22px rgba(231, 76, 60, 0.45);
    border-color: rgba(231, 76, 60, 0.55);
  }
}

/* ==========================================================================
   PRINT MEDIA RULES (For Table QR Cards)
   ========================================================================== */

@media print {
  body {
    background: #ffffff !important;
    color: #000000 !important;
    background-image: none !important;
  }
  
  .dashboard-header,
  .dashboard-nav,
  .audio-toggle-btn,
  .stats-container,
  .control-bar,
  .qr-panel > h2,
  .qr-panel > p,
  .qr-form-card,
  .qr-header-actions,
  .login-overlay {
    display: none !important;
  }
  
  .dashboard-main {
    padding: 0 !important;
    margin: 0 !important;
  }

  .qr-panel {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    padding: 0 !important;
  }

  .qr-setup-grid {
    grid-template-columns: 1fr !important;
  }

  .qr-cards-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 20px !important;
  }

  .qr-table-card {
    page-break-inside: avoid;
    box-shadow: none !important;
    border: 2px solid #ccc !important;
  }
}

/* ==========================================================================
   COLLAPSIBLE SECTION STYLES (More Features Accordion)
   ========================================================================== */

.collapsible-section {
  background: rgba(20, 13, 8, 0.4);
  border: 1px solid rgba(197, 160, 89, 0.12);
  border-radius: 18px;
  padding: 0.5rem 1rem;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  transition: all var(--transition-normal);
}

.collapsible-section.expanded {
  background: rgba(20, 13, 8, 0.7);
  border-color: rgba(197, 160, 89, 0.3);
  box-shadow: var(--shadow-glass);
}

.collapsible-trigger {
  width: 100%;
  background: transparent;
  border: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 0.5rem;
  cursor: pointer;
  color: var(--color-gold);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  outline: none;
}

.collapsible-trigger span {
  font-family: var(--font-body);
}

.chevron-icon {
  width: 18px;
  height: 18px;
  transition: transform var(--transition-normal);
  color: var(--color-gold);
}

.chevron-icon.rotated {
  transform: rotate(180deg);
  color: var(--color-gold-hover);
}

.collapsible-content {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height var(--transition-normal) ease-out, opacity var(--transition-normal);
}

.collapsible-content.open {
  max-height: 500px;
  opacity: 1;
}

.placeholder-grid {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding-bottom: 0.5rem;
}

/* ==========================================================================
   USER MANAGEMENT PANEL
   ========================================================================== */

.user-management-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  animation: fadeIn var(--transition-normal);
}

@media (min-width: 992px) {
  .user-management-grid {
    grid-template-columns: 380px 1fr;
  }
}

.user-form-card {
  background: var(--bg-glass);
  border: var(--border-glass);
  box-shadow: var(--shadow-glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 20px;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  align-self: start;
}

.user-form-card h3 {
  font-size: 1.25rem;
  margin-bottom: 0.25rem;
  color: var(--color-gold);
}

.roster-card {
  background: var(--bg-glass);
  border: var(--border-glass);
  box-shadow: var(--shadow-glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 20px;
  padding: 2rem;
}

.roster-card h3 {
  font-size: 1.25rem;
  margin-bottom: 1.25rem;
  color: var(--color-gold);
}

.roster-table-container {
  overflow-x: auto;
}

.roster-table {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
  font-family: var(--font-body);
}

.roster-table th {
  padding: 1rem;
  border-bottom: 1px solid rgba(197, 160, 89, 0.2);
  color: var(--color-gold);
  font-weight: 600;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.roster-table td {
  padding: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  color: var(--color-cream);
  font-size: 0.95rem;
  vertical-align: middle;
}

.roster-table tr:hover td {
  background: rgba(255, 255, 255, 0.02);
}

.btn-delete-user {
  background: rgba(231, 76, 60, 0.08);
  border: 1px solid rgba(231, 76, 60, 0.2);
  color: var(--color-alert);
  padding: 0.4rem 0.8rem;
  border-radius: 6px;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 0.8rem;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 0.3rem;
  outline: none;
}

.btn-delete-user:hover:not(:disabled) {
  background: var(--color-alert);
  color: #fff;
  box-shadow: 0 0 10px var(--color-alert-glow);
}

.btn-delete-user:disabled {
  opacity: 0.3;
  cursor: not-allowed;
  border-color: rgba(255, 255, 255, 0.05);
  color: var(--color-cream-dim);
  background: transparent;
}

/* ==========================================================================
   ANIMATED LUXURY AMBIENT BACKGROUND SYSTEM
   ========================================================================== */

.ambient-bg-glow {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -2;
  overflow: hidden;
  pointer-events: none;
  background-color: rgba(54, 37, 23, 0.9);
}

.glow-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  -webkit-filter: blur(60px);
  will-change: transform;
}

.orb-1 {
  width: 500px;
  height: 500px;
  background: var(--color-gold);
  top: -150px;
  right: -100px;
  opacity: 0.28;
  animation: floatOrb1 15s infinite alternate ease-in-out;
}

.orb-2 {
  width: 600px;
  height: 600px;
  background: var(--color-creamy-coffee);
  bottom: -150px;
  left: -100px;
  opacity: 0.45;
  animation: floatOrb2 17s infinite alternate ease-in-out;
}

.orb-3 {
  width: 420px;
  height: 420px;
  background: var(--color-gold);
  top: 25%;
  left: 10%;
  opacity: 0.20;
  animation: floatOrb3 13s infinite alternate ease-in-out;
}

@keyframes floatOrb1 {
  0% { transform: translate3d(0, 0, 0) scale(1) rotate(0deg); }
  50% { transform: translate3d(-180px, 120px, 0) scale(1.15) rotate(180deg); }
  100% { transform: translate3d(-60px, -90px, 0) scale(0.9) rotate(360deg); }
}

@keyframes floatOrb2 {
  0% { transform: translate3d(0, 0, 0) scale(0.9) rotate(0deg); }
  50% { transform: translate3d(200px, -150px, 0) scale(1.2) rotate(-180deg); }
  100% { transform: translate3d(80px, 100px, 0) scale(0.95) rotate(-360deg); }
}

@keyframes floatOrb3 {
  0% { transform: translate3d(0, 0, 0) scale(1.1); }
  50% { transform: translate3d(-120px, 160px, 0) scale(0.9); }
  100% { transform: translate3d(80px, -70px, 0) scale(1.15); }
}

/* Intermediate screens: keep brand and profile on one row, wrap navigation tabs centered on second row */
@media (max-width: 1200px) and (min-width: 769px) {
  .dashboard-header {
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 1rem 1.5rem;
    gap: 1rem;
  }
  
  .dashboard-brand {
    flex: 1 0 auto;
    justify-content: flex-start;
  }
  
  .dashboard-profile-floating {
    flex: 1 0 auto;
    justify-content: flex-end;
  }
  
  .dashboard-nav {
    flex: 1 1 100%;
    justify-content: center;
    order: 3;
    margin-top: 0.5rem;
  }
}

/* ==========================================================================
   RESPONSIVE DESIGN FOR STAFF DASHBOARD (Mobile & Tablet)
   ========================================================================== */
@media (max-width: 768px) {
  /* Header adjustment */
  .dashboard-header {
    flex-direction: column;
    padding: 1.25rem 1rem;
    gap: 1rem;
    align-items: stretch;
    text-align: center;
  }
  
  .dashboard-brand {
    justify-content: center;
  }
  
  .dashboard-nav {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.5rem;
  }
  
  .nav-tab {
    padding: 0.5rem 0.8rem;
    font-size: 0.85rem;
    flex: 1 1 calc(50% - 0.5rem);
    justify-content: center;
  }
  
  .dashboard-profile-floating {
    position: static;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
    margin-top: 0.5rem;
  }
  
  .staff-welcome-tag {
    justify-content: center;
  }
  
  .audio-toggle-btn {
    justify-content: center;
    width: 100%;
  }

  /* Main container padding */
  .dashboard-main {
    padding: 1rem;
  }

  /* Stats container layout */
  .stats-container {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  /* Control bar layout */
  .control-bar {
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
  }

  .filter-group {
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .filter-btn {
    flex: 1 1 auto;
    text-align: center;
    padding: 0.4rem 0.75rem;
    font-size: 0.8rem;
  }

  .clear-completed-btn {
    justify-content: center;
    width: 100%;
  }

  /* Workboard Grid layout */
  .workboard-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .board-column {
    min-height: auto;
    padding: 1rem;
  }
  
  /* User Roster Table adjustments */
  .user-management-grid {
    grid-template-columns: 1fr !important;
    gap: 1.5rem;
  }
  
  .roster-table th, .roster-table td {
    padding: 0.75rem 0.5rem;
    font-size: 0.85rem;
  }
}

/* ==========================================================================
   CUSTOMER DIGITAL MENU OVERLAY & CARDS STYLING
   ========================================================================== */

/* Menu Drawer Transition Overlay */
.menu-drawer {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bg-glass-heavy);
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform var(--transition-slow);
}

.menu-drawer.open {
  transform: translateY(0);
}

.menu-drawer-header {
  padding: 1.25rem 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: var(--border-glass);
  background: rgba(20, 13, 8, 0.4);
}

.menu-drawer-close {
  cursor: pointer;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.05);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(197, 160, 89, 0.25);
  color: var(--color-gold);
  transition: var(--transition-fast);
}

.menu-drawer-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--color-gold-hover);
  transform: scale(1.05);
}

.menu-drawer-title-container {
  text-align: center;
  flex-grow: 1;
}

.menu-drawer-title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 0.15rem;
}

.menu-drawer-subtitle {
  font-size: 0.75rem;
  text-transform: uppercase;
  color: var(--color-gold);
  letter-spacing: 0.12em;
  font-weight: 600;
}

.menu-drawer-body {
  flex-grow: 1;
  overflow-y: auto;
  padding: 1rem 1.5rem 6.5rem 1.5rem; /* bottom padding to clear floating footer */
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

/* Parisian Backdrop Banner -> Modern Category Showcase Hero */
.menu-hero-card {
  background: rgba(20, 13, 8, 0.75);
  border: var(--border-glass);
  border-radius: 20px;
  padding: 1.25rem;
  box-shadow: var(--shadow-glass);
  display: flex;
  align-items: center;
  gap: 1.5rem;
  transition: all var(--transition-normal);
}

.menu-hero-img-container {
  width: 140px;
  height: 140px;
  min-width: 140px;
  background-color: #faf6eb;
  border-radius: 16px;
  border: 1px solid rgba(197, 160, 89, 0.35);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding: 10px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.4);
}

.menu-hero-text-container {
  flex: 1;
}

.menu-hero-text-container h3 {
  font-family: var(--font-display);
  font-size: 1.45rem;
  color: var(--color-gold);
  margin-bottom: 0.35rem;
  text-shadow: 0 2px 4px rgba(0,0,0,0.5);
}

.menu-hero-text-container p {
  font-size: 0.88rem;
  line-height: 1.45;
  color: var(--color-cream-dim);
}

@media (max-width: 600px) {
  .menu-hero-card {
    flex-direction: column;
    text-align: center;
    gap: 1rem;
    padding: 1.25rem 1rem;
  }
  .menu-hero-img-container {
    width: 120px;
    height: 120px;
    min-width: 120px;
  }
}

/* Live Search Container */
.menu-search-container {
  width: 100%;
}

.search-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.search-input-wrapper input {
  width: 100%;
  background: rgba(20, 13, 8, 0.6);
  border: 1px solid rgba(197, 160, 89, 0.25);
  border-radius: 50px;
  padding: 0.75rem 1rem 0.75rem 2.75rem;
  color: var(--color-cream);
  font-family: inherit;
  font-size: 0.9rem;
  transition: var(--transition-fast);
}

.search-input-wrapper input:focus {
  outline: none;
  border-color: var(--color-gold);
  box-shadow: 0 0 12px var(--color-gold-glow);
  background: rgba(20, 13, 8, 0.8);
}

.search-icon {
  position: absolute;
  left: 1rem;
  color: var(--color-gold);
  pointer-events: none;
}

/* Category Pill horizontal swipe */
.cust-category-scroll {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  padding-bottom: 0.4rem;
  scrollbar-width: none; /* Hide standard scrollbars */
}

.cust-category-scroll::-webkit-scrollbar {
  display: none; /* Hide Chrome/Safari scrollbar */
}

.cust-category-pill {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(197, 160, 89, 0.15);
  border-radius: 50px;
  padding: 0.5rem 1.15rem;
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--color-cream-dim);
  cursor: pointer;
  white-space: nowrap;
  transition: var(--transition-fast);
}

.cust-category-pill:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--color-cream);
}

.cust-category-pill.active {
  background: var(--color-gold);
  border-color: var(--color-gold);
  color: #1a100a;
  font-weight: 600;
  box-shadow: 0 4px 10px rgba(197, 160, 89, 0.25);
}

/* Menu Items Responsive Grid */
.menu-items-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
}

@media (max-width: 480px) {
  .menu-items-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
  }
}

@media (min-width: 768px) {
  .menu-items-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
  }
}

/* Menu Item Card styling */
.menu-item-card {
  background: rgba(20, 13, 8, 0.45);
  border: var(--border-glass);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--shadow-glass);
  display: flex;
  flex-direction: column;
  transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1), 
              border-color 0.3s ease, 
              box-shadow 0.3s ease;
  position: relative;
  z-index: 1;
}

.menu-item-card:hover,
.menu-item-card.expanded {
  transform: scale(1.25) !important;
  z-index: 50;
  border-color: rgba(197, 160, 89, 0.65);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.85), 0 0 25px rgba(197, 160, 89, 0.35);
}

.menu-item-img-wrapper {
  aspect-ratio: 1.25 / 1;
  position: relative;
  background-color: #faf6eb;
  border-radius: 12px;
  border: 1px solid rgba(197, 160, 89, 0.15);
  margin: 10px 10px 0 10px;
  box-shadow: inset 0 0 10px rgba(0,0,0,0.05);
  overflow: hidden;
}

.menu-item-img {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}

.menu-item-card:hover .menu-item-img,
.menu-item-card.expanded .menu-item-img {
  transform: scale(1.12);
}

.menu-item-sig-badge {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  background: var(--color-gold);
  color: #1a100a;
  font-size: 0.65rem;
  font-weight: bold;
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.25);
}

.menu-item-soldout-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(12, 8, 5, 0.75);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
}

.menu-item-soldout-overlay span {
  border: 1.5px solid var(--color-alert);
  color: var(--color-alert);
  padding: 0.25rem 0.6rem;
  text-transform: uppercase;
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: bold;
  border-radius: 4px;
  letter-spacing: 0.05em;
  transform: rotate(-5deg);
}

.menu-item-card.sold-out {
  opacity: 0.8;
  border-color: rgba(231, 76, 60, 0.2);
}

.menu-item-info {
  padding: 0.75rem 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  flex-grow: 1;
}

.menu-item-header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.15rem;
}

.menu-item-title {
  font-size: 0.98rem;
  font-weight: 600;
  color: var(--color-cream);
  font-family: var(--font-body);
  line-height: 1.25;
  display: block; /* Allow long drink names (e.g. Spanish Latte, Indian Ocean Mojito) to wrap naturally instead of truncating */
}

.menu-item-price {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--color-gold);
  font-size: 0.95rem;
  margin-top: 0.1rem;
}

.menu-item-desc {
  font-size: 0.75rem;
  line-height: 1.35;
  color: var(--color-cream-dim);
  margin-top: 0.15rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  height: 2.7em;
  transition: height 0.35s cubic-bezier(0.16, 1, 0.3, 1), 
              max-height 0.35s cubic-bezier(0.16, 1, 0.3, 1), 
              color 0.25s ease;
}

.menu-item-card:hover .menu-item-desc,
.menu-item-card.expanded .menu-item-desc {
  -webkit-line-clamp: unset;
  display: block;
  height: auto;
  max-height: 200px;
  color: var(--color-cream);
}

.menu-item-meta {
  margin-top: auto;
  padding-top: 0.35rem;
}

.menu-item-category-tag {
  font-size: 0.6rem;
  text-transform: uppercase;
  color: var(--color-gold);
  background: rgba(197, 160, 89, 0.08);
  padding: 0.15rem 0.4rem;
  border-radius: 4px;
  letter-spacing: 0.05em;
  border: 1px solid rgba(197, 160, 89, 0.12);
}

/* Floating Pinned Drawer Footer CTA */
.menu-drawer-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 1rem 1.5rem;
  background: linear-gradient(to top, rgba(12, 8, 5, 0.95) 75%, transparent);
  border-top: var(--border-glass);
}

.menu-call-waiter-btn {
  width: 100%;
  background: var(--color-gold) !important;
  border-color: var(--color-gold) !important;
  box-shadow: 0 4px 15px rgba(197, 160, 89, 0.3) !important;
  cursor: pointer;
  transition: var(--transition-fast) !important;
}

.menu-call-waiter-btn:hover {
  background: var(--color-gold-hover) !important;
  box-shadow: 0 6px 20px rgba(197, 160, 89, 0.45) !important;
  transform: translateY(-2px);
}

/* --- STAFF PORTAL INLINE TOGGLE SWITCHES --- */
.switch {
  position: relative;
  display: inline-block;
}

.slider {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: .4s;
  border-radius: 34px;
}

.slider:before {
  position: absolute;
  content: "";
  height: 14px;
  width: 14px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: .4s;
  border-radius: 50%;
}

input:checked + .slider:before {
  transform: translateX(20px);
}

/* Database Resiliency Volatile Banner */
.db-warning-banner {
  background: linear-gradient(135deg, rgba(231, 76, 60, 0.25), rgba(243, 156, 18, 0.25));
  border: 1px solid rgba(231, 76, 60, 0.45);
  border-radius: 12px;
  padding: 0.95rem 1.25rem;
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  color: #fff;
  font-family: var(--font-body);
  font-size: 0.88rem;
  line-height: 1.45;
  box-shadow: 0 4px 15px rgba(0,0,0,0.25);
  backdrop-filter: blur(10px);
  animation: bannerPulse 4s infinite ease-in-out;
}

.db-warning-banner svg {
  color: #e74c3c;
  flex-shrink: 0;
  animation: iconBlink 2s infinite ease-in-out;
}

@keyframes bannerPulse {
  0%, 100% { border-color: rgba(231, 76, 60, 0.45); box-shadow: 0 4px 15px rgba(0,0,0,0.25); }
  50% { border-color: rgba(243, 156, 18, 0.65); box-shadow: 0 4px 20px rgba(243, 156, 18, 0.15); }
}

@keyframes iconBlink {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(0.95); }
}

/* ==========================================================================
   PREMIUM FLOATING TABLESIDE SERVICE WIDGET
   ========================================================================== */

.floating-service-widget {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: 92%;
  max-width: 440px;
  background: rgba(20, 13, 8, 0.88);
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  border: 1px solid rgba(197, 160, 89, 0.28);
  border-radius: 20px;
  padding: 12px 14px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), 0 0 15px rgba(197, 160, 89, 0.15);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  gap: 8px;
  animation: slideUpWidget 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards,
             pulseWidgetBorder 4s infinite ease-in-out;
}

@keyframes pulseWidgetBorder {
  0%, 100% {
    border-color: rgba(197, 160, 89, 0.25);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), 0 0 12px rgba(197, 160, 89, 0.15);
  }
  50% {
    border-color: rgba(197, 160, 89, 0.65);
    box-shadow: 0 10px 35px rgba(0, 0, 0, 0.6), 0 0 25px rgba(197, 160, 89, 0.45);
  }
}

@keyframes slideUpWidget {
  from {
    transform: translate(-50%, 40px);
    opacity: 0;
  }
  to {
    transform: translate(-50%, 0);
    opacity: 1;
  }
}

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

.widget-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 4px;
}

.widget-table-info {
  display: flex;
  align-items: center;
  gap: 6px;
}

.widget-table-dot {
  width: 7px;
  height: 7px;
  background-color: #2ecc71;
  border-radius: 50%;
  box-shadow: 0 0 8px rgba(46, 204, 113, 0.8);
  display: inline-block;
  animation: pulseDot 2s infinite;
}

@keyframes pulseDot {
  0% { transform: scale(1); opacity: 1; box-shadow: 0 0 8px rgba(46, 204, 113, 0.8); }
  50% { transform: scale(1.2); opacity: 0.6; box-shadow: 0 0 12px rgba(46, 204, 113, 0.4); }
  100% { transform: scale(1); opacity: 1; box-shadow: 0 0 8px rgba(46, 204, 113, 0.8); }
}

#tableText {
  font-family: var(--font-display);
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--color-gold);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.widget-sync-status {
  font-family: var(--font-body);
  font-size: 0.65rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.4);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.widget-actions {
  display: flex;
  gap: 8px;
  width: 100%;
}

.widget-btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(197, 160, 89, 0.15);
  border-radius: 12px;
  padding: 8px 4px;
  color: #fff;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  outline: none;
}

/* Dynamic breathing gold pulse animation on the active buttons */
.widget-btn:not(:disabled):not(.cooldown-active) {
  animation: pulseButtonBorder 3s infinite ease-in-out;
}

@keyframes pulseButtonBorder {
  0%, 100% {
    border-color: rgba(197, 160, 89, 0.15);
    box-shadow: 0 0 0 rgba(197, 160, 89, 0);
    background: rgba(255, 255, 255, 0.03);
  }
  50% {
    border-color: rgba(197, 160, 89, 0.45);
    box-shadow: 0 0 10px rgba(197, 160, 89, 0.15), inset 0 0 8px rgba(197, 160, 89, 0.06);
    background: rgba(197, 160, 89, 0.05);
  }
}

.widget-btn:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(197, 160, 89, 0.4);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.widget-btn:active:not(:disabled) {
  transform: translateY(0);
}

.widget-btn:disabled {
  cursor: not-allowed;
  opacity: 0.55;
  background: rgba(20, 13, 8, 0.4) !important;
  border-color: rgba(197, 160, 89, 0.05) !important;
}

/* Premium Locked State for Water & Bill Buttons */
.widget-btn.locked-state {
  opacity: 0.65;
  border-style: dashed !important;
  border-color: rgba(197, 160, 89, 0.25) !important;
  animation: none !important; /* disable pulsing */
  background: rgba(255, 255, 255, 0.01) !important;
}

.widget-btn.locked-state:hover {
  opacity: 0.85;
  background: rgba(197, 160, 89, 0.04) !important;
  border-color: rgba(197, 160, 89, 0.4) !important;
  transform: translateY(-1px);
}

.widget-btn.locked-state .widget-btn-ewt {
  color: var(--color-cream-dim) !important;
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}


.widget-btn-icon {
  font-size: 1.15rem;
  transition: transform 0.2s ease;
}

.widget-btn:hover:not(:disabled) .widget-btn-icon {
  transform: scale(1.15);
}

.widget-btn-title {
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--color-cream);
  letter-spacing: 0.02em;
}

.widget-btn-ewt {
  font-family: var(--font-body);
  font-size: 0.62rem;
  font-weight: 700;
  color: var(--color-gold);
  background: rgba(197, 160, 89, 0.1);
  padding: 1px 6px;
  border-radius: 4px;
  border: 1px solid rgba(197, 160, 89, 0.12);
  transition: all 0.25s ease;
}

.widget-btn.cooldown-active .widget-btn-ewt {
  color: var(--color-alert) !important;
  background: rgba(231, 76, 60, 0.1) !important;
  border-color: rgba(231, 76, 60, 0.2) !important;
}

/* Float Tracker above widget */
.guest-tracker-panel {
  position: fixed !important;
  bottom: 112px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 92% !important;
  max-width: 440px !important;
  z-index: 10050 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: block;
}

.guest-tracker-panel .tracker-heading {
  display: none !important; /* Hide tracker section heading to save vital screen estate */
}

.tracker-cards-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.tracker-card {
  margin: 0 !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5), 0 0 10px rgba(197,160,89,0.1) !important;
  border: 1px solid rgba(197, 160, 89, 0.3) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  animation: slideUpCard 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards !important;
}

.menu-container-flat {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin-bottom: 2rem;
  width: 100%;
}

/* ═══════════════════════════════════════════════════════════════════
   BAR / KITCHEN SLIDING SWITCHER
═══════════════════════════════════════════════════════════════════ */
.menu-type-switcher {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: rgba(20, 13, 8, 0.7);
  border: 1px solid rgba(212, 175, 55, 0.2);
  border-radius: 14px;
  padding: 4px;
  gap: 0;
  overflow: hidden;
}

/* The gliding highlight pill */
.switcher-glider {
  position: absolute;
  top: 4px;
  left: 4px;
  width: calc(50% - 4px);
  height: calc(100% - 8px);
  background: linear-gradient(135deg, rgba(212,175,55,0.9) 0%, rgba(180,145,40,0.95) 100%);
  border-radius: 10px;
  box-shadow: 0 2px 10px rgba(212,175,55,0.3);
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
  z-index: 0;
  pointer-events: none;
}

.switcher-btn {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.6rem 0.5rem;
  border: none;
  background: transparent;
  border-radius: 10px;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-cream-dim);
  cursor: pointer;
  transition: color 0.25s ease;
  white-space: nowrap;
}

.switcher-btn .switcher-icon {
  font-size: 1rem;
}

.switcher-btn.active {
  color: #1a100a;
  font-weight: 700;
}

.switcher-btn:not(.active):hover {
  color: var(--color-cream);
}

/* ═══════════════════════════════════════════════════════════════════
   KITCHEN CARD EMOJI PLACEHOLDER
═══════════════════════════════════════════════════════════════════ */
.menu-item-emoji-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.5rem;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.4));
  user-select: none;
  pointer-events: none;
}

/* ═══════════════════════════════════════════════════════════════════
   DIET / ORIGIN TAG CHIPS
═══════════════════════════════════════════════════════════════════ */
.menu-item-tags-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  margin-top: 0.3rem;
}

.menu-item-tag {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 600;
  font-family: var(--font-body);
  padding: 2px 8px;
  border-radius: 20px;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* ═══════════════════════════════════════════════════════════════════
   LUXURY DESIGN UPGRADES: STAGGERED ANIMATIONS, SHIMMERS, GRADIENTS
   ═══════════════════════════════════════════════════════════════════ */

/* Staggered card fade-in */
.menu-item-card {
  animation: itemCardFadeIn 0.55s cubic-bezier(0.16, 1, 0.3, 1) both;
}

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

/* Skeleton Loader Shimmer styles */
.skeleton-card {
  background: rgba(20, 13, 8, 0.4);
  border: 1px solid rgba(197, 160, 89, 0.08);
  border-radius: 16px;
  height: 200px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: 12px;
  gap: 10px;
  box-shadow: var(--shadow-glass);
}

.skeleton-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: -150%;
  width: 50%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(212, 175, 55, 0.07) 50%,
    transparent 100%
  );
  animation: shimmerSweep 1.4s infinite ease-in-out;
}

@keyframes shimmerSweep {
  0% { left: -150%; }
  50% { left: 150%; }
  100% { left: 150%; }
}

.skeleton-img {
  height: 95px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.02);
}

.skeleton-title {
  height: 14px;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 4px;
  width: 60%;
}

.skeleton-desc {
  height: 10px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 4px;
  width: 90%;
}

.skeleton-price {
  height: 12px;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 4px;
  width: 30%;
  margin-top: auto;
}

/* Signature Premium Border Pulsing Glow */
.signature-glow-card {
  position: relative;
  border-color: rgba(212, 175, 55, 0.3) !important;
  animation: pulseSignatureGlow 3.5s infinite alternate ease-in-out,
             itemCardFadeIn 0.55s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes pulseSignatureGlow {
  0% {
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5), 0 0 4px rgba(212, 175, 55, 0.05);
    border-color: rgba(212, 175, 55, 0.25);
  }
  100% {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.65), 0 0 16px rgba(212, 175, 55, 0.28);
    border-color: rgba(212, 175, 55, 0.6);
  }
}

/* Premium Category Pill Enhancements */
.cust-category-pill {
  transition: all 0.35s cubic-bezier(0.25, 1, 0.5, 1);
}

.cust-category-pill:active {
  transform: scale(0.95);
}

.cust-category-pill.active {
  transform: scale(1.05);
  box-shadow: 0 4px 15px rgba(197, 160, 89, 0.35), 0 0 8px rgba(197, 160, 89, 0.2);
  border-color: rgba(197, 160, 89, 0.85);
}

/* ═══════════════════════════════════════════════════════════════════
   WIDGET BUTTON HAPTIC MICRO-ANIMATIONS
   ═══════════════════════════════════════════════════════════════════ */

/* Wobble/Shake for Waiter Bell Icon */
.wobble-anim .widget-btn-icon {
  animation: bellWobble 0.65s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
  transform-origin: top center;
}

@keyframes bellWobble {
  0%, 100% { transform: rotate(0); }
  15% { transform: rotate(-16deg); }
  30% { transform: rotate(14deg); }
  45% { transform: rotate(-10deg); }
  60% { transform: rotate(8deg); }
  75% { transform: rotate(-4deg); }
}

/* Ripple/Pulse for Water Droplet */
.ripple-anim .widget-btn-icon {
  animation: waterRipple 0.65s cubic-bezier(0.25, 1, 0.5, 1) both;
}

@keyframes waterRipple {
  0% {
    transform: scale(1);
    filter: drop-shadow(0 0 0 rgba(52, 152, 219, 0.8));
  }
  50% {
    transform: scale(1.35);
    filter: drop-shadow(0 0 16px rgba(52, 152, 219, 0.95));
  }
  100% {
    transform: scale(1);
    filter: drop-shadow(0 0 0 rgba(52, 152, 219, 0));
  }
}

/* Slide Up/Down for Bill Icon */
.slide-anim .widget-btn-icon {
  animation: billSlide 0.65s cubic-bezier(0.25, 1, 0.5, 1) both;
}

@keyframes billSlide {
  0%, 100% { transform: translateY(0) scale(1); }
  30% { transform: translateY(-8px) scale(1.1); }
  50% { transform: translateY(2px) scale(0.95); }
  75% { transform: translateY(-2px) scale(1.02); }
}

/* ==========================================================================
   MENU HUB TAB STYLING
   ========================================================================== */
.menu-hub-tab-btn {
  background: transparent;
  border: 1px solid transparent;
  color: var(--color-cream-dim);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.9rem;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.menu-hub-tab-btn:hover {
  color: var(--color-cream);
  background: rgba(255, 255, 255, 0.03);
}

.menu-hub-tab-btn.active {
  color: var(--color-gold);
  background: rgba(197, 160, 89, 0.08);
  border-color: rgba(197, 160, 89, 0.25);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

/* ==========================================================================
   RESPONSIVE OVERFLOWS FOR DESKTOPS
   ========================================================================== */

/* ==========================================================================
   TERMINAL SECURITY & SESSION OVERHAUL STYLES
   ========================================================================== */

/* Active Online Pulse Indicator */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.25rem 0.6rem;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.status-badge.online {
  color: var(--color-success);
  border-color: rgba(46, 204, 113, 0.2);
  background: rgba(46, 204, 113, 0.05);
}

.status-badge.offline {
  color: var(--color-cream-dim);
  opacity: 0.65;
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}

.status-badge.online .status-dot {
  background: var(--color-success);
  box-shadow: 0 0 8px var(--color-success);
  animation: pulseGreen 1.8s infinite ease-in-out;
}

@keyframes pulseGreen {
  0% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(46, 204, 113, 0.5);
  }
  70% {
    transform: scale(1);
    box-shadow: 0 0 0 6px rgba(46, 204, 113, 0);
  }
  100% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(46, 204, 113, 0);
  }
}

/* Action Button Overrides for Table */
.btn-roster-action {
  font-size: 0.75rem;
  font-weight: 500;
  padding: 0.35rem 0.7rem;
  border-radius: 6px;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  border: 1px solid transparent;
  background: transparent;
  color: var(--color-cream-dim);
}

.btn-roster-action.reset {
  color: var(--color-gold);
  border-color: rgba(197, 160, 89, 0.2);
  background: rgba(197, 160, 89, 0.05);
}

.btn-roster-action.reset:hover {
  color: var(--color-gold-hover);
  border-color: var(--color-gold);
  background: rgba(197, 160, 89, 0.1);
  box-shadow: 0 2px 10px rgba(197, 160, 89, 0.15);
}

.btn-roster-action.terminate {
  color: #ff5e57;
  border-color: rgba(255, 94, 87, 0.2);
  background: rgba(255, 94, 87, 0.05);
}

.btn-roster-action.terminate:hover {
  color: #ff3b30;
  border-color: #ff5e57;
  background: rgba(255, 94, 87, 0.1);
  box-shadow: 0 2px 10px rgba(255, 94, 87, 0.15);
}

/* Form success and failure alerts */
.alert-box {
  padding: 0.75rem 1rem;
  border-radius: 8px;
  font-size: 0.85rem;
  text-align: center;
  font-weight: 500;
  margin-top: 1rem;
  width: 100%;
}

.alert-box.success {
  background: rgba(46, 204, 113, 0.08);
  border: 1px solid rgba(46, 204, 113, 0.25);
  color: var(--color-success);
}

.alert-box.danger {
  background: rgba(231, 76, 60, 0.08);
  border: 1px solid rgba(231, 76, 60, 0.25);
  color: #ff5e57;
}

/* ==========================================================================
   TABLESIDE POS LINKER & LUXURY RECEIPT WIDGETS
   ========================================================================== */

.linker-section {
  width: 100%;
  margin-bottom: 2rem;
  animation: fadeIn var(--transition-normal);
}

.table-linker-panel {
  background: var(--bg-glass-heavy);
  border: var(--border-glass);
  box-shadow: var(--shadow-glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 20px;
  padding: 1.5rem;
}

.table-linker-panel .panel-header h2 {
  font-size: 1.2rem;
  margin: 0 0 0.25rem 0;
  color: var(--color-gold);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.table-linker-panel .panel-header .panel-subtitle {
  font-size: 0.8rem;
  color: var(--color-cream-dim);
  margin: 0;
}

.table-linker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
  margin-top: 1.25rem;
}

.table-link-card {
  background: rgba(20, 13, 8, 0.4);
  border: 1px solid rgba(197, 160, 89, 0.15);
  border-radius: 12px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  transition: all var(--transition-normal);
}

.table-link-card:hover {
  border-color: rgba(197, 160, 89, 0.35);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.table-link-card.is-linked {
  border-color: rgba(46, 204, 113, 0.3);
  background: rgba(46, 204, 113, 0.04);
}

.link-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.link-table-num {
  font-weight: 700;
  color: var(--color-cream);
  font-size: 0.9rem;
}

.link-badge {
  font-size: 0.65rem;
  color: #ff9f43;
  border: 1px solid rgba(255, 159, 67, 0.3);
  padding: 0.15rem 0.4rem;
  border-radius: 4px;
  background: rgba(255, 159, 67, 0.05);
  font-weight: 600;
  letter-spacing: 0.05em;
}

.link-badge.is-paid {
  color: var(--color-success);
  border: 1px solid rgba(46, 204, 113, 0.3);
  background: rgba(46, 204, 113, 0.05);
}

.link-card-body {
  display: flex;
  gap: 0.5rem;
}

.link-input {
  background: rgba(20, 13, 8, 0.7);
  border: 1px solid rgba(197, 160, 89, 0.2);
  border-radius: 6px;
  padding: 0.4rem 0.6rem;
  color: var(--color-cream);
  font-size: 0.8rem;
  width: 100%;
  min-width: 0;
  outline: none;
  font-family: inherit;
  transition: border-color var(--transition-fast);
}

.link-input:focus {
  border-color: var(--color-gold);
}

.link-input:disabled {
  opacity: 0.65;
  color: var(--color-cream-dim);
  cursor: not-allowed;
  border-color: rgba(255, 255, 255, 0.05);
}

.btn-link-pos {
  background: var(--color-gold);
  border: none;
  border-radius: 6px;
  color: var(--color-espresso);
  padding: 0.4rem 0.8rem;
  font-weight: 600;
  font-size: 0.8rem;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.btn-link-pos:hover {
  background: var(--color-gold-hover);
  transform: translateY(-1px);
}

.btn-unlink-pos {
  background: rgba(231, 76, 60, 0.12);
  border: 1px solid rgba(231, 76, 60, 0.3);
  border-radius: 6px;
  color: #ff5e57;
  padding: 0.4rem 0.8rem;
  font-weight: 600;
  font-size: 0.8rem;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.btn-unlink-pos:hover {
  background: #ff5e57;
  border-color: #ff5e57;
  color: #fff;
  transform: translateY(-1px);
}

/* Customer Luxury Receipt Styling */
.receipt-card-luxury {
  background: linear-gradient(135deg, rgba(197, 160, 89, 0.08) 0%, rgba(20, 13, 8, 0.6) 100%) !important;
  border: 1px solid rgba(197, 160, 89, 0.35) !important;
  box-shadow: 0 8px 25px rgba(197, 160, 89, 0.1) !important;
  position: relative;
  overflow: hidden;
  animation: pulseGlow 3s infinite alternate;
}

.receipt-glow-effect {
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, rgba(197, 160, 89, 0.03) 0%, transparent 70%);
  pointer-events: none;
}

.btn-customer-receipt {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: linear-gradient(90deg, #c5a059 0%, #e0c07e 100%);
  color: #1c120a;
  font-family: var(--font-body);
  font-weight: bold;
  padding: 0.7rem 1rem;
  border-radius: 8px;
  text-decoration: none;
  font-size: 0.85rem;
  letter-spacing: 0.05em;
  transition: all 0.3s;
  box-shadow: 0 4px 15px rgba(197, 160, 89, 0.25);
  text-transform: uppercase;
  margin-top: 0.5rem;
  box-sizing: border-box;
  border: none;
}

.btn-customer-receipt:hover {
  box-shadow: 0 6px 20px rgba(197, 160, 89, 0.4);
  transform: translateY(-2px);
  filter: brightness(1.08);
}

/* Custom styles for Personal PIN Update and Welcome Widget */
.staff-pin-btn {
  background: rgba(197, 160, 89, 0.15);
  border: 1px solid rgba(197, 160, 89, 0.3);
  color: var(--color-gold);
  cursor: pointer;
  padding: 0.3rem 0.6rem;
  font-size: 0.75rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 4px;
  border-radius: 6px;
  transition: all 0.2s ease;
  margin-left: 5px;
}
.staff-pin-btn:hover {
  background: rgba(197, 160, 89, 0.3);
  border-color: var(--color-gold);
  transform: translateY(-1px);
}
.modal-close-btn {
  background: transparent;
  border: none;
  color: var(--color-cream-dim);
  cursor: pointer;
  font-size: 1.5rem;
  transition: color 0.2s;
  padding: 0;
  line-height: 1;
}
.modal-close-btn:hover {
  color: var(--color-gold);
}

/* User table POS badges */
.pos-badge-linked {
  background: rgba(46, 204, 113, 0.15);
  color: #2ecc71;
  border: 1px solid rgba(46, 204, 113, 0.3);
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.pos-badge-not-linked {
  background: rgba(231, 76, 60, 0.15);
  color: #e74c3c;
  border: 1px solid rgba(231, 76, 60, 0.3);
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* Button style for Link POS inside roster actions */
.btn-roster-action.link-pos {
  background: rgba(197, 160, 89, 0.15);
  border: 1px solid rgba(197, 160, 89, 0.3);
  color: var(--color-gold);
}
.btn-roster-action.link-pos:hover {
  background: var(--color-gold);
  color: #140d08;
}

/* Disabled state styling for request card Complete button */
.btn-card-action.btn-done-action:disabled {
  opacity: 0.4;
  background: rgba(197, 160, 89, 0.05) !important;
  border-color: rgba(197, 160, 89, 0.1) !important;
  color: var(--color-cream-dim) !important;
  cursor: not-allowed !important;
  box-shadow: none !important;
  transform: none !important;
}

/* Sub-Tab Navigation Bar inside Management Hub */
.sub-tab-bar {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  background: rgba(20, 13, 8, 0.4);
  border: 1px solid rgba(197, 160, 89, 0.15);
  border-radius: 12px;
  padding: 0.35rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
  box-shadow: inset 0 2px 10px rgba(0, 0, 0, 0.2);
}
.sub-tab-btn {
  background: transparent;
  border: 1px solid transparent;
  color: var(--color-cream-dim);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.85rem;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.sub-tab-btn:hover {
  color: var(--color-cream);
  background: rgba(255, 255, 255, 0.03);
}
.sub-tab-btn.active {
  color: var(--color-gold);
  background: rgba(197, 160, 89, 0.08);
  border-color: rgba(197, 160, 89, 0.25);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}
.sub-pane {
  display: none;
  animation: fadeIn var(--transition-normal);
}
.sub-pane.active {
  display: block;
}

/* ==========================================================================
   PREMIUM ANIMATED SPLASH SCREEN (REUSABLE SYSTEM)
   ========================================================================== */
.splash-screen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: radial-gradient(circle at center, #422d1d 0%, #110b07 100%); /* Center-illuminated vignettes coffee gradient */
  z-index: 100000;     /* Float above everything */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transform: translateY(0);
  transition: transform 1.1s cubic-bezier(0.85, 0, 0.15, 1), opacity 0.5s ease-out 0.6s;
  pointer-events: all;
}

.splash-screen.fade-out {
  transform: translateY(-100vh);
  opacity: 0.9;
  pointer-events: none;
}

/* Layered dissolve for inner elements on shutter slide-out */
.splash-screen.fade-out .splash-logo {
  transform: scale(0.9);
  opacity: 0;
  transition: transform 0.8s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.6s ease-out;
}

.splash-screen.fade-out .splash-footer {
  transform: translateY(15px);
  opacity: 0;
  transition: transform 0.8s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.6s ease-out;
}

.splash-screen.fade-out .splash-loader {
  opacity: 0;
  transition: opacity 0.5s ease-out;
}

.splash-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

.splash-logo-wrapper {
  position: relative;
  width: 160px;
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.splash-logo-ripple {
  position: absolute;
  width: 100px;
  height: 100px;
  border: 1px solid rgba(197, 160, 89, 0.28);
  border-radius: 50%;
  opacity: 0;
  pointer-events: none;
  animation: splashLogoRippleLoop 3s infinite cubic-bezier(0.1, 0.8, 0.3, 1);
  z-index: 1;
}

.splash-logo {
  width: 140px;
  height: auto;
  object-fit: contain;
  z-index: 2;
  opacity: 0;
  animation: splashLogoEntrance 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.splash-logo-glow {
  position: absolute;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(197, 160, 89, 0.18) 0%, rgba(197, 160, 89, 0) 70%);
  filter: blur(12px);
  z-index: 1;
  pointer-events: none;
  animation: splashLogoGlowPulse 4s infinite ease-in-out;
}

.splash-loader {
  width: 65px;
  height: 2px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
  opacity: 0;
  animation: fadeIn 0.6s ease forwards 0.8s;
}

.splash-loader-progress {
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, var(--color-gold), transparent);
  animation: splashLoaderSweep 1.8s infinite ease-in-out;
}

.splash-footer {
  position: absolute;
  bottom: 50px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  opacity: 0;
  animation: splashFadeInUp 1s cubic-bezier(0.16, 1, 0.3, 1) forwards 0.6s;
  border-top: 1px solid rgba(197, 160, 89, 0.12);
  padding-top: 12px;
  width: 160px;
}

.splash-credit-label {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-cream-dim);
  font-family: var(--font-body);
  font-weight: 500;
}

.splash-designer-name {
  font-size: 2.40rem; /* Elegant cursive calligraphy lettering */
  font-family: 'Pinyon Script', cursive; /* Fancy signature font loaded from Google Fonts */
  font-weight: 400;
  color: var(--color-gold);
  text-shadow: 0 0 15px rgba(197, 160, 89, 0.4);
  margin-top: -6px; /* Offset scripts vertical height */
}

/* Animations Keyframes */
@keyframes splashLogoEntrance {
  0% {
    transform: scale(0.82);
    opacity: 0;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes splashLogoGlowPulse {
  0%, 100% {
    transform: scale(0.92);
    opacity: 0.7;
  }
  50% {
    transform: scale(1.12);
    opacity: 1;
  }
}

@keyframes splashLogoRippleLoop {
  0% {
    transform: scale(0.75);
    opacity: 0.8;
    box-shadow: 0 0 10px rgba(197, 160, 89, 0.1);
  }
  100% {
    transform: scale(1.75);
    opacity: 0;
    box-shadow: 0 0 40px rgba(197, 160, 89, 0);
  }
}

@keyframes splashLoaderSweep {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}

@keyframes splashFadeInUp {
  0% {
    transform: translateY(15px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

/* ==========================================================================
   DEEGAAN POS TERMINAL WIDGET & AUTO-LOGIN MODAL
   ========================================================================== */
#posTerminalModal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10050;
  background: rgba(15, 10, 6, 0.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  box-sizing: border-box;
  animation: fadeIn 0.3s ease-out;
}

#posTerminalModal.hidden {
  display: none !important;
}

.pos-modal-card {
  width: 95%;
  max-width: 1450px;
  height: 90%;
  background: rgba(26, 19, 13, 0.96);
  border: 1px solid rgba(197, 160, 89, 0.35);
  border-radius: 20px;
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.85), 0 0 40px rgba(197, 160, 89, 0.12);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: slideInUp 0.35s cubic-bezier(0.16, 1, 0.3, 1);
  position: relative;
}

.pos-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 2rem;
  background: rgba(36, 26, 18, 0.95);
  border-bottom: 1px solid rgba(197, 160, 89, 0.25);
  user-select: none;
}

.pos-modal-title {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.pos-modal-title h3 {
  margin: 0;
  font-size: 1.35rem;
  color: var(--color-gold);
  font-family: var(--font-display);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.pos-terminal-indicator {
  font-size: 1.4rem;
  filter: drop-shadow(0 0 5px rgba(197, 160, 89, 0.6));
}

.pos-modal-actions {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}

.pos-modal-actions .spinner {
  width: 18px;
  height: 18px;
  border: 2px solid transparent;
  border-top-color: var(--color-gold);
  border-bottom-color: var(--color-gold);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

.pos-modal-body {
  flex: 1;
  background: #ffffff;
  position: relative;
  overflow: hidden;
  border-bottom-left-radius: 19px;
  border-bottom-right-radius: 19px;
}

#posTerminalIframe {
  width: 100%;
  height: 100%;
  border: none;
  background: #ffffff;
}

/* Make sure modal is highly responsive */
@media (max-width: 768px) {
  #posTerminalModal {
    padding: 0.5rem;
  }
  .pos-modal-card {
    width: 100%;
    height: 98%;
    border-radius: 12px;
  }
  .pos-modal-header {
    padding: 1rem;
  }
  .pos-modal-title h3 {
    font-size: 1.15rem;
  }
}

