/* ═══════════════════════════════════════════════════════════
   Basketr — Theme Overrides (Light)
   Dark :root variables and Tailwind dark coercions removed.
   All surface/text/border variables defined in style.css.
   ═══════════════════════════════════════════════════════════ */

/* ─── Returning-visitor layout fixes: handled by style.css ─── */

/* ─── Card ─── */
.rd-card {
  background: var(--surface-raised);
  border-radius: 16px;
  border: 1px solid var(--border);
  transition: all 0.2s ease;
}
.rd-card--glow {
  box-shadow: 0 0 30px rgba(16, 185, 129, 0.08);
}

/* ─── Bottom Nav ─── */
.nav-tab {
  color: var(--text-secondary) !important;
  background: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
}
.nav-tab.active {
  color: var(--accent) !important;
  background: none !important;
}
.nav-tab .nav-dot {
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--accent);
  margin: 2px auto 0;
  opacity: 0;
  transition: opacity 0.2s;
}
.nav-tab.active .nav-dot { opacity: 1; }

/* ─── Desktop Navigation ─── */
.desktop-tab:hover {
  background: var(--surface-card-hover) !important;
  color: var(--text-primary) !important;
}
.desktop-tab.active {
  background: var(--accent-dim) !important;
  color: var(--accent) !important;
}

/* ─── App Header (Desktop) ─── */
#appDesktopHeader {
  background: var(--surface-raised) !important;
  border-bottom-color: var(--border) !important;
}

/* ─── Search Input ─── */
#searchInput, input[type="text"], input[type="email"], input[type="password"], textarea {
  background: var(--surface-raised) !important;
  border-color: var(--border) !important;
  color: var(--text-primary) !important;
  border-radius: 14px !important;
}
input::placeholder { color: var(--text-dim) !important; }
input:focus { border-color: var(--accent-border) !important; }
#searchInput:focus, #landingSearchInput:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-dim) !important;
}

/* ─── Forms ─── */
select {
  background: var(--surface-raised) !important;
  color: var(--text-primary) !important;
  border-color: var(--border) !important;
}

/* ─── Product Cards ─── */
.product-card {
  background: var(--surface-raised) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
}
.product-card:hover {
  border-color: var(--border-hover) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.06) !important;
  transform: translateY(-2px) !important;
}

/* ─── Store Total Cards & Optimise Groups ─── */
.store-total-card {
  background: var(--surface-raised) !important;
  border-color: var(--border) !important;
}
.store-total-card.cheapest {
  border-color: var(--accent) !important;
  background: var(--accent-dim) !important;
}
.opt-store-group {
  background: var(--surface-raised) !important;
  border-left-color: var(--accent-border) !important;
}

/* ─── Loyalty Cards ─── */
.loyalty-card {
  background: var(--surface-raised) !important;
  border-color: var(--border) !important;
}

/* ─── Modals ─── */
.modal-sheet {
  background: var(--surface-raised) !important;
}
#upgradeModal .modal-sheet { background: var(--surface-raised) !important; }

/* ─── Auth Tabs ─── */
.auth-tab { color: var(--text-secondary) !important; }
.auth-tab.active {
  background: var(--surface-raised) !important;
  color: var(--accent) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.08) !important;
}

/* ─── Skeleton ─── */
.skeleton {
  background: linear-gradient(90deg, #f1f5f9 25%, #e2e8f0 50%, #f1f5f9 75%) !important;
  background-size: 200% 100% !important;
  animation: skshimmer 1.5s infinite !important;
  position: relative;
  overflow: hidden;
}
@keyframes skshimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* ─── My Shopping Tabs ─── */
.my-shopping-tab { color: var(--text-secondary) !important; border-bottom-color: transparent !important; }
.my-shopping-tab.active { color: var(--accent) !important; border-bottom-color: var(--accent) !important; }

/* ─── Buttons ─── */
#searchBtn {
  background: linear-gradient(135deg, #10B981 0%, #059669 100%) !important;
  box-shadow: 0 4px 20px rgba(16, 185, 129, 0.25) !important;
}
#searchBtn:hover { background: linear-gradient(135deg, #059669 0%, #047857 100%) !important; }
button.bg-emerald-600 {
  background: linear-gradient(135deg, #10B981 0%, #059669 100%) !important;
  box-shadow: 0 4px 20px rgba(16, 185, 129, 0.25) !important;
}

/* ─── Notification Badge ─── */
#notification-badge-mobile, #notification-badge-desktop {
  background: var(--accent) !important;
}

/* ─── Price Bars ─── */
.price-bar-fill { background: var(--accent) !important; }

/* ─── Barcode Scan Button ─── */
button[onclick*="startBarcodeScanner"] {
  background: var(--accent-dim) !important;
  border-color: var(--accent-border) !important;
  color: var(--accent) !important;
}

/* ─── Store Logo Square ─── */
.store-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  color: white;
  flex-shrink: 0;
  border-radius: 4px;
  line-height: 1;
}

/* ─── View min-height ─── */
#view-search, #view-categories, #view-basket, #view-receipts,
#view-settings, #view-help, #view-my-shopping, #view-favourites,
#view-alerts, #view-lists, #view-list-detail, #view-internal {
  min-height: 100vh;
}

/* ─── Sticky search bar background ─── */
#view-search > div:first-child {
  background: linear-gradient(180deg, var(--surface-base) 85%, transparent) !important;
}

/* ─── Scrollbar ─── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-hover); border-radius: 2px; }

/* ─── Desktop: search sticky bar sits under 56px desktop header ─── */
@media (min-width: 768px) {
  .search-sticky-bar { top: 56px !important; }
}

/* ─── Text muted alias ─── */
.text-muted { color: var(--text-muted, var(--text-dim)) !important; }
