/* Storefront visual layer
   Solid gray palette, balanced radius, no glow-heavy effects. */

:root,
html[data-mode="light"],
body[data-theme="light"] {
  color-scheme: light;
  --sf-bg: #f0f1f3;
  --sf-bg-alt: #e7e8eb;
  --sf-surface: #ffffff;
  --sf-surface-soft: #f6f7f9;
  --sf-text: #1b1d21;
  --sf-text-muted: #666c76;
  --sf-border: #d8dbe1;
  --sf-border-strong: #c5cad3;
  --sf-accent: #2a2f38;
  --sf-accent-ink: #ffffff;
  --sf-success: #2f7d4d;
  --sf-warning: #a56a21;
  --sf-danger: #a23737;
  --sf-radius-xs: 8px;
  --sf-radius-sm: 10px;
  --sf-radius-md: 14px;
  --sf-radius-lg: 18px;
  --sf-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.06);
  --sf-shadow-md: 0 6px 16px rgba(0, 0, 0, 0.08);
}

html[data-mode="dark"],
body[data-theme="dark"] {
  color-scheme: dark;
  --sf-bg: #1f2126;
  --sf-bg-alt: #2a2d34;
  --sf-surface: #2b2e35;
  --sf-surface-soft: #333740;
  --sf-text: #f0f2f5;
  --sf-text-muted: #b4bac4;
  --sf-border: #414754;
  --sf-border-strong: #525a69;
  --sf-accent: #e3e6ec;
  --sf-accent-ink: #20242c;
  --sf-success: #79c597;
  --sf-warning: #d0a36e;
  --sf-danger: #dd8e8e;
  --sf-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.24);
  --sf-shadow-md: 0 8px 18px rgba(0, 0, 0, 0.3);
}

body.storefront-page {
  background: linear-gradient(160deg, var(--sf-bg) 0%, var(--sf-bg-alt) 100%) !important;
  color: var(--sf-text) !important;
}

body.storefront-page,
body.storefront-page h1,
body.storefront-page h2,
body.storefront-page h3,
body.storefront-page h4,
body.storefront-page h5,
body.storefront-page h6,
body.storefront-page p,
body.storefront-page label,
body.storefront-page .modal-title,
body.storefront-page .form-label,
body.storefront-page .h5,
body.storefront-page .h6 {
  color: var(--sf-text) !important;
}

body.storefront-page .store-header,
body.storefront-page .store-footer {
  background: var(--sf-surface) !important;
  color: var(--sf-text) !important;
  border-color: var(--sf-border) !important;
  box-shadow: var(--sf-shadow-sm) !important;
}

body.storefront-page .store-header h1,
body.storefront-page .store-name {
  color: var(--sf-text) !important;
}

body.storefront-page .store-footer p,
body.storefront-page .store-footer .store-support {
  color: var(--sf-text-muted) !important;
}

body.storefront-page .store-footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

body.storefront-page #footerStoreName {
  display: none !important;
}

body.storefront-page .store-main {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  margin-top: 12px;
}

body.storefront-page .btn-track-order,
body.storefront-page .btn-mode-toggle,
body.storefront-page .btn-payment,
body.storefront-page .modal-footer .btn {
  border-radius: var(--sf-radius-sm) !important;
}

body.storefront-page .btn-track-order,
body.storefront-page .btn-mode-toggle {
  background: var(--sf-surface-soft) !important;
  border: 1px solid var(--sf-border) !important;
  color: var(--sf-text) !important;
  box-shadow: none !important;
}

body.storefront-page .btn-mode-toggle {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  font-weight: 700 !important;
  letter-spacing: 0.2px;
  padding: 7px 12px !important;
}

body.storefront-page .btn-mode-toggle i {
  font-size: 0.86rem !important;
}

body.storefront-page .btn-track-order:hover,
body.storefront-page .btn-mode-toggle:hover {
  background: var(--sf-surface) !important;
  border-color: var(--sf-border-strong) !important;
  transform: translateY(-1px);
}

body.storefront-page #purchaseBtn,
body.storefront-page #trackBtn,
body.storefront-page .btn-payment {
  background: var(--sf-accent) !important;
  border: 1px solid var(--sf-accent) !important;
  color: var(--sf-accent-ink) !important;
  box-shadow: none !important;
}

body.storefront-page #purchaseBtn:disabled {
  opacity: 0.6 !important;
  cursor: not-allowed !important;
}

body.storefront-page .network-tabs {
  gap: 14px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--sf-border);
  padding-bottom: 6px;
  background: transparent !important;
}

body.storefront-page .network-btn {
  min-width: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  color: var(--sf-text-muted) !important;
  box-shadow: none !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  padding: 6px 2px !important;
}

body.storefront-page .network-btn:hover {
  background: transparent !important;
  border-color: var(--sf-border-strong) !important;
  color: var(--sf-text) !important;
}

