/* =============================================
   GROOMO MOBILE APP UI THEME
   Complete Android Native App Interface
   Inspired by: Swiggy, Zomato, Urban Company, Uber
   ============================================= */

/* ===== 1. APP COLOR SYSTEM ===== */
:root {
  --primary: #2563EB;
  --primary-dark: #1d4ed8;
  --primary-light: #EFF6FF;
  --primary-glow: rgba(37,99,235,0.12);
  --primary-rgb: 37,99,235;
  --p: #2563EB;
  --pd: #1d4ed8;
  --pl: #EFF6FF;
  --app-bg: #F2F2F7;
  --app-surface: #FFFFFF;
  --app-text: #1C1C1E;
  --app-text-secondary: #8E8E93;
  --app-text-tertiary: #C7C7CC;
  --app-border: #E5E5EA;
  --app-elevation-1: 0 1px 3px rgba(0,0,0,0.06);
  --app-elevation-2: 0 4px 12px rgba(0,0,0,0.08);
  --app-elevation-3: 0 8px 28px rgba(0,0,0,0.1);
  --app-elevation-4: 0 12px 40px rgba(0,0,0,0.12);
  --app-radius-sm: 10px;
  --app-radius: 14px;
  --app-radius-lg: 18px;
  --app-radius-xl: 22px;
  --shadow-glow: 0 4px 20px rgba(37,99,235,0.25);
  --app-nav-height: 52px;
  --app-top-height: 48px;
  --radius-xl: 18px;
  --radius-lg: 14px;
  --radius: 12px;
  --radius-sm: 10px;
  --radius-full: 50px;
  --shadow-card: 0 1px 3px rgba(0,0,0,0.06);
  --shadow: 0 4px 12px rgba(0,0,0,0.08);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
  --shadow-hover: 0 8px 30px rgba(0,0,0,0.1);
  --border-light: #E5E5EA;
  --border: #E5E5EA;
  --bg: #f8fafc;
  --text-muted: #94a3b8;
  --text-secondary: #64748b;
  --text-primary: #1e293b;
  --text: #1e293b;
  --secondary: #1e293b;
  --card-bg: #ffffff;
  --card-shadow: 0 1px 3px rgba(0,0,0,0.06);
  --btn-text: #ffffff;
  --bottom-nav-bg: #ffffff;
  --sidebar-bg: #ffffff;
  --sidebar-text: #475569;
  --sidebar-active-bg: #EFF6FF;
  --table-header-color: #64748b;
  --warning: #F59E0B;
  --warning-light: #FEF3C7;
  --success: #10B981;
  --success-light: #D1FAE5;
  --danger: #EF4444;
  --danger-light: #FEE2E2;
  --info: #3B82F6;
  --info-light: #DBEAFE;
  --transition: all 0.25s ease;
  --transition-bounce: all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  --sp-success: #10B981;
}

