/* ============================================
   QUADROVEL — Cart Page Styles
   Loads after style.css (cascade)
   ============================================ */

/* btn--gray (redeclare local) */
.btn--gray {
  background: #F0F0F0;
  color: var(--text-dark);
  border: 1px solid #E0E0E0;
}
.btn--gray:hover { background: #E5E5E5; }

/* Cart thumbnail placeholder */
.placeholder--cart-thumb {
  aspect-ratio: 1;
  background: linear-gradient(135deg, #0F2330, #1A4858);
  color: rgba(255,255,255,0.8);
  border: 3px solid #1A1A1A;
  border-radius: 2px;
  font-size: 9px;
}

/* ============================================
   CHECKOUT STEPS
   ============================================ */
.checkout-steps {
  background: var(--bg-section);
  padding: 22px 0;
  border-bottom: 1px solid #ECECEC;
}
.checkout-steps__list {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 22px;
  list-style: none;
  flex-wrap: wrap;
}
.checkout-step {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  padding-bottom: 6px;
}
.checkout-step.is-active {
  color: var(--text-dark);
  border-bottom: 2px solid var(--brand-pink);
}
.checkout-step__arrow {
  display: inline-flex;
  align-items: center;
  color: var(--text-muted);
}

/* ============================================
   CART SECTION
   ============================================ */
.cart-section {
  padding: 32px 0 60px;
  background: #FFF;
}

/* ============================================
   BANNERS
   ============================================ */
.cart-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 22px;
  border-radius: 4px;
  margin-bottom: 24px;
  color: #FFF;
  font-size: 14px;
}
.cart-banner__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(255,255,255,0.18);
  flex-shrink: 0;
}
.cart-banner__text { flex: 1; }
.cart-banner__link {
  font-weight: 800;
  text-decoration: underline;
  margin-left: 12px;
  color: #FFF;
}
.cart-banner__close {
  color: #FFF;
  opacity: 0.85;
  transition: opacity 0.2s;
  padding: 4px;
}
.cart-banner__close:hover { opacity: 1; }

.cart-banner--success { background: #2D9F60; }
.cart-banner--info {
  background: #D9941A;
  display: none;
}
body.is-banner-dismissed .cart-banner--success { display: none; }
body.is-cep-filled .cart-banner--success { display: none; }
body.is-cep-filled .cart-banner--info { display: flex; }

/* ============================================
   FREE SHIPPING PROGRESS
   ============================================ */
.free-shipping {
  border: 2px dashed #DDD;
  border-radius: 6px;
  padding: 14px 22px;
  margin-bottom: 32px;
  text-align: center;
}
.free-shipping__msg {
  font-family: 'Open Sans', sans-serif;
  font-size: 13px;
  color: var(--text-dark);
}
.free-shipping__msg strong { color: var(--brand-pink); font-weight: 800; }
.free-shipping__bar {
  height: 8px;
  background: #F2F2F2;
  border-radius: 4px;
  margin-top: 12px;
  overflow: hidden;
}
.free-shipping__fill {
  height: 100%;
  width: 70%;
  background-image: repeating-linear-gradient(
    45deg,
    var(--brand-pink) 0,
    var(--brand-pink) 8px,
    var(--brand-pink-dark) 8px,
    var(--brand-pink-dark) 16px
  );
  background-size: 22px 22px;
  animation: barberPole 1.6s linear infinite;
}
@keyframes barberPole {
  from { background-position: 0 0; }
  to   { background-position: 44px 0; }
}

/* ============================================
   CART GRID (2-col desktop)
   ============================================ */
.cart-grid {
  display: grid;
  grid-template-columns: 1.85fr 1fr;
  gap: 32px;
  align-items: flex-start;
}

/* ============================================
   CART TABLE
   ============================================ */
.cart-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 22px;
}
.cart-table thead th {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  padding: 14px 12px;
  text-align: center;
  border-bottom: 1px solid #EEE;
  text-transform: uppercase;
}
.cart-table thead .cart-table__col--product { text-align: left; padding-left: 0; }
.cart-table thead .cart-table__col--subtotal { text-align: right; padding-right: 0; }
.cart-table thead .cart-table__col--remove { width: 36px; }
.cart-table tbody td {
  padding: 24px 12px;
  vertical-align: top;
  border-bottom: 1px solid #F5F5F5;
}
.cart-table__remove {
  color: #BBB;
  font-size: 20px;
  font-weight: 400;
  line-height: 1;
  padding: 4px;
  transition: color 0.2s;
}
.cart-table__remove:hover { color: var(--brand-pink); }
.cart-table__product {
  display: flex;
  align-items: flex-start;
  gap: 18px;
}
.cart-table__thumb {
  width: 100px;
  flex-shrink: 0;
}
.cart-table__thumb-img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  display: block;
  border-radius: 4px;
}
.cart-empty {
  text-align: center;
  padding: 80px 20px;
  color: var(--text-muted);
  font-size: 15px;
}
.cart-empty a {
  color: var(--brand-pink);
  font-weight: 700;
  text-decoration: underline;
}
.cart-table__info {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cart-table__name {
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  color: var(--text-dark);
  font-weight: 400;
}
.cart-table__edit {
  font-size: 11px;
  font-style: italic;
  color: var(--text-muted);
  margin-bottom: 6px;
  text-decoration: none;
  display: inline-block;
}
.cart-table__edit:hover { color: var(--brand-pink); }
.cart-table__details-label {
  font-size: 13px;
  color: var(--text-dark);
  margin-top: 4px;
}
.cart-table__details {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.5;
}
.cart-table__details strong {
  color: var(--text-dark);
  font-weight: 700;
}
.cart-table__price {
  text-align: center;
  font-size: 14px;
  color: var(--text-dark);
  font-family: 'Open Sans', sans-serif;
  vertical-align: middle !important;
}
.cart-table__qty {
  text-align: center;
  vertical-align: middle !important;
}
.cart-table__subtotal {
  text-align: right;
  font-family: 'Open Sans', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--brand-pink);
  padding-right: 0 !important;
  vertical-align: middle !important;
}