body.storefront-page .network-btn.active {
  background: transparent !important;
  color: var(--sf-text) !important;
  border-color: var(--sf-accent) !important;
}

body.storefront-page .packages-container {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 10px !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

body.storefront-page .package-card,
body.storefront-page .package-card.mtn,
body.storefront-page .package-card.airteltigo,
body.storefront-page .package-card.telecel,
body.storefront-page .package-card.vodafone {
  min-height: 62px !important;
  border-radius: var(--sf-radius-sm) !important;
  background: var(--sf-surface-soft) !important;
  border: 1px solid var(--sf-border) !important;
  box-shadow: none !important;
  padding: 8px 4px !important;
  gap: 3px !important;
  text-align: center;
  transition: border-color 0.16s ease, background-color 0.16s ease;
}

body.storefront-page .package-card::before {
  display: none !important;
}

body.storefront-page .package-card:hover {
  border-color: var(--sf-border-strong) !important;
  transform: none !important;
  background: var(--sf-surface) !important;
}

body.storefront-page .package-card.selected {
  border-color: var(--sf-accent) !important;
  background: var(--sf-surface) !important;
  transform: none !important;
  box-shadow: none !important;
}

body.storefront-page .package-size {
  color: var(--sf-text) !important;
  font-size: 0.77rem !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
}

body.storefront-page .package-price {
  color: var(--sf-text) !important;
  font-size: 0.74rem !important;
  font-weight: 600 !important;
  line-height: 1.1 !important;
}

body.storefront-page .package-label {
  color: var(--sf-text-muted) !important;
  font-size: 0.62rem !important;
  text-transform: uppercase;
  letter-spacing: 0.35px;
  border: none !important;
  border-radius: 0;
  padding: 0 !important;
  font-weight: 700 !important;
}

body.storefront-page .checkout-card,
body.storefront-page .summary-section,
body.storefront-page .selected-package-card,
body.storefront-page .modal-content,
body.storefront-page .modal-body,
body.storefront-page .modal-footer,
body.storefront-page .receipt-details,
body.storefront-page .tracking-result-item,
body.storefront-page .form-control,
body.storefront-page .alert {
  background: var(--sf-surface) !important;
  color: var(--sf-text) !important;
  border-color: var(--sf-border) !important;
}

body.storefront-page .selected-package-card {
  border-radius: var(--sf-radius-md) !important;
}

body.storefront-page .text-muted,
body.storefront-page small {
  color: var(--sf-text-muted) !important;
}

body.storefront-page .text-primary,
body.storefront-page .text-success,
body.storefront-page .text-danger,
body.storefront-page .text-dark,
body.storefront-page .text-black {
  color: var(--sf-text) !important;
}

body.storefront-page [style*="color: black"],
body.storefront-page [style*="color:#000"],
body.storefront-page [style*="color: #000"] {
  color: var(--sf-text) !important;
}

body.storefront-page .form-control {
  border-radius: var(--sf-radius-sm) !important;
}

body.storefront-page .form-control:focus {
  border-color: var(--sf-border-strong) !important;
  box-shadow: 0 0 0 2px rgba(115, 123, 138, 0.2) !important;
}

body.storefront-page .modal-dialog {
  border-radius: var(--sf-radius-lg) !important;
}

body.storefront-page .modal-content {
  border-radius: var(--sf-radius-lg) !important;
  overflow: hidden;
}

body.storefront-page .modal-header {
  background: var(--sf-surface-soft) !important;
  border-bottom: 1px solid var(--sf-border) !important;
}

body.storefront-page .modal-header .modal-title {
  color: var(--sf-text) !important;
  font-weight: 700 !important;
}

body.storefront-page .modal-header .btn-close {
  filter: none !important;
  opacity: 0.7;
}

body.storefront-page .modal-header .btn-close:hover {
  opacity: 1;
}

body.storefront-page .store-support-badge {
  background: var(--sf-surface-soft) !important;
  color: var(--sf-text) !important;
  border: 1px solid var(--sf-border) !important;
  border-radius: 999px !important;
  padding: 5px 10px !important;
}

body.storefront-page .store-support-badge:hover {
  border-color: var(--sf-border-strong) !important;
  text-decoration: none !important;
}

/* Tracking modal */
body.storefront-page #trackOrderModal .modal-header {
  background: var(--sf-surface-soft) !important;
}

body.storefront-page #trackingStatus {
  background: transparent !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.storefront-page .tracking-status-wrap {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  color: var(--sf-text) !important;
}

body.storefront-page .tracking-input-row {
  display: flex;
  align-items: stretch;
  gap: 8px;
}

body.storefront-page .tracking-paste-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  border-radius: var(--sf-radius-sm) !important;
  border-color: var(--sf-border) !important;
  color: var(--sf-text) !important;
  background: var(--sf-surface-soft) !important;
  white-space: nowrap;
}

