
/* Mobi-Fon stock hotfix: sidebar contrast + Final v7 checkout visual restore */
:root {
  --mf-pink: #e91e63;
  --mf-pink-dark: #c2185b;
  --mf-pink-darker: #8e1142;
  --mf-text: #2f2f2f;
  --mf-muted: #666;
  --mf-border: #e5e5e5;
  --mf-bg-soft: #f7f7f9;
}

/* Sidebar/category readability */
.list-group a,
.list-group a.list-group-item {
  color: var(--mf-text) !important;
  background: #fff !important;
  border-color: #ddd !important;
  text-shadow: none !important;
}
.list-group a:hover,
.list-group a:focus {
  color: #1f1f1f !important;
  background: #f5f5f7 !important;
  text-shadow: none !important;
}
.list-group a.active,
.list-group a.active:hover,
.list-group a.active:focus,
.list-group .list-group-item.active,
.list-group .list-group-item.active:hover,
.list-group .list-group-item.active:focus {
  color: #fff !important;
  background: linear-gradient(to bottom, var(--mf-pink), var(--mf-pink-dark)) !important;
  border-color: var(--mf-pink-dark) !important;
  text-shadow: none !important;
}
.list-group a.active small,
.list-group a.active .badge,
.list-group .list-group-item.active small,
.list-group .list-group-item.active .badge {
  color: #fff !important;
}

/* Product card buy action readability in stock theme */
.product-thumb .button-group {
  background-color: #f2f2f4 !important;
}
.product-thumb .button-group button {
  color: var(--mf-muted) !important;
  background-color: #f2f2f4 !important;
}
.product-thumb .button-group button:first-child {
  background: linear-gradient(to bottom, var(--mf-pink), var(--mf-pink-dark)) !important;
  color: #fff !important;
}
.product-thumb .button-group button:first-child:hover,
.product-thumb .button-group button:first-child:focus {
  background: linear-gradient(to bottom, var(--mf-pink-dark), var(--mf-pink-darker)) !important;
  color: #fff !important;
}
.product-thumb .button-group button + button {
  border-left: 1px solid #ddd !important;
}
.product-thumb .button-group button + button:hover,
.product-thumb .button-group button + button:focus {
  background-color: #e7e7eb !important;
  color: #222 !important;
}

/* Final v7 checkout visual restore */
.mf-checkout-page { padding: 12px 0 40px !important; }
.mf-checkout-progress-bar {
  background: #fff !important;
  border-bottom: 1px solid #eee !important;
  padding: 14px 0 8px !important;
  margin-bottom: 20px !important;
}
.mf-checkout-steps-row {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.mf-checkout-step {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 4px !important;
}
.mf-step-circle {
  width: 38px !important;
  height: 38px !important;
  border-radius: 50% !important;
  background: #e9ecef !important;
  color: #a0a0a0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  border: 3px solid #fff !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.10) !important;
  transition: all .3s ease !important;
}
.mf-checkout-step span {
  font-size: 10px !important;
  font-weight: 600 !important;
  color: #9a9a9a !important;
  white-space: nowrap !important;
}
.mf-checkout-step.active .mf-step-circle {
  background: linear-gradient(135deg, var(--mf-pink), var(--mf-pink-dark)) !important;
  color: #fff !important;
  transform: scale(1.08) !important;
}
.mf-checkout-step.active span { color: var(--mf-pink-dark) !important; }
.mf-checkout-step.done .mf-step-circle,
.mf-checkout-step.completed .mf-step-circle {
  background: #28a745 !important;
  border-color: #28a745 !important;
  color: #fff !important;
}
.mf-checkout-step-line {
  flex: 1 !important;
  height: 3px !important;
  background: #e9ecef !important;
  min-width: 25px !important;
  max-width: 70px !important;
  margin-bottom: 20px !important;
  border-radius: 3px !important;
}
.mf-checkout-progress-track {
  height: 4px !important;
  background: #f0f0f0 !important;
  border-radius: 4px !important;
  margin: 8px 0 4px !important;
  overflow: hidden !important;
}
.mf-checkout-progress-fill {
  height: 100% !important;
  background: linear-gradient(90deg, var(--mf-pink), var(--mf-pink-dark)) !important;
  border-radius: 4px !important;
  transition: width .5s ease !important;
}
.mf-progress-label {
  text-align: center !important;
  font-size: 12px !important;
  color: #777 !important;
  font-weight: 600 !important;
}
.mf-progress-label ~ .mf-progress-label,
#mf-ck-progress + #mf-ck-progress,
.mf-checkout-progress-bar ~ .mf-checkout-progress-bar { display: none !important; }

.mf-checkout-container { padding-top: 8px !important; padding-bottom: 40px !important; }
.mf-checkout-header { margin-bottom: 20px !important; }
.mf-checkout-header h1 {
  font-size: 24px !important;
  font-weight: 800 !important;
  color: #1a1a2e !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 0 4px !important;
}
.mf-checkout-header h1 .fa { color: var(--mf-pink-dark) !important; }
.mf-checkout-subtitle {
  color: #888 !important;
  font-size: 13px !important;
  margin: 0 !important;
}

#accordion .panel.mf-panel {
  border-radius: 12px !important;
  overflow: hidden !important;
  border: 1px solid #e9ecef !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
  margin-bottom: 12px !important;
}
#accordion .panel.mf-panel > .panel-heading.mf-panel-heading,
#accordion .mf-panel > .mf-panel-heading {
  background: linear-gradient(135deg, var(--mf-pink), var(--mf-pink-dark)) !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}