/* Quantity Stepper */
.qty-stepper {
  display: inline-flex;
  align-items: center;
  border: 1px solid #DDD;
  border-radius: 4px;
  overflow: hidden;
  background: #FFF;
}
.qty-stepper__btn {
  width: 30px;
  height: 34px;
  background: #FFF;
  color: var(--text-dark);
  font-size: 16px;
  font-weight: 400;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}
.qty-stepper__btn:hover { background: #F5F5F5; }
.qty-stepper__value {
  width: 36px;
  text-align: center;
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  color: var(--text-dark);
  border-left: 1px solid #DDD;
  border-right: 1px solid #DDD;
  padding: 6px 0;
  user-select: none;
}

/* ============================================
   CART ACTIONS (cupom + atualizar)
   ============================================ */
.cart-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.cupom-box {
  border: 2px dashed #DDD;
  border-radius: 6px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: 460px;
  flex: 1;
}
.cupom-input {
  flex: 1;
  padding: 10px 14px;
  border: 1px solid #DDD;
  border-radius: 4px;
  font-size: 13px;
  font-family: 'Open Sans', sans-serif;
  outline: none;
  color: var(--text-dark);
  background: #FFF;
}
.cupom-input:focus { border-color: var(--brand-pink); }
.cupom-input::placeholder { color: #999; }
.cupom-btn {
  padding: 10px 22px !important;
  font-size: 11px !important;
}
.update-cart-btn {
  padding: 12px 28px;
  font-size: 11px;
}

/* ============================================
   SUMMARY CARD
   ============================================ */
.summary-card {
  background: #FFF;
  border: 1px solid #EEE;
  border-radius: 6px;
  padding: 28px 26px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  position: sticky;
  top: 100px;
}
.summary-card__title {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--text-dark);
  margin-bottom: 18px;
  text-transform: uppercase;
}
.summary-card__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 0;
  border-bottom: 1px solid #F0F0F0;
}
.summary-card__label {
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  color: var(--text-dark);
}
.summary-card__value {
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  color: var(--text-dark);
}
.summary-card__entrega-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 18px 0;
  border-bottom: 1px solid #F0F0F0;
  gap: 18px;
}
.summary-card__entrega-content {
  flex: 1;
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.summary-card__entrega-help {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.5;
}
body.is-cep-filled .summary-card__entrega-help { display: none; }
.summary-card__frete-options {
  display: none;
  flex-direction: column;
  gap: 4px;
  align-items: flex-end;
}
body.is-cep-filled .summary-card__frete-options { display: flex; }
.frete-option {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13px;
  flex-direction: row-reverse;
}
.frete-option input[type="radio"] {
  accent-color: var(--brand-pink);
  cursor: pointer;
}
.frete-option__label { color: var(--text-dark); }
.frete-option__label strong { color: var(--brand-pink); font-weight: 600; }
.summary-card__frete-help {
  font-size: 11px;
  color: var(--text-muted);
}
.summary-card__cep-label {
  font-size: 12px;
  color: var(--text-muted);
}
.summary-card__cep-input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #DDD;
  border-radius: 4px;
  font-size: 13px;
  font-family: 'Open Sans', sans-serif;
  outline: none;
  text-align: left;
  background: #FFF;
}
.summary-card__cep-input:focus { border-color: var(--brand-pink); }
.summary-card__total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 22px 0 18px;
}
.summary-card__total-value {
  font-family: 'Open Sans', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--brand-pink);
}
.summary-card__cta {
  margin-top: 4px;
}

