/* ==========================================================================
   Free Shipping Progress Bar — Pharmavida
   Paleta: #87B13B (primary), #295441 (dark green), #FFA41C (accent)
   ========================================================================== */

/* ── Variables ─────────────────────────────────────────────────────────── */
:root {
  --fsb-color-fill:     #87B13B;
  --fsb-color-achieved: #295441;
  --fsb-color-track:    #e6eedd;
  --fsb-color-text:     #282828;
  --fsb-color-success:  #295441;
  --fsb-radius:         50px;
  --fsb-height-sm:      6px;
  --fsb-height-lg:      9px;
  --fsb-transition:     width 0.6s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* ── Shared base ───────────────────────────────────────────────────────── */
.pv-fsb {
  font-size: 13px;
  color: var(--fsb-color-text);
  line-height: 1.4;
}

/* SVG icon herdado de currentColor */
.pv-fsb .pv-icon {
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
}

.pv-fsb__message {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 7px;
}

.pv-fsb__message--success {
  color: var(--fsb-color-success);
  font-weight: 600;
}

.pv-fsb__amount {
  color: #295441;
  font-weight: 700;
  white-space: nowrap;
}

/* ── Progress track & fill ─────────────────────────────────────────────── */
.pv-fsb__track {
  width: 100%;
  background: var(--fsb-color-track);
  border-radius: var(--fsb-radius);
  overflow: hidden;
  height: var(--fsb-height-sm);
}

.pv-fsb__track--lg {
  height: var(--fsb-height-lg);
}

.pv-fsb__fill {
  height: 100%;
  background: linear-gradient(90deg, #6a9a2a, #87B13B);
  border-radius: var(--fsb-radius);
  transition: var(--fsb-transition);
  min-width: 3px;
}

.pv-fsb__fill--achieved {
  background: linear-gradient(90deg, #1e4332, #295441);
}

/* ── Mini-cart (dentro do #canvas-mini-cart) ───────────────────────────── */
.pv-fsb--minicart {
  padding: 10px 14px 13px;
  border-top: 1px solid rgba(135, 177, 59, 0.25);
  background: #f8fbf2;
  color: #295441;
}

.pv-fsb--minicart .pv-fsb__message--success {
  color: #295441;
}

/* ── Página /cart ──────────────────────────────────────────────────────── */
.pv-fsb--cart {
  margin-bottom: 20px;
  color: #295441;
}

.pv-fsb--cart .pv-fsb__inner {
  background: rgba(135, 177, 59, 0.07);
  border: 1px solid rgba(135, 177, 59, 0.35);
  border-radius: 10px;
  padding: 14px 16px;
}

/* Texto flui normalmente em bloco — sem flex, para que "Adiciona mais X €
   ao carrinho..." quebre em limites de palavra em vez de fragmentar cada
   item (texto, strong, texto) numa coluna estreita. */
.pv-fsb__label {
  margin: 0 0 10px;
  font-size: 14px;
  line-height: 1.5;
}

.pv-fsb__label .pv-icon {
  margin-right: 6px;
  position: relative;
  top: -1px;
}

.pv-fsb__label--success {
  color: var(--fsb-color-success);
}

.pv-fsb__hint {
  margin: 9px 0 0;
  font-size: 12px;
  color: #6a7a5a;
  text-align: right;
}

/* ── Checkout ──────────────────────────────────────────────────────────── */
.pv-fsb--checkout {
  padding: 10px 0 14px;
  border-bottom: 1px solid rgba(135, 177, 59, 0.2);
  margin-bottom: 12px;
  color: #295441;
}

/* ── Blockcart modal (injectada via JS em #blockcart-modal) ────────────── */
.pv-fsb--modal {
  padding: 12px 14px;
  margin: 12px 0 14px;
  background: #f8fbf2;
  border: 1px solid rgba(135, 177, 59, 0.35);
  border-radius: 8px;
  color: #295441;
}

.pv-fsb--modal .pv-fsb__message {
  margin-bottom: 9px;
}

/* ── Mobile ─────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .pv-fsb--cart .pv-fsb__inner {
    padding: 12px 14px;
  }
}