.mf-panel-confirm > .mf-panel-heading.mf-panel-heading-confirm {
  background: linear-gradient(135deg, #1a1a2e, #16213e) !important;
}
.mf-panel-step-badge {
  width: 32px !important;
  height: 32px !important;
  background: rgba(255,255,255,0.25) !important;
  border-radius: 50% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  color: #fff !important;
  flex-shrink: 0 !important;
  margin: 14px 0 14px 16px !important;
}
.mf-badge-check { background: rgba(255,255,255,0.35) !important; }
#accordion .panel.mf-panel > .panel-heading.mf-panel-heading .panel-title {
  flex: 1 !important;
  margin: 0 !important;
  padding: 14px 16px 14px 0 !important;
}
#accordion .panel.mf-panel > .panel-heading.mf-panel-heading .panel-title,
#accordion .panel.mf-panel > .panel-heading.mf-panel-heading .panel-title a,
#accordion .panel.mf-panel > .panel-heading.mf-panel-heading .panel-title a.accordion-toggle {
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  display: block !important;
}
#accordion .panel.mf-panel > .panel-collapse > .panel-body.mf-panel-body,
#accordion .panel.mf-panel > .panel-collapse > .panel-body {
  padding: 24px 20px !important;
  background: #fff !important;
}
#accordion .form-control,
.mf-panel-body .form-control {
  border: 1.5px solid #e0e6ee !important;
  border-radius: 8px !important;
  height: auto !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  color: #333 !important;
}
#accordion .form-control:focus,
.mf-panel-body .form-control:focus {
  border-color: var(--mf-pink-dark) !important;
  box-shadow: 0 0 0 3px rgba(194,24,91,.12) !important;
}
.mf-panel-body .btn-primary,
.mf-panel-body #button-payment-address,
.mf-panel-body #button-shipping-address,
.mf-panel-body #button-shipping-method,
.mf-panel-body #button-payment-method,
.mf-panel-body #button-account,
.mf-panel-body #button-guest,
.mf-panel-body #button-login,
#button-payment-address,
#button-shipping-address,
#button-shipping-method,
#button-payment-method,
#button-login {
  background: linear-gradient(135deg, var(--mf-pink), var(--mf-pink-dark)) !important;
  border: none !important;
  border-radius: 24px !important;
  padding: 11px 28px !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 14px rgba(194,24,91,0.30) !important;
  color: #fff !important;
}
#button-confirm {
  background: linear-gradient(135deg, #28a745, #20a83a) !important;
  border: none !important;
  border-radius: 40px !important;
  padding: 14px 34px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  color: #fff !important;
  box-shadow: 0 6px 20px rgba(40,167,69,.32) !important;
  text-transform: uppercase !important;
}
.mf-panel-body .btn-primary:hover,
#button-payment-address:hover,
#button-shipping-address:hover,
#button-shipping-method:hover,
#button-payment-method:hover,
#button-login:hover,
#button-confirm:hover {
  filter: brightness(.98) !important;
  color: #fff !important;
}
.text-danger:not(:empty) {
  font-size: 12px !important;
  color: #dc3545 !important;
  margin-top: 3px !important;
  padding: 3px 8px !important;
  background: #fff5f7 !important;
  border-radius: 4px !important;
  display: block !important;
}