body.storefront-page .tracking-paste-btn:hover {
  border-color: var(--sf-border-strong) !important;
  background: var(--sf-surface) !important;
}

body.storefront-page .tracking-spinner {
  color: var(--sf-accent) !important;
}

body.storefront-page .tracking-recent-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

body.storefront-page .tracking-ref-chip {
  border-radius: 999px !important;
  border-color: var(--sf-border) !important;
  background: var(--sf-surface-soft) !important;
  color: var(--sf-text) !important;
}

body.storefront-page .tracking-ref-chip:hover {
  border-color: var(--sf-border-strong) !important;
  background: var(--sf-surface) !important;
}

body.storefront-page .tracking-result-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 10px;
}

body.storefront-page .tracking-result-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--sf-border);
  padding: 8px 0;
}

body.storefront-page .tracking-result-row:last-child {
  border-bottom: none;
}

body.storefront-page .tracking-result-row span {
  display: block;
  color: var(--sf-text-muted) !important;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.35px;
  text-transform: uppercase;
  margin-bottom: 0;
}

body.storefront-page .tracking-result-row strong {
  display: block;
  color: var(--sf-text) !important;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.2;
  word-break: break-word;
  text-align: right;
}

body.storefront-page .tracking-status-text {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--sf-border);
  border-radius: 999px;
  font-size: 0.72rem !important;
  padding: 3px 10px;
}

body.storefront-page .tracking-status-text.status-success {
  border-color: var(--sf-success);
  color: var(--sf-success) !important;
}

body.storefront-page .tracking-status-text.status-warning {
  border-color: var(--sf-warning);
  color: var(--sf-warning) !important;
}

body.storefront-page .tracking-status-text.status-danger {
  border-color: var(--sf-danger);
  color: var(--sf-danger) !important;
}

body.storefront-page .tracking-status-text.status-secondary {
  border-color: var(--sf-border-strong);
  color: var(--sf-text-muted) !important;
}

/* Receipt modal */
body.storefront-page #receiptModal .modal-header {
  background: var(--sf-surface-soft) !important;
}

body.storefront-page .receipt-content {
  text-align: left;
}

body.storefront-page .receipt-top {
  display: block;
  margin-bottom: 8px !important;
}

body.storefront-page .receipt-status-pill {
  display: none;
}

body.storefront-page .receipt-success-icon {
  display: none;
}

body.storefront-page .receipt-top p {
  font-size: 0.85rem;
  margin: 0;
}

body.storefront-page .receipt-details {
  border-radius: var(--sf-radius-md) !important;
  border: 1px solid var(--sf-border) !important;
  background: transparent !important;
  padding: 12px !important;
}

body.storefront-page .receipt-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid var(--sf-border);
}

body.storefront-page .receipt-row:last-child {
  border-bottom: none;
}

body.storefront-page .receipt-row span {
  color: var(--sf-text-muted) !important;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.35px;
  text-transform: uppercase;
}

body.storefront-page .receipt-row strong {
  color: var(--sf-text) !important;
  font-size: 0.8rem;
  font-weight: 700;
  text-align: right;
  word-break: break-word;
}

body.storefront-page .receipt-note {
  border: 1px solid var(--sf-border) !important;
  border-radius: var(--sf-radius-sm) !important;
  background: var(--sf-surface-soft) !important;
  color: var(--sf-text-muted) !important;
}

/* Storefront config page parity */
body.storefront-config-page {
  background: linear-gradient(160deg, var(--sf-bg) 0%, var(--sf-bg-alt) 100%) !important;
  color: var(--sf-text) !important;
}

body.storefront-config-page .card,
body.storefront-config-page .modal-content,
body.storefront-config-page .form-control,
body.storefront-config-page .input-group-text,
body.storefront-config-page .table,
body.storefront-config-page .navbar,
body.storefront-config-page .dropdown-menu {
  background: var(--sf-surface) !important;
  color: var(--sf-text) !important;
  border-color: var(--sf-border) !important;
  border-radius: var(--sf-radius-md) !important;
}

body.storefront-config-page .btn-primary,
body.storefront-config-page .btn-success,
body.storefront-config-page .btn-outline-primary:hover {
  background: var(--sf-accent) !important;
  color: var(--sf-accent-ink) !important;
  border-color: var(--sf-accent) !important;
}

@media (max-width: 576px) {
  body.storefront-page .packages-container {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  body.storefront-page .package-card {
    min-height: 58px !important;
    padding: 7px 1px !important;
  }

  body.storefront-page .package-size {
    font-size: 0.72rem !important;
  }

  body.storefront-page .package-price {
    font-size: 0.7rem !important;
  }

  body.storefront-page .tracking-input-row {
    flex-direction: column;
  }

  body.storefront-page .tracking-result-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }

  body.storefront-page .tracking-result-row strong {
    text-align: left;
  }
}