/* ===== 2. GLOBAL APP RESET ===== */
body {
  background: var(--app-bg) !important;
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  color: var(--app-text) !important;
  overscroll-behavior: none !important;
}
*, *::before, *::after { -webkit-tap-highlight-color: transparent !important; }
::selection { background: var(--primary) !important; color: #fff !important; }

/* ===== 3. SKELETON LOADING ===== */
@keyframes appShimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.app-skeleton {
  background: linear-gradient(90deg, #E8E8ED 25%, #F2F2F7 50%, #E8E8ED 75%) !important;
  background-size: 200% 100% !important;
  animation: appShimmer 1.5s infinite ease-in-out !important;
  border-radius: var(--app-radius-sm) !important;
  pointer-events: none !important;
}
.app-skeleton-text { height: 12px; margin-bottom: 8px; width: 80%; }
.app-skeleton-text.w-60 { width: 60%; }
.app-skeleton-avatar { width: 48px; height: 48px; border-radius: 50%; }
.app-skeleton-card { height: 160px; border-radius: var(--app-radius); }
.app-skeleton-btn { height: 44px; border-radius: var(--app-radius-sm); width: 100%; }

/* ===== 4. BOTTOM SHEET ===== */
.app-bottom-sheet {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  z-index: 1060 !important;
  background: #fff !important;
  border-radius: 20px 20px 0 0 !important;
  box-shadow: var(--app-elevation-4) !important;
  transform: translateY(100%) !important;
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1) !important;
  max-height: 80vh !important;
  overflow-y: auto !important;
}
.app-bottom-sheet.open {
  transform: translateY(0) !important;
}
.app-bottom-sheet .sheet-handle {
  width: 36px;
  height: 4px;
  background: #D1D1D6;
  border-radius: 2px;
  margin: 8px auto;
  flex-shrink: 0;
}
.app-bottom-sheet-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 1059;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.app-bottom-sheet-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

/* ===== 5. PULL TO REFRESH ===== */
.app-pull-indicator {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  height: 0 !important;
  overflow: hidden !important;
  transition: height 0.3s ease !important;
  color: var(--app-text-secondary) !important;
  font-size: 0.75rem !important;
}
.app-pull-indicator.show {
  height: 40px !important;
}
.app-pull-indicator .spinner {
  width: 20px;
  height: 20px;
  border: 2.5px solid #E5E5EA;
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: appSpin 0.6s linear infinite;
  margin-right: 8px;
}
@keyframes appSpin { to { transform: rotate(360deg); } }

/* ===== 6. RIPPLE EFFECT ===== */
.app-ripple {
  position: absolute !important;
  border-radius: 50% !important;
  background: rgba(0,0,0,0.08) !important;
  transform: scale(0) !important;
  animation: appRipple 0.6s ease-out !important;
  pointer-events: none !important;
}
@keyframes appRipple {
  to { transform: scale(4); opacity: 0; }
}

/* ===== 7. PAGE TRANSITION ===== */
.page-fade-in {
  animation: appPageIn 0.35s cubic-bezier(0.4,0,0.2,1) !important;
}
@keyframes appPageIn {
  from { opacity: 0.5; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ===== 8. CUSTOMER PANEL ===== */

/* --- 8a. Header --- */
.main-header {
  background: var(--app-surface) !important;
  border-bottom: 1px solid var(--app-border) !important;
  box-shadow: none !important;
}
.main-header.scrolled { box-shadow: var(--app-elevation-1) !important; }
.header-inner {
  height: var(--app-top-height) !important;
  padding: 0 12px !important;
}
.header-logo {
  font-size: 1.15rem !important;
  margin-right: 0 !important;
}
.header-logo span { color: #000 !important; }
.header-search { display: none !important; }
.header-location {
  background: var(--app-bg) !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 0.25rem 0.6rem !important;
  font-size: 0.65rem !important;
  height: 28px !important;
  line-height: 1 !important;
}
.header-icon {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: var(--app-bg) !important;
  color: #000 !important;
  font-size: 0.95rem !important;
}
.header-icon:hover { background: #E8E8ED !important; }
.header-user {
  border-radius: 16px !important;
  background: var(--app-bg) !important;
  padding: 0.15rem 0.4rem !important;
  gap: 4px !important;
}
.header-user img { width: 24px !important; height: 24px !important; }
.header-badge {
  background: var(--primary) !important;
  font-size: 0.45rem !important;
  min-width: 12px !important;
  height: 12px !important;
  line-height: 12px !important;
  top: -1px !important;
  right: -2px !important;
  padding: 0 0.2rem !important;
}
.header-hamburger {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: var(--app-bg) !important;
  color: #000 !important;
  font-size: 1rem !important;
}
.header-mobile-menu {
  top: var(--app-top-height) !important;
  background: var(--app-surface) !important;
}

/* --- 8b. Hero Section (Minimal App Style) --- */
.hero-section {
  background: var(--app-surface) !important;
  padding: 0.25rem 0 0 !important;
  position: relative !important;
  isolation: unset !important;
}
.hero-section::before, .hero-section::after, .hero-grid-bg, .hero-visual, .hero-stats, .hero-content p {
  display: none !important;
}
.hero-content { max-width: 100% !important; }
.hero-content h1 {
  font-size: 1.25rem !important;
  color: #000 !important;
  margin-bottom: 0.35rem !important;
  padding: 0 16px !important;
  line-height: 1.3 !important;
  letter-spacing: -0.02em !important;
}
.hero-content h1 .highlight {
  background: linear-gradient(135deg, var(--primary), #FF8C3A) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}
.hero-badge {
  background: var(--primary-light) !important;
  border: none !important;
  color: var(--primary-dark) !important;
  font-size: 0.55rem !important;
  padding: 0.15rem 0.6rem !important;
  margin: 0 16px 0.35rem !important;
  display: inline-flex !important;
  border-radius: 6px !important;
}
.hero-badge .dot { display: none !important; }
.hero-search {
  background: transparent !important;
  border: none !important;
  padding: 0.5rem 16px !important;
  backdrop-filter: none !important;
  border-radius: 0 !important;
  max-width: 100% !important;
  gap: 8px !important;
}
.hero-search .search-group {
  flex: 1 !important;
}
.hero-search .search-group i {
  left: 0.85rem !important;
  color: #8E8E93 !important;
  font-size: 0.85rem !important;
}
.hero-search .search-group input {
  background: var(--app-bg) !important;
  border: none !important;
  border-radius: var(--app-radius-sm) !important;
  padding: 0.65rem 1rem 0.65rem 2.3rem !important;
  font-size: 0.85rem !important;
  color: #000 !important;
  box-shadow: none !important;
  height: 42px !important;
  font-family: inherit !important;
}
.hero-search .search-group input:focus {
  background: #fff !important;
  box-shadow: 0 0 0 2px rgba(255,107,0,0.2) !important;
}
.hero-search .btn-search {
  height: 42px !important;
  border-radius: var(--app-radius-sm) !important;
  padding: 0 1.2rem !important;
  font-size: 0.8rem !important;
  box-shadow: none !important;
  font-weight: 700 !important;
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
  border: none !important;
  color: #fff !important;
}

/* --- 8c. Promo Banner Slider --- */
.app-banner-scroll {
  display: flex !important;
  overflow-x: auto !important;
  scroll-snap-type: x mandatory !important;
  gap: 0 !important;
  padding: 0.75rem 16px !important;
  scrollbar-width: none !important;
  -webkit-overflow-scrolling: touch !important;
}
.app-banner-scroll::-webkit-scrollbar { display: none !important; }
.app-banner-item {
  min-width: calc(100vw - 48px) !important;
  height: 140px !important;
  border-radius: var(--app-radius) !important;
  margin-right: 12px !important;
  scroll-snap-align: start !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: flex-end !important;
  padding: 16px !important;
  color: #fff !important;
  position: relative !important;
  overflow: hidden !important;
}
.app-banner-item:nth-child(1) { background: linear-gradient(135deg, #FF6B00, #FF8C3A) !important; }
.app-banner-item:nth-child(2) { background: linear-gradient(135deg, #1E293B, #334155) !important; }
.app-banner-item:nth-child(3) { background: linear-gradient(135deg, #059669, #10B981) !important; }
.app-banner-dots {
  display: flex !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 0 16px 0.5rem !important;
}
.app-banner-dot {
  width: 6px !important;
  height: 6px !important;
  border-radius: 3px !important;
  background: #D1D1D6 !important;
  transition: all 0.3s ease !important;
}
.app-banner-dot.active {
  width: 18px !important;
  background: var(--primary) !important;
}

/* --- 8d. Section Styles --- */
.section { padding: 0 !important; }
.section + .section { margin-top: 0 !important; }
.section-header {
  padding: 0.75rem 16px 0.5rem !important;
  margin-bottom: 0 !important;
  align-items: center !important;
}
.section-label {
  font-size: 0.6rem !important;
  margin-bottom: 0.15rem !important;
  display: block !important;
}
.section-title {
  font-size: 1rem !important;
  color: #000 !important;
}
.section-subtitle { display: none !important; }
.view-all {
  font-size: 0.7rem !important;
  font-weight: 600 !important;
}

/* --- 8e. Category Scroll (iOS-style) --- */
.category-scroll {
  gap: 0 !important;
  padding: 0 12px 0.75rem !important;
  scroll-snap-type: x mandatory !important;
}
.category-card {
  width: 64px !important;
  padding: 0 6px !important;
  scroll-snap-align: start !important;
}
.category-card:hover { transform: none !important; }
.category-card .icon-circle {
  width: 48px !important;
  height: 48px !important;
  border-radius: 12px !important;
  background: var(--primary-light) !important;
  box-shadow: none !important;
  font-size: 1.05rem !important;
  margin: 0 auto 0.3rem !important;
}
.category-card .icon-circle::after { display: none !important; }
.category-card:hover .icon-circle {
  background: var(--primary) !important;
  color: #fff !important;
  transform: none !important;
  box-shadow: none !important;
}
.category-card:hover .icon-circle::after { display: none !important; }
.category-card .cat-name {
  font-size: 0.58rem !important;
  color: #666 !important;
}

/* --- 8f. Shop Cards (Horizontal Scroll, Uber/Swiggy-style) --- */
.shop-grid {
  display: flex !important;
  gap: 0 !important;
  overflow-x: auto !important;
  scroll-snap-type: x mandatory !important;
  padding: 0 12px 0.5rem !important;
  scrollbar-width: none !important;
}
.shop-grid::-webkit-scrollbar { display: none !important; }
.shop-card {
  min-width: 220px !important;
  width: 220px !important;
  margin-right: 12px !important;
  scroll-snap-align: start !important;
  border-radius: var(--app-radius) !important;
  box-shadow: var(--app-elevation-2) !important;
  border: none !important;
  overflow: hidden !important;
  cursor: pointer !important;
}
.shop-card:hover {
  transform: none !important;
  box-shadow: var(--app-elevation-2) !important;
}
.shop-card .shop-img {
  height: 120px !important;
  position: relative !important;
}
.shop-card .shop-img img { transition: none !important; }
.shop-card:hover .shop-img img { transform: none !important; }
.shop-card .shop-img-overlay {
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.5)) !important;
}
.shop-card .offer-badge {
  top: 8px !important;
  left: 8px !important;
  font-size: 0.6rem !important;
  padding: 0.15rem 0.5rem !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
}
.shop-card .rating-badge {
  position: absolute !important;
  bottom: 8px !important;
  right: 8px !important;
  background: rgba(0,0,0,0.75) !important;
  color: #fff !important;
  padding: 0.1rem 0.45rem !important;
  border-radius: 6px !important;
  font-size: 0.6rem !important;
  backdrop-filter: none !important;
  box-shadow: none !important;
}
.shop-card .rating-badge i { color: #FFD700 !important; font-size: 0.55rem !important; }
.shop-card .shop-info { padding: 0.65rem 0.75rem !important; }
.shop-card .shop-name {
  font-size: 0.8rem !important;
  margin-bottom: 0.15rem !important;
}
.shop-card .shop-meta {
  font-size: 0.6rem !important;
  gap: 0.4rem !important;
}
.shop-card .shop-categories {
  font-size: 0.6rem !important;
  margin-top: 0.2rem !important;
}

/* --- 8g. Service Cards (App-style) --- */
.service-card {
  border-radius: var(--app-radius) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  padding: 0.75rem !important;
}
.service-card:hover {
  transform: none !important;
  box-shadow: var(--app-elevation-1) !important;
  border-color: transparent !important;
}
.service-card .svc-icon {
  width: 34px !important;
  height: 34px !important;
  border-radius: var(--app-radius-sm) !important;
  font-size: 0.85rem !important;
  margin-bottom: 0.4rem !important;
}
.service-card .service-info h6 { font-size: 0.78rem !important; }
.service-card .service-desc { font-size: 0.65rem !important; }
.service-card .service-meta { font-size: 0.65rem !important; }
.service-card .price-tag { font-size: 0.85rem !important; }
.service-card .original-price { font-size: 0.7rem !important; }
.service-card .discount-badge { font-size: 0.6rem !important; }

/* --- 8h. Offer Cards --- */
.offers-scroll {
  gap: 0 !important;
  padding: 0 12px 0.75rem !important;
  scroll-snap-type: x mandatory !important;
}
.offer-card {
  min-width: 250px !important;
  border-radius: var(--app-radius) !important;
  padding: 0.9rem !important;
  margin-right: 12px !important;
  scroll-snap-align: start !important;
}
.offer-card:hover { transform: none !important; }
.offer-card .offer-badge-icon { font-size: 0.6rem !important; padding: 0.2rem 0.5rem !important; }
.offer-card h5 { font-size: 0.95rem !important; }
.offer-card p { font-size: 0.7rem !important; }
.offer-card .offer-code { font-size: 0.75rem !important; padding: 0.25rem 0.7rem !important; }

/* --- 8i. Price Range --- */
.price-range-scroll {
  padding: 0 12px 0.75rem !important;
  gap: 0 !important;
}
.price-card {
  min-width: 85px !important;
  padding: 0.65rem !important;
  border-radius: var(--app-radius-sm) !important;
  border: 1px solid var(--app-border) !important;
  margin-right: 8px !important;
  background: var(--app-surface) !important;
}
.price-card:hover { transform: none !important; border-color: var(--primary) !important; }
.price-card .price-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 8px !important;
  font-size: 0.75rem !important;
}
.price-label { font-size: 0.6rem !important; }
.price-arrow { display: none !important; }

/* --- 8j. Customer Bottom Nav (Swiggy-style) --- */
.mobile-bottom-nav {
  background: var(--app-surface) !important;
  border-top: none !important;
  box-shadow: 0 -2px 16px rgba(0,0,0,0.06) !important;
  padding: 4px 0 calc(4px + env(safe-area-inset-bottom, 4px)) !important;
  z-index: 1055 !important;
}
.mb-nav-item {
  color: var(--app-text-secondary) !important;
  font-size: 0.5rem !important;
  padding: 3px 0 !important;
  min-height: 38px !important;
  position: relative !important;
}
.mb-nav-item i {
  font-size: 1.1rem !important;
  margin-bottom: 1px !important;
  transition: all 0.25s cubic-bezier(0.34,1.56,0.64,1) !important;
  display: block !important;
}
.mb-nav-item span { line-height: 1.1 !important; }
.mb-nav-item.active {
  color: var(--primary) !important;
}
.mb-nav-item.active i {
  transform: scale(1.15) !important;
  filter: drop-shadow(0 2px 6px rgba(255,107,0,0.3)) !important;
}
.mb-nav-item:active i { transform: scale(0.9) !important; }
.mb-badge {
  position: absolute !important;
  top: -1px !important;
  right: 50% !important;
  transform: translateX(calc(50% + 6px)) !important;
  background: #EF4444 !important;
  color: #fff !important;
  font-size: 0.45rem !important;
  min-width: 14px !important;
  height: 14px !important;
  border-radius: 7px !important;
  padding: 0 3px !important;
}
body { padding-bottom: calc(48px + env(safe-area-inset-bottom, 0px)) !important; }
.main-footer { display: none !important; }

/* --- 8k. Floating Action Button --- */
.fab {
  position: fixed !important;
  bottom: calc(56px + env(safe-area-inset-bottom, 0px)) !important;
  right: 16px !important;
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 4px 20px rgba(255,107,0,0.4) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.2rem !important;
  cursor: pointer !important;
  z-index: 1040 !important;
  transition: transform 0.2s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.2s ease !important;
}
.fab:active { transform: scale(0.9) !important; box-shadow: 0 2px 12px rgba(255,107,0,0.3) !important; }

/* --- 8l. Mobile Menu --- */
.mobile-nav-link {
  font-size: 0.85rem !important;
  padding: 0.65rem 0.75rem !important;
  min-height: 44px !important;
  border-radius: var(--app-radius-sm) !important;
}

/* --- 8m. Customer Login/Register --- */
.app-login-wrap {
  min-height: 100vh !important;
  background: var(--app-surface) !important;
  padding: 2rem 1.5rem !important;
  display: flex !important;
  flex-direction: column !important;
}
.app-login-wrap .brand {
  font-size: 1.5rem;
  font-weight: 900;
  color: var(--primary);
  margin-bottom: 0.5rem;
}

/* ===== 9. PROVIDER PANEL (Mobile App) ===== */

/* --- 9a. Topbar --- */
.admin-topbar {
  background: var(--app-surface) !important;
  border-bottom: 1px solid var(--app-border) !important;
  height: var(--app-top-height) !important;
  padding: 0 12px !important;
  backdrop-filter: none !important;
}
.admin-topbar .topbar-brand {
  font-size: 1rem !important;
  margin-left: 0 !important;
}
.admin-topbar .page-title { display: none !important; }
.admin-topbar .admin-avatar { width: 28px !important; height: 28px !important; }
.admin-topbar .badge { font-size: 0.45rem !important; min-width: 14px !important; height: 14px !important; line-height: 14px !important; padding: 0 3px !important; top: -2px !important; right: -4px !important; }
.admin-content {
  padding: 12px !important;
  padding-bottom: calc(60px + env(safe-area-inset-bottom, 0px)) !important;
}

/* --- 9b. Dashboard Stats (Cards) --- */
.stat-card {
  border-radius: var(--app-radius) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  padding: 0.85rem !important;
  background: var(--app-surface) !important;
}
.stat-card:hover {
  transform: none !important;
  box-shadow: var(--app-elevation-1) !important;
}
.stat-card .stat-value { font-size: 1.25rem !important; }
.stat-card .stat-label { font-size: 0.6rem !important; }
.stat-card .stat-icon {
  width: 38px !important;
  height: 38px !important;
  border-radius: var(--app-radius-sm) !important;
  font-size: 0.95rem !important;
}

/* --- 9e. Provider Bottom Nav --- */
.provider-bottom-nav {
  background: var(--app-surface) !important;
  border-top: none !important;
  box-shadow: 0 -2px 16px rgba(0,0,0,0.06) !important;
  padding: 4px 0 calc(4px + env(safe-area-inset-bottom, 4px)) !important;
}
.pbn-item {
  color: var(--app-text-secondary) !important;
  font-size: 0.5rem !important;
  min-height: 38px !important;
  padding: 3px 0 !important;
}
.pbn-item i { font-size: 1.1rem !important; margin-bottom: 1px !important; }
.pbn-item.active { color: var(--primary) !important; }
.pbn-item.active i {
  transform: scale(1.15) !important;
  filter: drop-shadow(0 2px 6px rgba(255,107,0,0.3)) !important;
}
.pbn-item:active i { transform: scale(0.9) !important; }

/* ===== 10. REPORTS / DASHBOARD ===== */
.dash-stat-card {
  border-radius: var(--app-radius) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  background: var(--app-surface) !important;
}
.dash-stat-card:hover { box-shadow: var(--app-elevation-1) !important; transform: none !important; }
.summary-card {
  border-radius: var(--app-radius) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  background: var(--app-surface) !important;
}
.summary-card:hover { box-shadow: var(--app-elevation-1) !important; }

/* ===== 11. STAFF APP (Enhancements) ===== */
.sa-top {
  height: var(--app-top-height) !important;
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
  box-shadow: 0 2px 16px rgba(255,107,0,0.3) !important;
}
.sa-top h1 { font-size: 0.95rem !important; }
.sa-top .top-icon { width: 32px !important; height: 32px !important; border-radius: 50% !important; }
.stat {
  border-radius: var(--app-radius) !important;
  background: var(--app-surface) !important;
  box-shadow: var(--app-elevation-1) !important;
  padding: 0.75rem !important;
  border: none !important;
}
.stat:active { transform: scale(0.97) !important; }
.stat h3 { font-size: 1.2rem !important; }
.stat p { font-size: 0.6rem !important; }
.btn-p {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
  border-radius: var(--app-radius-sm) !important;
  box-shadow: 0 4px 15px rgba(255,107,0,0.25) !important;
  min-height: 42px !important;
}
.btn-p:active { transform: scale(0.97) !important; }
.status-badge { border-radius: 6px !important; font-size: 0.55rem !important; }
.status-badge.accepted { background: var(--primary-light) !important; color: var(--primary-dark) !important; }
.card-warning {
  border-radius: var(--app-radius) !important;
  background: var(--primary-light) !important;
  border: none !important;
}
.card { border-radius: var(--app-radius) !important; border: none !important; box-shadow: var(--app-elevation-1) !important; }
.card:active { transform: scale(0.97) !important; }
.job-item { border-radius: var(--app-radius) !important; background: var(--app-surface) !important; box-shadow: var(--app-elevation-1) !important; border: none !important; }
.job-item:active { transform: scale(0.97) !important; }
.inp {
  border-radius: var(--app-radius-sm) !important;
  border: 1.5px solid var(--app-border) !important;
  font-size: 0.85rem !important;
  padding: 0.55rem 0.85rem !important;
  background: var(--app-bg) !important;
}
.inp:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(255,107,0,0.15) !important;
  background: #fff !important;
}
.icon-wrap {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
  box-shadow: 0 8px 30px rgba(255,107,0,0.35) !important;
}
.btn-login {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
  border-radius: var(--app-radius-sm) !important;
  box-shadow: 0 4px 20px rgba(255,107,0,0.25) !important;
  min-height: 44px !important;
}
.card-profile .card-b {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
}

/* Staff nav */
.nav .nav-a { color: var(--app-text-secondary) !important; }
.nav .nav-a.act { color: var(--primary) !important; }
.nav .nav-a.act .nav-ind { background: var(--primary) !important; }

/* ===== 12. STAFF MANAGER ===== */
.app-header {
  height: 46px !important;
  border-bottom: 1px solid var(--app-border) !important;
  background: var(--app-surface) !important;
}
.app-header .brand { font-size: 0.95rem !important; }
.app-container { padding: 8px 12px !important; }
.app-card {
  border-radius: var(--app-radius) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  margin-bottom: 10px !important;
}
.app-card-header { padding: 10px 12px !important; }
.app-card-header h6 { font-size: 0.78rem !important; }
.app-card-body { padding: 8px 12px 12px !important; }
.stat-box { border-radius: var(--app-radius-sm) !important; background: var(--app-bg) !important; }
.stat-box .num { font-size: 1.05rem !important; }
.stat-box .label { font-size: 0.55rem !important; }
.nav-bottombar {
  background: var(--app-surface) !important;
  border-top: none !important;
  box-shadow: 0 -2px 16px rgba(0,0,0,0.06) !important;
  padding: 4px 0 calc(4px + env(safe-area-inset-bottom, 4px)) !important;
}
.nav-bottombar a {
  color: var(--app-text-secondary) !important;
  font-size: 0.5rem !important;
  padding: 4px 0 6px !important;
}
.nav-bottombar a i { font-size: 1.05rem !important; margin-bottom: 1px !important; }
.nav-bottombar a.active { color: var(--primary) !important; }
.nav-bottombar a.active i { filter: drop-shadow(0 2px 6px rgba(255,107,0,0.3)) !important; }

/* ===== 13. BUTTONS (App-style) ===== */
.btn {
  border-radius: var(--app-radius-sm) !important;
  padding: 0.5rem 1.1rem !important;
  font-size: 0.82rem !important;
  font-weight: 700 !important;
  transition: transform 0.15s ease, box-shadow 0.2s ease !important;
}
.btn:active { transform: scale(0.96) !important; }
.btn-primary {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
  box-shadow: 0 4px 12px rgba(255,107,0,0.2) !important;
  border: none !important;
}
.btn-primary:hover { transform: translateY(-1px) !important; box-shadow: 0 6px 20px rgba(255,107,0,0.3) !important; }
.btn-outline-primary {
  border: 1.5px solid var(--primary) !important;
  color: var(--primary) !important;
}
.btn-outline-primary:hover { background: var(--primary-light) !important; color: var(--primary) !important; }
.btn-sm { padding: 0.35rem 0.85rem !important; font-size: 0.75rem !important; min-height: 32px !important; }
.btn-lg { padding: 0.7rem 1.5rem !important; font-size: 0.9rem !important; min-height: 48px !important; }

/* ===== 14. INPUTS ===== */
.form-control, .form-select {
  border-radius: var(--app-radius-sm) !important;
  border: 1.5px solid var(--app-border) !important;
  font-size: 0.85rem !important;
  padding: 0.55rem 0.85rem !important;
  background: var(--app-bg) !important;
  height: 42px !important;
}
.form-control:focus, .form-select:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(255,107,0,0.15) !important;
  background: #fff !important;
}

/* ===== 15. TABLES → Mobile Cards ===== */
.table-modern thead th { font-size: 0.6rem !important; }
.table-modern tbody td { font-size: 0.75rem !important; }
@media (max-width: 768px) {
  .table-card-wrap tbody tr {
    border-radius: var(--app-radius) !important;
    box-shadow: var(--app-elevation-1) !important;
    border: none !important;
    margin-bottom: 10px !important;
  }
  .table-card-wrap tbody td { font-size: 0.72rem !important; padding: 8px 12px !important; }
  .table-card-wrap tbody td:first-child { font-size: 0.8rem !important; }
  .table-card-wrap tbody td:first-child::before { color: var(--primary) !important; }
}

/* --- 8n. Why Choose Groomo Section --- */
.section.bg-white {
  background: var(--app-surface) !important;
  border-top: 1px solid var(--app-border) !important;
  padding: 1.25rem 0 !important;
}
.section.bg-white .text-center.mb-5 { margin-bottom: 0.75rem !important; }
.section.bg-white .col-md-3.col-6 { padding: 0.35rem !important; }
.section.bg-white .text-center h6.fw-bold { font-size: 0.72rem !important; color: #000 !important; }

/* --- 8o. Trending Section --- */
.trending-section {
  background: var(--app-bg) !important;
  border-top: 1px solid var(--app-border) !important;
  border-bottom: none !important;
  padding: 1rem 0 !important;
}
.trending-section .row.g-3 { margin: 0 !important; }
.trending-section .col-md-6.col-lg-3 { padding: 0.35rem !important; }

/* --- 8p. Nearby Shops / Load More --- */
#loadMore { padding: 0.25rem 0 !important; }

/* ===== 16. GLASS CARD ===== */
.glass-card {
  background: rgba(255,255,255,0.85) !important;
  backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
  border-radius: var(--app-radius) !important;
}

/* ===== 17. MODALS (App-style) ===== */
.modal-content {
  border-radius: var(--app-radius-lg) !important;
  border: none !important;
  box-shadow: var(--app-elevation-4) !important;
}
.modal-header { padding: 1rem 1.25rem !important; border-bottom: 1px solid var(--app-border) !important; }
.modal-body { padding: 1.25rem !important; }
.modal-footer { padding: 0.75rem 1.25rem !important; border-top: 1px solid var(--app-border) !important; }

/* ===== 18. NOTIFICATIONS ===== */
.notification-card {
  border-radius: var(--app-radius) !important;
  border: none !important;
  box-shadow: var(--app-elevation-1) !important;
  margin-bottom: 8px !important;
  background: var(--app-surface) !important;
}
.notification-card.unread { background: var(--primary-light) !important; }

/* ===== 19. TRACKING UI ===== */
.track-container { padding: 0 !important; }
.track-header {
  background: var(--app-surface) !important;
  padding: 1rem !important;
  border-bottom: 1px solid var(--app-border) !important;
}
.track-header h2 { font-size: 1.1rem !important; }
.live-indicator { font-size: 0.65rem !important; }
.live-dot { width: 6px !important; height: 6px !important; }
.timeline-step .step-icon { width: 28px !important; height: 28px !important; font-size: 0.65rem !important; }
.timeline-step .step-info h6 { font-size: 0.82rem !important; }
.staff-card { border-radius: var(--app-radius) !important; box-shadow: var(--app-elevation-1) !important; border: none !important; }

/* ===== 20. CART ===== */
.cart-item {
  border-radius: var(--app-radius) !important;
  border: none !important;
  box-shadow: var(--app-elevation-1) !important;
  margin-bottom: 8px !important;
  padding: 0.85rem !important;
}
.cart-summary {
  border-radius: var(--app-radius) !important;
  border: none !important;
  box-shadow: var(--app-elevation-1) !important;
}

/* ===== 21. BOOKING FLOW STEPS ===== */
.booking-step {
  border-radius: var(--app-radius) !important;
  background: var(--app-surface) !important;
  box-shadow: var(--app-elevation-1) !important;
  padding: 1rem !important;
  margin-bottom: 12px !important;
}
.booking-step .step-number {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--primary-light);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 800;
}

/* ===== 22. PAGE-SPECIFIC CONTENT OVERRIDES ===== */

/* --- 22a. Admin Reports - Report Tabs --- */
.report-tabs {
  display: flex !important;
  gap: 8px !important;
  overflow-x: auto !important;
  scrollbar-width: none !important;
  padding: 0.75rem 0 0.5rem !important;
  -webkit-overflow-scrolling: touch !important;
}
.report-tabs::-webkit-scrollbar { display: none !important; }
.report-tab {
  flex-shrink: 0 !important;
  padding: 0.4rem 0.85rem !important;
  border-radius: var(--app-radius-sm) !important;
  background: var(--app-bg) !important;
  color: var(--app-text-secondary) !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  border: none !important;
  transition: all 0.2s ease !important;
  white-space: nowrap !important;
}
.report-tab:hover { background: #E8E8ED !important; color: var(--app-text) !important; }
.report-tab.active {
  background: var(--primary-light) !important;
  color: var(--primary-dark) !important;
  font-weight: 700 !important;
}
.report-tab i { margin-right: 4px !important; font-size: 0.65rem !important; }

/* --- 22b. Period Buttons --- */
.period-btn {
  display: inline-flex !important;
  padding: 0.35rem 0.75rem !important;
  border-radius: var(--app-radius-sm) !important;
  background: var(--app-bg) !important;
  color: var(--app-text-secondary) !important;
  font-size: 0.68rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  border: none !important;
  transition: all 0.2s ease !important;
  white-space: nowrap !important;
}
.period-btn:hover { background: #E8E8ED !important; color: var(--app-text) !important; }
.period-btn.active {
  background: var(--primary-light) !important;
  color: var(--primary-dark) !important;
  font-weight: 700 !important;
}

/* --- 22c. Dash Card (Admin Dashboard) --- */
.dash-card {
  background: var(--app-surface) !important;
  border-radius: var(--app-radius) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  padding: 0.85rem !important;
}
.dash-card h6 {
  font-size: 0.68rem !important;
  color: var(--app-text-secondary) !important;
  margin-bottom: 0.35rem !important;
}
.dash-card .num {
  font-size: 1.35rem !important;
  font-weight: 800 !important;
  color: var(--app-text) !important;
}

/* --- 22d. Chart Containers --- */
.chart-container {
  background: var(--app-surface) !important;
  border-radius: var(--app-radius) !important;
  padding: 0.75rem !important;
  margin-bottom: 12px !important;
}
.chart-container canvas { max-height: 220px !important; }

/* --- 22e. Booking Cards (Customer) --- */
.booking-card {
  border-radius: var(--app-radius) !important;
  background: var(--app-surface) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  overflow: hidden !important;
  margin-bottom: 10px !important;
}
.booking-card:hover { box-shadow: var(--app-elevation-2) !important; }

/* --- 22f. Ticket Cards (Customer Support) --- */
.ticket-card {
  border-radius: var(--app-radius) !important;
  background: var(--app-surface) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  overflow: hidden !important;
  margin-bottom: 10px !important;
}
.ticket-card:hover { box-shadow: var(--app-elevation-2) !important; }
.ticket-card .ticket-status {
  font-size: 0.6rem !important;
  padding: 0.15rem 0.55rem !important;
  border-radius: 6px !important;
}

/* --- 22g. Review Cards --- */
.review-card {
  border-radius: var(--app-radius) !important;
  background: var(--app-surface) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  overflow: hidden !important;
  margin-bottom: 10px !important;
  padding: 0.85rem !important;
}

/* --- 22h. Saved Shop Cards --- */
.saved-shop-card.shop-card {
  min-width: 160px !important;
  width: 160px !important;
  margin-bottom: 0 !important;
}

/* --- 22i. Service Result Cards (Search) --- */
.service-result-card {
  border-radius: var(--app-radius) !important;
  background: var(--app-surface) !important;
  box-shadow: var(--app-elevation-1) !important;
  border: none !important;
  overflow: hidden !important;
  margin-bottom: 10px !important;
}
.service-result-card:hover { box-shadow: var(--app-elevation-2) !important; }

/* --- 22j. Address Cards --- */
.address-card {
  border-radius: var(--app-radius) !important;
  background: var(--app-surface) !important;
  box-shadow: var(--app-elevation-1) !important;
  padding: 0.85rem !important;
  border: 1.5px solid var(--app-border) !important;
}

/* --- 22k. List Group Item Action (Profile Menu / CMS Pages) --- */
.list-group-item-action {
  border-radius: var(--app-radius-sm) !important;
  padding: 0.65rem 0.85rem !important;
  font-size: 0.82rem !important;
  color: var(--app-text) !important;
  border: none !important;
  transition: all 0.2s ease !important;
  margin-bottom: 4px !important;
  background: transparent !important;
}
.list-group-item-action:hover {
  background: var(--app-bg) !important;
  color: var(--app-text) !important;
}
.list-group-item-action.active {
  background: var(--primary-light) !important;
  color: var(--primary-dark) !important;
  font-weight: 700 !important;
}
.list-group-item-action i {
  width: 20px !important;
  text-align: center !important;
  color: var(--app-text-secondary) !important;
  font-size: 0.8rem !important;
}
.list-group-item-action.active i { color: var(--primary) !important; }
.list-group-item-action.text-danger,
.list-group-item-action.text-danger i { color: #EF4444 !important; }
.list-group-item-action.border-0 { border: none !important; }

/* --- 22l. CMS Content Pages --- */
.cms-content {
  font-size: 0.88rem !important;
  line-height: 1.75 !important;
  color: var(--app-text) !important;
}
.cms-content h1, .cms-content h2, .cms-content h3,
.cms-content h4, .cms-content h5, .cms-content h6 {
  color: #000 !important;
  margin-top: 1.25rem !important;
  margin-bottom: 0.5rem !important;
  font-weight: 700 !important;
}
.cms-content p { margin-bottom: 0.85rem !important; }
.cms-content a { color: var(--primary) !important; }
.cms-content ul, .cms-content ol { padding-left: 1.25rem !important; }

/* --- 22m. Pagination --- */
.pagination {
  gap: 4px !important;
  flex-wrap: wrap !important;
}
.page-link {
  border-radius: var(--app-radius-sm) !important;
  border: none !important;
  font-size: 0.75rem !important;
  padding: 0.35rem 0.7rem !important;
  color: var(--app-text) !important;
  background: var(--app-bg) !important;
  font-weight: 600 !important;
}
.page-link:hover { background: #E8E8ED !important; color: var(--app-text) !important; }
.page-item.active .page-link {
  background: var(--primary-light) !important;
  color: var(--primary-dark) !important;
  font-weight: 800 !important;
}
.page-item.disabled .page-link {
  opacity: 0.4 !important;
  background: var(--app-bg) !important;
}

/* --- 22n. Balance & Payout Cards (Provider) --- */
.balance-card {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark)) !important;
  border-radius: var(--app-radius-lg) !important;
  padding: 1.25rem !important;
  color: #fff !important;
  box-shadow: 0 6px 24px rgba(255,107,0,0.3) !important;
  margin-bottom: 16px !important;
}
.balance-card .balance-label {
  font-size: 0.65rem !important;
  opacity: 0.85 !important;
  margin-bottom: 0.25rem !important;
}
.balance-card .balance-amount {
  font-size: 1.6rem !important;
  font-weight: 900 !important;
}
.payout-form {
  background: var(--app-surface) !important;
  border-radius: var(--app-radius) !important;
  box-shadow: var(--app-elevation-1) !important;
  padding: 1rem !important;
}
.payout-form .payout-form-header {
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  margin-bottom: 0.75rem !important;
}

/* --- 22o. Tracking Timeline (Booking Tracking) --- */
.tracking-timeline {
  background: var(--app-surface) !important;
  border-radius: var(--app-radius) !important;
  padding: 1rem !important;
  box-shadow: var(--app-elevation-1) !important;
}
.timeline-step {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 8px 0 !important;
  position: relative !important;
}
.timeline-step::before {
  content: '' !important;
  position: absolute !important;
  left: 13px !important;
  top: 32px !important;
  bottom: -8px !important;
  width: 2px !important;
  background: var(--app-border) !important;
}
.timeline-step:last-child::before { display: none !important; }
.timeline-step .step-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  background: var(--app-bg) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0.65rem !important;
  flex-shrink: 0 !important;
  position: relative !important;
  z-index: 1 !important;
}
.timeline-step.completed .step-icon { background: #10B981 !important; color: #fff !important; }
.timeline-step.active .step-icon { background: var(--primary) !important; color: #fff !important; box-shadow: 0 0 0 4px rgba(255,107,0,0.2) !important; }
.timeline-step .step-info h6 { font-size: 0.82rem !important; margin-bottom: 0.1rem !important; }
.timeline-step .step-info p { font-size: 0.65rem !important; color: var(--app-text-secondary) !important; margin: 0 !important; }

/* --- 22p. Star Rating --- */
.star-rating {
  display: inline-flex !important;
  gap: 2px !important;
}
.star-rating i, .star-rating .fa-star,
.star-rating .fa-star-half-alt, .star-rating .fa-star-o {
  color: #F59E0B !important;
  font-size: 0.75rem !important;
}
.star-rating .fa-star-o, .star-rating .far.fa-star { color: #D1D1D6 !important; }

/* --- 22q. Filter Buttons --- */
.filter-btn {
  border-radius: 20px !important;
  font-size: 0.65rem !important;
  padding: 0.3rem 0.7rem !important;
  background: var(--app-bg) !important;
  color: var(--app-text-secondary) !important;
  border: 1px solid var(--app-border) !important;
  font-weight: 600 !important;
  transition: all 0.2s ease !important;
}
.filter-btn.active {
  background: var(--primary-light) !important;
  color: var(--primary-dark) !important;
  border-color: var(--primary) !important;
  font-weight: 700 !important;
}
.filter-btn:hover { background: #E8E8ED !important; }

/* --- 22r. Service Items --- */
.service-item {
  padding: 0.6rem 0 !important;
  border-bottom: 1px solid var(--app-border) !important;
}
.service-item:last-child { border-bottom: none !important; }

/* --- 22s. Nav Tabs (if any) --- */
.nav-tabs .nav-link {
  border: none !important;
  color: var(--app-text-secondary) !important;
  font-size: 0.78rem !important;
  padding: 0.5rem 0.85rem !important;
  font-weight: 600 !important;
  border-radius: var(--app-radius-sm) !important;
  background: transparent !important;
  border-bottom: 2px solid transparent !important;
}
.nav-tabs .nav-link:hover { background: var(--app-bg) !important; color: var(--app-text) !important; }
.nav-tabs .nav-link.active {
  color: var(--primary) !important;
  border-bottom-color: var(--primary) !important;
  background: var(--primary-light) !important;
}

/* --- 22t. Admin Login Pages --- */
.admin-login-wrap, .login-wrap {
  min-height: 100vh !important;
  background: var(--app-surface) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 1.5rem !important;
}
.admin-login-wrap .login-card, .login-card {
  width: 100% !important;
  max-width: 380px !important;
  background: var(--app-surface) !important;
  border-radius: var(--app-radius-lg) !important;
  box-shadow: var(--app-elevation-2) !important;
  padding: 2rem !important;
  border: none !important;
}
.login-card h3, .login-card h4 {
  font-size: 1.2rem !important;
  font-weight: 800 !important;
  color: #000 !important;
  margin-bottom: 0.25rem !important;
}
.login-card p { font-size: 0.75rem !important; color: var(--app-text-secondary) !important; }

/* --- 22u. Alert Styles --- */
.alert {
  border-radius: var(--app-radius-sm) !important;
  border: none !important;
  font-size: 0.78rem !important;
  padding: 0.65rem 0.85rem !important;
}
.alert-success { background: #D1FAE5 !important; color: #065F46 !important; }
.alert-danger { background: #FEE2E2 !important; color: #991B1B !important; }
.alert-warning { background: #FEF3C7 !important; color: #92400E !important; }
.alert-info { background: #DBEAFE !important; color: #1E40AF !important; }

/* --- 22w. Badge status variants --- */
.badge-success-light, .badge.bg-success-light,
.badge.bg-warning-light, .badge.bg-danger-light,
.badge.bg-info-light {
  font-size: 0.6rem !important;
  padding: 0.2rem 0.55rem !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
}
.badge-success-light, .badge.bg-success-light { background: #D1FAE5 !important; color: #065F46 !important; }
.badge.bg-warning-light { background: #FEF3C7 !important; color: #92400E !important; }
.badge.bg-danger-light { background: #FEE2E2 !important; color: #991B1B !important; }
.badge.bg-info-light { background: #DBEAFE !important; color: #1E40AF !important; }

/* --- 22x. Booking status tabs/categories --- */
.booking-filter-tabs, .status-tabs {
  display: flex !important;
  gap: 6px !important;
  overflow-x: auto !important;
  scrollbar-width: none !important;
  padding: 0.5rem 0 !important;
}
.booking-filter-tabs::-webkit-scrollbar, .status-tabs::-webkit-scrollbar { display: none !important; }
.booking-filter-tabs a, .status-tabs a,
.booking-filter-tabs .filter-tab, .status-tabs .filter-tab {
  flex-shrink: 0 !important;
  padding: 0.3rem 0.75rem !important;
  border-radius: var(--app-radius-sm) !important;
  background: var(--app-bg) !important;
  color: var(--app-text-secondary) !important;
  font-size: 0.68rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  border: none !important;
  white-space: nowrap !important;
}
.booking-filter-tabs a.active, .status-tabs a.active,
.booking-filter-tabs .filter-tab.active, .status-tabs .filter-tab.active {
  background: var(--primary-light) !important;
  color: var(--primary-dark) !important;
}

/* --- 22y. Shop detail page --- */
.shop-detail-header {
  background: var(--app-surface) !important;
  border-radius: 0 0 var(--app-radius-lg) var(--app-radius-lg) !important;
  overflow: hidden !important;
}
.shop-detail-header .shop-cover {
  height: 160px !important;
  object-fit: cover !important;
}
.shop-detail-header .shop-info-overlay {
  padding: 0.75rem 1rem !important;
  background: var(--app-surface) !important;
}

/* --- 22z. Wait List / Queue Card --- */
.wait-card {
  background: var(--app-surface) !important;
  border-radius: var(--app-radius) !important;
  box-shadow: var(--app-elevation-1) !important;
  padding: 1rem !important;
  text-align: center !important;
}
.wait-card .wait-number {
  font-size: 2rem !important;
  font-weight: 900 !important;
  color: var(--primary) !important;
}

/* --- 22aa. Customer Page - Order Detail Timeline --- */
.tracking-timeline .tracking-step {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 8px 0 !important;
  position: relative !important;
}
.tracking-timeline .tracking-step::before {
  content: '' !important;
  position: absolute !important;
  left: 13px !important;
  top: 32px !important;
  bottom: -8px !important;
  width: 2px !important;
  background: var(--app-border) !important;
}
.tracking-timeline .tracking-step:last-child::before { display: none !important; }
.tracking-timeline .step-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  background: var(--app-bg) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0.65rem !important;
  flex-shrink: 0 !important;
  z-index: 1 !important;
}
.tracking-timeline .tracking-step.completed .step-icon { background: #10B981 !important; color: #fff !important; }
.tracking-timeline .tracking-step.active .step-icon { background: var(--primary) !important; color: #fff !important; }
.tracking-timeline .step-content { flex: 1 !important; padding-top: 2px !important; }
.tracking-timeline .step-content h6 { font-size: 0.82rem !important; margin-bottom: 0.1rem !important; }
.tracking-timeline .step-content p { font-size: 0.65rem !important; color: var(--app-text-secondary) !important; margin: 0 !important; }

/* --- 22bb. btn-soft --- */
.btn-soft {
  background: transparent !important;
  border: 1.5px solid var(--app-border) !important;
  color: var(--app-text-secondary) !important;
  border-radius: var(--app-radius-sm) !important;
  font-size: 0.78rem !important;
  padding: 0.4rem 0.85rem !important;
  font-weight: 600 !important;
  transition: all 0.2s ease !important;
}
.btn-soft:hover { background: var(--app-bg) !important; border-color: var(--primary) !important; color: var(--primary) !important; }

/* --- 22cc. Unsaved button --- */
.unsave-btn {
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  z-index: 3 !important;
  width: 30px !important;
  height: 30px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  border: none !important;
  background: rgba(255,255,255,0.9) !important;
  color: var(--danger) !important;
  font-size: 0.7rem !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
  transition: all 0.2s ease !important;
}
.unsave-btn:hover { background: var(--danger) !important; color: #fff !important; transform: scale(1.1) !important; }

/* --- 22dd. Search page classes --- */
.search-page .form-control { border-radius: var(--app-radius-sm) !important; border-color: var(--app-border) !important; }
.advanced-search-form {
  border: 1px solid var(--app-border) !important;
  border-radius: var(--app-radius) !important;
  background: var(--app-surface) !important;
  padding: 0.85rem !important;
}
.price-chip {
  border-radius: 20px !important;
  font-size: 0.65rem !important;
  padding: 0.3rem 0.7rem !important;
  border: 1px solid var(--app-border) !important;
  background: var(--app-bg) !important;
  color: var(--app-text-secondary) !important;
}
.search-item { transition: all 0.2s ease !important; }

/* --- 22ee. Ticket messages --- */
.ticket-msg {
  background: var(--app-bg) !important;
  border-radius: var(--app-radius) !important;
  padding: 12px 16px !important;
  margin-bottom: 8px !important;
}
.ticket-msg.admin, .ticket-msg.provider {
  background: var(--primary-light) !important;
  border-left: 3px solid var(--primary) !important;
}
.ticket-msg .msg-time { font-size: 0.6rem !important; color: var(--app-text-secondary) !important; }

/* --- 22ff. Track Booking Page (full override) --- */
.track-container { max-width: 720px !important; margin: 0 auto !important; padding: 0 !important; }
.track-header { text-align: center !important; padding: 20px 0 16px !important; }
.track-header h2 { font-size: 1.1rem !important; font-weight: 800 !important; color: #000 !important; }
.track-header .order-ref { font-size: 0.75rem !important; color: var(--app-text-secondary) !important; }
.live-indicator { display: inline-flex !important; align-items: center !important; gap: 6px !important; padding: 4px 14px !important; background: #FEF2F2 !important; border-radius: 20px !important; font-size: 0.7rem !important; font-weight: 600 !important; color: #DC2626 !important; margin-top: 8px !important; }
.live-dot { width: 6px !important; height: 6px !important; background: #DC2626 !important; border-radius: 50% !important; }
.map-section { position: relative !important; border-radius: var(--app-radius) !important; overflow: hidden !important; background: var(--app-bg) !important; margin-bottom: 20px !important; box-shadow: var(--app-elevation-1) !important; }
#trackMap { height: 300px !important; width: 100% !important; }
.map-overlay { position: absolute !important; top: 12px !important; left: 12px !important; right: 12px !important; display: flex !important; justify-content: space-between !important; pointer-events: none !important; z-index: 1000 !important; }
.map-overlay .eta-box { background: rgba(255,255,255,0.95) !important; border-radius: var(--app-radius-sm) !important; padding: 10px 14px !important; box-shadow: var(--app-elevation-2) !important; }
.map-overlay .eta-box .eta-label { font-size: 0.6rem !important; text-transform: uppercase !important; color: var(--app-text-secondary) !important; letter-spacing: 0.3px !important; }
.map-overlay .eta-box .eta-value { font-size: 1.1rem !important; font-weight: 800 !important; color: #000 !important; }
.map-overlay .shop-info { background: rgba(255,255,255,0.95) !important; border-radius: var(--app-radius-sm) !important; padding: 8px 12px !important; text-align: right !important; }
.map-overlay .shop-info strong { font-size: 0.78rem !important; display: block !important; color: #000 !important; }
.map-overlay .shop-info small { font-size: 0.6rem !important; color: var(--app-text-secondary) !important; }
.timeline { padding: 0 !important; position: relative !important; }
.timeline-step { display: flex !important; gap: 14px !important; padding: 12px 0 !important; position: relative !important; }
.timeline-step .step-icon { width: 36px !important; height: 36px !important; border-radius: 50% !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 0.8rem !important; flex-shrink: 0 !important; background: var(--app-bg) !important; color: var(--app-text-tertiary) !important; }
.timeline-step.completed .step-icon { background: #D1FAE5 !important; color: #10B981 !important; }
.timeline-step.active .step-icon { background: var(--primary-light) !important; color: var(--primary) !important; box-shadow: 0 0 0 4px rgba(255,107,0,0.15) !important; }
.timeline-step .step-info { flex: 1 !important; padding-top: 4px !important; }
.timeline-step .step-info h6 { font-size: 0.85rem !important; font-weight: 600 !important; margin: 0 !important; color: #000 !important; }
.timeline-step .step-info p { font-size: 0.72rem !important; color: var(--app-text-secondary) !important; margin: 2px 0 0 !important; }
.timeline-step.completed .step-info h6 { color: #10B981 !important; }
.timeline-step.active .step-info h6 { color: var(--primary) !important; }
.staff-card { display: flex !important; align-items: center !important; gap: 12px !important; background: #FFF8F0 !important; border: 1px solid #FFE0B2 !important; border-radius: var(--app-radius) !important; padding: 12px 16px !important; margin: 16px 0 !important; }
.staff-card img { width: 44px !important; height: 44px !important; border-radius: 50% !important; object-fit: cover !important; }
.staff-card .staff-name { font-weight: 700 !important; font-size: 0.9rem !important; color: #000 !important; }
.staff-card .staff-phone { font-size: 0.75rem !important; color: var(--app-text-secondary) !important; }
.staff-card .actions { margin-left: auto !important; display: flex !important; gap: 8px !important; }
.staff-card .actions a { background: var(--primary) !important; color: #fff !important; border-radius: var(--app-radius-sm) !important; padding: 6px 14px !important; font-size: 0.75rem !important; font-weight: 600 !important; text-decoration: none !important; }
.action-buttons { display: flex !important; gap: 10px !important; margin-bottom: 16px !important; }
.action-buttons a, .action-buttons button { flex: 1 !important; text-align: center !important; border-radius: var(--app-radius) !important; padding: 14px !important; font-weight: 700 !important; font-size: 0.85rem !important; text-decoration: none !important; border: none !important; }
.btn-contact { background: var(--primary-light) !important; color: var(--primary) !important; }
.btn-cancel { background: #FEF2F2 !important; color: #DC2626 !important; }
.callout-box { background: #F0F9FF !important; border: 1px solid #BAE6FD !important; border-radius: var(--app-radius-sm) !important; padding: 14px !important; font-size: 0.78rem !important; color: #0369A1 !important; margin-bottom: 16px !important; }

/* --- 22gg. Category Page Items --- */
.category-item .card {
  border-radius: var(--app-radius) !important;
  transition: all 0.3s cubic-bezier(0.34,1.56,0.64,1) !important;
  border: 1px solid var(--app-border) !important;
  cursor: pointer !important;
}
.category-item .card:hover { transform: translateY(-4px) !important; border-color: var(--primary) !important; }
.cat-icon-wrap {
  width: 80px !important;
  height: 80px !important;
  border-radius: 24px !important;
  background: linear-gradient(135deg, var(--primary-light), #fff) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 2rem !important;
  color: var(--primary) !important;
  transition: all 0.3s cubic-bezier(0.34,1.56,0.64,1) !important;
}

/* --- 22hh. OTP Input --- */
.otp-input {
  width: 44px !important;
  height: 52px !important;
  font-size: 1.3rem !important;
  text-align: center !important;
  border-radius: var(--app-radius-sm) !important;
  border: 1.5px solid var(--app-border) !important;
  background: var(--app-bg) !important;
}
.otp-input:focus { border-color: var(--primary) !important; box-shadow: 0 0 0 3px var(--primary-light) !important; }

/* --- 22ii. Staff Manager - btn-sm-round & bg-purple --- */
.btn-sm-round {
  border-radius: 20px !important;
  font-size: 0.72rem !important;
  padding: 0.3rem 0.75rem !important;
  font-weight: 600 !important;
  border: none !important;
  transition: all 0.2s ease !important;
}
.bg-purple { background: #7C3AED !important; color: #fff !important; }

/* --- 22jj. Staff Tracking - Live Map --- */
#staffMap { height: 500px !important; border-radius: var(--app-radius) !important; }
.staff-marker-popup { min-width: 180px !important; }
.staff-marker-popup h6 { font-weight: 700 !important; font-size: 0.85rem !important; color: #000 !important; }
.staff-marker-popup small { color: var(--app-text-secondary) !important; font-size: 0.7rem !important; }
.staff-list-card {
  background: var(--app-surface) !important;
  border-radius: var(--app-radius) !important;
  border: 1px solid var(--app-border) !important;
  padding: 10px 12px !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 8px !important;
  cursor: pointer !important;
  transition: all 0.15s ease !important;
}
.staff-list-card:hover { border-color: var(--primary) !important; }
.staff-list-card .status-dot { width: 8px !important; height: 8px !important; border-radius: 50% !important; flex-shrink: 0 !important; }
.staff-list-card .status-dot.online { background: #10B981 !important; }
.staff-list-card .status-dot.offline { background: #9CA3AF !important; }
.staff-list-card .status-dot.busy { background: #F59E0B !important; }

/* --- 22kk. Cart Map --- */
#cartMap { border-radius: var(--app-radius) !important; }

/* ===== 23. ADMIN PANEL OVERRIDES (blue theme) ===== */
.admin-card {
  border-radius: var(--app-radius);
  box-shadow: var(--app-elevation-1);
  border: none;
}
.admin-card .card-header-custom {
  padding: 0.85rem 1rem 0;
  font-size: 0.78rem;
}
.admin-card .card-body-custom {
  padding: 0.65rem 1rem 0.85rem;
}
.admin-card .card-header-custom i {
  color: var(--primary);
  font-size: 0.8rem;
}
.admin-btn {
  border-radius: var(--app-radius-sm);
  padding: 0.45rem 1rem;
  min-height: 38px;
}
.admin-btn-outline {
  border-radius: var(--app-radius-sm);
  padding: 0.4rem 0.85rem;
}
.admin-input, .admin-select {
  border-radius: var(--app-radius-sm);
  border: 1.5px solid var(--app-border);
  background: var(--app-bg);
  height: 42px;
}
.admin-input:focus, .admin-select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.15);
  background: #fff;
}
.admin-table {
  width: 100%;
  font-size: 0.75rem;
}
.admin-table thead th {
  font-size: 0.6rem;
  color: var(--app-text-secondary);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--app-border);
  padding: 0.5rem 0.4rem;
  background: transparent;
}
.admin-table tbody td {
  padding: 0.5rem 0.4rem;
  border-bottom: 1px solid var(--app-border);
  vertical-align: middle;
}
.admin-table tbody tr:last-child td {
  border-bottom: none;
}
.dash-stat-card {
  border-radius: var(--app-radius);
  box-shadow: var(--app-elevation-1);
  border: none;
  background: var(--app-surface);
}
.dash-stat-card:hover {
  box-shadow: var(--app-elevation-1);
  transform: none;
}

/* ===== 24. RESPONSIVE ===== */
@media (max-width: 991.98px) {
  .header-search { display: none !important; }
  .shop-grid { grid-template-columns: none !important; }
  .table-card-wrap thead { display: none !important; }
  .admin-content { padding: 10px !important; }
}
@media (min-width: 992px) {
  .header-search { display: flex !important; }
  .mobile-bottom-nav { display: none !important; }
  .provider-bottom-nav { display: none !important; }
}
@media (max-width: 576px) {
  .hero-content h1 { font-size: 1.1rem !important; padding: 0 12px !important; }
  .shop-card { min-width: 190px !important; width: 190px !important; }
  .shop-card .shop-img { height: 100px !important; }
  .category-card { width: 56px !important; }
  .category-card .icon-circle { width: 42px !important; height: 42px !important; font-size: 0.9rem !important; border-radius: 10px !important; }
  .category-card .cat-name { font-size: 0.5rem !important; }
  .offer-card { min-width: 220px !important; }
  .app-banner-item { min-width: calc(100vw - 32px) !important; height: 120px !important; }
  .section-header { padding: 0.5rem 12px 0.35rem !important; }
  .section-title { font-size: 0.9rem !important; }
  .hero-search { padding: 0 12px !important; }
  .hero-section { padding: 0.5rem 0 0.25rem !important; }
}

/* ===== 25. PWA / STANDALONE ===== */
@media (display-mode: standalone) {
  .main-header { padding-top: env(safe-area-inset-top) !important; }
  .mobile-bottom-nav, .provider-bottom-nav {
    padding-bottom: calc(4px + env(safe-area-inset-bottom, 4px)) !important;
  }
  body { padding-top: env(safe-area-inset-top) !important; }
}

/* ===== 26. SCROLLBAR ===== */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #D1D1D6; border-radius: 2px; }

/* ===== 27. PULL INDICATOR ===== */
.pull-indicator::after { background: #D1D1D6 !important; }

/* ===== 28. CUSTOMER SEARCH PAGE ===== */
.search-box-mobile .input-group-text,
.search-box-mobile .form-control { background: var(--app-bg) !important; border-color: var(--app-border) !important; }

/* ===== 27. SETTINGS PAGE ===== */
.app-bottom-nav { display: none !important; }

/* ===== 28. BADGE ===== */
.badge { border-radius: 6px !important; font-weight: 600 !important; }

/* ===== 29. IOS SAFE AREA ===== */
.mobile-safe-bottom { padding-bottom: env(safe-area-inset-bottom) !important; }
.mobile-safe-top { padding-top: env(safe-area-inset-top) !important; }

/* ===== 30. FLAT PAGE HEADER ===== */
.pg-hdr {
  padding: 0.5rem 16px 0.35rem !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.pg-hdr .back-btn {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: var(--app-bg) !important;
  border: 1px solid var(--app-border) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
  transition: all 0.15s ease !important;
  color: var(--app-text) !important;
  font-size: 0.8rem !important;
  padding: 0 !important;
  line-height: 1 !important;
}
.pg-hdr .back-btn:active { background: var(--app-border) !important; }
.pg-hdr .pg-title {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  margin: 0 !important;
  color: #000 !important;
  line-height: 1.3 !important;
}
.pg-hdr .pg-sub {
  font-size: 0.65rem !important;
  color: var(--app-text-secondary) !important;
  margin: 0 0 1px !important;
  line-height: 1.2 !important;
}
.pg-body {
  padding: 0 16px 16px !important;
}
@media (max-width:576px) {
  .pg-hdr { padding: 0.4rem 12px 0.25rem !important; }
  .pg-hdr .pg-title { font-size: 1rem !important; }
  .pg-body { padding: 0 12px 12px !important; }
}

/* ===== 31. MOBILE BREADCRUMB HIDE ===== */
.breadcrumb { display: none !important; }

/* ===== 32. SECTION PT OVERRIDE ===== */
section.section.pt-4 { padding-top: 0 !important; }