.mf-checkout-sidebar { padding-left: 20px !important; }
.mf-order-summary {
  background: #fff !important;
  border-radius: 14px !important;
  border: 1px solid #e9ecef !important;
  overflow: hidden !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08) !important;
  position: sticky !important;
  top: 90px !important;
  margin-bottom: 20px !important;
}
.mf-order-summary-head {
  background: linear-gradient(135deg, var(--mf-pink), var(--mf-pink-dark)) !important;
  color: #fff !important;
  padding: 16px 20px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.mf-order-summary-body {
  padding: 14px !important;
  max-height: 380px !important;
  overflow-y: auto !important;
}
.mf-summary-loading,
.mf-summary-empty {
  text-align: center !important;
  color: #aaa !important;
  padding: 18px 0 !important;
  font-size: 13px !important;
}
.mf-summary-item {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 8px 0 !important;
  border-bottom: 1px solid #f5f5f5 !important;
}
.mf-summary-item img {
  width: 52px !important;
  height: 52px !important;
  object-fit: contain !important;
  border-radius: 8px !important;
  border: 1px solid #eee !important;
  flex-shrink: 0 !important;
}
.mf-summary-item-name { font-size: 12px !important; font-weight: 600 !important; color: #333 !important; line-height: 1.4 !important; }
.mf-summary-item-qty { font-size: 11px !important; color: #999 !important; margin-top: 2px !important; }
.mf-summary-item-price { font-size: 13px !important; font-weight: 700 !important; color: var(--mf-pink-dark) !important; white-space: nowrap !important; }
.mf-summary-total-row {
  display: flex !important;
  justify-content: space-between !important;
  padding: 6px 0 !important;
  font-size: 13px !important;
  border-top: 1px solid #f0f0f0 !important;
  margin-top: 4px !important;
}
.mf-summary-total-row.is-grand {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--mf-pink-dark) !important;
  border-top: 2px solid var(--mf-pink-dark) !important;
  padding-top: 10px !important;
  margin-top: 6px !important;
}
.mf-order-summary-foot {
  padding: 12px 14px !important;
  background: #f8f9fa !important;
  border-top: 1px solid #f0f0f0 !important;
}
.mf-secure-badges { display: flex !important; gap: 14px !important; flex-wrap: wrap !important; }
.mf-secure-badges span { font-size: 11px !important; color: #888 !important; display: flex !important; align-items: center !important; gap: 5px !important; }
.mf-secure-badges span .fa { color: #22c55e !important; }
.mf-checkout-help {
  background: #fff !important;
  border-radius: 12px !important;
  padding: 16px !important;
  border: 1px solid #e9ecef !important;
  text-align: center !important;
}
.mf-checkout-help h5 { font-size: 13px !important; font-weight: 700 !important; color: #333 !important; margin: 0 0 8px !important; }
.mf-help-phone {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: linear-gradient(135deg, var(--mf-pink), var(--mf-pink-dark)) !important;
  color: #fff !important;
  padding: 10px 20px !important;
  border-radius: 24px !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  text-decoration: none !important;
  margin-bottom: 6px !important;
}
.mf-help-hours { font-size: 11px !important; color: #999 !important; margin: 4px 0 0 !important; }
.mf-same-address-box,
.mf-invoice-toggle-row {
  background: var(--mf-bg-soft) !important;
  border: 1px solid var(--mf-border) !important;
  border-radius: 10px !important;
  padding: 14px 16px !important;
  margin-bottom: 16px !important;
}
.mf-form-section-title {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #1a1a2e !important;
  margin: 0 0 14px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.mf-form-section-title .fa { color: var(--mf-pink-dark) !important; }
.mf-checkbox-invoice,
.mf-checkbox-same { font-weight: 600 !important; color: #333 !important; }
.mf-same-address-hint,
.mf-help-company { color: #777 !important; }

/* Responsive */
@media (max-width: 991px) {
  .mf-checkout-sidebar { padding-left: 15px !important; margin-top: 20px !important; }
  .mf-order-summary { position: static !important; top: auto !important; }
  .mf-checkout-steps-row { gap: 0 !important; }
  .mf-step-circle { width: 28px !important; height: 28px !important; font-size: 12px !important; }
  .mf-checkout-step span { font-size: 10px !important; }
  .mf-checkout-step-line { min-width: 16px !important; }
}
@media (max-width: 767px) {
  .mf-checkout-progress-bar { padding: 12px 0 0 !important; }
  .mf-checkout-steps-row { justify-content: space-between !important; }
  .mf-panel-body { padding: 16px !important; }
  .mf-checkout-header h1 { font-size: 20px !important; }
}