/* ============================================
   RESPONSIVE — TABLET (≤1024px)
   ============================================ */
@media (max-width: 1024px) {
  .cart-grid { grid-template-columns: 1fr; }
  .summary-card { position: static; }
}

/* ============================================
   RESPONSIVE — MOBILE (≤768px)
   ============================================ */
@media (max-width: 768px) {
  body { overflow-x: hidden; }

  .checkout-steps { padding: 18px 0; }
  .checkout-steps__list { gap: 0; }
  .checkout-step:not(.is-active),
  .checkout-step__arrow { display: none; }
  .checkout-step.is-active {
    font-size: 14px;
    padding-bottom: 0;
    border-bottom: none;
  }

  .cart-section { padding: 20px 0 40px; }

  .cart-banner {
    flex-wrap: wrap;
    padding: 12px 16px;
    font-size: 13px;
    gap: 10px;
  }
  .cart-banner__link {
    display: block;
    width: 100%;
    margin-left: 0;
    margin-top: 4px;
  }
  /* Success banner hidden on mobile per print */
  .cart-banner--success { display: none; }
  body.is-banner-dismissed .cart-banner--success { display: none; }

  .free-shipping { padding: 14px 18px; margin-bottom: 24px; }
  .free-shipping__msg { font-size: 12px; line-height: 1.5; }

  /* Cart table → stacked card */
  .cart-table thead { display: none; }
  .cart-table,
  .cart-table tbody,
  .cart-table tr,
  .cart-table td { display: block; width: 100%; }
  .cart-table tbody td { border: none; padding: 0; }
  .cart-row {
    position: relative;
    background: #FFF;
    padding: 18px 16px;
    border-bottom: 1px solid #EEE;
    display: block;
  }
  .cart-table__col--remove {
    position: absolute;
    top: 12px;
    right: 12px;
    width: auto;
    padding: 0 !important;
  }
  .cart-table__col--remove .cart-table__remove {
    font-size: 22px;
    color: #999;
  }
  .cart-table__col--product {
    display: block;
    width: 100%;
  }
  .cart-table__product {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 14px;
    align-items: flex-start;
  }
  .cart-table__thumb { width: 100%; }
  .cart-table__name { font-size: 15px; font-weight: 600; }
  .cart-table__edit {
    display: inline-block;
    margin-top: 8px;
    margin-bottom: 4px;
  }
  .cart-table__details-label { margin-top: 8px; }

  /* Mobile rows: PREÇO / QUANTIDADE / SUBTOTAL */
  .cart-table__price,
  .cart-table__qty,
  .cart-table__subtotal {
    text-align: left !important;
    display: flex !important;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0 !important;
    border-top: 1px solid #F0F0F0;
    width: 100%;
  }
  .cart-table__price::before {
    content: 'PREÇO';
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--text-dark);
  }
  .cart-table__qty::before {
    content: 'QUANTIDADE';
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--text-dark);
  }
  .cart-table__subtotal::before {
    content: 'SUBTOTAL';
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--text-dark);
  }

  /* Bottom actions stacked */
  .cart-actions { flex-direction: column-reverse; gap: 16px; }
  .update-cart-btn { width: 100%; padding: 14px; }
  .cupom-box {
    flex-direction: column;
    max-width: 100%;
    gap: 10px;
    padding: 16px 14px;
  }
  .cupom-input { width: 100%; }
  .cupom-btn { width: 100%; padding: 14px !important; }

  /* Summary card full-width mobile */
  .summary-card { padding: 22px 20px; }
  .summary-card__title { font-size: 18px; }
  .summary-card__total-value { font-size: 22px; }
}
